GaussianBayesTree.h
Go to the documentation of this file.
1 /* ----------------------------------------------------------------------------
2 
3  * GTSAM Copyright 2010, Georgia Tech Research Corporation,
4  * Atlanta, Georgia 30332-0415
5  * All Rights Reserved
6  * Authors: Frank Dellaert, et al. (see THANKS for the full author list)
7 
8  * See LICENSE for the license information
9 
10  * -------------------------------------------------------------------------- */
11 
20 #pragma once
21 
26 
27 namespace gtsam {
28 
29  // Forward declarations
30  class GaussianConditional;
31  class VectorValues;
32 
33  /* ************************************************************************* */
35  class GTSAM_EXPORT GaussianBayesTreeClique :
36  public BayesTreeCliqueBase<GaussianBayesTreeClique, GaussianFactorGraph>
37  {
38  public:
41  typedef std::shared_ptr<This> shared_ptr;
42  typedef std::weak_ptr<This> weak_ptr;
44  GaussianBayesTreeClique(const std::shared_ptr<GaussianConditional>& conditional) : Base(conditional) {}
45  };
46 
47  /* ************************************************************************* */
49  class GTSAM_EXPORT GaussianBayesTree :
50  public BayesTree<GaussianBayesTreeClique>
51  {
52  private:
54 
55  public:
57  typedef std::shared_ptr<This> shared_ptr;
58 
61 
63  bool equals(const This& other, double tol = 1e-9) const;
64 
66  VectorValues optimize() const;
67 
93  VectorValues optimizeGradientSearch() const;
94 
100  VectorValues gradient(const VectorValues& x0) const;
101 
107  VectorValues gradientAtZero() const;
108 
110  double error(const VectorValues& x) const;
111 
117  double determinant() const;
118 
124  double logDeterminant() const;
125 
128  Matrix marginalCovariance(Key key) const;
129  };
130 
132  template<>
133  struct traits<GaussianBayesTree> : public Testable<GaussianBayesTree> {
134  };
135 
136 } //\ namespace gtsam
const gtsam::Symbol key('X', 0)
BayesTreeCliqueBase< GaussianBayesTreeClique, GaussianFactorGraph > Base
std::shared_ptr< This > shared_ptr
GaussianBayesTreeClique This
void determinant(const MatrixType &m)
Definition: determinant.cpp:14
double logDeterminant(const typename BAYESTREE::sharedClique &clique)
Eigen::MatrixXd Matrix
Definition: base/Matrix.h:39
std::shared_ptr< This > shared_ptr
Point3 optimize(const NonlinearFactorGraph &graph, const Values &values, Key landmarkKey)
Array< double, 1, 3 > e(1./3., 0.5, 2.)
Linear Factor Graph where all factors are Gaussians.
GaussianBayesTreeClique(const std::shared_ptr< GaussianConditional > &conditional)
BayesTree< GaussianBayesTreeClique > Base
Bayes Tree is a tree of cliques of a Bayes Chain.
traits
Definition: chartTesting.h:28
static Symbol x0('x', 0)
Chordal Bayes Net, the result of eliminating a factor graph.
static double error
Definition: testRot3.cpp:37
const G double tol
Definition: Group.h:86
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy x
Base class for cliques of a BayesTree.
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:102
std::weak_ptr< This > weak_ptr


gtsam
Author(s):
autogenerated on Tue Jul 4 2023 02:34:15