29 #ifndef HPP_CORE_PATH_OPTIMIZATION_SPLINE_GRADIENT_BASED_HH
30 #define HPP_CORE_PATH_OPTIMIZATION_SPLINE_GRADIENT_BASED_HH
32 #include <hpp/constraints/explicit-constraint-set.hh>
33 #include <hpp/constraints/solver/by-substitution.hh>
43 namespace pathOptimization {
44 template <
int _PolynomeBasis,
int _SplineOrder>
49 enum { PolynomeBasis = _PolynomeBasis, SplineOrder = _SplineOrder };
50 typedef shared_ptr<SplineGradientBased>
Ptr_t;
113 const bool& useExplicitInput =
false)
const;
121 struct CollisionFunctions;
123 void addCollisionConstraint(
const std::size_t idxSpline,
129 CollisionFunctions& functions)
const;
134 CollisionFunctions& functions,
const std::size_t iF,
138 template <
typename Cost_t>
139 bool checkHessian(
const Cost_t& cost,
const matrix_t& H,
Common base for optimization-based path optimizer with splines.
Definition: spline-gradient-based-abstract.hh:47
Definition: spline-gradient-based.hh:46
#define HPP_CORE_DLLAPI
Definition: config.hh:88
virtual PathVectorPtr_t optimize(const PathVectorPtr_t &path)
virtual void addProblemConstraints(const PathVectorPtr_t &init, const Splines_t &splines, LinearConstraint &lc, SplineOptimizationDatas_t &sods) const
static Ptr_t create(const ProblemConstPtr_t &problem)
SplineGradientBased(const ProblemConstPtr_t &problem)
std::vector< std::pair< PathValidationReportPtr_t, std::size_t > > Reports_t
Definition: spline-gradient-based-abstract.hh:136
std::vector< SplinePtr_t > Splines_t
Definition: spline-gradient-based-abstract.hh:52
bool checkOptimum_
Definition: spline-gradient-based.hh:117
std::vector< SplineOptimizationData > SplineOptimizationDatas_t
Definition: spline-gradient-based-abstract.hh:170
Eigen::RowBlockIndices RowBlockIndices
Definition: spline-gradient-based-abstract.hh:154
Eigen::RowBlockIndices computeActiveParameters(const PathPtr_t &path, const constraints::solver::BySubstitution &hs, const value_type &guessThr=-1, const bool &useExplicitInput=false) const
Spline::Ptr_t SplinePtr_t
Definition: spline-gradient-based-abstract.hh:51
SplineGradientBasedAbstract< _PolynomeBasis, _SplineOrder > Base
Definition: spline-gradient-based.hh:48
void addProblemConstraintOnPath(const PathPtr_t &path, const size_type &idxSpline, const SplinePtr_t &spline, LinearConstraint &lc, SplineOptimizationData &sod) const
shared_ptr< SplineGradientBased > Ptr_t
Definition: spline-gradient-based.hh:50
pinocchio::value_type value_type
Definition: fwd.hh:174
shared_ptr< PathVector > PathVectorPtr_t
Definition: fwd.hh:193
pinocchio::size_type size_type
Definition: fwd.hh:173
constraints::solver::BySubstitution BySubstitution
Definition: config-projector.hh:41
shared_ptr< const Problem > ProblemConstPtr_t
Definition: fwd.hh:197
shared_ptr< Path > PathPtr_t
Definition: fwd.hh:187
shared_ptr< PathValidationReport > PathValidationReportPtr_t
Definition: fwd.hh:317
pinocchio::matrix_t matrix_t
Definition: fwd.hh:162
Definition: bi-rrt-planner.hh:35
A linear constraint .
Definition: linear-constraint.hh:39
Definition: spline-gradient-based-abstract.hh:157