Go to the documentation of this file.
31 using namespace gtsam;
45 const std::vector<double>
table{2, 5, 3, 6, 4, 7};
90 vector<double>{-0.69314718, -1.6094379, -1.0986123, -1.7917595,
91 -1.3862944, -1.9459101, -3.2188758, -4.0073332, -3.5553481,
92 -4.1743873, -3.8066625, -4.3174881});
130 keys.insert(
pA.keys().begin(),
pA.keys().end());
141 auto actual = std::dynamic_pointer_cast<DecisionTreeFactor>(
f1.sum(1));
146 auto actual2 = std::dynamic_pointer_cast<DecisionTreeFactor>(
f1.max(1));
151 auto actual22 = std::dynamic_pointer_cast<DecisionTreeFactor>(
f2.sum(1));
161 std::vector<std::pair<DiscreteValues, double>>
expected;
163 for (
size_t a : {0, 1, 2}) {
164 for (
size_t b : {0, 1}) {
181 "0.0 0.0 0.0 0.60658897 0.61241912 0.61241969 0.61247685 0.61247742 0.0 "
182 "0.0 0.0 0.99995287 1.0 1.0 1.0 1.0");
215 size_t maxNrAssignments = 5;
216 auto pruned5 =
f.
prune(maxNrAssignments);
223 maxNrAssignments = 2;
224 auto pruned2 =
f.
prune(maxNrAssignments);
229 "0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 "
230 "0.999952870000 1.0 1.0 1.0 1.0");
231 maxNrAssignments = 5;
244 std::vector<std::string>
names = {
"A",
"S",
"T",
"L",
"B",
"E",
"X",
"D"};
253 DiscreteKey A(0, 2),
S(1, 2),
T(2, 2),
L(3, 2),
B(4, 2),
E(5, 2),
X(6, 2),
300 for (
bool showZero : {
true,
false}) {
341 auto keyFormatter = [](
Key key) {
return key == 12 ?
"A" :
"B"; };
342 DecisionTreeFactor::Names
names{{12, {
"Zero",
"One",
"Two"}},
355 "<table class='DecisionTreeFactor'>\n"
357 " <tr><th>A</th><th>B</th><th>value</th></tr>\n"
360 " <tr><th>Zero</th><th>-</th><td>1</td></tr>\n"
361 " <tr><th>Zero</th><th>+</th><td>2</td></tr>\n"
362 " <tr><th>One</th><th>-</th><td>3</td></tr>\n"
363 " <tr><th>One</th><th>+</th><td>4</td></tr>\n"
364 " <tr><th>Two</th><th>-</th><td>5</td></tr>\n"
365 " <tr><th>Two</th><th>+</th><td>6</td></tr>\n"
369 auto keyFormatter = [](
Key key) {
return key == 12 ?
"A" :
"B"; };
370 DecisionTreeFactor::Names
names{{12, {
"Zero",
"One",
"Two"}},
std::vector< double > cpt() const
static int runAllTests(TestResult &result)
virtual AlgebraicDecisionTree< Key > errorTree() const
Compute error for each assignment and return as a tree.
string markdown(const DiscreteValues &values, const KeyFormatter &keyFormatter, const DiscreteValues::Names &names)
Free version of markdown.
Matrix< SCALARB, Dynamic, Dynamic, opt_B > B
double computeThreshold(const size_t N) const
Compute the probability value which is the threshold above which only N leaves are present.
Array< double, 1, 3 > e(1./3., 0.5, 2.)
#define EXPECT_LONGS_EQUAL(expected, actual)
Concept check for values that can be used in unit tests.
#define EXPECT(condition)
void dot(std::ostream &os, const KeyFormatter &keyFormatter=DefaultKeyFormatter, bool showZero=true) const
GaussianFactorGraphValuePair Y
DecisionTreeFactor f(A &B &C, "1 5 3 7 2 6 4 8")
DecisionTreeFactor prune(size_t maxNrAssignments) const
Prune the decision tree of discrete variables.
void maybeSaveDotFile(const DecisionTreeFactor &f, const string &filename)
const KeyFormatter & formatter
double f2(const Vector2 &x)
Eigen::Triplet< double > T
const EIGEN_DEVICE_FUNC LogReturnType log() const
Variable ordering for the elimination algorithm.
TEST(DecisionTreeFactor, ConstructorsMatch)
DecisionTreeFactor create(const Signature &signature)
Matrix< SCALARA, Dynamic, Dynamic, opt_A > A
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")
AlgebraicDecisionTree< Key > ADT
signatures for conditional densities
#define EXPECT_DOUBLES_EQUAL(expected, actual, threshold)
const gtsam::Symbol key('X', 0)
double f3(double x1, double x2)
const KeyVector & keys() const
Access the factor's involved variable keys.
std::pair< Key, size_t > DiscreteKey
std::string html(const KeyFormatter &keyFormatter=DefaultKeyFormatter, const Names &names={}) const override
Render as html table.
DiscreteFactor::shared_ptr sum(size_t nrFrontals) const override
Create new factor by summing all values with the same separator values.
double f4(double x, double y, double z)
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
std::vector< std::pair< DiscreteValues, double > > enumerate() const
Enumerate all values into a map from values to double.
DiscreteKeys discreteKeys() const
bool assert_inequal(const Matrix &A, const Matrix &B, double tol)
DiscreteKeys discreteKeys() const
Return all the discrete keys associated with this factor.
std::uint64_t Key
Integer nonlinear key type.
std::string markdown(const KeyFormatter &keyFormatter=DefaultKeyFormatter, const Names &names={}) const override
Render as markdown table.
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:07:09