Go to the documentation of this file.
30 class DecisionTreeFactor;
31 class DiscreteConditional;
44 typedef std::shared_ptr<DiscreteFactor>
50 using Unary = std::function<double(
const double&)>;
53 using Binary = std::function<double(
const double,
const double)>;
71 template <
typename CONTAINER>
73 const std::map<Key, size_t> cardinalities = {})
74 :
Base(
keys), cardinalities_(cardinalities) {}
85 const std::string&
s =
"DiscreteFactor\n",
165 virtual uint64_t nrValues()
const = 0;
192 virtual std::string
html(
194 const Names&
names = {})
const = 0;
199 #if GTSAM_ENABLE_BOOST_SERIALIZATION
201 friend class boost::serialization::access;
202 template <
class ARCHIVE>
203 void serialize(ARCHIVE& ar,
const unsigned int ) {
204 ar& BOOST_SERIALIZATION_BASE_OBJECT_NVP(
Base);
205 ar& BOOST_SERIALIZATION_NVP(cardinalities_);
231 std::vector<double>
expNormalize(
const std::vector<double>& logProbs);
EIGEN_STRONG_INLINE Packet4f print(const Packet4f &a)
string markdown(const DiscreteValues &values, const KeyFormatter &keyFormatter, const DiscreteValues::Names &names)
Free version of markdown.
Array< double, 1, 3 > e(1./3., 0.5, 2.)
std::map< Key, size_t > cardinalities() const
Concept check for values that can be used in unit tests.
std::map< Key, size_t > cardinalities_
Map of Keys and their cardinalities.
const KeyFormatter & formatter
Variable ordering for the elimination algorithm.
DiscreteKeys is a set of keys that can be assembled using the & operator.
The base class for all factors.
KeyFormatter DefaultKeyFormatter
Assign default key formatter.
Point2 operator*(double s, const Point2 &p)
multiply with scalar
Algebraic Decision Trees.
std::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
void print(const std::string &s="DiscreteFactor\n", const KeyFormatter &formatter=DefaultKeyFormatter) const override
print
DiscreteFactor This
This class.
DiscreteFactor(const CONTAINER &keys, const std::map< Key, size_t > cardinalities={})
std::function< double(const double, const double)> Binary
size_t cardinality(Key j) const
std::shared_ptr< DiscreteFactor > shared_ptr
shared_ptr to this class
DiscreteValues::Names Names
Translation table from values to strings.
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE CwiseBinaryOp< internal::scalar_quotient_op< Scalar, typename OtherDerived::Scalar >, const Derived, const OtherDerived > operator/(const EIGEN_CURRENT_STORAGE_BASE_CLASS< OtherDerived > &other) const
std::vector< double > expNormalize(const std::vector< double > &logProbs)
Normalize a set of log probabilities.
Factor Base
Our base class.
unsigned __int64 uint64_t
string html(const DiscreteValues &values, const KeyFormatter &keyFormatter, const DiscreteValues::Names &names)
Free version of html.
std::map< Key, std::vector< std::string > > Names
Translation table from values to strings.
std::function< double(const Assignment< Key > &, const double &)> UnaryAssignment
std::uint64_t Key
Integer nonlinear key type.
std::function< double(const double &)> Unary
double operator()(const DiscreteValues &values) const
Find value for given assignment of values to variables.
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:02:11