OpenVDB
12.0.0
|
#include <openvdb/math/Vec2.h>
Inherits Tuple< 2, T >.
Public Types | |
using | value_type = T |
using | ValueType = T |
Public Member Functions | |
Vec2 ()=default | |
Vec2 (T val) | |
Construct a vector all of whose components have the given value. More... | |
Vec2 (T x, T y) | |
Constructor with two arguments, e.g. Vec2f v(1,2,3);. More... | |
template<typename Source > | |
Vec2 (Source *a) | |
Constructor with array argument, e.g. float a[2]; Vec2f v(a);. More... | |
template<typename Source > | |
Vec2 (const Tuple< 2, Source > &t) | |
Conversion constructor. More... | |
template<typename Other > | |
Vec2 (Other val, typename std::enable_if< std::is_arithmetic< Other >::value, Conversion >::type=Conversion{}) | |
Construct a vector all of whose components have the given value, which may be of an arithmetic type different from this vector's value type. More... | |
T & | x () |
Reference to the component, e.g. v.x() = 4.5f;. More... | |
T & | y () |
T | x () const |
Get the component, e.g. float f = v.y();. More... | |
T | y () const |
T & | operator() (int i) |
Alternative indexed reference to the elements. More... | |
T | operator() (int i) const |
Alternative indexed constant reference to the elements,. More... | |
T * | asPointer () |
const T * | asPointer () const |
const Vec2< T > & | init (T x=0, T y=0) |
const Vec2< T > & | setZero () |
Set "this" vector to zero. More... | |
template<typename Source > | |
const Vec2< T > & | operator= (const Vec2< Source > &v) |
Assignment operator. More... | |
bool | operator== (const Vec2< T > &v) const |
Equality operator, does exact floating point comparisons. More... | |
bool | operator!= (const Vec2< T > &v) const |
Inequality operator, does exact floating point comparisons. More... | |
bool | eq (const Vec2< T > &v, T eps=static_cast< T >(1.0e-7)) const |
Test if "this" vector is equivalent to vector v with tolerance of eps. More... | |
Vec2< T > | operator- () const |
Negation operator, for e.g. v1 = -v2;. More... | |
template<typename T0 , typename T1 > | |
const Vec2< T > & | add (const Vec2< T0 > &v1, const Vec2< T1 > &v2) |
template<typename T0 , typename T1 > | |
const Vec2< T > & | sub (const Vec2< T0 > &v1, const Vec2< T1 > &v2) |
template<typename T0 , typename T1 > | |
const Vec2< T > & | scale (T0 scalar, const Vec2< T1 > &v) |
template<typename T0 , typename T1 > | |
const Vec2< T > & | div (T0 scalar, const Vec2< T1 > &v) |
T | dot (const Vec2< T > &v) const |
Dot product. More... | |
T | length () const |
Length of the vector. More... | |
T | lengthSqr () const |
const Vec2< T > & | exp () |
const Vec2< T > & | log () |
T | sum () const |
Return the sum of all the vector components. More... | |
T | product () const |
Return the product of all the vector components. More... | |
bool | normalize (T eps=static_cast< T >(1.0e-8)) |
this = normalized this More... | |
Vec2< T > | unit (T eps=0) const |
return normalized this, throws if null vector More... | |
Vec2< T > | unit (T eps, T &len) const |
return normalized this and length, throws if null vector More... | |
Vec2< T > | unitSafe () const |
return normalized this, or (1, 0) if this is null vector More... | |
template<typename S > | |
const Vec2< T > & | operator*= (S scalar) |
Multiply each element of this vector by scalar. More... | |
template<typename S > | |
const Vec2< T > & | operator*= (const Vec2< S > &v1) |
Multiply each element of this vector by the corresponding element of the given vector. More... | |
template<typename S > | |
const Vec2< T > & | operator/= (S scalar) |
Divide each element of this vector by scalar. More... | |
template<typename S > | |
const Vec2< T > & | operator/= (const Vec2< S > &v1) |
Divide each element of this vector by the corresponding element of the given vector. More... | |
template<typename S > | |
const Vec2< T > & | operator+= (S scalar) |
Add scalar to each element of this vector. More... | |
template<typename S > | |
const Vec2< T > & | operator+= (const Vec2< S > &v1) |
Add each element of the given vector to the corresponding element of this vector. More... | |
template<typename S > | |
const Vec2< T > & | operator-= (S scalar) |
Subtract scalar from each element of this vector. More... | |
template<typename S > | |
const Vec2< T > & | operator-= (const Vec2< S > &v1) |
Subtract each element of the given vector from the corresponding element of this vector. More... | |
T | component (const Vec2< T > &onto, T eps=static_cast< T >(1.0e-8)) const |
Vec2< T > | projection (const Vec2< T > &onto, T eps=static_cast< T >(1.0e-8)) const |
Vec2< T > | getArbPerpendicular () const |
T | operator[] (IdxT i) const |
T & | operator[] (IdxT i) |
T | operator[] (int i) const |
T & | operator[] (int i) |
std::string | str () const |
void | write (std::ostream &os) const |
void | read (std::istream &is) |
bool | isNan () const |
True if a Nan is present in this tuple. More... | |
bool | isInfinite () const |
True if an Inf is present in this tuple. More... | |
bool | isFinite () const |
True if no Nan or Inf values are present. More... | |
bool | isZero () const |
True if all elements are exactly zero. More... | |
Compatibility | |
These are mostly for backwards compatibility with functions that take old-style Vs (which are just arrays). | |
void | toV (S *v) const |
Copies this tuple into an array of a compatible type. More... | |
value_type * | asV () |
Exposes the internal array. Be careful when using this function. More... | |
value_type const * | asV () const |
Exposes the internal array. Be careful when using this function. More... | |
Static Public Member Functions | |
static unsigned | numRows () |
static unsigned | numColumns () |
static unsigned | numElements () |
static Vec2< T > | zero () |
Predefined constants, e.g. Vec2f v = Vec2f::xNegAxis();. More... | |
static Vec2< T > | ones () |
Static Public Attributes | |
static const int | size |
Protected Attributes | |
T | mm [SIZE] |
using value_type = T |
using ValueType = T |
|
default |
Trivial constructor, the vector is NOT initialized
|
inlineexplicit |
Construct a vector all of whose components have the given value.
|
inline |
Constructor with two arguments, e.g. Vec2f v(1,2,3);.
|
inline |
Constructor with array argument, e.g. float a[2]; Vec2f v(a);.
Conversion constructor.
|
inlineexplicit |
Construct a vector all of whose components have the given value, which may be of an arithmetic type different from this vector's value type.
Type conversion warnings are suppressed.
this = v1 + v2 "this", v1 and v2 need not be distinct objects, e.g. v.add(v1,v);
|
inline |
|
inline |
|
inlineinherited |
Exposes the internal array. Be careful when using this function.
|
inlineinherited |
Exposes the internal array. Be careful when using this function.
|
inline |
Returns the scalar component of v in the direction of onto, onto need not be unit. e.g float c = Vec2f::component(v1,v2);
|
inline |
Dot product.
|
inline |
Test if "this" vector is equivalent to vector v with tolerance of eps.
|
inline |
Return a reference to itsef after the exponent has been applied to all the vector components.
|
inline |
Return an arbitrary unit vector perpendicular to v Vector v must be a unit vector e.g. v.normalize(); Vec2f n = Vec2f::getArbPerpendicular(v);
|
inline |
"this" vector gets initialized to [x, y, z], calling v.init(); has same effect as calling v = Vec2::zero();
|
inlineinherited |
True if no Nan or Inf values are present.
|
inlineinherited |
True if an Inf is present in this tuple.
|
inlineinherited |
True if a Nan is present in this tuple.
|
inlineinherited |
True if all elements are exactly zero.
|
inline |
Length of the vector.
|
inline |
Squared length of the vector, much faster than length() as it does not involve square root
|
inline |
Return a reference to itself after log has been applied to all the vector components.
|
inline |
this = normalized this
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inline |
Inequality operator, does exact floating point comparisons.
|
inline |
Alternative indexed reference to the elements.
|
inline |
Alternative indexed constant reference to the elements,.
|
inline |
Multiply each element of this vector by scalar.
Multiply each element of this vector by the corresponding element of the given vector.
|
inline |
Add scalar to each element of this vector.
Add each element of the given vector to the corresponding element of this vector.
|
inline |
Negation operator, for e.g. v1 = -v2;.
|
inline |
Subtract scalar from each element of this vector.
Subtract each element of the given vector from the corresponding element of this vector.
|
inline |
Divide each element of this vector by scalar.
Divide each element of this vector by the corresponding element of the given vector.
|
inline |
Equality operator, does exact floating point comparisons.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inline |
Return the product of all the vector components.
Return the projection of v onto the vector, onto need not be unit e.g. Vec2f v = Vec2f::projection(v,n);
|
inlineinherited |
this = scalar*v, v need not be a distinct object from "this", e.g. v.scale(1.5,v1);
|
inline |
Set "this" vector to zero.
|
inlineinherited |
this = v1 - v2 "this", v1 and v2 need not be distinct objects, e.g. v.sub(v1,v);
|
inline |
Return the sum of all the vector components.
|
inlineinherited |
Copies this tuple into an array of a compatible type.
|
inline |
return normalized this, throws if null vector
|
inline |
return normalized this and length, throws if null vector
|
inline |
return normalized this, or (1, 0) if this is null vector
|
inlineinherited |
|
inline |
Reference to the component, e.g. v.x() = 4.5f;.
|
inline |
Get the component, e.g. float f = v.y();.
|
inline |
|
inline |
|
inlinestatic |
Predefined constants, e.g. Vec2f v = Vec2f::xNegAxis();.
|
protectedinherited |
|
staticinherited |