129 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
		
		
			
		
	
	
			129 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
|  | /**
 | ||
|  |  * @file    testGaussianBayesNet.cpp | ||
|  |  * @brief   Unit tests for GaussianBayesNet | ||
|  |  * @author  Frank Dellaert | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | // STL/C++
 | ||
|  | #include <iostream>
 | ||
|  | #include <sstream>
 | ||
|  | #include <CppUnitLite/TestHarness.h>
 | ||
|  | #include <boost/tuple/tuple.hpp>
 | ||
|  | #include <boost/foreach.hpp>
 | ||
|  | 
 | ||
|  | #ifdef HAVE_BOOST_SERIALIZATION
 | ||
|  | #include <boost/archive/text_oarchive.hpp>
 | ||
|  | #include <boost/archive/text_iarchive.hpp>
 | ||
|  | #endif //HAVE_BOOST_SERIALIZATION
 | ||
|  | 
 | ||
|  | #include "GaussianBayesNet.h"
 | ||
|  | #include "smallExample.h"
 | ||
|  | 
 | ||
|  | using namespace gtsam; | ||
|  | 
 | ||
|  | /* ************************************************************************* */ | ||
|  | TEST( GaussianBayesNet, constructor ) | ||
|  | { | ||
|  |   // small Bayes Net x <- y
 | ||
|  |   // x y d
 | ||
|  |   // 1 1 9
 | ||
|  |   //   1 5
 | ||
|  |   Matrix R11 = Matrix_(1,1,1.0), S12 = Matrix_(1,1,1.0); | ||
|  |   Matrix                         R22 = Matrix_(1,1,1.0); | ||
|  |   Vector d1(1), d2(1); | ||
|  |   d1(0) = 9; d2(0) = 5; | ||
|  |    | ||
|  |   // define nodes and specify in reverse topological sort (i.e. parents last)
 | ||
|  |   ConditionalGaussian x(d1,R11,"y",S12), y(d2,R22); | ||
|  | 
 | ||
|  |   // check small example which uses constructor
 | ||
|  |   GaussianBayesNet cbn = createSmallGaussianBayesNet(); | ||
|  |   CHECK( x.equals(*cbn["x"]) ); | ||
|  |   CHECK( y.equals(*cbn["y"]) ); | ||
|  | } | ||
|  | 
 | ||
|  | /* ************************************************************************* */ | ||
|  | TEST( GaussianBayesNet, matrix ) | ||
|  | { | ||
|  |   // Create a test graph
 | ||
|  |   GaussianBayesNet cbn = createSmallGaussianBayesNet(); | ||
|  | 
 | ||
|  |   Matrix R; Vector d; | ||
|  |   boost::tie(R,d) = cbn.matrix(); // find matrix and RHS
 | ||
|  | 
 | ||
|  |   Matrix R1 = Matrix_(2,2, | ||
|  | 		      1.0, 1.0, | ||
|  | 		      0.0, 1.0 | ||
|  |     ); | ||
|  |   Vector d1 = Vector_(2, 9.0, 5.0); | ||
|  | 
 | ||
|  |   EQUALITY(R,R1); | ||
|  |   CHECK(d==d1); | ||
|  | } | ||
|  | 
 | ||
|  | /* ************************************************************************* */ | ||
|  | TEST( GaussianBayesNet, optimize ) | ||
|  | { | ||
|  |   // optimize small Bayes Net
 | ||
|  |   GaussianBayesNet cbn = createSmallGaussianBayesNet(); | ||
|  |   boost::shared_ptr<VectorConfig> actual = cbn.optimize(); | ||
|  | 
 | ||
|  |   VectorConfig expected; | ||
|  |   Vector x(1), y(1); | ||
|  |   x(0) = 4; y(0) = 5; | ||
|  |   expected.insert("x",x); | ||
|  |   expected.insert("y",y); | ||
|  | 
 | ||
|  |   CHECK(actual->equals(expected)); | ||
|  | } | ||
|  | 
 | ||
|  | /* ************************************************************************* */ | ||
|  | #ifdef HAVE_BOOST_SERIALIZATION
 | ||
|  | TEST( GaussianBayesNet, serialize ) | ||
|  | { | ||
|  | //     //create a starting CBN
 | ||
|  | //     GaussianBayesNet cbn = createSmallGaussianBayesNet();
 | ||
|  | //     
 | ||
|  | //     //serialize the CBN
 | ||
|  | //     std::ostringstream in_archive_stream;
 | ||
|  | //     boost::archive::text_oarchive in_archive(in_archive_stream);
 | ||
|  | //     in_archive << cbn;
 | ||
|  | //     std::string serialized = in_archive_stream.str();
 | ||
|  | //     
 | ||
|  | //     //DEBUG
 | ||
|  | //     std::cout << "CBN Raw string: [" << serialized << "]" << std::endl;
 | ||
|  | //     
 | ||
|  | //     //remove newlines/carriage returns
 | ||
|  | //     std::string clean;
 | ||
|  | //     BOOST_FOREACH(char s, serialized)
 | ||
|  | //     {
 | ||
|  | // 	if (s != '\n') 
 | ||
|  | // 	{
 | ||
|  | // 	    //copy in character
 | ||
|  | // 	    clean.append(std::string(1,s));
 | ||
|  | // 	}
 | ||
|  | // 	else
 | ||
|  | // 	{
 | ||
|  | // 	    std::cout << "   Newline character found!" << std::endl;
 | ||
|  | // 	    //replace with an identifiable string
 | ||
|  | // 	    clean.append(std::string(1,' '));
 | ||
|  | // 	}
 | ||
|  | //     }
 | ||
|  | // 
 | ||
|  | //     
 | ||
|  | //     std::cout << "Cleaned CBN String: [" << clean << "]" << std::endl;
 | ||
|  | //     
 | ||
|  | //     //deserialize the CBN
 | ||
|  | //     std::istringstream out_archive_stream(clean);
 | ||
|  | //     boost::archive::text_iarchive out_archive(out_archive_stream);
 | ||
|  | //     GaussianBayesNet output;
 | ||
|  | //     out_archive >> output;
 | ||
|  | //     CHECK(cbn.equals(output));
 | ||
|  | } | ||
|  | #endif //HAVE_BOOST_SERIALIZATION
 | ||
|  | 
 | ||
|  | /* ************************************************************************* */ | ||
|  | int main() { TestResult tr; return TestRegistry::runAllTests(tr);} | ||
|  | /* ************************************************************************* */ |