| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  *  @file   testLinearFactor.cpp | 
					
						
							|  |  |  |  *  @brief  Unit tests for Linear Factor | 
					
						
							|  |  |  |  *  @author Christian Potthast | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  |  *  @author Frank Dellaert | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |  **/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <iostream>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/tuple/tuple.hpp>
 | 
					
						
							| 
									
										
										
										
											2009-10-31 23:24:22 +08:00
										 |  |  | #include <boost/assign/std/list.hpp> // for operator +=
 | 
					
						
							|  |  |  | using namespace boost::assign; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Matrix.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | #include "Ordering.h"
 | 
					
						
							|  |  |  | #include "ConditionalGaussian.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | #include "smallExample.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | using namespace std; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | using namespace gtsam; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, linearFactor ) | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	double sigma = 0.1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix A1(2,2); | 
					
						
							|  |  |  | 	A1(0,0) = -1.0 ; A1(0,1) = 0.0; | 
					
						
							|  |  |  | 	A1(1,0) = 0.0 ; A1(1,1) = -1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix A2(2,2); | 
					
						
							|  |  |  | 	A2(0,0) = 1.0 ; A2(0,1) = 0.0; | 
					
						
							|  |  |  | 	A2(1,0) = 0.0 ; A2(1,1) = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector b(2); | 
					
						
							|  |  |  | 	b(0) = 0.2 ; b(1) = -0.1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	LinearFactor expected("x1", A1,  "x2", A2, b, sigma); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// create a small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// get the factor "f2" from the factor graph
 | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr lf = fg[1]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// check if the two factors are the same
 | 
					
						
							|  |  |  | 	CHECK(assert_equal(expected,*lf)); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-12 11:50:44 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, keys ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get the factor "f2" from the small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr lf = fg[1]; | 
					
						
							|  |  |  | 	list<string> expected; | 
					
						
							|  |  |  | 	expected.push_back("x1"); | 
					
						
							|  |  |  | 	expected.push_back("x2"); | 
					
						
							|  |  |  | 	CHECK(lf->keys() == expected); | 
					
						
							| 
									
										
										
										
											2009-09-12 11:50:44 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, variables ) | 
					
						
							|  |  |  | {	 | 
					
						
							|  |  |  |   // get the factor "f2" from the small linear factor graph
 | 
					
						
							|  |  |  |   LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							|  |  |  |   LinearFactor::shared_ptr lf = fg[1]; | 
					
						
							|  |  |  |   VariableSet vs = lf->variables(); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   //TODO: test this
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | TEST( LinearFactor, getDim ) | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get a factor
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr factor = fg[0]; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get the size of a variable
 | 
					
						
							|  |  |  | 	size_t actual = factor->getDim("x1"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// verify
 | 
					
						
							|  |  |  | 	size_t expected = 2; | 
					
						
							|  |  |  | 	CHECK(actual == expected); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, combine ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	// create a small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get two factors from it and insert the factors into a vector
 | 
					
						
							|  |  |  | 	vector<LinearFactor::shared_ptr> lfg; | 
					
						
							|  |  |  | 	lfg.push_back(fg[4 - 1]); | 
					
						
							|  |  |  | 	lfg.push_back(fg[2 - 1]); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// combine in a factor
 | 
					
						
							|  |  |  | 	LinearFactor combined(lfg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// sigmas
 | 
					
						
							|  |  |  | 	double sigma2 = 0.1; | 
					
						
							|  |  |  | 	double sigma4 = 0.2; | 
					
						
							|  |  |  | 	Vector sigmas = Vector_(4, sigma4, sigma4, sigma2, sigma2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the expected combined linear factor
 | 
					
						
							|  |  |  | 	Matrix Ax2 = Matrix_(4, 2, // x2
 | 
					
						
							|  |  |  | 			-1., 0., | 
					
						
							|  |  |  | 			+0., -1., | 
					
						
							|  |  |  | 			1., 0., | 
					
						
							|  |  |  | 			+0., 1.); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix Al1 = Matrix_(4, 2,	// l1
 | 
					
						
							|  |  |  | 			1., 0., | 
					
						
							|  |  |  | 			0., 1., | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 			0., 0., | 
					
						
							|  |  |  | 			0., 0.); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix Ax1 = Matrix_(4, 2,	// x1
 | 
					
						
							|  |  |  | 			0.00, 0., // f4
 | 
					
						
							|  |  |  | 			0.00, 0., // f4
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 			-1., 0., // f2
 | 
					
						
							|  |  |  | 			0.00, -1. // f2
 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the RHS
 | 
					
						
							|  |  |  | 	Vector b2(4); | 
					
						
							|  |  |  | 	b2(0) = -0.2; | 
					
						
							|  |  |  | 	b2(1) = 0.3; | 
					
						
							|  |  |  | 	b2(2) = 0.2; | 
					
						
							|  |  |  | 	b2(3) = -0.1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// use general constructor for making arbitrary factors
 | 
					
						
							|  |  |  | 	vector<pair<string, Matrix> > meas; | 
					
						
							|  |  |  | 	meas.push_back(make_pair("x2", Ax2)); | 
					
						
							|  |  |  | 	meas.push_back(make_pair("l1", Al1)); | 
					
						
							|  |  |  | 	meas.push_back(make_pair("x1", Ax1)); | 
					
						
							|  |  |  | 	LinearFactor expected(meas, b2, sigmas); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expected,combined)); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | TEST( NonlinearFactorGraph, combine2){ | 
					
						
							|  |  |  | 	double sigma1 = 0.0957; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	Matrix A11(2,2); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	A11(0,0) = 1; A11(0,1) =  0; | 
					
						
							|  |  |  | 	A11(1,0) = 0;       A11(1,1) = 1; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	Vector b(2); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	b(0) = 2; b(1) = -1; | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr f1(new LinearFactor("x1", A11, b*sigma1, sigma1)); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	double sigma2 = 0.5; | 
					
						
							|  |  |  | 	A11(0,0) = 1; A11(0,1) =  0; | 
					
						
							|  |  |  | 	A11(1,0) = 0; A11(1,1) = -1; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	b(0) = 4 ; b(1) = -5; | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	LinearFactor::shared_ptr f2(new LinearFactor("x1", A11, b*sigma2, sigma2)); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	double sigma3 = 0.25; | 
					
						
							|  |  |  | 	A11(0,0) = 1; A11(0,1) =  0; | 
					
						
							|  |  |  | 	A11(1,0) = 0; A11(1,1) = -1; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	b(0) = 3 ; b(1) = -88; | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	LinearFactor::shared_ptr f3(new LinearFactor("x1", A11, b*sigma3, sigma3)); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// TODO: find a real sigma value for this example
 | 
					
						
							|  |  |  | 	double sigma4 = 0.1; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	A11(0,0) = 6; A11(0,1) =  0; | 
					
						
							|  |  |  | 	A11(1,0) = 0; A11(1,1) = 7; | 
					
						
							|  |  |  | 	b(0) = 5 ; b(1) = -6; | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	LinearFactor::shared_ptr f4(new LinearFactor("x1", A11*sigma4, b*sigma4, sigma4)); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	vector<LinearFactor::shared_ptr> lfg; | 
					
						
							|  |  |  | 	lfg.push_back(f1); | 
					
						
							|  |  |  | 	lfg.push_back(f2); | 
					
						
							|  |  |  | 	lfg.push_back(f3); | 
					
						
							|  |  |  | 	lfg.push_back(f4); | 
					
						
							|  |  |  | 	LinearFactor combined(lfg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	Vector sigmas = Vector_(8, sigma1, sigma1, sigma2, sigma2, sigma3, sigma3, sigma4, sigma4); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	Matrix A22(8,2); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	A22(0,0) = 1; A22(0,1) =  0; | 
					
						
							|  |  |  | 	A22(1,0) = 0;       A22(1,1) = 1; | 
					
						
							|  |  |  | 	A22(2,0) = 1;       A22(2,1) =  0; | 
					
						
							|  |  |  | 	A22(3,0) = 0;       A22(3,1) = -1; | 
					
						
							|  |  |  | 	A22(4,0) = 1;       A22(4,1) =  0; | 
					
						
							|  |  |  | 	A22(5,0) = 0;       A22(5,1) = -1; | 
					
						
							|  |  |  | 	A22(6,0) = 0.6;       A22(6,1) =  0; | 
					
						
							|  |  |  | 	A22(7,0) = 0;       A22(7,1) =  0.7; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	Vector exb(8); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	exb(0) = 2*sigma1 ; exb(1) = -1*sigma1;  exb(2) = 4*sigma2 ; exb(3) = -5*sigma2; | 
					
						
							|  |  |  | 	exb(4) = 3*sigma3 ; exb(5) = -88*sigma3; exb(6) = 5*sigma4 ; exb(7) = -6*sigma4; | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	vector<pair<string, Matrix> > meas; | 
					
						
							|  |  |  | 	meas.push_back(make_pair("x1", A22)); | 
					
						
							|  |  |  | 	LinearFactor expected(meas, exb, sigmas); | 
					
						
							| 
									
										
										
										
											2009-10-23 01:23:24 +08:00
										 |  |  | 	CHECK(assert_equal(expected,combined)); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  | TEST( LinearFactor, linearFactorN){ | 
					
						
							|  |  |  |   vector<LinearFactor::shared_ptr> f; | 
					
						
							|  |  |  |   f.push_back(LinearFactor::shared_ptr(new LinearFactor("x1", Matrix_(2,2, | 
					
						
							|  |  |  |       1.0, 0.0, | 
					
						
							|  |  |  |       0.0, 1.0), | 
					
						
							|  |  |  |       Vector_(2, | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  |       10.0, 5.0), 1))); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |   f.push_back(LinearFactor::shared_ptr(new LinearFactor("x1", Matrix_(2,2, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0), | 
					
						
							|  |  |  |       "x2", Matrix_(2,2, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0), | 
					
						
							|  |  |  |       Vector_(2, | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  |       1.0, -2.0), 1))); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |   f.push_back(LinearFactor::shared_ptr(new LinearFactor("x2", Matrix_(2,2, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0), | 
					
						
							|  |  |  |       "x3", Matrix_(2,2, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0), | 
					
						
							|  |  |  |       Vector_(2, | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  |       1.5, -1.5), 1))); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |   f.push_back(LinearFactor::shared_ptr(new LinearFactor("x3", Matrix_(2,2, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0), | 
					
						
							|  |  |  |       "x4", Matrix_(2,2, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0), | 
					
						
							|  |  |  |       Vector_(2, | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  |       2.0, -1.0), 1))); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 23:31:45 +08:00
										 |  |  |   LinearFactor combinedFactor(f); | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 23:13:13 +08:00
										 |  |  |   vector<pair<string, Matrix> > combinedMeasurement; | 
					
						
							|  |  |  |   combinedMeasurement.push_back(make_pair("x1", Matrix_(8,2, | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |       1.0, 0.0, | 
					
						
							|  |  |  |       0.0, 1.0, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0))); | 
					
						
							| 
									
										
										
										
											2009-10-27 23:13:13 +08:00
										 |  |  |   combinedMeasurement.push_back(make_pair("x2", Matrix_(8,2, | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0))); | 
					
						
							| 
									
										
										
										
											2009-10-27 23:13:13 +08:00
										 |  |  |   combinedMeasurement.push_back(make_pair("x3", Matrix_(8,2, | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0, | 
					
						
							|  |  |  |       -10.0, 0.0, | 
					
						
							|  |  |  |       0.0, -10.0))); | 
					
						
							| 
									
										
										
										
											2009-10-27 23:13:13 +08:00
										 |  |  |   combinedMeasurement.push_back(make_pair("x4", Matrix_(8,2, | 
					
						
							| 
									
										
										
										
											2009-10-22 23:52:39 +08:00
										 |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       0.0, 0.0, | 
					
						
							|  |  |  |       10.0, 0.0, | 
					
						
							|  |  |  |       0.0, 10.0))); | 
					
						
							|  |  |  |   Vector b = Vector_(8, | 
					
						
							|  |  |  |       10.0, 5.0, 1.0, -2.0, 1.5, -1.5, 2.0, -1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  |   LinearFactor expected(combinedMeasurement, b, 1.); | 
					
						
							| 
									
										
										
										
											2009-10-27 23:13:13 +08:00
										 |  |  |   CHECK(combinedFactor.equals(expected)); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, error ) | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	// create a small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get the first factor from the factor graph
 | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr lf = fg[0]; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// check the error of the first factor with noisy config
 | 
					
						
							|  |  |  | 	VectorConfig cfg = createZeroDelta(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// calculate the error from the factor "f1"
 | 
					
						
							|  |  |  | 	// note the error is the same as in testNonlinearFactor
 | 
					
						
							|  |  |  | 	double actual = lf->error(cfg); | 
					
						
							|  |  |  | 	DOUBLES_EQUAL( 1.0, actual, 0.00000001 ); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, eliminate ) | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	// create a small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get two factors from it and insert the factors into a vector
 | 
					
						
							|  |  |  | 	vector<LinearFactor::shared_ptr> lfg; | 
					
						
							|  |  |  | 	lfg.push_back(fg[4 - 1]); | 
					
						
							|  |  |  | 	lfg.push_back(fg[2 - 1]); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// combine in a factor
 | 
					
						
							|  |  |  | 	LinearFactor combined(lfg); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// eliminate the combined factor
 | 
					
						
							|  |  |  | 	ConditionalGaussian::shared_ptr actualCG; | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr actualLF; | 
					
						
							|  |  |  | 	boost::tie(actualCG,actualLF) = combined.eliminate("x2"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// create expected Conditional Gaussian
 | 
					
						
							|  |  |  | 	Matrix R11 = Matrix_(2,2, | 
					
						
							|  |  |  | 			1.0, 0.0, | 
					
						
							|  |  |  | 			0.0, 1.0 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 	Matrix S12 = Matrix_(2,2, | 
					
						
							|  |  |  | 			-0.2, 0.0, | 
					
						
							|  |  |  | 			+0.0,-0.2 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 	Matrix S13 = Matrix_(2,2, | 
					
						
							|  |  |  | 			-0.8, 0.0, | 
					
						
							|  |  |  | 			+0.0,-0.8 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 	Vector d(2); d(0) = 0.2; d(1) = -0.14; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | 	Vector sigmas(2); | 
					
						
							|  |  |  | 	sigmas(0) = 1/sqrt(125.0); | 
					
						
							|  |  |  | 	sigmas(1) = 1/sqrt(125.0); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Check the conditional Gaussian
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | 	ConditionalGaussian expectedCG("x2", d,R11,"l1",S12,"x1",S13,sigmas); | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// the expected linear factor
 | 
					
						
							|  |  |  | 	double sigma = 0.2236; | 
					
						
							|  |  |  | 	Matrix Bl1 = Matrix_(2,2, | 
					
						
							|  |  |  | 			// l1
 | 
					
						
							|  |  |  | 			1.00, 0.00, | 
					
						
							|  |  |  | 			0.00, 1.00 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix Bx1 = Matrix_(2,2, | 
					
						
							|  |  |  | 			// x1
 | 
					
						
							|  |  |  | 			-1.00,  0.00, | 
					
						
							|  |  |  | 			+0.00, -1.00 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the RHS
 | 
					
						
							|  |  |  | 	Vector b1(2); b1(0) = 0.0; b1(1) = 0.2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	LinearFactor expectedLF("l1", Bl1, "x1", Bx1, b1, sigma); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// check if the result matches
 | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedCG,*actualCG,1e-4)); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expectedLF,*actualLF,1e-5)); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | ///* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, eliminate2 )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, eliminate2 )" << endl;
 | 
					
						
							|  |  |  | //	// sigmas
 | 
					
						
							|  |  |  | //	double sigma1 = 0.2;
 | 
					
						
							|  |  |  | //	double sigma2 = 0.1;
 | 
					
						
							|  |  |  | //	Vector sigmas = Vector_(4, sigma1, sigma1, sigma2, sigma2);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// the combined linear factor
 | 
					
						
							|  |  |  | //	Matrix Ax2 = Matrix_(4,2,
 | 
					
						
							|  |  |  | //			// x2
 | 
					
						
							|  |  |  | //			-1., 0.,
 | 
					
						
							|  |  |  | //			+0.,-1.,
 | 
					
						
							|  |  |  | //			1., 0.,
 | 
					
						
							|  |  |  | //			+0.,1.
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	Matrix Al1x1 = Matrix_(4,4,
 | 
					
						
							|  |  |  | //			// l1   x1
 | 
					
						
							|  |  |  | //			1., 0., 0.00,  0., // f4
 | 
					
						
							|  |  |  | //			0., 1., 0.00,  0., // f4
 | 
					
						
							|  |  |  | //			0., 0., -1.,  0., // f2
 | 
					
						
							|  |  |  | //			0., 0., 0.00,-1.  // f2
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// the RHS
 | 
					
						
							|  |  |  | //	Vector b2(4);
 | 
					
						
							|  |  |  | //	b2(0) = -1*sigma1;
 | 
					
						
							|  |  |  | //	b2(1) = 1.5*sigma1;
 | 
					
						
							|  |  |  | //	b2(2) = 2*sigma2;
 | 
					
						
							|  |  |  | //	b2(3) = -1*sigma2;
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	vector<pair<string, Matrix> > meas;
 | 
					
						
							|  |  |  | //	meas.push_back(make_pair("x2", Ax2));
 | 
					
						
							|  |  |  | //	meas.push_back(make_pair("l1x1", Al1x1));
 | 
					
						
							|  |  |  | //	LinearFactor combined(meas, b2, sigmas);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// eliminate the combined factor
 | 
					
						
							|  |  |  | //	ConditionalGaussian::shared_ptr actualCG;
 | 
					
						
							|  |  |  | //	LinearFactor::shared_ptr actualLF;
 | 
					
						
							|  |  |  | //	boost::tie(actualCG,actualLF) = combined.eliminate("x2");
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// create expected Conditional Gaussian
 | 
					
						
							|  |  |  | //	Matrix R11 = Matrix_(2,2,
 | 
					
						
							|  |  |  | //			11.1803,  0.00,
 | 
					
						
							|  |  |  | //			0.00, 11.1803
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //	Matrix S12 = Matrix_(2,4,
 | 
					
						
							|  |  |  | //			-2.23607, 0.00,-8.94427, 0.00,
 | 
					
						
							|  |  |  | //			+0.00,-2.23607,+0.00,-8.94427
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //	Vector d(2); d(0) = 2.23607; d(1) = -1.56525;
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	Vector sigmas(2);
 | 
					
						
							|  |  |  | //	sigmas(0) = R11(0,0);
 | 
					
						
							|  |  |  | //	sigmas(1) = R11(1,1);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //
 | 
					
						
							|  |  |  | //	// normalize the existing matrices
 | 
					
						
							|  |  |  | //	Matrix N = eye(2,2);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	N(0,0) = 1/sigmas(0);
 | 
					
						
							|  |  |  | //	N(1,1) = 1/sigmas(1);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //	S12 = N*S12;
 | 
					
						
							|  |  |  | //	R11 = N*R11;
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	ConditionalGaussian expectedCG("x2",d,R11,"l1x1",S12,sigmas);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //
 | 
					
						
							|  |  |  | //	// the expected linear factor
 | 
					
						
							|  |  |  | //	double sigma = 0.2236;
 | 
					
						
							|  |  |  | //	Matrix Bl1x1 = Matrix_(2,4,
 | 
					
						
							|  |  |  | //			// l1          x1
 | 
					
						
							|  |  |  | //			1.00, 0.00, -1.00,  0.00,
 | 
					
						
							|  |  |  | //			0.00, 1.00, +0.00, -1.00
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// the RHS
 | 
					
						
							|  |  |  | //	Vector b1(2); b1(0) = 0.0; b1(1) = 0.894427;
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	LinearFactor expectedLF("l1x1", Bl1x1, b1*sigma, sigma);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// check if the result matches
 | 
					
						
							|  |  |  | //	CHECK(assert_equal(expectedCG,*actualCG,1e-4)); //FAILS
 | 
					
						
							|  |  |  | //	CHECK(assert_equal(expectedLF,*actualLF,1e-5)); //FAILS
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | ////* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, default_error )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, default_error )" << endl;
 | 
					
						
							|  |  |  | //	LinearFactor f;
 | 
					
						
							|  |  |  | //	VectorConfig c;
 | 
					
						
							|  |  |  | //	double actual = f.error(c);
 | 
					
						
							|  |  |  | //	CHECK(actual==0.0);
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | ////* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, eliminate_empty )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, eliminate_empty )" << endl;
 | 
					
						
							|  |  |  | //	// create an empty factor
 | 
					
						
							|  |  |  | //	LinearFactor f;
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// eliminate the empty factor
 | 
					
						
							|  |  |  | //	ConditionalGaussian::shared_ptr actualCG;
 | 
					
						
							|  |  |  | //	LinearFactor::shared_ptr actualLF;
 | 
					
						
							|  |  |  | //	boost::tie(actualCG,actualLF) = f.eliminate("x2");
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// expected Conditional Gaussian is just a parent-less node with P(x)=1
 | 
					
						
							|  |  |  | //	ConditionalGaussian expectedCG("x2");
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// expected remaining factor is still empty :-)
 | 
					
						
							|  |  |  | //	LinearFactor expectedLF;
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// check if the result matches
 | 
					
						
							|  |  |  | //	CHECK(actualCG->equals(expectedCG));
 | 
					
						
							|  |  |  | //	CHECK(actualLF->equals(expectedLF));
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | ////* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, empty )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, empty )" << endl;
 | 
					
						
							|  |  |  | //	// create an empty factor
 | 
					
						
							|  |  |  | //	LinearFactor f;
 | 
					
						
							|  |  |  | //	CHECK(f.empty()==true);
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( LinearFactor, matrix ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// create a small linear factor graph
 | 
					
						
							|  |  |  | 	LinearFactorGraph fg = createLinearFactorGraph(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	// get the factor "f2" from the factor graph
 | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr lf = fg[1]; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // render with a given ordering
 | 
					
						
							|  |  |  |   Ordering ord; | 
					
						
							| 
									
										
										
										
											2009-10-31 23:24:22 +08:00
										 |  |  |   ord += "x1","x2"; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	Matrix A; Vector b; | 
					
						
							|  |  |  | 	boost::tie(A,b) = lf->matrix(ord); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	Matrix A1 = Matrix_(2,4, | 
					
						
							|  |  |  | 			-10.0,  0.0, 10.0,  0.0, | 
					
						
							|  |  |  | 			000.0,-10.0,  0.0, 10.0 ); | 
					
						
							|  |  |  | 	Vector b1 = Vector_(2, 2.0, -1.0); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | 	EQUALITY(A,A1); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 	EQUALITY(b,b1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | ///* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, size )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, size )" << endl;
 | 
					
						
							|  |  |  | //	// create a linear factor graph
 | 
					
						
							|  |  |  | //	LinearFactorGraph fg = createLinearFactorGraph();
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	// get some factors from the graph
 | 
					
						
							|  |  |  | //	boost::shared_ptr<LinearFactor> factor1 = fg[0];
 | 
					
						
							|  |  |  | //	boost::shared_ptr<LinearFactor> factor2 = fg[1];
 | 
					
						
							|  |  |  | //	boost::shared_ptr<LinearFactor> factor3 = fg[2];
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	CHECK(factor1->size() == 1);
 | 
					
						
							|  |  |  | //	CHECK(factor2->size() == 2);
 | 
					
						
							|  |  |  | //	CHECK(factor3->size() == 2);
 | 
					
						
							|  |  |  | //}
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | ///* ************************************************************************* */
 | 
					
						
							|  |  |  | //TEST( LinearFactor, CONSTRUCTOR_ConditionalGaussian )
 | 
					
						
							|  |  |  | //{
 | 
					
						
							|  |  |  | //	cout << "TEST( LinearFactor, CONSTRUCTOR_ConditionalGaussian )" << endl;
 | 
					
						
							|  |  |  | //	Matrix R11 = Matrix_(2,2,
 | 
					
						
							|  |  |  | //			11.1803,  0.00,
 | 
					
						
							|  |  |  | //			0.00, 11.1803
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //	Matrix S12 = Matrix_(2,2,
 | 
					
						
							|  |  |  | //			-2.23607, 0.00,
 | 
					
						
							|  |  |  | //			+0.00,-2.23607
 | 
					
						
							|  |  |  | //	);
 | 
					
						
							|  |  |  | //	Vector d(2); d(0) = 2.23607; d(1) = -1.56525;
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	Vector sigmas(2);
 | 
					
						
							|  |  |  | //	sigmas(0) = R11(0,0);
 | 
					
						
							|  |  |  | //	sigmas(1) = R11(1,1);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //
 | 
					
						
							|  |  |  | //	// normalize the existing matrices
 | 
					
						
							|  |  |  | //	Matrix N = eye(2,2);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	N(0,0) = 1/sigmas(0);
 | 
					
						
							|  |  |  | //	N(1,1) = 1/sigmas(1);
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //	S12 = N*S12;
 | 
					
						
							|  |  |  | //	R11 = N*R11;
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-11-05 14:59:59 +08:00
										 |  |  | //	ConditionalGaussian::shared_ptr CG(new ConditionalGaussian("x2",d,R11,"l1x1",S12,sigmas));
 | 
					
						
							| 
									
										
										
										
											2009-11-05 04:59:16 +08:00
										 |  |  | //	LinearFactor actualLF(CG);
 | 
					
						
							|  |  |  | //	//  actualLF.print();
 | 
					
						
							|  |  |  | //	double precision = 11.1803;
 | 
					
						
							|  |  |  | //	double sigma = 1/sqrt(precision);
 | 
					
						
							|  |  |  | //	LinearFactor expectedLF("x2",R11,"l1x1",S12,d, sigma);
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	CHECK(assert_equal(expectedLF,actualLF,1e-5)); //FAILS Precisions are incorrect
 | 
					
						
							|  |  |  | //}
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { TestResult tr; return TestRegistry::runAllTests(tr);} | 
					
						
							|  |  |  | /* ************************************************************************* */ |