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>
43namespace pathOptimization {
44template <
int _PolynomeBasis,
int _SplineOrder>
49 enum { PolynomeBasis = _PolynomeBasis, SplineOrder = _SplineOrder };
50 typedef shared_ptr<SplineGradientBased>
Ptr_t;
111 const PathPtr_t& path,
const constraints::solver::BySubstitution& hs,
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
std::vector< SplinePtr_t > Splines_t
Definition spline-gradient-based-abstract.hh:52
std::vector< SplineOptimizationData > SplineOptimizationDatas_t
Definition spline-gradient-based-abstract.hh:170
Spline::Ptr_t SplinePtr_t
Definition spline-gradient-based-abstract.hh:51
#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
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:326
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