testSimPolygon2D.cpp
Go to the documentation of this file.
1 
8 
10 
11 using namespace std;
12 using namespace gtsam;
13 
14 const double tol=1e-5;
15 
16 /* ************************************************************************* */
17 TEST(testPolygon, triangle_basic) {
18 
19  // create a triangle from points, extract landmarks/walls, check occupancy
20  Point2 pA(0,0), pB(2.0, 0.0), pC(0.0, 1.0);
21 
22  // construct and extract data
23  SimPolygon2D actTriangle = SimPolygon2D::createTriangle(pA, pB, pC);
24  LONGS_EQUAL(3, actTriangle.size());
25  EXPECT(assert_equal(pA, actTriangle.landmark(0)));
26  EXPECT(assert_equal(pB, actTriangle.landmark(1)));
27  EXPECT(assert_equal(pC, actTriangle.landmark(2)));
28 
29  // get walls out
30  vector<SimWall2D> actWalls = actTriangle.walls();
31  vector<SimWall2D> expWalls;
32  expWalls.push_back(SimWall2D(pA, pB));
33  expWalls.push_back(SimWall2D(pB, pC));
34  expWalls.push_back(SimWall2D(pC, pA));
35  EXPECT(assert_container_equal(expWalls, actWalls, tol));
36 
37  // check occupancy - used in sampling more points
38  // treat as closed polygon - points along edges also count
39  EXPECT(actTriangle.contains(Point2(0.25, 0.5)));
40  EXPECT(actTriangle.contains(pA));
41  EXPECT(actTriangle.contains(pB));
42  EXPECT(actTriangle.contains(pC));
43  EXPECT(actTriangle.contains(Point2(1.0, 0.0)));
44 
45  EXPECT(!actTriangle.contains(Point2(1.0, 1.0)));
46  EXPECT(!actTriangle.contains(Point2(-1.0, 1.0)));
47 }
48 
49 /* ************************************************************************* */
50 TEST(testPolygon, rectangle_basic) {
51 
52  // creates an axis-aligned rectangle given a lower left corner and a height and width
53  double height = 3.0, width = 2.0;
54  Point2 pA(1.0, 0.0), pB(3.0, 0.0), pC(3.0, 3.0), pD(1.0, 3.0);
55 
56  // construct and extract data
57  SimPolygon2D actRectangle = SimPolygon2D::createRectangle(pA, height, width);
58  LONGS_EQUAL(4, actRectangle.size());
59  EXPECT(assert_equal(pA, actRectangle.landmark(0)));
60  EXPECT(assert_equal(pB, actRectangle.landmark(1)));
61  EXPECT(assert_equal(pC, actRectangle.landmark(2)));
62  EXPECT(assert_equal(pD, actRectangle.landmark(3)));
63 
64  // get walls out
65  vector<SimWall2D> actWalls = actRectangle.walls();
66  vector<SimWall2D> expWalls;
67  expWalls.push_back(SimWall2D(pA, pB));
68  expWalls.push_back(SimWall2D(pB, pC));
69  expWalls.push_back(SimWall2D(pC, pD));
70  expWalls.push_back(SimWall2D(pD, pA));
71  EXPECT(assert_container_equal(expWalls, actWalls, tol));
72 
73  // check occupancy - used in sampling more points
74  // treat as closed polygon - points along edges also count
75  EXPECT(actRectangle.contains(Point2(2.0, 1.0)));
76  EXPECT(actRectangle.contains(pA));
77  EXPECT(actRectangle.contains(pB));
78  EXPECT(actRectangle.contains(pC));
79  EXPECT(actRectangle.contains(pD));
80  EXPECT(actRectangle.contains(Point2(1.0, 0.0)));
81 
82  EXPECT(!actRectangle.contains(Point2(0.9, 0.5)));
83  EXPECT(!actRectangle.contains(Point2(-1.0, 1.0)));
84 }
85 
86 /* ************************************************************************* */
87 TEST(testPolygon, triangle_generator) {
88  // generate random triangles in a bounded region with no overlap
89  double side_len = 10.0; // box of length 10, centered on origin
90  double mean_side_len = 2.0; // mean length of sides
91  double sigma_side_len = 0.5; // stddev for length of sides
92  double min_vertex_dist = 0.4; // minimum allowable distance between vertices
93  double min_side_len = 0.1;
94 
95  // initialize the random number generator for consistency
96  SimPolygon2D::seedGenerator(42u);
97 
98  vector<SimPolygon2D> existing_polys;
99 
100  SimPolygon2D actual = SimPolygon2D::randomTriangle(side_len, mean_side_len, sigma_side_len,
101  min_vertex_dist, min_side_len, existing_polys);
102 
103  // use a rectangle to check that it is within boundaries
104  SimPolygon2D bounding_rect = SimPolygon2D::createRectangle(Point2(-5.0,-5.0), side_len, side_len);
105 
106  EXPECT(bounding_rect.contains(actual.landmark(0)));
107  EXPECT(bounding_rect.contains(actual.landmark(1)));
108  EXPECT(bounding_rect.contains(actual.landmark(2)));
109 }
110 
111 /* ************************************************************************* */
112 TEST(testPolygon, rectangle_generator) {
113  // generate random rectangles in a bounded region with no overlap
114  double side_len = 10.0; // box of length 10, centered on origin
115  double mean_side_len = 2.0; // mean length of sides
116  double sigma_side_len = 0.5; // stddev for length of sides
117  double min_vertex_dist = 0.4; // minimum allowable distance between vertices
118  double min_side_len = 0.1;
119 
120  // initialize the random number generator for consistency
121  SimPolygon2D::seedGenerator(42u);
122 
123  vector<SimPolygon2D> existing_polys;
124 
125  SimPolygon2D actual = SimPolygon2D::randomRectangle(side_len, mean_side_len, sigma_side_len,
126  min_vertex_dist, min_side_len, existing_polys);
127 
128  // use a rectangle to check that it is within boundaries
129  SimPolygon2D bounding_rect = SimPolygon2D::createRectangle(Point2(-5.0,-5.0), side_len, side_len);
130 
131  EXPECT(bounding_rect.contains(actual.landmark(0)));
132  EXPECT(bounding_rect.contains(actual.landmark(1)));
133  EXPECT(bounding_rect.contains(actual.landmark(2)));
134  EXPECT(bounding_rect.contains(actual.landmark(3)));
135 }
136 
137 /* ************************************************************************* */
138 int main() { TestResult tr; return TestRegistry::runAllTests(tr); }
139 /* ************************************************************************* */
TestRegistry::runAllTests
static int runAllTests(TestResult &result)
Definition: TestRegistry.cpp:27
gtsam::SimPolygon2D::landmark
const Point2 & landmark(size_t i) const
Definition: SimPolygon2D.h:59
main
int main()
Definition: testSimPolygon2D.cpp:138
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
EXPECT
#define EXPECT(condition)
Definition: Test.h:150
TestHarness.h
asiaCPTs::pA
ADT pA
Definition: testAlgebraicDecisionTree.cpp:153
TestableAssertions.h
Provides additional testing facilities for common data structures.
gtsam::Point2
Vector2 Point2
Definition: Point2.h:32
asiaCPTs::pD
ADT pD
Definition: testAlgebraicDecisionTree.cpp:160
TestResult
Definition: TestResult.h:26
gtsam::assert_container_equal
bool assert_container_equal(const std::map< V1, V2 > &expected, const std::map< V1, V2 > &actual, double tol=1e-9)
Definition: TestableAssertions.h:90
gtsam::SimPolygon2D
Definition: SimPolygon2D.h:20
TEST
TEST(testPolygon, triangle_basic)
Definition: testSimPolygon2D.cpp:17
gtsam
traits
Definition: SFMdata.h:40
std
Definition: BFloat16.h:88
gtsam::SimPolygon2D::size
size_t size() const
Definition: SimPolygon2D.h:60
gtsam::assert_equal
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
Definition: Matrix.cpp:41
gtsam::SimPolygon2D::contains
bool contains(const Point2 &p) const
Definition: SimPolygon2D.cpp:68
gtsam::SimWall2D
Definition: SimWall2D.h:19
asiaCPTs::pB
ADT pB
Definition: testAlgebraicDecisionTree.cpp:157
SimPolygon2D.h
Polygons for simulation use.
gtsam::SimPolygon2D::walls
std::vector< SimWall2D > walls() const
Definition: SimPolygon2D.cpp:59
tol
const double tol
Definition: testSimPolygon2D.cpp:14
LONGS_EQUAL
#define LONGS_EQUAL(expected, actual)
Definition: Test.h:134


gtsam
Author(s):
autogenerated on Sat Jan 4 2025 04:07:06