26using JacobianVector = std::vector<Matrix>;
38using CustomErrorFunction = std::function<Vector(
const CustomFactor &,
const Values &,
const JacobianVector *)>;
49 CustomErrorFunction error_function_;
71 this->error_function_ = errorFunction;
80 Vector
unwhitenedError(
const Values &x, boost::optional<std::vector<Matrix> &> H = boost::none)
const override;
83 void print(
const std::string &s,
84 const KeyFormatter &keyFormatter = DefaultKeyFormatter)
const override;
97 template<
class ARCHIVE>
98 void serialize(ARCHIVE &ar,
const unsigned int ) {
99 ar & boost::serialization::make_nvp(
"CustomFactor",
100 boost::serialization::base_object<Base>(*
this));
Non-linear factor base classes.
Global functions in a separate testing namespace.
Definition: chartTesting.h:28
FastVector< Key > KeyVector
Define collection type once and for all - also used in wrappers.
Definition: Key.h:86
noiseModel::Base::shared_ptr SharedNoiseModel
Note, deliberately not in noiseModel namespace.
Definition: NoiseModel.h:736
std::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:35
This is the base class for all factor types.
Definition: Factor.h:56
const KeyVector & keys() const
Access the factor's involved variable keys.
Definition: Factor.h:125
Definition: CustomFactor.h:47
Vector unwhitenedError(const Values &x, boost::optional< std::vector< Matrix > & > H=boost::none) const override
Calls the errorFunction closure, which is a std::function object One can check if a derivative is nee...
Definition: CustomFactor.cpp:25
CustomFactor(const SharedNoiseModel &noiseModel, const KeyVector &keys, const CustomErrorFunction &errorFunction)
Constructor.
Definition: CustomFactor.h:69
CustomFactor()=default
Default Constructor for I/O.
friend class boost::serialization::access
Serialization function.
Definition: CustomFactor.h:96
bool sendable() const override
Mark not sendable.
Definition: CustomFactor.h:89
void print(const std::string &s, const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
print
Definition: CustomFactor.cpp:59
A nonlinear sum-of-squares factor with a zero-mean noise model implementing the density Templated on...
Definition: NonlinearFactor.h:162
NoiseModelFactor()
Default constructor for I/O only.
Definition: NonlinearFactor.h:177
const SharedNoiseModel & noiseModel() const
access to the noise model
Definition: NonlinearFactor.h:211
A non-templated config holding any types of Manifold-group elements.
Definition: Values.h:63