Open3D (C++ API)
PointCloud.h
Go to the documentation of this file.
1 // ----------------------------------------------------------------------------
2 // - Open3D: www.open3d.org -
3 // ----------------------------------------------------------------------------
4 // The MIT License (MIT)
5 //
6 // Copyright (c) 2018 www.open3d.org
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to deal
10 // in the Software without restriction, including without limitation the rights
11 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 // copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
14 //
15 // The above copyright notice and this permission notice shall be included in
16 // all copies or substantial portions of the Software.
17 //
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
24 // IN THE SOFTWARE.
25 // ----------------------------------------------------------------------------
26 
27 #pragma once
28 
29 #include <Eigen/Core>
30 #include <memory>
31 #include <tuple>
32 #include <vector>
33 
36 
37 namespace open3d {
38 
39 namespace camera {
40 class PinholeCameraIntrinsic;
41 }
42 
43 namespace geometry {
44 
45 class Image;
46 class RGBDImage;
47 class TriangleMesh;
48 class VoxelGrid;
49 
54 class PointCloud : public Geometry3D {
55 public:
61  PointCloud(const std::vector<Eigen::Vector3d> &points)
62  : Geometry3D(Geometry::GeometryType::PointCloud), points_(points) {}
63  ~PointCloud() override {}
64 
65 public:
66  PointCloud &Clear() override;
67  bool IsEmpty() const override;
68  Eigen::Vector3d GetMinBound() const override;
69  Eigen::Vector3d GetMaxBound() const override;
70  Eigen::Vector3d GetCenter() const override;
71  AxisAlignedBoundingBox GetAxisAlignedBoundingBox() const override;
72  OrientedBoundingBox GetOrientedBoundingBox() const override;
73  PointCloud &Transform(const Eigen::Matrix4d &transformation) override;
74  PointCloud &Translate(const Eigen::Vector3d &translation,
75  bool relative = true) override;
76  PointCloud &Scale(const double scale, bool center = true) override;
77  PointCloud &Rotate(const Eigen::Matrix3d &R, bool center = true) override;
78 
79  PointCloud &operator+=(const PointCloud &cloud);
80  PointCloud operator+(const PointCloud &cloud) const;
81 
83  bool HasPoints() const { return points_.size() > 0; }
84 
86  bool HasNormals() const {
87  return points_.size() > 0 && normals_.size() == points_.size();
88  }
89 
91  bool HasColors() const {
92  return points_.size() > 0 && colors_.size() == points_.size();
93  }
94 
97  for (size_t i = 0; i < normals_.size(); i++) {
98  normals_[i].normalize();
99  }
100  return *this;
101  }
102 
106  PointCloud &PaintUniformColor(const Eigen::Vector3d &color) {
107  ResizeAndPaintUniformColor(colors_, points_.size(), color);
108  return *this;
109  }
110 
118  PointCloud &RemoveNonFinitePoints(bool remove_nan = true,
119  bool remove_infinite = true);
120 
128  std::shared_ptr<PointCloud> SelectByIndex(
129  const std::vector<size_t> &indices, bool invert = false) const;
130 
138  std::shared_ptr<PointCloud> VoxelDownSample(double voxel_size) const;
139 
148  std::tuple<std::shared_ptr<PointCloud>,
149  Eigen::MatrixXi,
150  std::vector<std::vector<int>>>
151  VoxelDownSampleAndTrace(double voxel_size,
152  const Eigen::Vector3d &min_bound,
153  const Eigen::Vector3d &max_bound,
154  bool approximate_class = false) const;
155 
164  std::shared_ptr<PointCloud> UniformDownSample(size_t every_k_points) const;
165 
172  std::shared_ptr<PointCloud> Crop(const AxisAlignedBoundingBox &bbox) const;
173 
180  std::shared_ptr<PointCloud> Crop(const OrientedBoundingBox &bbox) const;
181 
187  std::tuple<std::shared_ptr<PointCloud>, std::vector<size_t>>
188  RemoveRadiusOutliers(size_t nb_points, double search_radius) const;
189 
195  std::tuple<std::shared_ptr<PointCloud>, std::vector<size_t>>
196  RemoveStatisticalOutliers(size_t nb_neighbors, double std_ratio) const;
197 
207  bool EstimateNormals(
208  const KDTreeSearchParam &search_param = KDTreeSearchParamKNN(),
209  bool fast_normal_computation = true);
210 
215  bool OrientNormalsToAlignWithDirection(
216  const Eigen::Vector3d &orientation_reference =
217  Eigen::Vector3d(0.0, 0.0, 1.0));
218 
223  bool OrientNormalsTowardsCameraLocation(
224  const Eigen::Vector3d &camera_location = Eigen::Vector3d::Zero());
225 
233  std::vector<double> ComputePointCloudDistance(const PointCloud &target);
234 
237  std::tuple<Eigen::Vector3d, Eigen::Matrix3d> ComputeMeanAndCovariance()
238  const;
239 
244  std::vector<double> ComputeMahalanobisDistance() const;
245 
248  std::vector<double> ComputeNearestNeighborDistance() const;
249 
251  std::tuple<std::shared_ptr<TriangleMesh>, std::vector<size_t>>
252  ComputeConvexHull() const;
253 
263  std::tuple<std::shared_ptr<TriangleMesh>, std::vector<size_t>>
264  HiddenPointRemoval(const Eigen::Vector3d &camera_location,
265  const double radius) const;
266 
278  std::vector<int> ClusterDBSCAN(double eps,
279  size_t min_points,
280  bool print_progress = false) const;
281 
291  std::tuple<Eigen::Vector4d, std::vector<size_t>> SegmentPlane(
292  const double distance_threshold = 0.01,
293  const int ransac_n = 3,
294  const int num_iterations = 100) const;
295 
315  static std::shared_ptr<PointCloud> CreateFromDepthImage(
316  const Image &depth,
317  const camera::PinholeCameraIntrinsic &intrinsic,
318  const Eigen::Matrix4d &extrinsic = Eigen::Matrix4d::Identity(),
319  double depth_scale = 1000.0,
320  double depth_trunc = 1000.0,
321  int stride = 1,
322  bool project_valid_depth_only = true);
323 
340  static std::shared_ptr<PointCloud> CreateFromRGBDImage(
341  const RGBDImage &image,
342  const camera::PinholeCameraIntrinsic &intrinsic,
343  const Eigen::Matrix4d &extrinsic = Eigen::Matrix4d::Identity(),
344  bool project_valid_depth_only = true);
345 
352  std::shared_ptr<PointCloud> CreateFromVoxelGrid(
353  const VoxelGrid &voxel_grid);
354 
355 public:
357  std::vector<Eigen::Vector3d> points_;
359  std::vector<Eigen::Vector3d> normals_;
361  std::vector<Eigen::Vector3d> colors_;
362 };
363 
364 } // namespace geometry
365 } // namespace open3d
The base geometry class.
Definition: Geometry.h:35
A bounding box that is aligned along the coordinate axes.
Definition: BoundingVolume.h:130
Contains the pinhole camera intrinsic parameters.
Definition: PinholeCameraIntrinsic.h:51
A bounding box oriented along an arbitrary frame of reference.
Definition: BoundingVolume.h:44
A point cloud consists of point coordinates, and optionally point colors and point normals...
Definition: PointCloud.h:54
bool HasPoints() const
Returns &#39;true&#39; if the point cloud contains points.
Definition: PointCloud.h:83
PointCloud & NormalizeNormals()
Normalize point normals to length 1.
Definition: PointCloud.h:96
std::vector< Eigen::Vector3d > points_
RGB colors of points.
Definition: PointCloud.h:357
PointCloud()
Default Constructor.
Definition: PointCloud.h:57
double voxel_size
Definition: FilePLY.cpp:285
PointCloud & PaintUniformColor(const Eigen::Vector3d &color)
Definition: PointCloud.h:106
Tensor operator+(T scalar_lhs, const Tensor &rhs)
Definition: Tensor.h:858
std::vector< Eigen::Vector3d > colors_
Points coordinates.
Definition: PointCloud.h:361
The base geometry class for 3D geometries.
Definition: Geometry3D.h:46
Base class for KDTree search parameters.
Definition: KDTreeSearchParam.h:35
RGBDImage is for a pair of registered color and depth images,.
Definition: RGBDImage.h:46
std::vector< Eigen::Vector3d > normals_
Points normals.
Definition: PointCloud.h:359
bool HasNormals() const
Returns true if the point cloud contains point normals.
Definition: PointCloud.h:86
int points
Definition: FilePCD.cpp:70
Definition: Reduction.cpp:36
~PointCloud() override
Definition: PointCloud.h:63
VoxelGrid is a collection of voxels which are aligned in grid.
Definition: VoxelGrid.h:81
GeometryType
Specifies possible geometry types.
Definition: Geometry.h:40
bool HasColors() const
Returns true if the point cloud contains point colors.
Definition: PointCloud.h:91
KDTree search parameters for pure KNN search.
Definition: KDTreeSearchParam.h:63
PointCloud(const std::vector< Eigen::Vector3d > &points)
Parameterized Constructor.
Definition: PointCloud.h:61
The Image class stores image with customizable width, height, num of channels and bytes per channel...
Definition: Image.h:53