| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file   testPose2.cpp | 
					
						
							|  |  |  |  * @brief  Unit tests for Pose2 class | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | #include "numericalDerivative.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | #include "Pose2.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | #include "Point2.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | #include "Rot2.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | //TEST(Pose2, print) {
 | 
					
						
							|  |  |  | //  Pose2 pose(Point2(1.0,2.0), Rot2(3.0));
 | 
					
						
							|  |  |  | //  pose.print("thepose");
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, constructors) { | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Point2 p; | 
					
						
							| 
									
										
										
										
											2009-12-18 08:09:54 +08:00
										 |  |  |   Pose2 pose(0,p); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Pose2 origin; | 
					
						
							|  |  |  |   assert_equal(pose,origin); | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | TEST(Pose2, exmap) { | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose(M_PI_2, Point2(1,2)); | 
					
						
							|  |  |  |   Pose2 expected(M_PI_2+0.018, Point2(1.01, 1.985)); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  |   Pose2 actual = pose.exmap(Vector_(3, 0.01, -0.015, 0.018)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-18 08:09:54 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, log) { | 
					
						
							|  |  |  |   Pose2 pose0(M_PI_2, Point2(1, 2)); | 
					
						
							|  |  |  |   Pose2 pose(M_PI, Point2(1.1, 2.1)); | 
					
						
							|  |  |  |   Vector expected = Vector_(3, 0.1, 0.1, M_PI_2); | 
					
						
							|  |  |  |   Vector actual = pose0.log(pose); | 
					
						
							|  |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | //TEST(Pose2, rotate) {
 | 
					
						
							|  |  |  | //  std::cout << "rotate\n";
 | 
					
						
							|  |  |  | //	double theta = 0.1, c=cos(theta),s=sin(theta);
 | 
					
						
							|  |  |  | //	Pose2 p1(1,0,0.2), p2(0,1,0.4);
 | 
					
						
							|  |  |  | //	CHECK(assert_equal(Pose2( c,s,0.3),p1.rotate(theta)));
 | 
					
						
							|  |  |  | //	CHECK(assert_equal(Pose2(-s,c,0.5),p2.rotate(theta)));
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  | //TEST(Pose2, operators) {
 | 
					
						
							|  |  |  | //  CHECK(assert_equal(Pose2(2,2,2),Pose2(1,1,1)+Pose2(1,1,1)));
 | 
					
						
							|  |  |  | //  CHECK(assert_equal(Pose2(0,0,0),Pose2(1,1,1)-Pose2(1,1,1)));
 | 
					
						
							|  |  |  | //}
 | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, transform_to ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose(M_PI_2, Point2(1,2)); // robot at (1,2) looking towards y
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Point2 point(-1,4);    // landmark at (-1,4)
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   // expected
 | 
					
						
							|  |  |  |   Point2 expected(2,2); | 
					
						
							|  |  |  |   Matrix expectedH1 = Matrix_(2,3, 0.0, -1.0, 2.0,  1.0, 0.0, -2.0); | 
					
						
							|  |  |  |   Matrix expectedH2 = Matrix_(2,2, 0.0, 1.0,  -1.0, 0.0); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   // actual
 | 
					
						
							|  |  |  |   Point2 actual = transform_to(pose,point); | 
					
						
							|  |  |  |   Matrix actualH1 = Dtransform_to1(pose,point); | 
					
						
							|  |  |  |   Matrix actualH2 = Dtransform_to2(pose,point); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(expected,actual)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expectedH2,actualH2)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Matrix numericalH1 = numericalDerivative21(transform_to, pose, point, 1e-5); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(numericalH1,actualH1)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Matrix numericalH2 = numericalDerivative22(transform_to, pose, point, 1e-5); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(numericalH2,actualH2)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, compose_a) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose1(Rot2(M_PI/10.0), Point2(.75, .5)); | 
					
						
							|  |  |  |   Pose2 pose2(Rot2(M_PI/4.0-M_PI/10.0), Point2(0.701289620636, 1.34933052585)); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose_expected(Rot2(M_PI/4.0), Point2(1.0, 2.0)); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Pose2 pose_actual_op = pose2 * pose1; | 
					
						
							|  |  |  |   Pose2 pose_actual_fcn = pose2.compose(pose1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_op)); | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_fcn)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, compose_b) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose1(Rot2(M_PI/4.0), Point2(1.0, 1.0)); | 
					
						
							|  |  |  |   Pose2 pose2(Rot2(M_PI/4.0), Point2(sqrt(.5), sqrt(.5))); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 pose_expected(Rot2(M_PI/2.0), Point2(1.0, 2.0)); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Pose2 pose_actual_op = pose2 * pose1; | 
					
						
							|  |  |  |   Pose2 pose_actual_fcn = pose2.compose(pose1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_op)); | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_fcn)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, between ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 p1(M_PI_2, Point2(1,2)); // robot at (1,2) looking towards y
 | 
					
						
							|  |  |  |   Pose2 p2(M_PI, Point2(-1,4));  // robot at (-1,4) loooking at negative x
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // expected
 | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 expected(M_PI_2, Point2(2,2)); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Matrix expectedH1 = Matrix_(3,3, | 
					
						
							|  |  |  |       0.0,-1.0,2.0, | 
					
						
							|  |  |  |       1.0,0.0,-2.0, | 
					
						
							|  |  |  |       0.0,0.0,-1.0 | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  |   Matrix expectedH2 = Matrix_(3,3, | 
					
						
							|  |  |  |       0.0,1.0,0.0, | 
					
						
							|  |  |  |       -1.0,0.0,0.0, | 
					
						
							|  |  |  |       0.0,0.0,1.0 | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // actual
 | 
					
						
							|  |  |  |   Pose2 actual = between(p1,p2); | 
					
						
							|  |  |  |   Matrix actualH1 = Dbetween1(p1,p2); | 
					
						
							|  |  |  |   Matrix actualH2 = Dbetween2(p1,p2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   CHECK(assert_equal(expected,actual)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expectedH2,actualH2)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Matrix numericalH1 = numericalDerivative21(between, p1, p2, 1e-5); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(numericalH1,actualH1)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Matrix numericalH2 = numericalDerivative22(between, p1, p2, 1e-5); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(numericalH2,actualH2)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   TestResult tr; | 
					
						
							|  |  |  |   return TestRegistry::runAllTests(tr); | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | } | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | 
 |