wbc
Scene.hpp
Go to the documentation of this file.
1#ifndef WBC_CORE_SCENE_HPP
2#define WBC_CORE_SCENE_HPP
3
4#include "Task.hpp"
5#include "Constraint.hpp"
7#include "RobotModel.hpp"
8#include "QPSolver.hpp"
10
11namespace wbc{
12
16class Scene{
17protected:
20 Eigen::VectorXd solver_output;
22 std::vector<types::Wrench> contact_wrenches;
23
24public:
26 ~Scene();
27
32 virtual bool configure(const std::vector<TaskPtr> &tasks) = 0;
33
38 virtual const HierarchicalQP& update() = 0;
39
44 virtual const types::JointCommand& solve(const HierarchicalQP& hqp) = 0;
45
50
55
59 const Eigen::VectorXd& getSolverOutputRaw() const { return solver_output; }
60
65 void setHessianRegularizer(const double reg){hessian_regularizer=reg;}
66
71
75 const std::vector<types::Wrench>& getContactWrenches(){return contact_wrenches;}
76};
77
78typedef std::shared_ptr<Scene> ScenePtr;
79
80template<typename T,typename RobotModelPtr,typename QPSolverPtr> Scene* createT(RobotModelPtr robot_model, QPSolverPtr solver, const double dt){return new T(robot_model,solver,dt);}
81
83 typedef std::map<std::string, Scene*(*)(RobotModelPtr, QPSolverPtr, double)> SceneMap;
84
85 static Scene *createInstance(const std::string& name, RobotModelPtr robot_model, QPSolverPtr solver, const double dt) {
86 SceneMap::iterator it = getSceneMap()->find(name);
87 if(it == getSceneMap()->end())
88 throw std::runtime_error("Failed to create instance of plugin " + name + ". Is the plugin registered?");
89 return it->second(robot_model, solver, dt);
90 }
91
92 template<typename T>
93 static T* createInstance(const std::string& name, RobotModelPtr robot_model, QPSolverPtr solver, const double dt){
94 Scene* tmp = createInstance(name, robot_model, solver, dt);
95 T* ret = dynamic_cast<T*>(tmp);
96 return ret;
97 }
98
100 if(!scene_map)
101 scene_map = new SceneMap;
102 return scene_map;
103 }
104
105 static void clear(){
106 scene_map->clear();
107 }
108
109private:
110 static SceneMap *scene_map;
111};
112
113template<typename T>
115 SceneRegistry(const std::string& name) {
116 SceneMap::iterator it = getSceneMap()->find(name);
117 if(it != getSceneMap()->end())
118 throw std::runtime_error("Failed to register plugin with name " + name + ". A plugin with the same name is already registered");
119
120 getSceneMap()->insert(std::make_pair(name, &createT<T,RobotModelPtr,QPSolverPtr>));
121 }
122};
123
124} // namespace wbc
125
126#endif // WBC_CORE_SCENE_HPP
Base class for all wbc scenes.
Definition Scene.hpp:16
virtual const HierarchicalQP & update()=0
Update the wbc scene and return the (updated) optimization problem.
std::vector< types::Wrench > contact_wrenches
Definition Scene.hpp:22
RobotModelPtr robot_model
Definition Scene.hpp:18
const Eigen::VectorXd & getSolverOutputRaw() const
Get current solver output in raw values.
Definition Scene.hpp:59
double hessian_regularizer
Definition Scene.hpp:21
const std::vector< types::Wrench > & getContactWrenches()
Get estimated contact wrenches.
Definition Scene.hpp:75
void setHessianRegularizer(const double reg)
setHessianRegularizer
Definition Scene.hpp:65
Scene(RobotModelPtr robot_model, QPSolverPtr solver, const double dt)
Definition Scene.cpp:9
QPSolverPtr getSolver()
Return the current solver.
Definition Scene.hpp:54
virtual bool configure(const std::vector< TaskPtr > &tasks)=0
Configure the WBC scene. Create tasks and sort them by priority given the task config.
Eigen::VectorXd solver_output
Definition Scene.hpp:20
virtual const types::JointCommand & solve(const HierarchicalQP &hqp)=0
Solve the given optimization problem.
double getHessianRegularizer()
Return the current value of hessian regularizer.
Definition Scene.hpp:70
~Scene()
Definition Scene.cpp:15
RobotModelPtr getRobotModel()
Return the current robot model.
Definition Scene.hpp:49
QPSolverPtr solver
Definition Scene.hpp:19
Definition JointCommand.hpp:8
Definition ContactsAccelerationConstraint.cpp:3
QPSolver * createT()
Definition QPSolver.hpp:35
std::shared_ptr< Scene > ScenePtr
Definition Scene.hpp:78
std::shared_ptr< QPSolver > QPSolverPtr
Definition QPSolver.hpp:33
std::shared_ptr< RobotModel > RobotModelPtr
Definition RobotModel.hpp:315
Describes a hierarchy of quadratic programs.
Definition QuadraticProgram.hpp:53
Definition Scene.hpp:82
static SceneMap * getSceneMap()
Definition Scene.hpp:99
std::map< std::string, Scene *(*)(RobotModelPtr, QPSolverPtr, double)> SceneMap
Definition Scene.hpp:83
static T * createInstance(const std::string &name, RobotModelPtr robot_model, QPSolverPtr solver, const double dt)
Definition Scene.hpp:93
static Scene * createInstance(const std::string &name, RobotModelPtr robot_model, QPSolverPtr solver, const double dt)
Definition Scene.hpp:85
static void clear()
Definition Scene.hpp:105
SceneRegistry(const std::string &name)
Definition Scene.hpp:115