| 
									
										
										
										
											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-22 00:43:23 +08:00
										 |  |  | #include <iostream>
 | 
					
						
							| 
									
										
										
										
											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-22 00:43:23 +08:00
										 |  |  | using namespace std; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-29 09:24:26 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, constructors) { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "constructors" << endl;
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-05 22:13:51 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, manifold) { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "manifold" << endl;
 | 
					
						
							| 
									
										
										
										
											2010-01-05 22:13:51 +08:00
										 |  |  | 	Pose2 t1(M_PI_2, Point2(1, 2)); | 
					
						
							|  |  |  | 	Pose2 t2(M_PI_2+0.018, Point2(1.015, 2.01)); | 
					
						
							|  |  |  | 	Pose2 origin; | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | 	Vector d12 = logmap(t1,t2); | 
					
						
							|  |  |  | 	CHECK(assert_equal(t2, expmap(t1,d12))); | 
					
						
							|  |  |  | 	CHECK(assert_equal(t2, expmap(origin,d12)*t1)); | 
					
						
							|  |  |  | 	Vector d21 = logmap(t2,t1); | 
					
						
							|  |  |  | 	CHECK(assert_equal(t1, expmap(t2,d21))); | 
					
						
							|  |  |  | 	CHECK(assert_equal(t1, expmap(origin,d21)*t2)); | 
					
						
							| 
									
										
										
										
											2010-01-05 22:13:51 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | TEST(Pose2, expmap) { | 
					
						
							|  |  |  |   //cout << "expmap" << endl;
 | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   Pose2 pose(M_PI_2, Point2(1, 2)); | 
					
						
							|  |  |  |   Pose2 expected(M_PI_2+0.018, Point2(1.015, 2.01)); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Pose2 actual = expmap(pose, Vector_(3, 0.01, -0.015, 0.018)); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							| 
									
										
										
										
											2009-12-08 22:02:56 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | TEST(Pose2, expmap0) { | 
					
						
							|  |  |  |   //cout << "expmap0" << endl;
 | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   Pose2 pose(M_PI_2, Point2(1, 2)); | 
					
						
							|  |  |  |   Pose2 expected(M_PI_2+0.018, Point2(1.015, 2.01)); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Pose2 actual = expmap<Pose2>(Vector_(3, 0.01, -0.015, 0.018)) * pose; | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-18 08:09:54 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | TEST(Pose2, logmap) { | 
					
						
							|  |  |  |   //cout << "logmap" << endl;
 | 
					
						
							| 
									
										
										
										
											2009-12-18 08:09:54 +08:00
										 |  |  |   Pose2 pose0(M_PI_2, Point2(1, 2)); | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   Pose2 pose(M_PI_2+0.018, Point2(1.015, 2.01)); | 
					
						
							|  |  |  |   Vector expected = Vector_(3, 0.01, -0.015, 0.018); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Vector actual = logmap(pose0,pose); | 
					
						
							| 
									
										
										
										
											2009-12-18 08:09:54 +08:00
										 |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, transform_to ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "transform_to" << endl;
 | 
					
						
							| 
									
										
										
										
											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); | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  | //  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)); | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  | //  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)); | 
					
						
							| 
									
										
										
										
											2010-01-12 10:08:41 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   transform_to(pose,point,actualH1,actualH2); | 
					
						
							|  |  |  |   CHECK(assert_equal(numericalH1,actualH1)); | 
					
						
							|  |  |  |   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-22 00:43:23 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "compose_a" << endl;
 | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   Pose2 pose1(M_PI/4.0, Point2(sqrt(0.5), sqrt(0.5))); | 
					
						
							|  |  |  |   Pose2 pose2(M_PI/2.0, Point2(0.0, 2.0)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Pose2 expected(3.0*M_PI/4.0, Point2(-sqrt(0.5), 3.0*sqrt(0.5))); | 
					
						
							|  |  |  |   Pose2 actual = pose2 * pose1; | 
					
						
							|  |  |  |   CHECK(assert_equal(expected, actual)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Point2 point(sqrt(0.5), 3.0*sqrt(0.5)); | 
					
						
							|  |  |  |   Point2 expected_point(-1.0, -1.0); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Point2 actual_point1 = transform_to(pose2 * pose1, point); | 
					
						
							|  |  |  |   Point2 actual_point2 = transform_to(pose2, transform_to(pose1, point)); | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |   CHECK(assert_equal(expected_point, actual_point1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expected_point, actual_point2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, compose_b) | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "compose_b" << endl;
 | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Pose2 pose_actual_fcn = compose(pose2,pose1); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_op)); | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_fcn)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  | TEST(Pose2, compose_c) | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   //cout << "compose_c" << endl;
 | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   Pose2 pose_actual_fcn = compose(pose2,pose1); | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_op)); | 
					
						
							|  |  |  |   CHECK(assert_equal(pose_expected, pose_actual_fcn)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 13:45:59 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, inverse ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Point2 origin, t(1,2); | 
					
						
							|  |  |  | 	Pose2 gTl(M_PI_2, t); // robot at (1,2) looking towards y
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Pose2 identity, lTg = inverse(gTl); | 
					
						
							|  |  |  | 	CHECK(assert_equal(identity,compose(lTg,gTl))); | 
					
						
							|  |  |  | 	CHECK(assert_equal(identity,compose(gTl,lTg))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Point2 l(4,5), g(-4,6); | 
					
						
							|  |  |  | 	CHECK(assert_equal(g,gTl*l)); | 
					
						
							|  |  |  | 	CHECK(assert_equal(l,lTg*g)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | Vector homogeneous(const Point2& p) { | 
					
						
							|  |  |  | 	return Vector_(3, p.x(), p.y(), 1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Matrix matrix(const Pose2& gTl) { | 
					
						
							|  |  |  | 	Matrix gRl = gTl.r().matrix(); | 
					
						
							|  |  |  | 	Point2 gt = gTl.t(); | 
					
						
							|  |  |  | 	return Matrix_(3, 3, | 
					
						
							|  |  |  | 			gRl(0, 0), gRl(0, 1), gt.x(), | 
					
						
							|  |  |  | 			gRl(1, 0), gRl(1, 1), gt.y(), | 
					
						
							|  |  |  | 			      0.0,       0.0,   1.0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TEST( Pose2, matrix ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Point2 origin, t(1,2); | 
					
						
							|  |  |  | 	Pose2 gT1(M_PI_2, t); // robot at (1,2) looking towards y
 | 
					
						
							|  |  |  |   Matrix gM1 = matrix(gT1); | 
					
						
							|  |  |  |   CHECK(assert_equal(Matrix_(3,3, | 
					
						
							|  |  |  |   		0.0, -1.0, 1.0, | 
					
						
							|  |  |  |   		1.0,  0.0, 2.0, | 
					
						
							|  |  |  |   		0.0,  0.0, 1.0), | 
					
						
							|  |  |  |   		gM1)); | 
					
						
							|  |  |  |   Rot2 gR1 = gT1.r(); | 
					
						
							|  |  |  |   CHECK(assert_equal(homogeneous(t),gM1*homogeneous(origin))); | 
					
						
							|  |  |  |   Point2 x_axis(1,0), y_axis(0,1); | 
					
						
							|  |  |  |   CHECK(assert_equal(Matrix_(2,2, | 
					
						
							|  |  |  |   		0.0, -1.0, | 
					
						
							|  |  |  |   		1.0,  0.0), | 
					
						
							|  |  |  |   		gR1.matrix())); | 
					
						
							|  |  |  |   CHECK(assert_equal(Point2(0,1),gR1*x_axis)); | 
					
						
							|  |  |  |   CHECK(assert_equal(Point2(-1,0),gR1*y_axis)); | 
					
						
							|  |  |  |   CHECK(assert_equal(homogeneous(Point2(1+0,2+1)),gM1*homogeneous(x_axis))); | 
					
						
							|  |  |  |   CHECK(assert_equal(homogeneous(Point2(1-1,2+0)),gM1*homogeneous(y_axis))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // check inverse pose
 | 
					
						
							|  |  |  |   Matrix _1Mg = matrix(inverse(gT1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(inverse(gM1),_1Mg)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-12-14 11:02:05 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, between ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  |   // <
 | 
					
						
							|  |  |  |   //
 | 
					
						
							|  |  |  | 	//       ^
 | 
					
						
							|  |  |  | 	//
 | 
					
						
							|  |  |  | 	// *--0--*--*
 | 
					
						
							| 
									
										
										
										
											2010-01-22 13:45:59 +08:00
										 |  |  |   Pose2 gT1(M_PI_2, Point2(1,2)); // robot at (1,2) looking towards y
 | 
					
						
							|  |  |  |   Pose2 gT2(M_PI, Point2(-1,4));  // robot at (-1,4) loooking at negative x
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  |   Matrix actualH1,actualH2; | 
					
						
							| 
									
										
										
										
											2009-12-17 05:39:03 +08:00
										 |  |  |   Pose2 expected(M_PI_2, Point2(2,2)); | 
					
						
							| 
									
										
										
										
											2010-01-22 13:45:59 +08:00
										 |  |  |   Pose2 actual1 = between(gT1,gT2); // gT2 * 1Tg does not make sense !!!!!
 | 
					
						
							|  |  |  |   GTSAM_PRINT(between(gT1,gT2)); | 
					
						
							|  |  |  |   // what we want is 1T2 = 1Tg * gT2 = between(2Tg,1Tg)
 | 
					
						
							|  |  |  | //  print(matrix(gT1));
 | 
					
						
							|  |  |  | //  print(matrix(gT2));
 | 
					
						
							|  |  |  | //  print(inverse(matrix(gT1))*matrix(gT2)); // 1T2
 | 
					
						
							|  |  |  | //  print(inverse(matrix(gT2))*matrix(gT1)); // 2T1
 | 
					
						
							|  |  |  | //  GTSAM_PRINT(between(inverse(gT2),inverse(gT1)));
 | 
					
						
							|  |  |  |   Pose2 actual2 = between(gT1,gT2,actualH1,actualH2); | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  |   CHECK(assert_equal(expected,actual1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(expected,actual2)); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Matrix expectedH1 = Matrix_(3,3, | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |       0.0,-1.0,-2.0, | 
					
						
							|  |  |  |       1.0, 0.0,-2.0, | 
					
						
							|  |  |  |       0.0, 0.0,-1.0 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   ); | 
					
						
							| 
									
										
										
										
											2010-01-22 13:45:59 +08:00
										 |  |  |   Matrix numericalH1 = numericalDerivative21(between<Pose2>, gT1, gT2, 1e-5); | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  |   CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  |   CHECK(assert_equal(numericalH1,actualH1)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   Matrix expectedH2 = Matrix_(3,3, | 
					
						
							| 
									
										
										
										
											2009-12-22 00:43:23 +08:00
										 |  |  |        1.0, 0.0, 0.0, | 
					
						
							|  |  |  |        0.0, 1.0, 0.0, | 
					
						
							|  |  |  |        0.0, 0.0, 1.0 | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   ); | 
					
						
							| 
									
										
										
										
											2010-01-22 13:45:59 +08:00
										 |  |  |   Matrix numericalH2 = numericalDerivative22(between<Pose2>, gT1, gT2, 1e-5); | 
					
						
							| 
									
										
										
										
											2009-12-15 08:00:02 +08:00
										 |  |  |   CHECK(assert_equal(expectedH2,actualH2)); | 
					
						
							|  |  |  |   CHECK(assert_equal(numericalH2,actualH2)); | 
					
						
							| 
									
										
										
										
											2009-12-09 03:12:20 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | // reverse situation for extra test
 | 
					
						
							|  |  |  | TEST( Pose2, between2 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Pose2 p2(M_PI_2, Point2(1,2)); // robot at (1,2) looking towards y
 | 
					
						
							|  |  |  |   Pose2 p1(M_PI, Point2(-1,4));  // robot at (-1,4) loooking at negative x
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Matrix actualH1,actualH2; | 
					
						
							|  |  |  |   between(p1,p2,actualH1,actualH2); | 
					
						
							|  |  |  |   Matrix numericalH1 = numericalDerivative21(between<Pose2>, p1, p2, 1e-5); | 
					
						
							|  |  |  |   CHECK(assert_equal(numericalH1,actualH1)); | 
					
						
							|  |  |  |   Matrix numericalH2 = numericalDerivative22(between<Pose2>, p1, p2, 1e-5); | 
					
						
							|  |  |  |   CHECK(assert_equal(numericalH2,actualH2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-13 14:02:18 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, round_trip ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Pose2 p1(1.23, 2.30, 0.2); | 
					
						
							|  |  |  | 	Pose2 odo(0.53, 0.39, 0.15); | 
					
						
							|  |  |  | 	Pose2 p2 = compose(odo, p1); | 
					
						
							|  |  |  | 	CHECK(assert_equal(odo, between(p1, p2))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-10 07:15:06 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(Pose2, members) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Pose2 pose; | 
					
						
							|  |  |  |   CHECK(pose.dim() == 3); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | // some shared test values
 | 
					
						
							|  |  |  | Pose2 x1, x2(1, 1, 0), x3(1, 1, M_PI_4); | 
					
						
							|  |  |  | Point2 l1(1, 0), l2(1, 1), l3(2, 2), l4(1, 3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, bearing ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Matrix expectedH1, actualH1, expectedH2, actualH2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish bearing is indeed zero
 | 
					
						
							|  |  |  | 	CHECK(assert_equal(Rot2(),bearing(x1,l1))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish bearing is indeed 45 degrees
 | 
					
						
							|  |  |  | 	CHECK(assert_equal(Rot2(M_PI_4),bearing(x1,l2))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish bearing is indeed 45 degrees even if shifted
 | 
					
						
							|  |  |  | 	Rot2 actual23 = bearing(x2, l3, actualH1, actualH2); | 
					
						
							|  |  |  | 	CHECK(assert_equal(Rot2(M_PI_4),actual23)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check numerical derivatives
 | 
					
						
							|  |  |  | 	expectedH1 = numericalDerivative21(bearing, x2, l3, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 	expectedH2 = numericalDerivative22(bearing, x2, l3, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish bearing is indeed 45 degrees even if rotated
 | 
					
						
							|  |  |  | 	Rot2 actual34 = bearing(x3, l4, actualH1, actualH2); | 
					
						
							|  |  |  | 	CHECK(assert_equal(Rot2(M_PI_4),actual34)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check numerical derivatives
 | 
					
						
							|  |  |  | 	expectedH1 = numericalDerivative21(bearing, x3, l4, 1e-5); | 
					
						
							|  |  |  | 	expectedH2 = numericalDerivative22(bearing, x3, l4, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( Pose2, range ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Matrix expectedH1, actualH1, expectedH2, actualH2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish range is indeed zero
 | 
					
						
							|  |  |  | 	DOUBLES_EQUAL(1,gtsam::range(x1,l1),1e-9); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// establish range is indeed 45 degrees
 | 
					
						
							|  |  |  | 	DOUBLES_EQUAL(sqrt(2),gtsam::range(x1,l2),1e-9); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Another pair
 | 
					
						
							|  |  |  | 	double actual23 = gtsam::range(x2, l3, actualH1, actualH2); | 
					
						
							|  |  |  | 	DOUBLES_EQUAL(sqrt(2),actual23,1e-9); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check numerical derivatives
 | 
					
						
							|  |  |  | 	expectedH1 = numericalDerivative21(range, x2, l3, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 	expectedH2 = numericalDerivative22(range, x2, l3, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Another test
 | 
					
						
							|  |  |  | 	double actual34 = gtsam::range(x3, l4, actualH1, actualH2); | 
					
						
							|  |  |  | 	DOUBLES_EQUAL(2,actual34,1e-9); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check numerical derivatives
 | 
					
						
							|  |  |  | 	expectedH1 = numericalDerivative21(range, x3, l4, 1e-5); | 
					
						
							|  |  |  | 	expectedH2 = numericalDerivative22(range, x3, l4, 1e-5); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedH1,actualH1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | } | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | 
 |