Open3D (C++ API)
IntersectionTest.h
Go to the documentation of this file.
1 // ----------------------------------------------------------------------------
2 // - Open3D: www.open3d.org -
3 // ----------------------------------------------------------------------------
4 // The MIT License (MIT)
5 //
6 // Copyright (c) 2019 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/Dense>
30 
31 namespace open3d {
32 namespace geometry {
33 
35 public:
36  static bool AABBAABB(const Eigen::Vector3d& min0,
37  const Eigen::Vector3d& max0,
38  const Eigen::Vector3d& min1,
39  const Eigen::Vector3d& max1);
40 
41  static bool TriangleTriangle3d(const Eigen::Vector3d& p0,
42  const Eigen::Vector3d& p1,
43  const Eigen::Vector3d& p2,
44  const Eigen::Vector3d& q0,
45  const Eigen::Vector3d& q1,
46  const Eigen::Vector3d& q2);
47 
48  static bool TriangleAABB(const Eigen::Vector3d& box_center,
49  const Eigen::Vector3d& box_half_size,
50  const Eigen::Vector3d& vert0,
51  const Eigen::Vector3d& vert1,
52  const Eigen::Vector3d& vert2);
53 
55  static bool PointsCoplanar(const Eigen::Vector3d& p0,
56  const Eigen::Vector3d& p1,
57  const Eigen::Vector3d& p2,
58  const Eigen::Vector3d& p3);
59 
66  static double LinesMinimumDistance(const Eigen::Vector3d& p0,
67  const Eigen::Vector3d& p1,
68  const Eigen::Vector3d& q0,
69  const Eigen::Vector3d& q1);
70 
76  static double LineSegmentsMinimumDistance(const Eigen::Vector3d& p0,
77  const Eigen::Vector3d& p1,
78  const Eigen::Vector3d& q0,
79  const Eigen::Vector3d& q1);
80 };
81 
82 } // namespace geometry
83 } // namespace open3d
static double LineSegmentsMinimumDistance(const Eigen::Vector3d &p0, const Eigen::Vector3d &p1, const Eigen::Vector3d &q0, const Eigen::Vector3d &q1)
Definition: IntersectionTest.cpp:136
static bool PointsCoplanar(const Eigen::Vector3d &p0, const Eigen::Vector3d &p1, const Eigen::Vector3d &p2, const Eigen::Vector3d &p3)
Tests if the given four points all lie on the same plane.
Definition: IntersectionTest.cpp:88
static double LinesMinimumDistance(const Eigen::Vector3d &p0, const Eigen::Vector3d &p1, const Eigen::Vector3d &q0, const Eigen::Vector3d &q1)
Definition: IntersectionTest.cpp:95
static bool TriangleTriangle3d(const Eigen::Vector3d &p0, const Eigen::Vector3d &p1, const Eigen::Vector3d &p2, const Eigen::Vector3d &q0, const Eigen::Vector3d &q1, const Eigen::Vector3d &q2)
Definition: IntersectionTest.cpp:51
static bool TriangleAABB(const Eigen::Vector3d &box_center, const Eigen::Vector3d &box_half_size, const Eigen::Vector3d &vert0, const Eigen::Vector3d &vert1, const Eigen::Vector3d &vert2)
Definition: IntersectionTest.cpp:75
Definition: Open3DViewer.h:29
static bool AABBAABB(const Eigen::Vector3d &min0, const Eigen::Vector3d &max0, const Eigen::Vector3d &min1, const Eigen::Vector3d &max1)
Definition: IntersectionTest.cpp:35
Definition: IntersectionTest.h:34