Go to the documentation of this file.
28 using namespace gtsam;
39 graph.
add(
A & AI,
"1 1 1 0 1 1 1 1 0 1 1 1");
42 graph.
add(
A & ME,
"1 1 1 0 1 1 1 1 0 1 1 1");
45 graph.
add(
A & PC,
"1 1 1 0 1 1 1 1 0 1 1 1");
46 graph.
add(ME & AI,
"0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0");
47 graph.
add(PC & ME,
"0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0");
48 graph.
add(PC & AI,
"0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0");
51 auto actualMPE =
graph.optimize();
117 *std::dynamic_pointer_cast<DecisionTreeFactor>(newFactorPtr);
120 auto normalizer = newFactor.
max(newFactor.
size());
122 newFactor = newFactor / *normalizer;
134 normalizer = expectedFactor.
max(expectedFactor.
size());
136 expectedFactor = expectedFactor / *normalizer;
146 expectedBayesNet.
add(signature);
147 expectedBayesNet.
add(
B |
A =
"5/3 3/5");
148 expectedBayesNet.
add(
A %
"1/1");
157 auto actualMPE =
graph.optimize();
162 auto mpeProbability = expectedBayesNet(mpe);
170 {Ordering::COLAMD, Ordering::METIS, Ordering::NATURAL,
192 {Ordering::COLAMD, Ordering::METIS, Ordering::NATURAL,
195 auto actualMPE = dag.
argmax();
197 auto actualMPE2 =
graph.optimize();
218 auto actualMPE =
graph.optimize();
233 graph.
add(
S &
C &
T2,
"0.80 0.20 0.20 0.80 0.95 0.05 0.05 0.95");
243 auto actualMPE =
graph.optimize();
271 " var0[label=\"0\"];\n"
272 " var1[label=\"1\"];\n"
273 " var2[label=\"2\"];\n"
275 " factor0[label=\"\", shape=point];\n"
278 " factor1[label=\"\", shape=point];\n"
293 vector<string>
names{
"C",
"A",
"B"};
300 " var0[label=\"C\"];\n"
301 " var1[label=\"A\"];\n"
302 " var2[label=\"B\"];\n"
304 " factor0[label=\"\", shape=point];\n"
307 " factor1[label=\"\", shape=point];\n"
324 "`DiscreteFactorGraph` of size 2\n"
341 vector<string>
names{
"C",
"A",
"B"};
static int runAllTests(TestResult &result)
std::pair< DiscreteConditional::shared_ptr, DiscreteFactor::shared_ptr > EliminateDiscrete(const DiscreteFactorGraph &factors, const Ordering &frontalKeys)
Main elimination function for DiscreteFactorGraph.
string markdown(const DiscreteValues &values, const KeyFormatter &keyFormatter, const DiscreteValues::Names &names)
Free version of markdown.
Matrix< SCALARB, Dynamic, Dynamic, opt_B > B
Array< double, 1, 3 > e(1./3., 0.5, 2.)
#define EXPECT_LONGS_EQUAL(expected, actual)
#define EXPECT(condition)
std::shared_ptr< This > shared_ptr
const KeyFormatter & formatter
void dot(std::ostream &os, const Values &values, const KeyFormatter &keyFormatter=DefaultKeyFormatter, const GraphvizFormatting &writer=GraphvizFormatting()) const
Output to graphviz format, stream version, with Values/extra options.
Provides additional testing facilities for common data structures.
Matrix< SCALARA, Dynamic, Dynamic, opt_A > A
const HybridBayesNet bayesNet
Elimination tree for discrete factors.
std::pair< std::shared_ptr< BayesNetType >, std::shared_ptr< FactorGraphType > > eliminate(Eliminate function) const
static const Pose3 T2(Rot3::Rodrigues(0.3, 0.2, 0.1), P2)
Discrete Bayes Tree, the result of eliminating a DiscreteJunctionTree.
#define EXPECT_DOUBLES_EQUAL(expected, actual, threshold)
static enum @1096 ordering
const gtsam::Symbol key('X', 0)
OrderingType
Type of ordering to use.
TEST(DiscreteFactorGraph, test)
TEST_UNSAFE(DiscreteFactorGraph, debugScheduler)
void add(const DiscreteKey &key, const std::string &spec)
Matrix< Scalar, Dynamic, Dynamic > C
std::pair< Key, size_t > DiscreteKey
shared_ptr max(size_t nrFrontals) const
Create new factor by maximizing over all values with the same separator.
std::shared_ptr< This > shared_ptr
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
void product(const MatrixType &m)
DiscreteValues argmax(DiscreteValues given=DiscreteValues()) const
argmax by back-substitution, optionally given certain variables.
static const Similarity3 T1(R, Point3(3.5, -8.2, 4.2), 1)
IsDerived< DERIVEDFACTOR > add(std::shared_ptr< DERIVEDFACTOR > factor)
add is a synonym for push_back.
NonlinearFactorGraph graph
std::uint64_t Key
Integer nonlinear key type.
Matrix< RealScalar, Dynamic, Dynamic > M
gtsam
Author(s):
autogenerated on Sat Jan 4 2025 04:05:54