22 constexpr Plane3() noexcept = default;
28 constexpr explicit Plane3(
const Plane3<U> & p ) noexcept :
n( p.n ),
d( T( p.d ) ) { }
42 const auto len =
n.length();
45 const auto rlen = 1 / len;
54 return s << pl.
n <<
'\n' << pl.
d;
59 return s >> pl.
n >> pl.
d;
72 return Plane3<T>{ ixf.
A.transposed() * pl.
n, pl.
d - dot( pl.
n, ixf.
b ) };
82 return invTransformed( plane, xf.inverse() );
88 return a.
n == b.
n && a.
d == b.
d;
92[[nodiscard]]
inline bool operator != (
const Plane3<T> & a,
const Plane3<T> & b )
#define MR_REQUIRES_IF_SUPPORTED(...)
Definition MRMacros.h:34
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...
Definition MRCameraOrientationPlugin.h:8
bool operator!=(const Color &a, const Color &b)
Definition MRMesh/MRColor.h:101
Definition MRMesh/MRAffineXf.h:23
V b
Definition MRMesh/MRAffineXf.h:28
M A
Definition MRMesh/MRAffineXf.h:27
constexpr Plane3() noexcept=default
Plane3 normalized() const
returns same plane represented with unit n-vector
Definition MRPlane3.h:40
Plane3< T > transformed(const Plane3< T > &plane, const AffineXf3< T > &xf)
Definition MRPlane3.h:80
Vector3< T > project(const Vector3< T > &p) const
finds the closest point on plane
Definition MRPlane3.h:50
T distance(const Vector3< T > &x) const
returns distance from given point to this plane (if n is a unit vector)
Definition MRPlane3.h:33
MR_REQUIRES_IF_SUPPORTED(!std::is_same_v< T, U >) const expr explicit Plane3(const Plane3< U > &p) noexcept
Definition MRPlane3.h:27
friend std::ostream & operator<<(std::ostream &s, const Plane3 &pl)
Definition MRPlane3.h:52
const Plane3 & operator+() const
returns same representation
Definition MRPlane3.h:38
Vector3< T > n
Definition MRPlane3.h:19
friend std::istream & operator>>(std::istream &s, Plane3 &pl)
Definition MRPlane3.h:57
T d
Definition MRPlane3.h:20
Plane3< T > invTransformed(const Plane3< T > &pl, const AffineXf3< T > &ixf)
Definition MRPlane3.h:70
Plane3 operator-() const
returns same plane represented with flipped direction of n-vector
Definition MRPlane3.h:36
static constexpr Plane3 fromDirAndPt(const Vector3< T > &n, const Vector3< T > &p)
Definition MRPlane3.h:30
Definition MRMesh/MRVector3.h:30
Definition MRMesh/MRVectorTraits.h:15