testPoseAdjointMap.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 
19 #pragma once
20 
21 #include <gtsam/geometry/Pose2.h>
22 #include <gtsam/geometry/Pose3.h>
23 
25 {
26  const double degree = M_PI / 180;
27 
28  // Return a covariance matrix for type T with non-zero values for every element.
29  // Use sigma_values^2 on the diagonal and fill in non-diagonal entries with
30  // correlation coefficient of 1. Note: a covariance matrix for T has the same
31  // dimensions as a Jacobian for T, the returned matrix is not a Jacobian.
32  template<class T>
33  typename T::Jacobian FullCovarianceFromSigmas(
34  const typename T::TangentVector &sigmas)
35  {
36  return sigmas * sigmas.transpose();
37  }
38 
39  // Return a covariance matrix with one non-zero element on the diagonal.
40  template<class T>
41  typename T::Jacobian SingleVariableCovarianceFromSigma(int idx, double sigma)
42  {
43  typename T::Jacobian cov = T::Jacobian::Zero();
44  cov(idx, idx) = sigma * sigma;
45  return cov;
46  }
47 
48  // Return a covariance matrix with two non-zero elements on the diagonal and
49  // a correlation of 1.0 between the two variables.
50  template<class T>
51  typename T::Jacobian TwoVariableCovarianceFromSigmas(int idx0, int idx1, double sigma0, double sigma1)
52  {
53  typename T::Jacobian cov = T::Jacobian::Zero();
54  cov(idx0, idx0) = sigma0 * sigma0;
55  cov(idx1, idx1) = sigma1 * sigma1;
56  cov(idx0, idx1) = cov(idx1, idx0) = sigma0 * sigma1;
57  return cov;
58  }
59 }
Pose2.h
2D Pose
simple_graph::sigma1
double sigma1
Definition: testJacobianFactor.cpp:193
test_constructor::sigmas
Vector1 sigmas
Definition: testHybridNonlinearFactor.cpp:52
test_pose_adjoint_map
Definition: testPoseAdjointMap.h:24
sampling::sigma
static const double sigma
Definition: testGaussianBayesNet.cpp:170
test_pose_adjoint_map::FullCovarianceFromSigmas
T::Jacobian FullCovarianceFromSigmas(const typename T::TangentVector &sigmas)
Definition: testPoseAdjointMap.h:33
test_pose_adjoint_map::degree
const double degree
Definition: testPoseAdjointMap.h:26
test_pose_adjoint_map::TwoVariableCovarianceFromSigmas
T::Jacobian TwoVariableCovarianceFromSigmas(int idx0, int idx1, double sigma0, double sigma1)
Definition: testPoseAdjointMap.h:51
M_PI
#define M_PI
Definition: mconf.h:117
test_pose_adjoint_map::SingleVariableCovarianceFromSigma
T::Jacobian SingleVariableCovarianceFromSigma(int idx, double sigma)
Definition: testPoseAdjointMap.h:41
Pose3.h
3D Pose manifold SO(3) x R^3 and group SE(3)


gtsam
Author(s):
autogenerated on Wed Jan 1 2025 04:06:54