36 class AxisAlignedBoundingBox;
52 R_(
Eigen::Matrix3d::Identity()),
62 const Eigen::Matrix3d& R,
63 const Eigen::Vector3d& extent)
73 virtual Eigen::Vector3d
GetMinBound()
const override;
74 virtual Eigen::Vector3d
GetMaxBound()
const override;
75 virtual Eigen::Vector3d
GetCenter()
const override;
78 bool robust)
const override;
80 const Eigen::Matrix4d& transformation)
override;
82 bool relative =
true)
override;
84 const Eigen::Vector3d& center)
override;
86 const Eigen::Vector3d& center)
override;
115 const std::vector<Eigen::Vector3d>&
points)
const;
134 const std::vector<Eigen::Vector3d>& points,
bool robust =
false);
170 const Eigen::Vector3d& max_bound)
172 min_bound_(min_bound),
173 max_bound_(max_bound),
180 virtual Eigen::Vector3d
GetMinBound()
const override;
181 virtual Eigen::Vector3d
GetMaxBound()
const override;
182 virtual Eigen::Vector3d
GetCenter()
const override;
185 bool robust =
false)
const override;
187 const Eigen::Matrix4d& transformation)
override;
189 const Eigen::Vector3d& translation,
bool relative =
true)
override;
201 const double scale,
const Eigen::Vector3d& center)
override;
206 const Eigen::Matrix3d& R,
const Eigen::Vector3d& center)
override;
211 Eigen::Vector3d
GetExtent()
const {
return (max_bound_ - min_bound_); }
218 double GetMaxExtent()
const {
return (max_bound_ - min_bound_).maxCoeff(); }
221 return (x - min_bound_(0)) / (max_bound_(0) - min_bound_(0));
225 return (y - min_bound_(1)) / (max_bound_(1) - min_bound_(1));
229 return (z - min_bound_(2)) / (max_bound_(2) - min_bound_(2));
241 const std::vector<Eigen::Vector3d>&
points)
const;
244 std::string GetPrintInfo()
const;
250 const std::vector<Eigen::Vector3d>& points);
OrientedBoundingBox & Clear() override
Clear all elements in the geometry.
Definition: BoundingVolume.cpp:40
The base geometry class.
Definition: Geometry.h:37
Eigen::Matrix3d R_
Definition: BoundingVolume.h:141
Eigen::Vector3d max_bound_
The upper x, y, z bounds of the bounding box.
Definition: BoundingVolume.h:256
A bounding box that is aligned along the coordinate axes.
Definition: BoundingVolume.h:155
~AxisAlignedBoundingBox() override
Definition: BoundingVolume.h:175
double GetXPercentage(double x) const
Definition: BoundingVolume.h:220
Eigen::Vector3d extent_
The extent of the bounding box in its frame of reference.
Definition: BoundingVolume.h:143
double Volume() const
Returns the volume of the bounding box.
Definition: BoundingVolume.cpp:102
A bounding box oriented along an arbitrary frame of reference.
Definition: BoundingVolume.h:44
Eigen::Vector3d min_bound_
The lower x, y, z bounds of the bounding box.
Definition: BoundingVolume.h:254
Definition: NonRigidOptimizer.cpp:41
bool IsEmpty() const override
Returns true iff the geometry is empty.
Definition: BoundingVolume.cpp:48
virtual Eigen::Vector3d GetCenter() const override
Returns the center of the geometry coordinates.
Definition: BoundingVolume.cpp:60
double GetMaxExtent() const
Definition: BoundingVolume.h:218
virtual OrientedBoundingBox & Transform(const Eigen::Matrix4d &transformation) override
Apply transformation (4x4 matrix) to the geometry coordinates.
Definition: BoundingVolume.cpp:70
double GetZPercentage(double z) const
Definition: BoundingVolume.h:228
virtual OrientedBoundingBox & Translate(const Eigen::Vector3d &translation, bool relative=true) override
Apply translation to the geometry coordinates.
Definition: BoundingVolume.cpp:78
std::vector< Eigen::Vector3d > GetBoxPoints() const
Definition: BoundingVolume.cpp:106
The base geometry class for 3D geometries.
Definition: Geometry3D.h:47
virtual AxisAlignedBoundingBox GetAxisAlignedBoundingBox() const override
Returns an axis-aligned bounding box of the geometry.
Definition: BoundingVolume.cpp:62
virtual Eigen::Vector3d GetMinBound() const override
Returns min bounds for geometry coordinates.
Definition: BoundingVolume.cpp:50
virtual OrientedBoundingBox & Scale(const double scale, const Eigen::Vector3d ¢er) override
Apply scaling to the geometry coordinates. Given a scaling factor , and center , a given point is tr...
Definition: BoundingVolume.cpp:88
Eigen::Vector3d color_
The color of the bounding box in RGB.
Definition: BoundingVolume.h:258
OrientedBoundingBox()
Default constructor.
Definition: BoundingVolume.h:49
~OrientedBoundingBox() override
Definition: BoundingVolume.h:68
double GetYPercentage(double y) const
Definition: BoundingVolume.h:224
static OrientedBoundingBox CreateFromPoints(const std::vector< Eigen::Vector3d > &points, bool robust=false)
Definition: BoundingVolume.cpp:148
AxisAlignedBoundingBox(const Eigen::Vector3d &min_bound, const Eigen::Vector3d &max_bound)
Parameterized constructor.
Definition: BoundingVolume.h:169
OrientedBoundingBox(const Eigen::Vector3d ¢er, const Eigen::Matrix3d &R, const Eigen::Vector3d &extent)
Parameterized constructor.
Definition: BoundingVolume.h:61
Definition: PinholeCameraIntrinsic.cpp:35
std::vector< size_t > GetPointIndicesWithinBoundingBox(const std::vector< Eigen::Vector3d > &points) const
Return indices to points that are within the bounding box.
Definition: BoundingVolume.cpp:122
virtual OrientedBoundingBox & Rotate(const Eigen::Matrix3d &R, const Eigen::Vector3d ¢er) override
Apply rotation to the geometry coordinates and normals. Given a rotation matrix , and center ...
Definition: BoundingVolume.cpp:95
Eigen::Vector3d color_
The color of the bounding box in RGB.
Definition: BoundingVolume.h:145
GeometryType
Specifies possible geometry types.
Definition: Geometry.h:42
virtual OrientedBoundingBox GetOrientedBoundingBox(bool robust) const override
Definition: BoundingVolume.cpp:66
Eigen::Vector3d GetExtent() const
Get the extent/length of the bounding box in x, y, and z dimension.
Definition: BoundingVolume.h:211
virtual Eigen::Vector3d GetMaxBound() const override
Returns max bounds for geometry coordinates.
Definition: BoundingVolume.cpp:55
AxisAlignedBoundingBox()
Default constructor.
Definition: BoundingVolume.h:160
static OrientedBoundingBox CreateFromAxisAlignedBoundingBox(const AxisAlignedBoundingBox &aabox)
Definition: BoundingVolume.cpp:139
Eigen::Vector3d GetHalfExtent() const
Returns the half extent of the bounding box.
Definition: BoundingVolume.h:214
Eigen::Vector3d center_
The center point of the bounding box.
Definition: BoundingVolume.h:138