4 #ifndef OPENVDB_MATH_VEC2_HAS_BEEN_INCLUDED
5 #define OPENVDB_MATH_VEC2_HAS_BEEN_INCLUDED
12 #include <type_traits>
20 template<
typename T>
class Mat2;
45 template <
typename Source>
48 this->
mm[0] =
static_cast<T>(a[0]);
49 this->
mm[1] =
static_cast<T>(a[1]);
53 template<
typename Source>
56 this->
mm[0] =
static_cast<T>(t[0]);
57 this->
mm[1] =
static_cast<T>(t[1]);
63 template<
typename Other>
67 this->
mm[0] = this->
mm[1] =
static_cast<T>(
val);
71 T&
x() {
return this->
mm[0];}
72 T&
y() {
return this->
mm[1];}
75 T x()
const {
return this->
mm[0];}
76 T y()
const {
return this->
mm[1];}
91 this->
mm[0] =
x; this->
mm[1] =
y;
98 this->
mm[0] = 0; this->
mm[1] = 0;
103 template<
typename Source>
123 bool eq(
const Vec2<T> &
v, T eps = static_cast<T>(1.0e-7))
const
134 template <
typename T0,
typename T1>
137 this->
mm[0] = v1[0] + v2[0];
138 this->
mm[1] = v1[1] + v2[1];
145 template <
typename T0,
typename T1>
148 this->
mm[0] = v1[0] - v2[0];
149 this->
mm[1] = v1[1] - v2[1];
156 template <
typename T0,
typename T1>
159 this->
mm[0] = scalar * v[0];
160 this->
mm[1] = scalar * v[1];
165 template <
typename T0,
typename T1>
168 this->
mm[0] = v[0] / scalar;
169 this->
mm[1] = v[1] / scalar;
180 return static_cast<T>(
sqrt(
double(this->
mm[0]*this->
mm[0] + this->
mm[1]*this->
mm[1])));
191 this->
mm[0] = std::exp(this->
mm[0]);
192 this->
mm[1] = std::exp(this->
mm[1]);
208 return this->
mm[0] + this->
mm[1];
214 return this->
mm[0] * this->
mm[1];
249 return l2 ? *
this/
static_cast<T>(
sqrt(l2)) :
Vec2<T>(1,0);
253 template <
typename S>
256 this->
mm[0] *= scalar;
257 this->
mm[1] *= scalar;
262 template <
typename S>
265 this->
mm[0] *= v1[0];
266 this->
mm[1] *= v1[1];
271 template <
typename S>
274 this->
mm[0] /= scalar;
275 this->
mm[1] /= scalar;
280 template <
typename S>
283 this->
mm[0] /= v1[0];
284 this->
mm[1] /= v1[1];
289 template <
typename S>
292 this->
mm[0] += scalar;
293 this->
mm[1] += scalar;
298 template <
typename S>
301 this->
mm[0] += v1[0];
302 this->
mm[1] += v1[1];
307 template <
typename S>
310 this->
mm[0] -= scalar;
311 this->
mm[1] -= scalar;
316 template <
typename S>
319 this->
mm[0] -= v1[0];
320 this->
mm[1] -= v1[1];
336 return dot(onto)*(
T(1)/l);
346 return onto*(
dot(onto)*(
T(1)/l));
360 template <
typename S,
typename T>
367 template <
typename S,
typename T>
376 template <
typename T0,
typename T1>
384 template <
typename S,
typename T>
391 template <
typename S,
typename T>
400 template <
typename T0,
typename T1>
408 template <
typename T0,
typename T1>
417 template <
typename S,
typename T>
426 template <
typename T0,
typename T1>
435 template <
typename S,
typename T>
445 template <
typename T>
452 template <
typename T>
458 template <
typename T>
475 template <
typename T>
503 template <
typename T>
512 template <
typename T>
522 template <
typename T>
527 template <
typename T>
544 #endif // OPENVDB_MATH_VEC2_HAS_BEEN_INCLUDED
Vec2< T > minComponent(const Vec2< T > &v1, const Vec2< T > &v2)
Return component-wise minimum of the two vectors.
bool normalize(T eps=static_cast< T >(1.0e-8))
this = normalized this
const Vec2< T > & operator-=(const Vec2< S > &v1)
Subtract each element of the given vector from the corresponding element of this vector.
static unsigned numColumns()
const Vec2< T > & div(T0 scalar, const Vec2< T1 > &v)
T & x()
Reference to the component, e.g. v.x() = 4.5f;.
Vec2< T > projection(const Vec2< T > &onto, T eps=static_cast< T >(1.0e-8)) const
T length() const
Length of the vector.
T component(const Vec2< T > &onto, T eps=static_cast< T >(1.0e-8)) const
bool isExactlyEqual(const T0 &a, const T1 &b)
Return true if a is exactly equal to b.
GLsizei const GLfloat * value
void orthonormalize(Vec2< T > &v1, Vec2< T > &v2)
Vec2< T > operator-() const
Negation operator, for e.g. v1 = -v2;.
Vec3< typename promote< T, Coord::ValueType >::type > operator-(const Vec3< T > &v0, const Coord &v1)
Allow a Coord to be subtracted from a Vec3.
vfloat4 sqrt(const vfloat4 &a)
Mat3< typename promote< T0, T1 >::type > operator*(const Mat3< T0 > &m0, const Mat3< T1 > &m1)
Multiply m0 by m1 and return the resulting matrix.
GLboolean GLboolean GLboolean GLboolean a
#define OPENVDB_USE_VERSION_NAMESPACE
Vec2< T > Log(Vec2< T > v)
Return a vector with log applied to each of the components of the input vector.
Dummy class for tag dispatch of conversion constructors.
ImageBuf OIIO_API min(Image_or_Const A, Image_or_Const B, ROI roi={}, int nthreads=0)
**But if you need a result
T operator()(int i) const
Alternative indexed constant reference to the elements,.
GLfloat GLfloat GLfloat v2
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 d...
bool operator==(const Vec2< T > &v) const
Equality operator, does exact floating point comparisons.
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.
Vec2< typename promote< S, T >::type > operator/(S scalar, const Vec2< T > &v)
Divide scalar by each element of the given vector and return the result.
Vec2< T > getArbPerpendicular() const
const Vec2< T > & operator+=(const Vec2< S > &v1)
Add each element of the given vector to the corresponding element of this vector. ...
#define OPENVDB_IS_POD(Type)
static unsigned numRows()
bool isApproxEqual(const Type &a, const Type &b, const Type &tolerance)
Return true if a is equal to b to within the given tolerance.
Vec2(T val)
Construct a vector all of whose components have the given value.
Coord Abs(const Coord &xyz)
General-purpose arithmetic and comparison routines, most of which accept arbitrary value types (or at...
T product() const
Return the product of all the vector components.
T sum() const
Return the sum of all the vector components.
T angle(const Vec2< T > &v1, const Vec2< T > &v2)
const Vec2< T > & operator*=(S scalar)
Multiply each element of this vector by scalar.
SYS_API double acos(double x)
GLboolean GLboolean GLboolean b
const Vec2< T > & operator*=(const Vec2< S > &v1)
Multiply each element of this vector by the corresponding element of the given vector.
T dot(const Vec2< T > &v) const
Dot product.
const Vec2< T > & operator=(const Vec2< Source > &v)
Assignment operator.
T & operator()(int i)
Alternative indexed reference to the elements.
Vec2< T > unit(T eps, T &len) const
return normalized this and length, throws if null vector
const Vec2< T > & init(T x=0, T y=0)
Vec2(T x, T y)
Constructor with two arguments, e.g. Vec2f v(1,2,3);.
const Vec2< T > & operator/=(S scalar)
Divide each element of this vector by scalar.
const Vec2< T > & operator+=(S scalar)
Add scalar to each element of this vector.
bool operator!=(const Vec2< T > &v) const
Inequality operator, does exact floating point comparisons.
static Vec2< T > zero()
Predefined constants, e.g. Vec2f v = Vec2f::xNegAxis();.
Vec2(Source *a)
Constructor with array argument, e.g. float a[2]; Vec2f v(a);.
ImageBuf OIIO_API max(Image_or_Const A, Image_or_Const B, ROI roi={}, int nthreads=0)
Vec2< T > maxComponent(const Vec2< T > &v1, const Vec2< T > &v2)
Return component-wise maximum of the two vectors.
const Vec2< T > & setZero()
Set "this" vector to zero.
Vec3< typename promote< T, typename Coord::ValueType >::type > operator+(const Vec3< T > &v0, const Coord &v1)
Allow a Coord to be added to or subtracted from a Vec3.
const Vec2< T > & operator-=(S scalar)
Subtract scalar from each element of this vector.
const Vec2< T > & scale(T0 scalar, const Vec2< T1 > &v)
static unsigned numElements()
Vec2< T > unit(T eps=0) const
return normalized this, throws if null vector
const Vec2< T > & operator/=(const Vec2< S > &v1)
Divide each element of this vector by the corresponding element of the given vector.
OIIO_FORCEINLINE T log(const T &v)
Vec2< T > unitSafe() const
return normalized this, or (1, 0) if this is null vector
Vec2(const Tuple< 2, Source > &t)
Conversion constructor.
T x() const
Get the component, e.g. float f = v.y();.
#define OPENVDB_VERSION_NAME
The version namespace name for this library version.
const Vec2< T > & sub(const Vec2< T0 > &v1, const Vec2< T1 > &v2)
#define OPENVDB_THROW(exception, message)
const T * asPointer() const
Type Exp(const Type &x)
Return ex.
const Vec2< T > & add(const Vec2< T0 > &v1, const Vec2< T1 > &v2)