vector operations Boost , ,
QVM: Quaternions, Vectors, Matrices
Vector Operations
# include <boost/qvm/vec_operations.hpp >[ORIG_END] -->
namespace boost
{
namespace qvm
{
//*** Vector operations ***
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
A & assign ( A & a, B const & b );
//Only enabled if :
// is_vec <R>::value && is_vec <A>::value &&
// vec_traits <R>::dim ==vec_traits <A>::dim
template <class R,class A>
R convert_to ( A const & a );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
A & operator-= ( A & a, B const & b );
//Only enabled if : is_vec <A>::value
template <class A>
typename deduce_vec <A>::type
operator- ( A const & a );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
typename deduce_vec2 <A,B,vec_traits <A>::dim >::type
operator- ( A const & a, B const & b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
A & operator+= ( A & a, B const & b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
typename deduce_vec2 <A,B,vec_traits <A>::dim >::type
operator+ ( A const & a, B const & b );
//Only enabled if : is_vec <A>::value && is_scalar <B>::value
template <class A,class B>
A & operator/= ( A & a, B b );
//Only enabled if : is_vec <A>::value && is_scalar <B>::value
template <class A,class B>
typename deduce_vec <A>::type
operator/ ( A const & a, B b );
//Only enabled if : is_vec <A>::value && is_scalar <B>::value
template <class A,class B>
A & operator*= ( A & a, B b );
//Only enabled if : is_vec <A>::value && is_scalar <B>::value
template <class A>
typename deduce_vec <A>::type
operator* ( A const & a, B b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
bool operator== ( A const & a, B const & b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
bool operator!= ( A const & a, B const & b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B,class Cmp>
bool cmp ( A const & a, B const & b, Cmp pred );
//Only enabled if :
// is_vec <A>::value
template <class A>
typename vec_traits <A>::scalar_type
mag_sqr ( A const & a );
//Only enabled if :
// is_vec <A>::value
template <class A>
typename vec_traits <A>::scalar_type
mag ( A const & a );
//Only enabled if :
// is_vec <A>::value
template <class A>
typename deduce_vec <A>::type
normalized ( A const & a );
//Only enabled if :
// is_vec <A>::value
template <class A>
void normalize ( A & a );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==vec_traits <B>::dim
template <class A,class B>
typename deduce_scalar <A,B>::type
dot ( A const & a, B const & b );
//Only enabled if :
// is_vec <A>::value && is_vec <B>::value &&
// vec_traits <A>::dim ==3 && vec_traits <B>::dim ==3
template <class A,class B>
typename deduce_vec2 <A,B,3>::type
cross ( A const & a, B const & b );
template <class T,int S>
-unspecified-return-type- zero_vec ();
//Only enabled if :
// is_vec <A>::value
template <class A>
void set_zero ( A & a );
//Only enabled if : is_vec <A>::value
template <class A>
-unspecified-return-type- vref ( A & a );
//Only enabled if : is_vec <A>::value
template <class Scalar,class A>
-unspecified-return_type- scalar_cast ( A const & a );
}
}
Это список всех векторных операций, реализованных Boost QVM — нажмите на функции для отдельной документации. Общие примечания:
Все функции используютSFINAE/enable_if . Они доступны для любого типа C++, но только если он был зарегистрирован черезvec_traits. Шаблон.
Когда объекты возвращаются по значению, их тип выводится либо шаблономdeduce_vec (для унарных функций), либо шаблономdeduce_vec2 (для двоичных функций).
Тип скалярных аргументов выводится независимо от типа векторного аргумента, поэтому они не должны совпадать. Скалярные аргументы должны косвенно преобразовываться в векторный скалярный тип.
Статья vector operations раздела может быть полезна для разработчиков на c++ и boost.
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
:: Главная :: ::