40 GTSAM_CONCEPT_TESTABLE_TYPE(T)
45 typedef typename boost::shared_ptr<PriorFactor<VALUE> >
shared_ptr;
57 Base(model, key), prior_(prior) {
62 Base(
noiseModel::Gaussian::Covariance(covariance), key), prior_(prior) {
66 virtual gtsam::NonlinearFactor::shared_ptr
clone()
const {
67 return boost::static_pointer_cast<gtsam::NonlinearFactor>(
68 gtsam::NonlinearFactor::shared_ptr(
new This(*
this))); }
73 virtual void print(
const std::string& s,
const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const {
74 std::cout << s <<
"PriorFactor on " << keyFormatter(this->key()) <<
"\n";
76 this->noiseModel_->print(
" noise model: ");
81 const This* e = dynamic_cast<const This*> (&expected);
88 Vector
evaluateError(
const T& x, boost::optional<Matrix&> H = boost::none)
const {
95 const VALUE & prior()
const {
return prior_; }
101 template<
class ARCHIVE>
102 void serialize(ARCHIVE & ar,
const unsigned int ) {
103 ar & boost::serialization::make_nvp(
"NoiseModelFactor1",
104 boost::serialization::base_object<Base>(*
this));
105 ar & BOOST_SERIALIZATION_NVP(prior_);
109 enum { NeedsToAlign = (
sizeof(T) % 16) == 0 };
111 EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(NeedsToAlign)
This is the base class for all factor types.
Definition: Factor.h:54
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:57
virtual bool equals(const NonlinearFactor &expected, double tol=1e-9) const
equals
Definition: PriorFactor.h:80
Definition: PriorFactor.h:28
PriorFactor(Key key, const VALUE &prior, const Matrix &covariance)
Convenience constructor that takes a full covariance argument.
Definition: PriorFactor.h:61
Vector evaluateError(const T &x, boost::optional< Matrix & > H=boost::none) const
implement functions needed to derive from Factor
Definition: PriorFactor.h:88
friend class boost::serialization::access
Serialization function.
Definition: PriorFactor.h:100
boost::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:33
A convenient base class for creating your own NoiseModelFactor with 1 variable.
Definition: NonlinearFactor.h:276
Nonlinear factor base class.
Definition: NonlinearFactor.h:50
const SharedNoiseModel & noiseModel() const
access to the noise model
Definition: NonlinearFactor.h:210
virtual gtsam::NonlinearFactor::shared_ptr clone() const
Definition: PriorFactor.h:66
virtual void print(const std::string &s, const KeyFormatter &keyFormatter=DefaultKeyFormatter) const
implement functions needed for Testable
Definition: PriorFactor.h:73
A manifold defines a space in which there is a notion of a linear tangent space that can be centered ...
Definition: concepts.h:30
Non-linear factor base classes.
boost::shared_ptr< PriorFactor< VALUE > > shared_ptr
The measurement.
Definition: PriorFactor.h:45
PriorFactor()
default constructor - only use for serialization
Definition: PriorFactor.h:51
Global functions in a separate testing namespace.
Definition: chartTesting.h:28
Concept check for values that can be used in unit tests.
noiseModel::Base::shared_ptr SharedNoiseModel
Note, deliberately not in noiseModel namespace.
Definition: NoiseModel.h:1072
PriorFactor< VALUE > This
Typedef to this class.
Definition: PriorFactor.h:48
virtual bool equals(const NonlinearFactor &f, double tol=1e-9) const
Check if two factors are equal.
Definition: NonlinearFactor.cpp:71
PriorFactor(Key key, const VALUE &prior, const SharedNoiseModel &model=nullptr)
Constructor.
Definition: PriorFactor.h:56