Directory: | ./ |
---|---|
File: | src/math/op-point-modifier.cpp |
Date: | 2025-01-13 12:33:34 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 39 | 64 | 60.9% |
Branches: | 56 | 180 | 31.1% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * Copyright 2010, | ||
3 | * François Bleibel, | ||
4 | * Olivier Stasse, | ||
5 | * | ||
6 | * CNRS/AIST | ||
7 | * | ||
8 | */ | ||
9 | |||
10 | #include <dynamic-graph/all-commands.h> | ||
11 | #include <dynamic-graph/all-signals.h> | ||
12 | #include <dynamic-graph/factory.h> | ||
13 | |||
14 | #include <sot/core/matrix-geometry.hh> | ||
15 | #include <sot/core/op-point-modifier.hh> | ||
16 | |||
17 | using namespace std; | ||
18 | using namespace dynamicgraph::sot; | ||
19 | using namespace dynamicgraph; | ||
20 | |||
21 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | DYNAMICGRAPH_FACTORY_ENTITY_PLUGIN(OpPointModifier, "OpPointModifier"); |
22 | |||
23 | /* --------------------------------------------------------------------- */ | ||
24 | /* --------------------------------------------------------------------- */ | ||
25 | /* --------------------------------------------------------------------- */ | ||
26 | |||
27 | 4 | OpPointModifier::OpPointModifier(const std::string &name) | |
28 | : Entity(name), | ||
29 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | jacobianSIN(NULL, |
30 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | "OpPointModifior(" + name + ")::input(matrix)::jacobianIN"), |
31 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | positionSIN( |
32 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
8 | NULL, "OpPointModifior(" + name + ")::input(matrixhomo)::positionIN"), |
33 |
4/8✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 4 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 4 times.
✗ Branch 11 not taken.
|
4 | jacobianSOUT( |
34 | boost::bind(&OpPointModifier::jacobianSOUT_function, this, _1, _2), | ||
35 | jacobianSIN, | ||
36 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
8 | "OpPointModifior(" + name + ")::output(matrix)::jacobian"), |
37 |
4/8✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 4 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 4 times.
✗ Branch 11 not taken.
|
4 | positionSOUT( |
38 | boost::bind(&OpPointModifier::positionSOUT_function, this, _1, _2), | ||
39 | positionSIN, | ||
40 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
8 | "OpPointModifior(" + name + ")::output(matrixhomo)::position"), |
41 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | transformation(), |
42 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | isEndEffector(true) { |
43 | sotDEBUGIN(15); | ||
44 | |||
45 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
8 | signalRegistration(jacobianSIN << positionSIN << jacobianSOUT |
46 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | << positionSOUT); |
47 | { | ||
48 | using namespace dynamicgraph::command; | ||
49 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | addCommand( |
50 | "getTransformation", | ||
51 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | makeDirectGetter(*this, &transformation.matrix(), |
52 |
3/6✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 4 times.
✗ Branch 10 not taken.
|
8 | docDirectGetter("transformation", "matrix 4x4 homo"))); |
53 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | addCommand( |
54 | "setTransformation", | ||
55 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | makeDirectSetter(*this, &transformation.matrix(), |
56 |
3/6✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 4 times.
✗ Branch 10 not taken.
|
8 | docDirectSetter("dimension", "matrix 4x4 homo"))); |
57 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | addCommand("getEndEffector", |
58 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | makeDirectGetter(*this, &isEndEffector, |
59 |
3/6✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 4 times.
✗ Branch 10 not taken.
|
8 | docDirectGetter("end effector mode", "bool"))); |
60 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | addCommand("setEndEffector", |
61 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | makeDirectSetter(*this, &isEndEffector, |
62 |
3/6✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 4 times.
✗ Branch 10 not taken.
|
8 | docDirectSetter("end effector mode", "bool"))); |
63 | } | ||
64 | |||
65 | sotDEBUGOUT(15); | ||
66 | 4 | } | |
67 | |||
68 | 4 | dynamicgraph::Matrix &OpPointModifier::jacobianSOUT_function( | |
69 | dynamicgraph::Matrix &res, const int &iter) { | ||
70 |
1/2✓ Branch 0 taken 4 times.
✗ Branch 1 not taken.
|
4 | if (isEndEffector) { |
71 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | const dynamicgraph::Matrix &aJa = jacobianSIN(iter); |
72 | 4 | const MatrixHomogeneous &aMb = transformation; | |
73 | |||
74 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | MatrixTwist bVa; |
75 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | buildFrom(aMb.inverse(), bVa); |
76 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | res = bVa * aJa; // res := bJb |
77 | 4 | return res; | |
78 | } else { | ||
79 | /* Consider that the jacobian of point A in frame A is given: J = aJa | ||
80 | * and that homogenous transformation from A to B is given aMb in | ||
81 | * getTransfo() and homo transfo from 0 to A is given oMa in positionSIN. | ||
82 | * Then return oJb, the jacobian of point B expressed in frame O: | ||
83 | * oJb = ( oRa 0 ; 0 oRa ) * bVa * aJa | ||
84 | * = [ I skew(oAB); 0 I ] * oJa | ||
85 | * with oAB = oRb bAB = oRb (-bRa aAB ) = -oRa aAB, and aAB = | ||
86 | * translation(aMb). | ||
87 | */ | ||
88 | |||
89 | ✗ | const dynamicgraph::Matrix &oJa = jacobianSIN(iter); | |
90 | ✗ | const MatrixHomogeneous &aMb = transformation; | |
91 | ✗ | const MatrixHomogeneous &oMa = positionSIN(iter); | |
92 | ✗ | MatrixRotation oRa; | |
93 | ✗ | oRa = oMa.linear(); | |
94 | ✗ | dynamicgraph::Vector aAB(3); | |
95 | ✗ | aAB = aMb.translation(); | |
96 | ✗ | dynamicgraph::Vector oAB = oRa * aAB; | |
97 | |||
98 | ✗ | const dynamicgraph::Matrix::Index nq = oJa.cols(); | |
99 | ✗ | res.resize(6, oJa.cols()); | |
100 | ✗ | for (int j = 0; j < nq; ++j) { | |
101 | /* This is a I*Jtrans + skew*Jrot product, unrolled by hand ... */ | ||
102 | ✗ | res(0, j) = oJa(0, j) - oAB(1) * oJa(2 + 3, j) + oAB(2) * oJa(1 + 3, j); | |
103 | ✗ | res(1, j) = oJa(1, j) - oAB(2) * oJa(0 + 3, j) + oAB(0) * oJa(2 + 3, j); | |
104 | ✗ | res(2, j) = oJa(2, j) - oAB(0) * oJa(1 + 3, j) + oAB(1) * oJa(0 + 3, j); | |
105 | ✗ | for (int i = 0; i < 3; ++i) { | |
106 | ✗ | res(i + 3, j) = oJa(i + 3, j); | |
107 | } | ||
108 | } | ||
109 | ✗ | return res; // res := 0Jb | |
110 | } | ||
111 | } | ||
112 | |||
113 | 4 | MatrixHomogeneous &OpPointModifier::positionSOUT_function( | |
114 | MatrixHomogeneous &res, const int &iter) { | ||
115 | sotDEBUGIN(15); | ||
116 | sotDEBUGIN(15) << iter << " " << positionSIN.getTime() | ||
117 | << positionSOUT.getTime() << endl; | ||
118 | 4 | const MatrixHomogeneous &position = positionSIN(iter); | |
119 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | res = position * transformation; |
120 | sotDEBUGOUT(15); | ||
121 | 4 | return res; | |
122 | } | ||
123 | |||
124 | ✗ | void OpPointModifier::setTransformation(const Eigen::Matrix4d &tr) { | |
125 | ✗ | transformation.matrix() = tr; | |
126 | } | ||
127 | ✗ | const Eigen::Matrix4d &OpPointModifier::getTransformation(void) { | |
128 | ✗ | return transformation.matrix(); | |
129 | } | ||
130 | |||
131 | /* The following function needs an access to a specific signal via | ||
132 | * the pool, using the signal path <entity.signal>. this functionnality | ||
133 | * is deprecated, and the following function will have to be removed | ||
134 | * in a near future. A similar functionality is available using | ||
135 | * the <setTransformation> mthod, bound in python. | ||
136 | */ | ||
137 | #include <dynamic-graph/pool.h> | ||
138 | [[deprecated("use setTransformation")]] void | ||
139 | ✗ | OpPointModifier::setTransformationBySignalName(std::istringstream &cmdArgs) { | |
140 | Signal<Eigen::Matrix4d, int> &sig = | ||
141 | ✗ | dynamic_cast<Signal<Eigen::Matrix4d, int> &>( | |
142 | ✗ | PoolStorage::getInstance()->getSignal(cmdArgs)); | |
143 | ✗ | setTransformation(sig.accessCopy()); | |
144 | } | ||
145 |