Co-authored-by: Karen <kkaspar@codereckons.com> Co-authored-by: Joel FALCOU <jfalcou@codereckons.com> See merge request oss/rotgen!9
87 lines
No EOL
2.8 KiB
C++
87 lines
No EOL
2.8 KiB
C++
//==================================================================================================
|
|
/*
|
|
ROTGEN - Runtime Overlay for Eigen
|
|
Copyright : CODE RECKONS
|
|
SPDX-License-Identifier: BSL-1.0
|
|
*/
|
|
//==================================================================================================
|
|
|
|
//==================================================================================================
|
|
/*
|
|
This file is a X-File to generate various matrix_impl_* declarations variant
|
|
*/
|
|
//==================================================================================================
|
|
class CLASSNAME
|
|
{
|
|
public:
|
|
CLASSNAME(std::size_t rows = 0, std::size_t cols = 0);
|
|
CLASSNAME(std::size_t rows, std::size_t cols,std::initializer_list<TYPE> init);
|
|
|
|
CLASSNAME(std::initializer_list<std::initializer_list<TYPE>> init);
|
|
|
|
CLASSNAME(CLASSNAME const& other);
|
|
CLASSNAME(CLASSNAME&&) noexcept;
|
|
|
|
CLASSNAME& operator=(CLASSNAME const& other);
|
|
CLASSNAME& operator=(CLASSNAME&&) noexcept;
|
|
|
|
~CLASSNAME();
|
|
|
|
std::size_t rows() const;
|
|
std::size_t cols() const;
|
|
|
|
std::size_t size() const;
|
|
void resize(std::size_t new_rows, std::size_t new_cols);
|
|
void conservativeResize(std::size_t new_rows, std::size_t new_cols);
|
|
|
|
CLASSNAME transpose() const;
|
|
CLASSNAME conjugate() const;
|
|
CLASSNAME adjoint() const;
|
|
|
|
void transposeInPlace();
|
|
void adjointInPlace();
|
|
|
|
TYPE sum() const;
|
|
TYPE prod() const;
|
|
TYPE mean() const;
|
|
TYPE trace() const;
|
|
TYPE maxCoeff() const;
|
|
TYPE minCoeff() const;
|
|
TYPE maxCoeff(std::ptrdiff_t* row, std::ptrdiff_t* col) const;
|
|
TYPE minCoeff(std::ptrdiff_t* row, std::ptrdiff_t* col) const;
|
|
|
|
TYPE squaredNorm() const;
|
|
TYPE norm() const;
|
|
TYPE lp_norm(int p) const;
|
|
|
|
TYPE& operator()(std::size_t i, std::size_t j);
|
|
TYPE const& operator()(std::size_t i, std::size_t j) const;
|
|
|
|
TYPE& operator()(std::size_t index);
|
|
TYPE const& operator()(std::size_t index) const;
|
|
|
|
CLASSNAME& operator+=(CLASSNAME const& rhs);
|
|
CLASSNAME& operator-=(CLASSNAME const& rhs);
|
|
CLASSNAME operator-() const;
|
|
CLASSNAME& operator*=(CLASSNAME const& rhs);
|
|
CLASSNAME& operator*=(TYPE d);
|
|
CLASSNAME& operator/=(TYPE d);
|
|
|
|
friend std::ostream& operator<<(std::ostream&,CLASSNAME const&);
|
|
friend bool operator==(CLASSNAME const& lhs, CLASSNAME const& rhs);
|
|
|
|
const TYPE* data() const;
|
|
|
|
static CLASSNAME Zero(std::size_t rows, std::size_t cols);
|
|
static CLASSNAME Constant(std::size_t rows, std::size_t cols, TYPE value);
|
|
static CLASSNAME Random(std::size_t rows, std::size_t cols);
|
|
static CLASSNAME Identity(std::size_t rows, std::size_t cols);
|
|
|
|
private:
|
|
struct payload;
|
|
std::unique_ptr<payload> storage_;
|
|
|
|
public:
|
|
std::unique_ptr<payload>& storage() { return storage_; }
|
|
std::unique_ptr<payload> const& storage() const { return storage_; }
|
|
}; |