49 using NoiseModelFactor1<VALUE>::evaluateError;
89 std::placeholders::_1, std::placeholders::_2, 1e-9)) :
91 j), feasible_(feasible), allow_error_(false), error_gain_(0.0),
100 std::placeholders::_1, std::placeholders::_2, 1e-9)) :
102 j), feasible_(feasible), allow_error_(true), error_gain_(error_gain),
110 void print(
const std::string& s =
"",
111 const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const override {
112 std::cout << (s.empty() ? s : s +
" ") <<
"Constraint: on [" 113 << keyFormatter(this->
key()) <<
"]\n";
121 const This* e =
dynamic_cast<const This*
>(&f);
123 && std::abs(error_gain_ - e->error_gain_) < tol;
132 const T& xj = c.
at<T>(this->
key());
134 if (allow_error_ || !compare_(xj, feasible_)) {
135 return error_gain_ *
dot(e, e);
146 *H = Matrix::Identity(nj,nj);
148 }
else if (compare_(feasible_, xj)) {
150 *H = Matrix::Identity(nj,nj);
151 return Vector::Zero(nj);
154 throw std::invalid_argument(
155 "Linearization point not feasible for " 156 + DefaultKeyFormatter(this->
key()) +
"!");
157 return Vector::Constant(nj, std::numeric_limits<double>::infinity());
163 const T& xj = x.
at<T>(this->
key());
172 gtsam::NonlinearFactor::shared_ptr
clone()
const override {
174 gtsam::NonlinearFactor::shared_ptr(
new This(*
this)));
183 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 184 friend class boost::serialization::access; 186 template<
class ARCHIVE>
187 void serialize(ARCHIVE & ar,
const unsigned int ) {
190 & boost::serialization::make_nvp(
"NoiseModelFactor1",
191 boost::serialization::base_object<Base>(*
this));
192 ar & BOOST_SERIALIZATION_NVP(feasible_);
193 ar & BOOST_SERIALIZATION_NVP(allow_error_);
194 ar & BOOST_SERIALIZATION_NVP(error_gain_);
201 template <
typename VALUE>
208 template<
class VALUE>
215 using NoiseModelFactor1<VALUE>::evaluateError;
227 GTSAM_CONCEPT_MANIFOLD_TYPE(X)
228 GTSAM_CONCEPT_TESTABLE_TYPE(X)
232 typedef std::shared_ptr<NonlinearEquality1<VALUE> >
shared_ptr;
250 gtsam::NonlinearFactor::shared_ptr
clone()
const override {
252 gtsam::NonlinearFactor::shared_ptr(
new This(*
this)));
264 void print(
const std::string& s =
"",
265 const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const override {
266 std::cout << s <<
": NonlinearEquality1(" << keyFormatter(this->
key())
268 this->noiseModel_->print();
276 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 277 friend class boost::serialization::access; 279 template<
class ARCHIVE>
280 void serialize(ARCHIVE & ar,
const unsigned int ) {
283 & boost::serialization::make_nvp(
"NoiseModelFactor1",
284 boost::serialization::base_object<Base>(*
this));
285 ar & BOOST_SERIALIZATION_NVP(value_);
291 template <
typename VALUE>
293 :
Testable<NonlinearEquality1<VALUE> > {};
306 GTSAM_CONCEPT_MANIFOLD_TYPE(T)
312 typedef std::shared_ptr<NonlinearEquality2<T>>
shared_ptr;
330 gtsam::NonlinearFactor::shared_ptr
clone()
const override {
332 gtsam::NonlinearFactor::shared_ptr(
new This(*
this)));
339 if (H1) *H1 = -Matrix::Identity(p, p);
340 if (H2) *H2 = Matrix::Identity(p, p);
347 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 348 friend class boost::serialization::access;
350 template <
class ARCHIVE>
351 void serialize(ARCHIVE& ar,
const unsigned int ) {
353 ar& boost::serialization::make_nvp(
354 "NoiseModelFactor2", boost::serialization::base_object<Base>(*
this));
360 template <
typename VALUE>
Definition: NonlinearFactor.h:431
NonlinearEquality1()
Default constructor to allow for serialization.
Definition: NonlinearEquality.h:222
bool equals(const NonlinearFactor &f, double tol=1e-9) const override
Concept check for values that can be used in unit tests.
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition: NonlinearEquality.h:330
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition: NonlinearEquality.h:250
double dot(const V1 &a, const V2 &b)
Definition: Vector.h:195
std::string serialize(const T &input)
serializes to a string
Definition: serialization.h:113
const ValueType at(Key j) const
Definition: Values-inl.h:204
Definition: Testable.h:152
virtual Vector evaluateError(const ValueTypes &... x, OptionalMatrixTypeT< ValueTypes >... H) const=0
Key key() const
Definition: NonlinearFactor.h:582
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition: NonlinearEquality.h:172
Definition: NonlinearFactor.h:68
NonlinearEquality1(const X &value, Key key, double mu=1000.0)
Definition: NonlinearEquality.h:240
Vector evaluateError(const T &x1, const T &x2, OptionalMatrixType H1, OptionalMatrixType H2) const override
g(x) with optional derivative2
Definition: NonlinearEquality.h:336
Definition: NonlinearEquality.h:43
GaussianFactor::shared_ptr linearize(const Values &x) const override
Linearize is over-written, because base linearization tries to whiten.
Definition: NonlinearEquality.h:162
const SharedNoiseModel & noiseModel() const
access to the noise model
Definition: NonlinearFactor.h:245
Matrix * OptionalMatrixType
Definition: NonlinearFactor.h:55
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
print
Definition: NonlinearEquality.h:110
Base class and basic functions for Manifold types.
NonlinearEquality2(Key key1, Key key2, double mu=1e4)
Definition: NonlinearEquality.h:324
NonlinearEquality(Key j, const T &feasible, const CompareFunction &_compare=std::bind(traits< T >::Equals, std::placeholders::_1, std::placeholders::_2, 1e-9))
Definition: NonlinearEquality.h:87
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
Print.
Definition: NonlinearEquality.h:264
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
std::shared_ptr< NonlinearEquality1< VALUE > > shared_ptr
fixed value for variable
Definition: NonlinearEquality.h:232
Definition: JacobianFactor.h:91
std::shared_ptr< This > shared_ptr
shared_ptr to this class
Definition: GaussianFactor.h:42
Vector evaluateError(const T &xj, OptionalMatrixType H) const override
Error function.
Definition: NonlinearEquality.h:142
Definition: chartTesting.h:28
Vector unwhitenedError(const Values &x, OptionalMatrixVecType H=nullptr) const override
Definition: NonlinearFactor.h:606
std::shared_ptr< This > shared_ptr
Definition: NonlinearFactor.h:209
Non-linear factor base classes.
Vector evaluateError(const X &x1, OptionalMatrixType H) const override
g(x) with optional derivative
Definition: NonlinearEquality.h:256
Definition: NonlinearEquality.h:209
NonlinearEquality()
Default constructor - only for serialization.
Definition: NonlinearEquality.h:75
#define GTSAM_MAKE_ALIGNED_OPERATOR_NEW
Definition: types.h:284
double error(const Values &c) const override
Actual error function calculation.
Definition: NonlinearEquality.h:131
std::function< bool(const T &, const T &)> CompareFunction
Function that compares two values.
Definition: NonlinearEquality.h:71
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:102
Definition: NonlinearEquality.h:301
NonlinearEquality(Key j, const T &feasible, double error_gain, const CompareFunction &_compare=std::bind(traits< T >::Equals, std::placeholders::_1, std::placeholders::_2, 1e-9))
Definition: NonlinearEquality.h:98
bool equals(const NonlinearFactor &f, double tol=1e-9) const override
Definition: NonlinearEquality.h:120
static shared_ptr All(size_t dim)
Definition: NoiseModel.h:466