/* ---------------------------------------------------------------------------- * GTSAM Copyright 2010, Georgia Tech Research Corporation, * Atlanta, Georgia 30332-0415 * All Rights Reserved * Authors: Frank Dellaert, et al. (see THANKS for the full author list) * See LICENSE for the license information * -------------------------------------------------------------------------- */ /** * @file LinearEqualityFactorGraph.cpp * @author Duy-Nguyen Ta * @author Krunal Chande * @author Luca Carlone * @date Dec 15, 2014 */ #include #include namespace gtsam { /* ************************************************************************* */ EqualityFactorGraph::shared_ptr LinearEqualityFactorGraph::linearize( const Values& linearizationPoint) const { EqualityFactorGraph::shared_ptr linearGraph( new EqualityFactorGraph()); for(const NonlinearFactor::shared_ptr& factor: *this){ JacobianFactor::shared_ptr jacobian = boost::dynamic_pointer_cast( factor->linearize(linearizationPoint)); ConstrainedFactor::shared_ptr constraint = boost::dynamic_pointer_cast(factor); linearGraph->add(LinearEquality(*jacobian, constraint->dualKey())); } return linearGraph; } /* ************************************************************************* */ bool LinearEqualityFactorGraph::checkFeasibility(const Values& values, double tol) const { for(const NonlinearFactor::shared_ptr& factor: *this){ NoiseModelFactor::shared_ptr noiseModelFactor = boost::dynamic_pointer_cast(factor); Vector error = noiseModelFactor->unwhitenedError(values); if (error.lpNorm() > tol) return false; } return true; } }