nlp_formulation.h
Go to the documentation of this file.
00001 /******************************************************************************
00002 Copyright (c) 2018, Alexander W. Winkler. All rights reserved.
00003 
00004 Redistribution and use in source and binary forms, with or without
00005 modification, are permitted provided that the following conditions are met:
00006 
00007 * Redistributions of source code must retain the above copyright notice, this
00008   list of conditions and the following disclaimer.
00009 
00010 * Redistributions in binary form must reproduce the above copyright notice,
00011   this list of conditions and the following disclaimer in the documentation
00012   and/or other materials provided with the distribution.
00013 
00014 * Neither the name of the copyright holder nor the names of its
00015   contributors may be used to endorse or promote products derived from
00016   this software without specific prior written permission.
00017 
00018 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00019 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00020 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00021 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
00022 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00023 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
00024 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00025 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00026 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00027 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00028 ******************************************************************************/
00029 
00030 #ifndef TOWR_NLP_FACTORY_H_
00031 #define TOWR_NLP_FACTORY_H_
00032 
00033 #include <ifopt/variable_set.h>
00034 #include <ifopt/constraint_set.h>
00035 #include <ifopt/cost_term.h>
00036 
00037 #include <towr/variables/spline_holder.h>
00038 #include <towr/models/robot_model.h>
00039 #include <towr/terrain/height_map.h>
00040 #include <towr/parameters.h>
00041 
00042 namespace towr {
00043 
00073 class NlpFormulation {
00074 public:
00075   using VariablePtrVec   = std::vector<ifopt::VariableSet::Ptr>;
00076   using ContraintPtrVec  = std::vector<ifopt::ConstraintSet::Ptr>;
00077   using CostPtrVec       = std::vector<ifopt::CostTerm::Ptr>;
00078   using EEPos            = std::vector<Eigen::Vector3d>;
00079   using Vector3d         = Eigen::Vector3d;
00080 
00081   NlpFormulation ();
00082   virtual ~NlpFormulation () = default;
00083 
00088   VariablePtrVec GetVariableSets(SplineHolder& spline_holder);
00089 
00094   ContraintPtrVec GetConstraints(const SplineHolder& spline_holder) const;
00095 
00097   ContraintPtrVec GetCosts() const;
00098 
00099 
00100   BaseState initial_base_;
00101   BaseState final_base_;
00102   EEPos  initial_ee_W_;
00103   RobotModel model_;
00104   HeightMap::Ptr terrain_;
00105   Parameters params_;
00106 
00107 private:
00108   // variables
00109   std::vector<NodesVariables::Ptr> MakeBaseVariables() const;
00110   std::vector<NodesVariablesPhaseBased::Ptr> MakeEndeffectorVariables() const;
00111   std::vector<NodesVariablesPhaseBased::Ptr> MakeForceVariables() const;
00112   std::vector<PhaseDurations::Ptr> MakeContactScheduleVariables() const;
00113 
00114   // constraints
00115   ContraintPtrVec GetConstraint(Parameters::ConstraintName name,
00116                                 const SplineHolder& splines) const;
00117   ContraintPtrVec MakeDynamicConstraint(const SplineHolder& s) const;
00118   ContraintPtrVec MakeRangeOfMotionBoxConstraint(const SplineHolder& s) const;
00119   ContraintPtrVec MakeTotalTimeConstraint() const;
00120   ContraintPtrVec MakeTerrainConstraint() const;
00121   ContraintPtrVec MakeForceConstraint() const;
00122   ContraintPtrVec MakeSwingConstraint() const;
00123   ContraintPtrVec MakeBaseRangeOfMotionConstraint(const SplineHolder& s) const;
00124   ContraintPtrVec MakeBaseAccConstraint(const SplineHolder& s) const;
00125 
00126   // costs
00127   CostPtrVec GetCost(const Parameters::CostName& id, double weight) const;
00128   CostPtrVec MakeForcesCost(double weight) const;
00129   CostPtrVec MakeEEMotionCost(double weight) const;
00130 };
00131 
00132 } /* namespace towr */
00133 
00134 #endif /* TOWR_NLP_FACTORY_H_ */


towr
Author(s): Alexander W. Winkler
autogenerated on Mon Apr 15 2019 02:42:32