2009-08-22 06:23:24 +08:00
|
|
|
/**
|
|
|
|
* @file LinearFactorGraph.h
|
|
|
|
* @brief Linear Factor Graph where all factors are Gaussians
|
|
|
|
* @author Kai Ni
|
|
|
|
* @author Christian Potthast
|
|
|
|
* @author Alireza Fathi
|
|
|
|
*/
|
|
|
|
|
|
|
|
// $Id: LinearFactorGraph.h,v 1.24 2009/08/14 20:48:51 acunning Exp $
|
|
|
|
|
|
|
|
// \callgraph
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
|
|
|
|
#include "LinearFactor.h"
|
2009-10-15 04:39:59 +08:00
|
|
|
#include "VectorConfig.h"
|
2009-08-22 06:23:24 +08:00
|
|
|
#include "FactorGraph.h"
|
2009-10-21 02:57:33 +08:00
|
|
|
#include "ChordalBayesNet.h"
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
namespace gtsam {
|
|
|
|
|
2009-10-07 02:25:04 +08:00
|
|
|
/**
|
|
|
|
* A Linear Factor Graph is a factor graph where all factors are Gaussian, i.e.
|
|
|
|
* Factor == LinearFactor
|
2009-10-15 04:39:59 +08:00
|
|
|
* VectorConfig = A configuration of vectors
|
2009-10-07 02:25:04 +08:00
|
|
|
* Most of the time, linear factor graphs arise by linearizing a non-linear factor graph.
|
|
|
|
*/
|
2009-10-15 04:39:59 +08:00
|
|
|
class LinearFactorGraph : public FactorGraph<LinearFactor, VectorConfig> {
|
2009-08-22 06:23:24 +08:00
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Default constructor
|
|
|
|
*/
|
|
|
|
LinearFactorGraph() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor that receives a Chordal Bayes Net and returns a LinearFactorGraph
|
|
|
|
*/
|
2009-08-23 06:01:17 +08:00
|
|
|
LinearFactorGraph(const ChordalBayesNet& CBN);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* given a chordal bayes net, sets the linear factor graph identical to that CBN
|
|
|
|
* FD: imperative !!
|
|
|
|
*/
|
2009-08-23 06:01:17 +08:00
|
|
|
void setCBN(const ChordalBayesNet& CBN);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* find the separator, i.e. all the nodes that have at least one
|
|
|
|
* common factor with the given node. FD: not used AFAIK.
|
|
|
|
*/
|
|
|
|
std::set<std::string> find_separator(const std::string& key) const;
|
|
|
|
|
2009-10-22 13:02:31 +08:00
|
|
|
/**
|
|
|
|
* Return indices for all factors that involve the given node
|
|
|
|
* @param key the key for the given node
|
|
|
|
*/
|
|
|
|
std::vector<int> factors(const std::string& key);
|
|
|
|
|
2009-08-22 06:23:24 +08:00
|
|
|
/**
|
|
|
|
* find all the factors that involve the given node and remove them
|
|
|
|
* from the factor graph
|
|
|
|
* @param key the key for the given node
|
|
|
|
*/
|
|
|
|
LinearFactorSet find_factors_and_remove(const std::string& key);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* extract and combine all the factors that involve a given node
|
2009-10-15 05:06:44 +08:00
|
|
|
* NOTE: the combined factor will be depends on a system-dependent
|
|
|
|
* ordering of the input set of factors. Do not rely on this order
|
|
|
|
* when using the function.
|
2009-08-22 06:23:24 +08:00
|
|
|
* @param key the key for the given node
|
|
|
|
* @return the combined linear factor
|
|
|
|
*/
|
|
|
|
boost::shared_ptr<MutableLinearFactor>
|
|
|
|
combine_factors(const std::string& key);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* eliminate one node yielding a ConditionalGaussian
|
|
|
|
* Eliminates the factors from the factor graph through find_factors_and_remove
|
|
|
|
* and adds a new factor to the factor graph
|
|
|
|
*/
|
|
|
|
ConditionalGaussian::shared_ptr eliminate_one(const std::string& key);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* eliminate factor graph in place(!) in the given order, yielding
|
|
|
|
* a chordal Bayes net
|
|
|
|
*/
|
2009-10-07 02:25:04 +08:00
|
|
|
boost::shared_ptr<ChordalBayesNet> eliminate(const Ordering& ordering);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Same as eliminate but allows for passing an incomplete ordering
|
|
|
|
* that does not completely eliminate the graph
|
|
|
|
*/
|
2009-10-07 02:25:04 +08:00
|
|
|
boost::shared_ptr<ChordalBayesNet> eliminate_partially(const Ordering& ordering);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* optimize a linear factor graph
|
|
|
|
* @param ordering fg in order
|
|
|
|
*/
|
2009-10-15 04:39:59 +08:00
|
|
|
VectorConfig optimize(const Ordering& ordering);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
2009-08-25 10:36:30 +08:00
|
|
|
* static function that combines two factor graphs
|
2009-08-22 06:23:24 +08:00
|
|
|
* @param const &lfg1 Linear factor graph
|
|
|
|
* @param const &lfg2 Linear factor graph
|
|
|
|
* @return a new combined factor graph
|
|
|
|
*/
|
2009-08-25 10:36:30 +08:00
|
|
|
static LinearFactorGraph combine2(const LinearFactorGraph& lfg1,
|
|
|
|
const LinearFactorGraph& lfg2);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* combine two factor graphs
|
|
|
|
* @param *lfg Linear factor graph
|
|
|
|
*/
|
2009-08-25 00:54:22 +08:00
|
|
|
void combine(const LinearFactorGraph &lfg);
|
2009-08-22 06:23:24 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Find all variables and their dimensions
|
|
|
|
* @return The set of all variable/dimension pairs
|
|
|
|
*/
|
|
|
|
VariableSet variables() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add zero-mean i.i.d. Gaussian prior terms to each variable
|
|
|
|
* @param sigma Standard deviation of Gaussian
|
|
|
|
*/
|
|
|
|
LinearFactorGraph add_priors(double sigma) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return (dense) matrix associated with factor graph
|
|
|
|
* @param ordering of variables needed for matrix column order
|
|
|
|
*/
|
|
|
|
std::pair<Matrix,Vector> matrix (const Ordering& ordering) const;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|