📄 vnl_matrix_fixed_ref.h
字号:
// non-const vnl_matrix reference, giving a slight increase in type safety.
//: Explicit conversion to a vnl_matrix_ref.
// This is a cheap conversion for those functions that have an interface
// for vnl_matrix_ref but not for vnl_matrix_fixed_ref. There is also a
// conversion operator that should work most of the time.
// \sa vnl_matrix_ref::non_const
vnl_matrix_ref<T> as_ref() { return vnl_matrix_ref<T>( num_rows, num_cols, data_block() ); }
//: Explicit conversion to a vnl_matrix_ref.
// This is a cheap conversion for those functions that have an interface
// for vnl_matrix_ref but not for vnl_matrix_fixed_ref. There is also a
// conversion operator that should work most of the time.
// \sa vnl_matrix_ref::non_const
const vnl_matrix_ref<T> as_ref() const { return vnl_matrix_ref<T>( num_rows, num_cols, const_cast<T*>(data_block()) ); }
//: Cheap conversion to vnl_matrix_ref
// Sometimes, such as with templated functions, the compiler cannot
// use this user-defined conversion. For those cases, use the
// explicit as_ref() method instead.
operator const vnl_matrix_ref<T>() const { return vnl_matrix_ref<T>( num_rows, num_cols, const_cast<T*>(data_block()) ); }
//: Convert to a vnl_matrix.
const vnl_matrix<T> as_matrix() const { return vnl_matrix<T>(const_cast<T*>(data_block()),num_rows,num_cols); }
//----------------------------------------------------------------------
typedef T element_type;
//: Iterators
typedef T *iterator;
//: Iterator pointing to start of data
iterator begin() const { return data_block(); }
//: Iterator pointing to element beyond end of data
iterator end() const { return begin() + this->size(); }
//--------------------------------------------------------------------------------
//: Return true if *this == rhs
bool operator_eq (vnl_matrix_fixed_ref_const<T,num_rows,num_cols> const & rhs) const
{
return equal( this->data_block(), rhs.data_block() );
}
//: Equality operator
bool operator==(vnl_matrix_fixed_ref_const<T,num_rows,num_cols> const &that) const { return this->operator_eq(that); }
//: Inequality operator
bool operator!=(vnl_matrix_fixed_ref_const<T,num_rows,num_cols> const &that) const { return !this->operator_eq(that); }
//--------------------------------------------------------------------------------
};
#undef VNL_MATRIX_FIXED_VCL60_WORKAROUND
// Helper routines for arithmetic. These routines know the size from
// the template parameters. The vector-vector operations are
// element-wise.
// Make the operators below inline because (1) they are small and
// (2) we then have less explicit instantiation trouble.
// --- Matrix-scalar -------------------------------------------------------------
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator+( const vnl_matrix_fixed_ref_const<T,m,n>& mat1, const vnl_matrix_fixed_ref_const<T,m,n>& mat2 )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::add( mat1.data_block(), mat2.data_block(), r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator+( const vnl_matrix_fixed_ref_const<T,m,n>& mat, T s )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::add( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator+( T s, const vnl_matrix_fixed_ref_const<T,m,n>& mat )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::add( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator-( const vnl_matrix_fixed_ref_const<T,m,n>& mat1, const vnl_matrix_fixed_ref_const<T,m,n>& mat2 )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::sub( mat1.data_block(), mat2.data_block(), r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator-( const vnl_matrix_fixed_ref_const<T,m,n>& mat, T s )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::sub( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator-( T s, const vnl_matrix_fixed_ref_const<T,m,n>& mat )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::sub( s, mat.data_block(), r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator*( const vnl_matrix_fixed_ref_const<T,m,n>& mat, T s )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::mul( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator*( T s, const vnl_matrix_fixed_ref_const<T,m,n>& mat )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::mul( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> operator/( const vnl_matrix_fixed_ref_const<T,m,n>& mat, T s )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::div( mat.data_block(), s, r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> element_product( const vnl_matrix_fixed_ref_const<T,m,n>& mat1,
const vnl_matrix_fixed_ref_const<T,m,n>& mat2 )
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::mul( mat1.data_block(), mat2.data_block(), r.data_block() );
return r;
}
template<class T, unsigned m, unsigned n>
inline
vnl_matrix_fixed<T,m,n> element_quotient( const vnl_matrix_fixed_ref_const<T,m,n>& mat1,
const vnl_matrix_fixed_ref_const<T,m,n>& mat2)
{
vnl_matrix_fixed<T,m,n> r;
vnl_matrix_fixed<T,m,n>::div( mat1.data_block(), mat2.data_block(), r.data_block() );
return r;
}
// The following two functions are helper functions that keep the
// matrix-matrix and matrix-vector multiplication code in one place,
// so that bug fixes, etc, can be localized.
template <class T, unsigned M, unsigned N>
inline
vnl_vector_fixed<T, M>
vnl_matrix_fixed_mat_vec_mult(const vnl_matrix_fixed_ref_const<T, M, N>& a,
const vnl_vector_fixed_ref_const<T, N>& b)
{
vnl_vector_fixed<T, M> out;
for (unsigned i = 0; i < M; ++i)
{
T accum = a(i,0) * b(0);
for (unsigned k = 1; k < N; ++k)
accum += a(i,k) * b(k);
out(i) = accum;
}
return out;
}
// see comment above
template <class T, unsigned M, unsigned N, unsigned O>
inline
vnl_matrix_fixed<T, M, O>
vnl_matrix_fixed_mat_mat_mult(const vnl_matrix_fixed_ref_const<T, M, N>& a,
const vnl_matrix_fixed_ref_const<T, N, O>& b)
{
vnl_matrix_fixed<T, M, O> out;
for (unsigned i = 0; i < M; ++i)
for (unsigned j = 0; j < O; ++j)
{
T accum = a(i,0) * b(0,j);
for (unsigned k = 1; k < N; ++k)
accum += a(i,k) * b(k,j);
out(i,j) = accum;
}
return out;
}
#ifndef VCL_VC_6
// The version for correct compilers
//: Multiply conformant vnl_matrix_fixed (M x N) and vector_fixed (N)
// \relates vnl_vector_fixed
// \relates vnl_matrix_fixed
template <class T, unsigned M, unsigned N>
inline
vnl_vector_fixed<T, M> operator*(const vnl_matrix_fixed_ref_const<T, M, N>& a, const vnl_vector_fixed_ref_const<T, N>& b)
{
return vnl_matrix_fixed_mat_vec_mult(a,b);
}
//: Multiply two conformant vnl_matrix_fixed (M x N) times (N x O)
// \relates vnl_matrix_fixed
template <class T, unsigned M, unsigned N, unsigned O>
inline
vnl_matrix_fixed<T, M, O> operator*(const vnl_matrix_fixed_ref_const<T, M, N>& a, const vnl_matrix_fixed_ref_const<T, N, O>& b)
{
return vnl_matrix_fixed_mat_mat_mult(a,b);
}
#endif // ! VCL_VC_6
// These overloads for the common case of mixing a fixed with a
// non-fixed. Because the operator* are templated, the fixed will not
// be automatically converted to a non-fixed-ref. These do it for you.
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator+( const vnl_matrix_fixed_ref_const<T,m,n>& a, const vnl_matrix<T>& b )
{
return a.as_ref() + b;
}
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator+( const vnl_matrix<T>& a, const vnl_matrix_fixed_ref_const<T,m,n>& b )
{
return a + b.as_ref();
}
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator-( const vnl_matrix_fixed_ref_const<T,m,n>& a, const vnl_matrix<T>& b )
{
return a.as_ref() - b;
}
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator-( const vnl_matrix<T>& a, const vnl_matrix_fixed_ref_const<T,m,n>& b )
{
return a - b.as_ref();
}
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator*( const vnl_matrix_fixed_ref_const<T,m,n>& a, const vnl_matrix<T>& b )
{
return a.as_ref() * b;
}
template<class T, unsigned m, unsigned n>
inline vnl_matrix<T> operator*( const vnl_matrix<T>& a, const vnl_matrix_fixed_ref_const<T,m,n>& b )
{
return a * b.as_ref();
}
template<class T, unsigned m, unsigned n>
inline vnl_vector<T> operator*( const vnl_matrix_fixed_ref_const<T,m,n>& a, const vnl_vector<T>& b )
{
return a.as_ref() * b;
}
template<class T, unsigned n>
inline vnl_vector<T> operator*( const vnl_matrix<T>& a, const vnl_vector_fixed_ref_const<T,n>& b )
{
return a * b.as_ref();
}
// --- I/O operations ------------------------------------------------------------
template<class T, unsigned m, unsigned n>
inline
vcl_ostream& operator<< (vcl_ostream& os, vnl_matrix_fixed_ref_const<T,m,n> const& mat)
{
mat.print(os);
return os;
}
template<class T, unsigned m, unsigned n>
inline
vcl_istream& operator>> (vcl_istream& is, vnl_matrix_fixed_ref<T,m,n> const& mat)
{
mat.read_ascii(is);
return is;
}
#endif // vnl_matrix_fixed_ref_h_
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -