16 constexpr Plane3() noexcept = default;
32 const auto len =
n.length();
35 const auto rlen = 1 / len;
52 return Plane3<T>{ ixf.
A.transposed() * pl.
n, pl.
d - dot( pl.
n, ixf.
b ) };
61 return invTransformed( plane, xf.
inverse() );
67 return a.
n == b.
n && a.
d == b.
d;
71[[nodiscard]]
inline bool operator != (
const Plane3<T> & a,
const Plane3<T> & b )
MRMESH_API bool operator==(const BitSet &a, const BitSet &b)
compare that two bit sets have the same set bits (they can be equal even if sizes are distinct but la...
bool operator!=(const SetBitIteratorT< T > &a, const SetBitIteratorT< T > &b)
Definition MRMesh/MRBitSet.h:282
Definition MRMesh/MRAffineXf.h:14
constexpr AffineXf inverse() const noexcept
computes inverse transformation
V b
Definition MRMesh/MRAffineXf.h:19
M A
Definition MRMesh/MRAffineXf.h:18
constexpr Plane3() noexcept=default
Plane3 normalized() const
returns same plane represented with unit n-vector
Definition MRPlane3.h:30
Plane3< T > transformed(const Plane3< T > &plane, const AffineXf3< T > &xf)
Definition MRPlane3.h:59
Vector3< T > project(const Vector3< T > &p) const
finds the closest point on plane
Definition MRPlane3.h:40
T distance(const Vector3< T > &x) const
returns distance from given point to this plane (if n is a unit vector)
Definition MRPlane3.h:23
const Plane3 & operator+() const
returns same representation
Definition MRPlane3.h:28
Vector3< T > n
Definition MRPlane3.h:13
constexpr Plane3(const Plane3< U > &p) noexcept
Definition MRPlane3.h:19
T d
Definition MRPlane3.h:14
Plane3< T > invTransformed(const Plane3< T > &pl, const AffineXf3< T > &ixf)
Definition MRPlane3.h:50
Plane3 operator-() const
returns same plane represented with flipped direction of n-vector
Definition MRPlane3.h:26
static constexpr Plane3 fromDirAndPt(const Vector3< T > &n, const Vector3< T > &p)
Definition MRPlane3.h:20
Definition MRMesh/MRVector3.h:19