45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
| /**
 | |
|  * @file summarization.h
 | |
|  *
 | |
|  * @brief Types and utility functions for summarization
 | |
|  * 
 | |
|  * @date Jun 22, 2012
 | |
|  * @author Alex Cunningham
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <gtsam_unstable/base/dllexport.h>
 | |
| #include <gtsam/linear/GaussianFactorGraph.h>
 | |
| #include <gtsam/linear/GaussianBayesTree.h>
 | |
| #include <gtsam/nonlinear/Ordering.h>
 | |
| 
 | |
| namespace gtsam {
 | |
| 
 | |
| /**
 | |
|  * Backsubstitution-based conditioning - reduces conditionals to
 | |
|  * densities on a sub-set of variables.
 | |
|  *
 | |
|  * Corner cases:
 | |
|  *  - If no frontal vars are saved, returns a null pointer
 | |
|  *
 | |
|  *  @param initConditional the conditional from which to remove a variable
 | |
|  *  @param saved_indices is the set of indices that should appear in the result
 | |
|  *  @param solution is a full solution for the system
 | |
|  */
 | |
| GTSAM_UNSTABLE_EXPORT gtsam::GaussianConditional::shared_ptr conditionDensity(const gtsam::GaussianConditional::shared_ptr& initConditional,
 | |
|     const std::set<gtsam::Index>& saved_indices, const gtsam::VectorValues& solution);
 | |
| 
 | |
| /**
 | |
|  * Backsubstitution-based conditioning for a complete Bayes Tree - reduces
 | |
|  * conditionals by solving out variables to eliminate. Traverses the tree to
 | |
|  * add the correct dummy factors whenever a separator is eliminated.
 | |
|  */
 | |
| GTSAM_UNSTABLE_EXPORT gtsam::GaussianFactorGraph conditionDensity(const gtsam::GaussianBayesTree& bayesTree,
 | |
|     const std::set<gtsam::Index>& saved_indices);
 | |
| 
 | |
| 
 | |
| } // \namespace gtsam
 | |
| 
 | |
| 
 |