17 #ifndef __sot_torque_control_simple_inverse_dyn_H__
18 #define __sot_torque_control_simple_inverse_dyn_H__
25 #if defined(simple_inverse_dyn_EXPORTS)
26 #define SOTSIMPLEINVERSEDYN_EXPORT __declspec(dllexport)
28 #define SOTSIMPLEINVERSEDYN_EXPORT __declspec(dllimport)
31 #define SOTSIMPLEINVERSEDYN_EXPORT
40 #include "boost/assign.hpp"
43 #include <pinocchio/multibody/model.hpp>
44 #include <pinocchio/parsers/urdf.hpp>
45 #include <tsid/contacts/contact-6d.hpp>
46 #include <tsid/formulations/inverse-dynamics-formulation-acc-force.hpp>
47 #include <tsid/robots/robot-wrapper.hpp>
48 #include <tsid/solvers/solver-HQP-base.hpp>
49 #include <tsid/tasks/task-com-equality.hpp>
50 #include <tsid/tasks/task-joint-posture.hpp>
51 #include <tsid/trajectories/trajectory-euclidian.hpp>
53 #include "pinocchio/algorithm/joint-configuration.hpp"
56 #include <dynamic-graph/signal-helper.h>
58 #include <sot/core/matrix-geometry.hh>
59 #include <sot/core/robot-utils.hh>
79 :
public ::dynamicgraph::Entity {
81 DYNAMIC_GRAPH_ENTITY_DECL();
84 EIGEN_MAKE_ALIGNED_OPERATOR_NEW
91 DECLARE_SIGNAL_IN(posture_ref_pos, dynamicgraph::Vector);
92 DECLARE_SIGNAL_IN(posture_ref_vel, dynamicgraph::Vector);
93 DECLARE_SIGNAL_IN(posture_ref_acc, dynamicgraph::Vector);
94 DECLARE_SIGNAL_IN(kp_posture, dynamicgraph::Vector);
95 DECLARE_SIGNAL_IN(kd_posture, dynamicgraph::Vector);
96 DECLARE_SIGNAL_IN(w_posture,
double);
98 DECLARE_SIGNAL_IN(kp_pos, dynamicgraph::Vector);
99 DECLARE_SIGNAL_IN(kd_pos, dynamicgraph::Vector);
101 DECLARE_SIGNAL_IN(com_ref_pos, dynamicgraph::Vector);
102 DECLARE_SIGNAL_IN(com_ref_vel, dynamicgraph::Vector);
103 DECLARE_SIGNAL_IN(com_ref_acc, dynamicgraph::Vector);
104 DECLARE_SIGNAL_IN(kp_com, dynamicgraph::Vector);
105 DECLARE_SIGNAL_IN(kd_com, dynamicgraph::Vector);
106 DECLARE_SIGNAL_IN(w_com,
double);
108 DECLARE_SIGNAL_IN(kp_contact, dynamicgraph::Vector);
109 DECLARE_SIGNAL_IN(kd_contact, dynamicgraph::Vector);
110 DECLARE_SIGNAL_IN(w_forces,
double);
111 DECLARE_SIGNAL_IN(mu,
double);
112 DECLARE_SIGNAL_IN(contact_points, dynamicgraph::Matrix);
113 DECLARE_SIGNAL_IN(contact_normal, dynamicgraph::Vector);
114 DECLARE_SIGNAL_IN(f_min,
double);
115 DECLARE_SIGNAL_IN(f_max,
double);
117 DECLARE_SIGNAL_IN(waist_ref_pos, dynamicgraph::Vector);
118 DECLARE_SIGNAL_IN(waist_ref_vel, dynamicgraph::Vector);
119 DECLARE_SIGNAL_IN(waist_ref_acc, dynamicgraph::Vector);
120 DECLARE_SIGNAL_IN(kp_waist, dynamicgraph::Vector);
121 DECLARE_SIGNAL_IN(kd_waist, dynamicgraph::Vector);
122 DECLARE_SIGNAL_IN(w_waist,
double);
124 DECLARE_SIGNAL_IN(q, dynamicgraph::Vector);
125 DECLARE_SIGNAL_IN(v, dynamicgraph::Vector);
128 dynamicgraph::Vector);
129 DECLARE_SIGNAL_INNER(active_joints_checked, dynamicgraph::Vector);
131 DECLARE_SIGNAL_OUT(tau_des, dynamicgraph::Vector);
132 DECLARE_SIGNAL_OUT(dv_des, dynamicgraph::Vector);
133 DECLARE_SIGNAL_OUT(v_des, dynamicgraph::Vector);
134 DECLARE_SIGNAL_OUT(q_des, dynamicgraph::Vector);
135 DECLARE_SIGNAL_OUT(u, dynamicgraph::Vector);
139 void init(
const double& dt,
const std::string& robotRef);
140 virtual void setControlOutputType(
const std::string& type);
141 void updateComOffset();
144 virtual void display(std::ostream& os)
const;
146 void sendMsg(
const std::string& msg, MsgType t = MSG_TYPE_INFO,
147 const char* =
"",
int = 0) {
148 logger_.stream(t) << (
"[" + name +
"] " + msg) <<
'\n';
165 tsid::InverseDynamicsFormulationAccForce*
m_invDyn;
190 tsid::math::Vector m_q_sot;
193 tsid::math::Vector m_tau_sot;
208 #endif // #ifndef __sot_torque_control_simple_inverse_dyn_H__