199 M(T_.
M,_t.
rot),
p(T_.
p,_t.vel) {}
ATTR_WARN_UNUSED_RESULT const BMVert * v
IMETHOD friend FrameVel operator*(const FrameVel &f1, const FrameVel &f2)
FrameVel(const RotationVel &_M, const VectorVel &_p)
FrameVel(const Frame &T_, const Twist &_t)
IMETHOD FrameVel & operator=(const Frame &arg)
IMETHOD Twist GetTwist() const
FrameVel(const Frame &T_)
IMETHOD Frame GetFrame() const
IMETHOD friend bool Equal(const FrameVel &r1, const Frame &r2, double eps)
IMETHOD friend bool Equal(const Frame &r1, const FrameVel &r2, double eps)
IMETHOD friend bool Equal(const FrameVel &r1, const FrameVel &r2, double eps)
IMETHOD FrameVel Inverse() const
static IMETHOD FrameVel Identity()
represents a frame transformation in 3D space (rotation + translation)
IMETHOD VectorVel UnitY() const
RotationVel(const Rotation &R_, const Vector &_w)
static IMETHOD RotationVel RotZ(const doubleVel &angle)
IMETHOD RotationVel & operator=(const RotationVel &arg)
IMETHOD RotationVel Inverse() const
IMETHOD VectorVel UnitX() const
static IMETHOD RotationVel Identity()
static IMETHOD RotationVel RotX(const doubleVel &angle)
IMETHOD friend bool Equal(const Rotation &r1, const RotationVel &r2, double eps)
static IMETHOD RotationVel Rot(const Vector &rotvec, const doubleVel &angle)
RotationVel(const Rotation &R_)
IMETHOD VectorVel UnitZ() const
IMETHOD void DoRotX(const doubleVel &angle)
IMETHOD void DoRotY(const doubleVel &angle)
IMETHOD friend bool Equal(const RotationVel &r1, const RotationVel &r2, double eps)
static IMETHOD RotationVel Rot2(const Vector &rotvec, const doubleVel &angle)
IMETHOD void DoRotZ(const doubleVel &angle)
IMETHOD friend bool Equal(const RotationVel &r1, const Rotation &r2, double eps)
IMETHOD friend RotationVel operator*(const RotationVel &r1, const RotationVel &r2)
static IMETHOD RotationVel RotY(const doubleVel &angle)
represents rotations in 3 dimensional space.
IMETHOD friend TwistVel operator/(const TwistVel &lhs, double rhs)
static IMETHOD TwistVel Zero()
IMETHOD friend void SetToZero(TwistVel &v)
IMETHOD friend bool Equal(const Twist &a, const TwistVel &b, double eps)
TwistVel(const Twist &p, const Twist &v)
IMETHOD TwistVel & operator+=(const TwistVel &arg)
IMETHOD friend TwistVel operator-(const TwistVel &lhs, const TwistVel &rhs)
IMETHOD friend TwistVel operator*(double lhs, const TwistVel &rhs)
IMETHOD friend TwistVel operator*(const doubleVel &lhs, const TwistVel &rhs)
IMETHOD Twist GetTwist() const
IMETHOD void ReverseSign()
IMETHOD Twist GetTwistDot() const
IMETHOD friend bool Equal(const TwistVel &a, const Twist &b, double eps)
IMETHOD friend TwistVel operator+(const TwistVel &lhs, const TwistVel &rhs)
IMETHOD TwistVel & operator-=(const TwistVel &arg)
IMETHOD friend TwistVel operator-(const TwistVel &arg)
IMETHOD friend TwistVel operator*(const TwistVel &lhs, double rhs)
IMETHOD TwistVel RefPoint(const VectorVel &v_base_AB)
IMETHOD friend TwistVel operator*(const TwistVel &lhs, const doubleVel &rhs)
IMETHOD friend TwistVel operator/(const TwistVel &lhs, const doubleVel &rhs)
TwistVel(const VectorVel &_vel, const VectorVel &_rot)
IMETHOD friend bool Equal(const TwistVel &a, const TwistVel &b, double eps)
represents both translational and rotational velocities.
static IMETHOD VectorVel Zero()
IMETHOD friend bool Equal(const Vector &r1, const VectorVel &r2, double eps)
IMETHOD friend doubleVel dot(const VectorVel &lhs, const Vector &rhs)
VectorVel(const Vector &_p, const Vector &_v)
IMETHOD friend VectorVel operator+(const VectorVel &r1, const VectorVel &r2)
IMETHOD friend void SetToZero(VectorVel &v)
IMETHOD friend VectorVel operator*(const Rotation &R, const VectorVel &x)
IMETHOD friend VectorVel operator-(const VectorVel &r1, const VectorVel &r2)
VectorVel(const Vector &_p)
IMETHOD friend doubleVel dot(const Vector &lhs, const VectorVel &rhs)
IMETHOD friend VectorVel operator/(const VectorVel &r1, double r2)
IMETHOD VectorVel & operator=(const VectorVel &arg)
IMETHOD friend doubleVel dot(const VectorVel &lhs, const VectorVel &rhs)
IMETHOD friend VectorVel operator*(const VectorVel &r1, const VectorVel &r2)
IMETHOD friend bool Equal(const VectorVel &r1, const Vector &r2, double eps)
IMETHOD VectorVel & operator-=(const VectorVel &arg)
IMETHOD friend bool Equal(const VectorVel &r1, const VectorVel &r2, double eps)
IMETHOD void ReverseSign()
IMETHOD doubleVel Norm() const
IMETHOD VectorVel & operator+=(const VectorVel &arg)
A concrete implementation of a 3 dimensional vector class.
local_group_size(16, 16) .push_constant(Type b
local_group_size(16, 16) .push_constant(Type rhs
IMETHOD Vector diff(const Vector &a, const Vector &b, double dt=1)
Rall1d< double > doubleVel
IMETHOD void random(doubleVel &F)
IMETHOD Vector addDelta(const Vector &a, const Vector &da, double dt=1)
IMETHOD void posrandom(doubleVel &F)
double epsilon
default precision while comparing with Equal(..,..) functions. Initialized at 0.0000001.
IMETHOD bool Equal(const VectorAcc &, const VectorAcc &, double=epsilon)
Traits are traits classes to determine the type of a derivative of another type.