/usr/include/libwildmagic/Wm5HPlane.h is in libwildmagic-dev 5.13-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 | // Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.2 (2011/03/27)
#ifndef WM5HPLANE_H
#define WM5HPLANE_H
#include "Wm5MathematicsLIB.h"
#include "Wm5APoint.h"
namespace Wm5
{
class WM5_MATHEMATICS_ITEM HPlane
{
public:
// The plane is represented as Dot(N,X) - c = 0, where N = (n0,n1,n2,0)
// is a unit-length normal vector, c is the plane constant, and
// X = (x0,x1,x2,1) is any point on the plane. The user must ensure
// that the normal vector is unit length. The storage as a 4-tuple is
// (n0,n1,n2,-c).
// Construction and destruction.
HPlane (); // uninitialized
HPlane (const HPlane& plane);
~HPlane ();
// Specify N and c directly.
HPlane (float normal0, float normal1, float normal2, float constant);
HPlane (const AVector& normal, float constant);
// N is specified, c = Dot(N,P) where P = (p0,p1,p2,1) is a point on the
// plane.
HPlane (const AVector& normal, const APoint& p);
// N = Cross(P1-P0,P2-P0)/Length(Cross(P1-P0,P2-P0)), c = Dot(N,P0) where
// P0, P1, P2 are points on the plane.
HPlane (const APoint& p0, const APoint& p1, const APoint& p2);
// Specify the entire (n0,n1,n2,-c) tuple.
HPlane (const HPoint& tuple);
// Implicit conversion to HPoint.
inline operator HPoint ();
inline operator HPoint () const;
// Coordinate access.
inline operator const float* () const;
inline operator float* ();
inline const float& operator[] (int i) const;
inline float& operator[] (int i);
// Assignment.
HPlane& operator= (const HPlane& plane);
// Comparison (for use by STL containers).
bool operator== (const HPlane& plane) const;
bool operator!= (const HPlane& plane) const;
bool operator< (const HPlane& plane) const;
bool operator<= (const HPlane& plane) const;
bool operator> (const HPlane& plane) const;
bool operator>= (const HPlane& plane) const;
// Access to individual components.
inline void SetNormal (const AVector& normal);
inline void SetConstant (float constant);
inline AVector GetNormal () const;
inline float GetConstant () const;
// Compute L = Length(n0,n1,n2) and set the plane to (n0,n1,n2,-c)/L.
// This is useful when transforming planes by homogeneous matrices, where
// the unit-length normal is not guaranteed. The function returns L.
float Normalize (const float epsilon = Mathf::ZERO_TOLERANCE);
// Compute d = Dot(N,P)-c where N is the plane normal and c is the plane
// constant. This is a signed distance. The sign of the return value is
// positive if the point is on the positive side of the plane, negative if
// the point is on the negative side, and zero if the point is on the
// plane.
float DistanceTo (const APoint& p) const;
// The "positive side" of the plane is the half space to which the plane
// normal points. The "negative side" is the other half space. The
// function returns +1 when P is on the positive side, -1 when P is on the
// the negative side, or 0 when P is on the plane.
int WhichSide (const APoint& p) const;
private:
// Storage is (n0,n1,n2,-c).
HPoint mTuple;
};
#include "Wm5HPlane.inl"
}
#endif
|