139 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
| /**
 | |
|  * @file testSimPolygon
 | |
|  * @author Alex Cunningham
 | |
|  */
 | |
| 
 | |
| #include <CppUnitLite/TestHarness.h>
 | |
| #include <gtsam/base/TestableAssertions.h>
 | |
| #include <gtsam_unstable/geometry/SimPolygon2D.h>
 | |
| 
 | |
| using namespace std;
 | |
| using namespace gtsam;
 | |
| 
 | |
| const double tol=1e-5;
 | |
| 
 | |
| /* ************************************************************************* */
 | |
| TEST(testPolygon, triangle_basic) {
 | |
| 
 | |
|   // create a triangle from points, extract landmarks/walls, check occupancy
 | |
|   Point2 pA, pB(2.0, 0.0), pC(0.0, 1.0);
 | |
| 
 | |
|   // construct and extract data
 | |
|   SimPolygon2D actTriangle = SimPolygon2D::createTriangle(pA, pB, pC);
 | |
|   LONGS_EQUAL(3, actTriangle.size());
 | |
|   EXPECT(assert_equal(pA, actTriangle.landmark(0)));
 | |
|   EXPECT(assert_equal(pB, actTriangle.landmark(1)));
 | |
|   EXPECT(assert_equal(pC, actTriangle.landmark(2)));
 | |
| 
 | |
|   // get walls out
 | |
|   vector<SimWall2D> actWalls = actTriangle.walls();
 | |
|   vector<SimWall2D> expWalls;
 | |
|   expWalls.push_back(SimWall2D(pA, pB));
 | |
|   expWalls.push_back(SimWall2D(pB, pC));
 | |
|   expWalls.push_back(SimWall2D(pC, pA));
 | |
|   EXPECT(assert_container_equal(expWalls, actWalls, tol));
 | |
| 
 | |
|   // check occupancy - used in sampling more points
 | |
|   // treat as closed polygon - points along edges also count
 | |
|   EXPECT(actTriangle.contains(Point2(0.25, 0.5)));
 | |
|   EXPECT(actTriangle.contains(pA));
 | |
|   EXPECT(actTriangle.contains(pB));
 | |
|   EXPECT(actTriangle.contains(pC));
 | |
|   EXPECT(actTriangle.contains(Point2(1.0, 0.0)));
 | |
| 
 | |
|   EXPECT(!actTriangle.contains(Point2(1.0, 1.0)));
 | |
|   EXPECT(!actTriangle.contains(Point2(-1.0, 1.0)));
 | |
| }
 | |
| 
 | |
| /* ************************************************************************* */
 | |
| TEST(testPolygon, rectangle_basic) {
 | |
| 
 | |
|   // creates an axis-aligned rectangle given a lower left corner and a height and width
 | |
|   double height = 3.0, width = 2.0;
 | |
|   Point2 pA(1.0, 0.0), pB(3.0, 0.0), pC(3.0, 3.0), pD(1.0, 3.0);
 | |
| 
 | |
|   // construct and extract data
 | |
|   SimPolygon2D actRectangle = SimPolygon2D::createRectangle(pA, height, width);
 | |
|   LONGS_EQUAL(4, actRectangle.size());
 | |
|   EXPECT(assert_equal(pA, actRectangle.landmark(0)));
 | |
|   EXPECT(assert_equal(pB, actRectangle.landmark(1)));
 | |
|   EXPECT(assert_equal(pC, actRectangle.landmark(2)));
 | |
|   EXPECT(assert_equal(pD, actRectangle.landmark(3)));
 | |
| 
 | |
|   // get walls out
 | |
|   vector<SimWall2D> actWalls = actRectangle.walls();
 | |
|   vector<SimWall2D> expWalls;
 | |
|   expWalls.push_back(SimWall2D(pA, pB));
 | |
|   expWalls.push_back(SimWall2D(pB, pC));
 | |
|   expWalls.push_back(SimWall2D(pC, pD));
 | |
|   expWalls.push_back(SimWall2D(pD, pA));
 | |
|   EXPECT(assert_container_equal(expWalls, actWalls, tol));
 | |
| 
 | |
|   // check occupancy - used in sampling more points
 | |
|   // treat as closed polygon - points along edges also count
 | |
|   EXPECT(actRectangle.contains(Point2(2.0, 1.0)));
 | |
|   EXPECT(actRectangle.contains(pA));
 | |
|   EXPECT(actRectangle.contains(pB));
 | |
|   EXPECT(actRectangle.contains(pC));
 | |
|   EXPECT(actRectangle.contains(pD));
 | |
|   EXPECT(actRectangle.contains(Point2(1.0, 0.0)));
 | |
| 
 | |
|   EXPECT(!actRectangle.contains(Point2(0.9, 0.5)));
 | |
|   EXPECT(!actRectangle.contains(Point2(-1.0, 1.0)));
 | |
| }
 | |
| 
 | |
| /* ************************************************************************* */
 | |
| TEST(testPolygon, triangle_generator) {
 | |
|   // generate random triangles in a bounded region with no overlap
 | |
|   double side_len = 10.0; // box of length 10, centered on origin
 | |
|   double mean_side_len = 2.0;   // mean length of sides
 | |
|   double sigma_side_len = 0.5;  // stddev for length of sides
 | |
|   double min_vertex_dist = 0.4; // minimum allowable distance between vertices
 | |
|   double min_side_len = 0.1;
 | |
| 
 | |
|   // initialize the random number generator for consistency
 | |
|   SimPolygon2D::seedGenerator(42u);
 | |
| 
 | |
|   vector<SimPolygon2D> existing_polys;
 | |
| 
 | |
|   SimPolygon2D actual = SimPolygon2D::randomTriangle(side_len, mean_side_len, sigma_side_len,
 | |
|       min_vertex_dist, min_side_len, existing_polys);
 | |
| 
 | |
|   // use a rectangle to check that it is within boundaries
 | |
|   SimPolygon2D bounding_rect = SimPolygon2D::createRectangle(Point2(-5.0,-5.0), side_len, side_len);
 | |
| 
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(0)));
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(1)));
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(2)));
 | |
| }
 | |
| 
 | |
| /* ************************************************************************* */
 | |
| TEST(testPolygon, rectangle_generator) {
 | |
|   // generate random rectangles in a bounded region with no overlap
 | |
|   double side_len = 10.0; // box of length 10, centered on origin
 | |
|   double mean_side_len = 2.0;   // mean length of sides
 | |
|   double sigma_side_len = 0.5;  // stddev for length of sides
 | |
|   double min_vertex_dist = 0.4; // minimum allowable distance between vertices
 | |
|   double min_side_len = 0.1;
 | |
| 
 | |
|   // initialize the random number generator for consistency
 | |
|   SimPolygon2D::seedGenerator(42u);
 | |
| 
 | |
|   vector<SimPolygon2D> existing_polys;
 | |
| 
 | |
|   SimPolygon2D actual = SimPolygon2D::randomRectangle(side_len, mean_side_len, sigma_side_len,
 | |
|       min_vertex_dist, min_side_len, existing_polys);
 | |
| 
 | |
|   // use a rectangle to check that it is within boundaries
 | |
|   SimPolygon2D bounding_rect = SimPolygon2D::createRectangle(Point2(-5.0,-5.0), side_len, side_len);
 | |
| 
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(0)));
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(1)));
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(2)));
 | |
|   EXPECT(bounding_rect.contains(actual.landmark(3)));
 | |
| }
 | |
| 
 | |
| /* ************************************************************************* */
 | |
| int main() { TestResult tr; return TestRegistry::runAllTests(tr); }
 | |
| /* ************************************************************************* */
 |