6 #ifndef __sot_torque_control_current_controller_H__
7 #define __sot_torque_control_current_controller_H__
14 #if defined(__sot_torque_control_current_controller_H__)
15 #define SOTCURRENTCONTROLLER_EXPORT __declspec(dllexport)
17 #define SOTCURRENTCONTROLLER_EXPORT __declspec(dllimport)
20 #define SOTCURRENTCONTROLLER_EXPORT
27 #include <pinocchio/fwd.hpp>
31 #include <dynamic-graph/signal-helper.h>
34 #include <pinocchio/multibody/model.hpp>
35 #include <pinocchio/parsers/urdf.hpp>
36 #include <sot/core/matrix-geometry.hh>
37 #include <sot/core/robot-utils.hh>
39 #include <tsid/robots/robot-wrapper.hpp>
41 #include "boost/assign.hpp"
52 :
public ::dynamicgraph::Entity {
54 DYNAMIC_GRAPH_ENTITY_DECL();
65 void init(
const double& dt,
const std::string& robotRef,
66 const unsigned int& currentOffsetIters);
72 dynamicgraph::Vector);
74 kp_current, dynamicgraph::Vector);
76 ki_current, dynamicgraph::Vector);
79 i_max, dynamicgraph::Vector);
83 dynamicgraph::Vector);
86 dynamicgraph::Vector);
91 dynamicgraph::Vector);
93 dq, dynamicgraph::Vector);
97 dynamicgraph::Vector);
101 percentage_bemf_compensation,
102 dynamicgraph::Vector);
106 dynamicgraph::Vector);
108 percentage_dead_zone_compensation,
109 dynamicgraph::Vector);
113 i_max_dead_zone_compensation,
114 dynamicgraph::Vector);
117 dynamicgraph::Vector);
120 i_sensor_offsets_real_in,
121 dynamicgraph::Vector);
126 dynamicgraph::Vector);
128 dynamicgraph::Vector);
132 dynamicgraph::Vector);
134 i_sensor_offsets_real_out,
135 dynamicgraph::Vector);
137 dynamicgraph::Vector);
140 dynamicgraph::Vector);
143 dynamicgraph::Vector);
147 void reset_integral();
150 virtual void display(std::ostream& os)
const;
152 void sendMsg(
const std::string& msg, MsgType t = MSG_TYPE_INFO,
153 const char* =
"",
int = 0) {
154 logger_.stream(t) << (
"[CurrentController-" + name +
"] " + msg) <<
'\n';
void sendMsg(const std::string &msg, MsgType t=MSG_TYPE_INFO, const char *="", int=0)
DECLARE_SIGNAL_OUT(i_errors, dynamicgraph::Vector)
bool m_is_first_iter
control loop time period
DECLARE_SIGNAL_IN(i_max_dead_zone_compensation, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(percentage_dead_zone_compensation, dynamicgraph::Vector)
current control dead zone offsets
DECLARE_SIGNAL_OUT(i_errors_ll_wo_bemf, dynamicgraph::Vector)
current tracking error
dynamicgraph::Vector m_dz_coeff
DECLARE_SIGNAL_IN(i_max, dynamicgraph::Vector)
proportional current feedback gain
DECLARE_SIGNAL_OUT(u_safe, dynamicgraph::Vector)
dynamicgraph::Vector m_i_offsets_real
RobotUtilShrPtr m_robot_util
DECLARE_SIGNAL_OUT(u, dynamicgraph::Vector)
real offset of the current sensors
DECLARE_SIGNAL_OUT(i_low_level, dynamicgraph::Vector)
dynamicgraph::Vector m_i_err_integr
DECLARE_SIGNAL_IN(i_sensor_offsets_low_level, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(percentage_bemf_compensation, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(u_max, dynamicgraph::Vector)
DECLARE_SIGNAL_OUT(i_real, dynamicgraph::Vector)
same as u when everything is fine, 0 otherwise
dynamicgraph::Vector m_avg_i_err_neg
DECLARE_SIGNAL_IN(i_des, dynamicgraph::Vector)
dynamicgraph::Vector m_avg_i_err_pos
int m_iter
true at the first iteration, false otherwise
DECLARE_SIGNAL_IN(ki_current, dynamicgraph::Vector)
proportional current feedback gain
DECLARE_SIGNAL_IN(bemf_factor, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(kp_current, dynamicgraph::Vector)
gains of current sensors
unsigned int m_currentOffsetIters
DECLARE_SIGNAL_OUT(i_sensor_offsets_real_out, dynamicgraph::Vector)
current measurements as seen by low-level ctrl
DECLARE_SIGNAL_OUT(dead_zone_compensation, dynamicgraph::Vector)
real offset of the current sensors
DECLARE_SIGNAL_IN(u_saturation, dynamicgraph::Vector)
bool m_emergency_stop_triggered
true if the entity has been successfully initialized
DECLARE_SIGNAL_IN(in_out_gain, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(i_sensor_offsets_real_in, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(dead_zone_offsets, dynamicgraph::Vector)
DECLARE_SIGNAL_IN(i_sens_gains, dynamicgraph::Vector)
motor currents
DECLARE_SIGNAL_IN(i_measured, dynamicgraph::Vector)
desired motor currents
DECLARE_SIGNAL_IN(dq, dynamicgraph::Vector)
gain from input to output control values
#define SOTCURRENTCONTROLLER_EXPORT
AdmittanceController EntityClassName