franka_model.h
Go to the documentation of this file.
1 /*
2  *
3  * Created on: 24 feb 2019
4  * Authors: Oliva Alexander, Gaz Claudio, Cognetti Marco
5  *
6  * C. Gaz, M. Cognetti, A. Oliva, P. Robuffo Giordano, A. De Luca, 'Dynamic
7  * Identification of the Franka Emika Panda Robot With Retrieval of Feasible
8  * Parameters Using Penalty-Based Optimization'. IEEE RA-L, 2019.
9  *
10  */
11 
12 #ifndef franka_model_h
13 #define franka_model_h
14 
15 #include <visp3/core/vpConfig.h>
16 #include <visp3/core/vpColVector.h>
17 #include <visp3/core/vpMatrix.h>
18 
19 namespace franka_model
20 {
21  const unsigned int njoints = 7;
22 
23  /*
24  * In order to speed up the code execution, we pre-compute the constant part
25  * of the friction model of each joint i (second term of the right member of
26  * the equation).
27  *
28  * tau_f(i) = FI_1(i)/(1+exp(-FI_2(i)*(dq(i)+FI_3(i)))) -
29  * FI_1(i)/(1+exp(-FI_2(i)*FI_3(i)))
30  *
31  * For further information refer to our paper and relative Supplementary
32  * Material:
33  * C. Gaz, M. Cognetti, A. Oliva, P. Robuffo Giordano, A. De Luca,
34  * 'Dynamic Identification of the Franka Emika Panda Robot With Retrieval of
35  * Feasible Parameters Using Penalty-Based Optimization'. IEEE RA-L, 2019.
36  */
37 
38  const double FI_11 = 0.54615;
39  const double FI_12 = 0.87224;
40  const double FI_13 = 0.64068;
41  const double FI_14 = 1.2794;
42  const double FI_15 = 0.83904;
43  const double FI_16 = 0.30301;
44  const double FI_17 = 0.56489;
45 
46  const double FI_21 = 5.1181;
47  const double FI_22 = 9.0657;
48  const double FI_23 = 10.136;
49  const double FI_24 = 5.5903;
50  const double FI_25 = 8.3469;
51  const double FI_26 = 17.133;
52  const double FI_27 = 10.336;
53 
54  const double FI_31 = 0.039533;
55  const double FI_32 = 0.025882;
56  const double FI_33 = -0.04607;
57  const double FI_34 = 0.036194;
58  const double FI_35 = 0.026226;
59  const double FI_36 = -0.021047;
60  const double FI_37 = 0.0035526;
61 
62  const double TAU_F_CONST_1 = FI_11/(1+exp(-FI_21*FI_31));
63  const double TAU_F_CONST_2 = FI_12/(1+exp(-FI_22*FI_32));
64  const double TAU_F_CONST_3 = FI_13/(1+exp(-FI_23*FI_33));
65  const double TAU_F_CONST_4 = FI_14/(1+exp(-FI_24*FI_34));
66  const double TAU_F_CONST_5 = FI_15/(1+exp(-FI_25*FI_35));
67  const double TAU_F_CONST_6 = FI_16/(1+exp(-FI_26*FI_36));
68  const double TAU_F_CONST_7 = FI_17/(1+exp(-FI_27*FI_37));
69 
70  vpMatrix massMatrix(const vpColVector &q, const double mL = 0,
71  const vpHomogeneousMatrix &flMcom = vpHomogeneousMatrix(),
72  const vpMatrix &I_L = vpMatrix(3,3));
73 
74  vpMatrix coriolisMatrix(const vpColVector &q,const vpColVector &dq,
75  const double mL = 0,
76  const vpHomogeneousMatrix &flMcom = vpHomogeneousMatrix(),
77  const vpMatrix &I_L = vpMatrix(3,3));
78 
79  vpColVector gravityVector(const vpColVector &q, const double mL = 0 ,
80  const vpHomogeneousMatrix &flMcom = vpHomogeneousMatrix(),
81  const vpColVector &g0 = vpColVector({0.0,0.0,-9.80665}));
82 
83  vpColVector friction(const vpColVector &dq);
84 }
85 
86 #endif /* frank_model_h */
const double TAU_F_CONST_5
Definition: franka_model.h:66
vpColVector friction(const vpColVector &dq)
const double FI_12
Definition: franka_model.h:39
const double FI_13
Definition: franka_model.h:40
const double FI_27
Definition: franka_model.h:52
const double FI_17
Definition: franka_model.h:44
const double FI_11
Definition: franka_model.h:38
const double TAU_F_CONST_6
Definition: franka_model.h:67
const double FI_33
Definition: franka_model.h:56
const double FI_14
Definition: franka_model.h:41
vpColVector gravityVector(const vpColVector &q, const double mL=0, const vpHomogeneousMatrix &flMcom=vpHomogeneousMatrix(), const vpColVector &g0=vpColVector({0.0, 0.0,-9.80665}))
const double FI_24
Definition: franka_model.h:49
const double FI_22
Definition: franka_model.h:47
const double FI_25
Definition: franka_model.h:50
const double TAU_F_CONST_4
Definition: franka_model.h:65
const double FI_16
Definition: franka_model.h:43
vpMatrix coriolisMatrix(const vpColVector &q, const vpColVector &dq, const double mL, const vpHomogeneousMatrix &flMcom, const vpMatrix &I_L)
const double TAU_F_CONST_7
Definition: franka_model.h:68
const double FI_32
Definition: franka_model.h:55
const double FI_34
Definition: franka_model.h:57
const double TAU_F_CONST_3
Definition: franka_model.h:64
const double FI_37
Definition: franka_model.h:60
const double FI_31
Definition: franka_model.h:54
const double FI_15
Definition: franka_model.h:42
INLINE Rall1d< T, V, S > exp(const Rall1d< T, V, S > &arg)
const double FI_35
Definition: franka_model.h:58
const double FI_23
Definition: franka_model.h:48
const double FI_21
Definition: franka_model.h:46
const double TAU_F_CONST_1
Definition: franka_model.h:62
const double FI_36
Definition: franka_model.h:59
vpMatrix massMatrix(const vpColVector &q, const double mL=0, const vpHomogeneousMatrix &flMcom=vpHomogeneousMatrix(), const vpMatrix &I_L=vpMatrix(3, 3))
Definition: MassMatrix.cpp:25
const double TAU_F_CONST_2
Definition: franka_model.h:63
const unsigned int njoints
Definition: franka_model.h:21
const double FI_26
Definition: franka_model.h:51


visp_ros
Author(s): Francois Pasteau, Fabien Spindler, Gatien Gaumerais, Alexander Oliva
autogenerated on Tue Mar 1 2022 00:03:22