Go to the documentation of this file.
33 class GaussianBayesNet;
34 class GaussianFactorGraph;
161 const std::vector<Vector>& gs,
double f);
165 template<
typename KEYS>
188 return std::make_shared<HessianFactor>(*
this); }
191 void print(
const std::string&
s =
"",
290 Matrix augmentedInformation()
const override;
298 Matrix information()
const override;
304 using Base::hessianDiagonal;
307 void hessianDiagonal(
double*
d)
const override;
310 std::map<Key,Matrix> hessianBlockDiagonal()
const override;
313 std::pair<Matrix, Vector> jacobian()
const override;
320 Matrix augmentedJacobian()
const override;
346 void gradientAtZero(
double*
d)
const override;
358 std::shared_ptr<GaussianConditional> eliminateCholesky(
const Ordering&
keys);
365 void Allocate(
const Scatter& scatter);
373 #if GTSAM_ENABLE_BOOST_SERIALIZATION
375 friend class boost::serialization::access;
376 template<
class ARCHIVE>
377 void serialize(ARCHIVE & ar,
const unsigned int ) {
379 ar & BOOST_SERIALIZATION_NVP(info_);
400 GTSAM_EXPORT std::pair<std::shared_ptr<GaussianConditional>, std::shared_ptr<HessianFactor> >
418 GTSAM_EXPORT std::pair<std::shared_ptr<GaussianConditional>, std::shared_ptr<GaussianFactor> >
virtual double error(const VectorValues &c) const
Expression of a fixed-size or dynamic-size block.
Contains the HessianFactor class, a general quadratic factor.
A thin wrapper around std::vector that uses a custom allocator.
A Gaussian factor using the canonical parameters (information form)
Array< double, 1, 3 > e(1./3., 0.5, 2.)
static const double d[K][N]
Pose3 g1(Rot3(), Point3(100.0, 0.0, 300.0))
const GaussianFactorGraph factors
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
void updateHessian(HessianFactor *other) const
const KeyFormatter & formatter
GaussianFactor Base
Typedef to base class.
std::shared_ptr< This > shared_ptr
A shared_ptr to this class.
Expression of a selfadjoint matrix from a triangular part of a dense matrix.
SymmetricBlockMatrix & info()
const SymmetricBlockMatrix & info() const
Return underlying information matrix.
constBlock aboveDiagonalRange(DenseIndex i_startBlock, DenseIndex i_endBlock, DenseIndex j_startBlock, DenseIndex j_endBlock) const
Get a range [i,j) from the matrix. Indices are in block units.
FastVector< Key > KeyVector
Define collection type once and for all - also used in wrappers.
KeyFormatter DefaultKeyFormatter
Assign default key formatter.
GaussianFactor::shared_ptr clone() const override
DecisionTreeFactor factor(D &C &B &A, "0.0 0.0 0.0 0.60658897 0.61241912 0.61241969 0.61247685 0.61247742 0.0 " "0.0 0.0 0.99995287 1.0 1.0 1.0 1.0")
std::pair< std::shared_ptr< GaussianConditional >, std::shared_ptr< GaussianFactor > > EliminatePreferCholesky(const GaussianFactorGraph &factors, const Ordering &keys)
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 y set format x g set format y g set format x2 g set format y2 g set format z g set angles radians set nogrid set key title set key left top Right noreverse box linetype linewidth samplen spacing width set nolabel set noarrow set nologscale set logscale x set set pointsize set encoding default set nopolar set noparametric set view
SymmetricBlockMatrix info_
The full augmented information matrix, s.t. the quadratic error is 0.5*[x -1]'H[x -1].
void print(const Matrix &A, const string &s, ostream &stream)
SymmetricBlockMatrix::constBlock constBlock
A block from the Hessian matrix (const version)
SymmetricBlockMatrix::constBlock linearTerm() const
std::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Pose3 g2(g1.expmap(h *V1_g1))
HessianFactor This
Typedef to this class.
Access to matrices via blocks of pre-defined sizes. Used in GaussianFactor and GaussianConditional.
std::shared_ptr< This > shared_ptr
shared_ptr to this class
void g(const string &key, int i)
DenseIndex rows() const
Row size.
const gtsam::Symbol key('X', 0)
Point2(* f)(const Point3 &, OptionalJacobian< 2, 3 >)
KeyVector::const_iterator const_iterator
Const iterator over keys.
~HessianFactor() override
SymmetricBlockMatrix::constBlock linearTerm(const_iterator j) const
ptrdiff_t DenseIndex
The index type for Eigen objects.
JacobiRotation< float > G
SymmetricBlockMatrix::Block linearTerm()
Eigen::SelfAdjointView< Block, Eigen::Upper > diagonalBlock(DenseIndex J)
Return the J'th diagonal block as a self adjoint view.
double constantTerm() const
DenseIndex getDim(DenseIndex block) const
Number of dimensions for variable on this diagonal block.
Double_ distance(const OrientedPlane3_ &p)
A factor with a quadratic error function - a Gaussian.
SymmetricBlockMatrix::Block Block
A block from the Hessian matrix.
constBlock aboveDiagonalBlock(DenseIndex I, DenseIndex J) const
Get block above the diagonal (I, J).
std::pair< std::shared_ptr< GaussianConditional >, std::shared_ptr< HessianFactor > > EliminateCholesky(const GaussianFactorGraph &factors, const Ordering &keys)
std::uint64_t Key
Integer nonlinear key type.
DenseIndex getDim(const_iterator variable) const override
Maps global variable indices to slot indices.
HessianFactor(const GaussianFactorGraph &factors)
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:02:21