testPreconditioner.cpp
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 
21 #include <gtsam/nonlinear/Values.h>
25 #include <gtsam/linear/PCGSolver.h>
26 #include <gtsam/geometry/Point2.h>
27 
28 using namespace std;
29 using namespace gtsam;
30 
31 /* ************************************************************************* */
32 TEST( PCGsolver, verySimpleLinearSystem) {
33 
34  // Ax = [4 1][u] = [1] x0 = [2]
35  // [1 3][v] [2] [1]
36  //
37  // exact solution x = [1/11, 7/11]';
38  //
39 
40  // Create a Gaussian Factor Graph
41  GaussianFactorGraph simpleGFG;
42  simpleGFG.emplace_shared<JacobianFactor>(0, (Matrix(2,2)<< 4, 1, 1, 3).finished(), (Vector(2) << 1,2 ).finished(), noiseModel::Unit::Create(2));
43 
44  // Exact solution already known
45  VectorValues exactSolution;
46  exactSolution.insert(0, (Vector(2) << 1./11., 7./11.).finished());
47  //exactSolution.print("Exact");
48 
49  // Solve the system using direct method
50  VectorValues deltaDirect = simpleGFG.optimize();
51  EXPECT(assert_equal(exactSolution, deltaDirect, 1e-7));
52  //deltaDirect.print("Direct");
53 
54  // Solve the system using Preconditioned Conjugate Gradient solver
55  // Common PCG parameters
56  gtsam::PCGSolverParameters::shared_ptr pcg = std::make_shared<gtsam::PCGSolverParameters>();
57  pcg->maxIterations = 500;
58  pcg->epsilon_abs = 0.0;
59  pcg->epsilon_rel = 0.0;
60  //pcg->setVerbosity("ERROR");
61 
62  // With Dummy preconditioner
63  pcg->preconditioner =
64  std::make_shared<gtsam::DummyPreconditionerParameters>();
65  VectorValues deltaPCGDummy = PCGSolver(*pcg).optimize(simpleGFG);
66  EXPECT(assert_equal(exactSolution, deltaPCGDummy, 1e-7));
67  //deltaPCGDummy.print("PCG Dummy");
68 
69  // With Block-Jacobi preconditioner
70  pcg->preconditioner =
71  std::make_shared<gtsam::BlockJacobiPreconditionerParameters>();
72  // It takes more than 1000 iterations for this test
73  pcg->maxIterations = 1500;
74  VectorValues deltaPCGJacobi = PCGSolver(*pcg).optimize(simpleGFG);
75 
76  EXPECT(assert_equal(exactSolution, deltaPCGJacobi, 1e-5));
77  //deltaPCGJacobi.print("PCG Jacobi");
78 }
79 
80 /* ************************************************************************* */
81 TEST(PCGSolver, simpleLinearSystem) {
82  // Create a Gaussian Factor Graph
83  GaussianFactorGraph simpleGFG;
84  //SharedDiagonal unit2 = noiseModel::Unit::Create(2);
85  SharedDiagonal unit2 = noiseModel::Diagonal::Sigmas(Vector2(0.5, 0.3));
86  simpleGFG.emplace_shared<JacobianFactor>(2, (Matrix(2,2)<< 10, 0, 0, 10).finished(), (Vector(2) << -1, -1).finished(), unit2);
87  simpleGFG.emplace_shared<JacobianFactor>(2, (Matrix(2,2)<< -10, 0, 0, -10).finished(), 0, (Matrix(2,2)<< 10, 0, 0, 10).finished(), (Vector(2) << 2, -1).finished(), unit2);
88  simpleGFG.emplace_shared<JacobianFactor>(2, (Matrix(2,2)<< -5, 0, 0, -5).finished(), 1, (Matrix(2,2)<< 5, 0, 0, 5).finished(), (Vector(2) << 0, 1).finished(), unit2);
89  simpleGFG.emplace_shared<JacobianFactor>(0, (Matrix(2,2)<< -5, 0, 0, -5).finished(), 1, (Matrix(2,2)<< 5, 0, 0, 5).finished(), (Vector(2) << -1, 1.5).finished(), unit2);
90  simpleGFG.emplace_shared<JacobianFactor>(0, (Matrix(2,2)<< 1, 0, 0, 1).finished(), (Vector(2) << 0, 0).finished(), unit2);
91  simpleGFG.emplace_shared<JacobianFactor>(1, (Matrix(2,2)<< 1, 0, 0, 1).finished(), (Vector(2) << 0, 0).finished(), unit2);
92  simpleGFG.emplace_shared<JacobianFactor>(2, (Matrix(2,2)<< 1, 0, 0, 1).finished(), (Vector(2) << 0, 0).finished(), unit2);
93  //simpleGFG.print("system");
94 
95  // Expected solution
96  VectorValues expectedSolution;
97  expectedSolution.insert(0, (Vector(2) << 0.100498, -0.196756).finished());
98  expectedSolution.insert(2, (Vector(2) << -0.0990413, -0.0980577).finished());
99  expectedSolution.insert(1, (Vector(2) << -0.0973252, 0.100582).finished());
100  //expectedSolution.print("Expected");
101 
102  // Solve the system using direct method
103  VectorValues deltaDirect = simpleGFG.optimize();
104  EXPECT(assert_equal(expectedSolution, deltaDirect, 1e-5));
105  //deltaDirect.print("Direct");
106 
107  // Solve the system using Preconditioned Conjugate Gradient solver
108  // Common PCG parameters
109  gtsam::PCGSolverParameters::shared_ptr pcg = std::make_shared<gtsam::PCGSolverParameters>();
110  pcg->maxIterations = 500;
111  pcg->epsilon_abs = 0.0;
112  pcg->epsilon_rel = 0.0;
113  //pcg->setVerbosity("ERROR");
114 
115  // With Dummy preconditioner
116  pcg->preconditioner =
117  std::make_shared<gtsam::DummyPreconditionerParameters>();
118  VectorValues deltaPCGDummy = PCGSolver(*pcg).optimize(simpleGFG);
119  EXPECT(assert_equal(expectedSolution, deltaPCGDummy, 1e-5));
120  //deltaPCGDummy.print("PCG Dummy");
121 
122  // With Block-Jacobi preconditioner
123  pcg->preconditioner =
124  std::make_shared<gtsam::BlockJacobiPreconditionerParameters>();
125  VectorValues deltaPCGJacobi = PCGSolver(*pcg).optimize(simpleGFG);
126  EXPECT(assert_equal(expectedSolution, deltaPCGJacobi, 1e-5));
127  //deltaPCGJacobi.print("PCG Jacobi");
128 
129 }
130 
131 /* ************************************************************************* */
132 int main() { TestResult tr; return TestRegistry::runAllTests(tr); }
133 /* ************************************************************************* */
TestRegistry::runAllTests
static int runAllTests(TestResult &result)
Definition: TestRegistry.cpp:27
GaussianFactorGraph.h
Linear Factor Graph where all factors are Gaussians.
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
EXPECT
#define EXPECT(condition)
Definition: Test.h:150
gtsam::Vector2
Eigen::Vector2d Vector2
Definition: Vector.h:43
TestHarness.h
gtsam::VectorValues::insert
iterator insert(const std::pair< Key, Vector > &key_value)
Definition: VectorValues.cpp:90
gtsam::JacobianFactor
Definition: JacobianFactor.h:91
gtsam::PCGSolver::optimize
VectorValues optimize(const GaussianFactorGraph &gfg, const KeyInfo &keyInfo, const std::map< Key, Vector > &lambda, const VectorValues &initial) override
Definition: PCGSolver.cpp:54
Point2.h
2D Point
TEST
TEST(PCGsolver, verySimpleLinearSystem)
Definition: testPreconditioner.cpp:32
gtsam::GaussianFactorGraph
Definition: GaussianFactorGraph.h:73
ceres::Matrix
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor > Matrix
Definition: gtsam/3rdparty/ceres/eigen.h:42
gtsam::VectorValues
Definition: VectorValues.h:74
gtsam::PCGSolver
Definition: PCGSolver.h:55
gtsam::SharedDiagonal
noiseModel::Diagonal::shared_ptr SharedDiagonal
Definition: NoiseModel.h:764
PCGSolver.h
VectorValues.h
Factor Graph Values.
gtsam::PCGSolverParameters::shared_ptr
std::shared_ptr< PCGSolverParameters > shared_ptr
Definition: PCGSolver.h:38
TestResult
Definition: TestResult.h:26
gtsam
traits
Definition: SFMdata.h:40
std
Definition: BFloat16.h:88
Preconditioner.h
gtsam::assert_equal
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
Definition: Matrix.cpp:41
main
int main()
Definition: testPreconditioner.cpp:132
gtsam::GaussianFactorGraph::optimize
VectorValues optimize(const Eliminate &function=EliminationTraitsType::DefaultEliminate) const
Definition: GaussianFactorGraph.cpp:309
ceres::Vector
Eigen::Matrix< double, Eigen::Dynamic, 1 > Vector
Definition: gtsam/3rdparty/ceres/eigen.h:38
Values.h
A non-templated config holding any types of Manifold-group elements.
gtsam::FactorGraph::emplace_shared
IsDerived< DERIVEDFACTOR > emplace_shared(Args &&... args)
Emplace a shared pointer to factor of given type.
Definition: FactorGraph.h:153


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:08:02