Directory: | ./ |
---|---|
File: | tests/features/test_feature_point6d.cpp |
Date: | 2025-01-13 12:33:34 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 127 | 135 | 94.1% |
Branches: | 120 | 252 | 47.6% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * Copyright 2019, | ||
3 | * François Bleibel, | ||
4 | * Olivier Stasse, | ||
5 | * | ||
6 | * CNRS/AIST | ||
7 | * | ||
8 | */ | ||
9 | |||
10 | /* -------------------------------------------------------------------------- */ | ||
11 | /* --- INCLUDES ------------------------------------------------------------- */ | ||
12 | /* -------------------------------------------------------------------------- */ | ||
13 | #include <dynamic-graph/linear-algebra.h> | ||
14 | |||
15 | #include <iostream> | ||
16 | #include <sot/core/debug.hh> | ||
17 | #include <sot/core/feature-abstract.hh> | ||
18 | #include <sot/core/feature-point6d.hh> | ||
19 | #include <sot/core/gain-adaptive.hh> | ||
20 | #include <sot/core/macros.hh> | ||
21 | #include <sot/core/sot.hh> | ||
22 | #include <sot/core/task.hh> | ||
23 | using namespace std; | ||
24 | using namespace dynamicgraph::sot; | ||
25 | |||
26 | class TestPoint6d { | ||
27 | public: | ||
28 | SOT_CORE_DISABLE_WARNING_PUSH | ||
29 | SOT_CORE_DISABLE_WARNING_DEPRECATED | ||
30 | FeaturePoint6d feature_, featureDes_; | ||
31 | SOT_CORE_DISABLE_WARNING_POP | ||
32 | Task task_; | ||
33 | int time_; | ||
34 | int dim_, robotDim_, featureDim_; | ||
35 | dynamicgraph::Vector manual_; | ||
36 | |||
37 | 1 | TestPoint6d(unsigned dim, std::string &name) | |
38 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | : feature_("feature" + name), |
39 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | featureDes_("featureDes" + name), |
40 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | task_("task" + name), |
41 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | time_(0) |
42 | |||
43 | { | ||
44 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | feature_.computationFrame("desired"); |
45 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | feature_.setReference(&featureDes_); |
46 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | feature_.selectionSIN = Flags(true); |
47 | |||
48 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | task_.addFeature(feature_); |
49 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | task_.setWithDerivative(true); |
50 | 1 | dim_ = dim; | |
51 | 1 | robotDim_ = featureDim_ = dim; | |
52 | |||
53 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | dynamicgraph::Matrix Jq(dim, dim); |
54 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | Jq.setIdentity(); |
55 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | feature_.articularJacobianSIN.setReference(&Jq); |
56 | |||
57 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | manual_.resize(dim); |
58 | 1 | } | |
59 | |||
60 | 4 | void setInputs(MatrixHomogeneous &s, MatrixHomogeneous &sd, | |
61 | dynamicgraph::Vector &vd, double gain) { | ||
62 | 4 | feature_.positionSIN = s; | |
63 | 4 | feature_.positionSIN.access(time_); | |
64 | 4 | feature_.positionSIN.setReady(); | |
65 | |||
66 | 4 | featureDes_.positionSIN = sd; | |
67 | 4 | featureDes_.positionSIN.access(time_); | |
68 | 4 | featureDes_.positionSIN.setReady(); | |
69 | |||
70 | 4 | featureDes_.velocitySIN = vd; | |
71 | 4 | featureDes_.velocitySIN.access(time_); | |
72 | 4 | featureDes_.velocitySIN.setReady(); | |
73 | |||
74 | 4 | task_.controlGainSIN = gain; | |
75 | 4 | task_.controlGainSIN.access(time_); | |
76 | 4 | task_.controlGainSIN.setReady(); | |
77 | 4 | } | |
78 | |||
79 | 4 | void printInputs() { | |
80 | 4 | std::cout << "----- inputs -----" << std::endl; | |
81 |
1/2✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | std::cout << "feature_.position: " << feature_.positionSIN(time_) |
82 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | << std::endl; |
83 |
1/2✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | std::cout << "featureDes_.position: " << featureDes_.positionSIN(time_) |
84 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | << std::endl; |
85 | 4 | std::cout << "featureDes_.velocity: " | |
86 |
2/4✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
|
4 | << featureDes_.velocitySIN(time_).transpose() << std::endl; |
87 | 4 | std::cout << "task.controlGain: " << task_.controlGainSIN(time_) | |
88 | 4 | << std::endl; | |
89 | 4 | } | |
90 | |||
91 | 4 | int recompute() { | |
92 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | feature_.errorSOUT.recompute(time_); |
93 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | feature_.errordotSOUT.recompute(time_); |
94 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | task_.taskSOUT.recompute(time_); |
95 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | task_.errorSOUT.recompute(time_); |
96 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | task_.errorTimeDerivativeSOUT.recompute(time_); |
97 | 4 | time_++; | |
98 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | MatrixHomogeneous s = feature_.positionSIN; |
99 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | MatrixHomogeneous sd = featureDes_.positionSIN; |
100 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | dynamicgraph::Vector vd = featureDes_.velocitySIN; |
101 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | double gain = task_.controlGainSIN; |
102 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | dynamicgraph::Vector manual; |
103 | const std::vector<dynamicgraph::sot::MultiBound> &taskTaskSOUT = | ||
104 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | task_.taskSOUT(time_); |
105 | |||
106 | /// Verify the computation of the desired frame. | ||
107 | /// -gain *(s-sd) - ([w]x (sd -s)-vd) | ||
108 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | dynamicgraph::Matrix aM; |
109 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | dynamicgraph::Vector aV; |
110 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | aM.resize(3, 3); |
111 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | aV.resize(3); |
112 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | aM(0, 0) = 0.0; |
113 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(0, 1) = -vd(5); |
114 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(0, 2) = vd(4); |
115 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(1, 0) = vd(5); |
116 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | aM(1, 1) = 0.0; |
117 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(1, 2) = -vd(3); |
118 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(2, 0) = -vd(4); |
119 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aM(2, 1) = vd(3); |
120 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | aM(2, 2) = 0.0; |
121 |
5/8✓ Branch 1 taken 12 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 12 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 12 times.
✗ Branch 8 not taken.
✓ Branch 9 taken 12 times.
✓ Branch 10 taken 4 times.
|
16 | for (unsigned int i = 0; i < 3; i++) aV(i) = sd(i, 3) - s(i, 3); |
122 | |||
123 |
2/4✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | aV = aM * aV; |
124 | |||
125 | /// Recompute error_th. | ||
126 |
2/2✓ Branch 0 taken 12 times.
✓ Branch 1 taken 4 times.
|
16 | for (unsigned int i = 0; i < 3; i++) { |
127 |
5/10✓ Branch 1 taken 12 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 12 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 12 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 12 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 12 times.
✗ Branch 14 not taken.
|
12 | manual_[i] = -gain * (s(i, 3) - sd(i, 3)) - (aV(i) - vd(i)); |
128 |
3/6✓ Branch 1 taken 12 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 12 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✓ Branch 8 taken 12 times.
|
12 | if (manual_[i] != taskTaskSOUT[i].getSingleBound()) return -1; |
129 | } | ||
130 | 4 | return 0; | |
131 | 4 | } | |
132 | |||
133 | 4 | void printOutput() { | |
134 | 4 | std::cout << "----- output -----" << std::endl; | |
135 | 4 | std::cout << "time: " << time_ << std::endl; | |
136 |
1/2✓ Branch 4 taken 4 times.
✗ Branch 5 not taken.
|
4 | std::cout << "feature.errorSOUT: " << feature_.errorSOUT(time_).transpose() |
137 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | << std::endl; |
138 | 4 | std::cout << "feature.errordotSOUT: " | |
139 |
2/4✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
|
4 | << feature_.errordotSOUT(time_).transpose() << std::endl; |
140 | 4 | std::cout << "task.taskSOUT: " << task_.taskSOUT(time_) << std::endl; | |
141 | // std::cout << "task.errorSOUT: " << task_.errorSOUT(time_) | ||
142 | //<< std::endl; | ||
143 | // std::cout << "task.errordtSOUT: " << task_.errorTimeDerivativeSOUT(time_) | ||
144 | //<< std::endl; | ||
145 |
2/4✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
|
4 | std::cout << "manual: " << manual_.transpose() << std::endl; |
146 | 4 | } | |
147 | |||
148 | 4 | int runTest(MatrixHomogeneous &s, MatrixHomogeneous &sd, | |
149 | dynamicgraph::Vector &vd, double gain) { | ||
150 | 4 | setInputs(s, sd, vd, gain); | |
151 | 4 | printInputs(); | |
152 | 4 | int r = recompute(); | |
153 | 4 | printOutput(); | |
154 | 4 | return r; | |
155 | } | ||
156 | }; | ||
157 | |||
158 | 1 | int main(void) { | |
159 | // Name of the robot | ||
160 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | std::string srobot("Robot"); |
161 | // Dimension of the robot. | ||
162 | 1 | unsigned int dim = 6; | |
163 | // Feature and Desired Feature | ||
164 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | MatrixHomogeneous s, sd; |
165 | // Desired velocity | ||
166 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | dynamicgraph::Vector vd(6); |
167 | // Task gain. | ||
168 | double gain; | ||
169 | // Result of test | ||
170 | int r; | ||
171 | |||
172 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | TestPoint6d testFeaturePoint6d(dim, srobot); |
173 | |||
174 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | std::cout << " ----- Test Velocity -----" << std::endl; |
175 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | s.setIdentity(); |
176 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | sd.setIdentity(); |
177 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | vd.setConstant(1.); |
178 | 1 | gain = 0.0; | |
179 | |||
180 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
|
1 | if ((r = testFeaturePoint6d.runTest(s, sd, vd, gain)) < 0) { |
181 | ✗ | std::cerr << "Failure on 1st test." << std::endl; | |
182 | ✗ | return r; | |
183 | } | ||
184 | |||
185 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | std::cout << " ----- Test Position -----" << std::endl; |
186 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | s.setIdentity(); |
187 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | sd.setIdentity(); |
188 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | sd.translation()[2] = 2.0; |
189 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | vd.setZero(); |
190 | 1 | gain = 1.0; | |
191 | |||
192 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
|
1 | if ((r = testFeaturePoint6d.runTest(s, sd, vd, gain)) < 0) { |
193 | ✗ | std::cerr << "Failure on 2nd test." << std::endl; | |
194 | ✗ | return r; | |
195 | } | ||
196 | |||
197 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | std::cout << " ----- Test both -----" << std::endl; |
198 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | s.setIdentity(); |
199 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | sd.setIdentity(); |
200 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | sd.translation()[2] = 2.0; |
201 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | vd.setConstant(1.); |
202 | 1 | gain = 3.0; | |
203 | |||
204 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
|
1 | if ((r = testFeaturePoint6d.runTest(s, sd, vd, gain)) < 0) { |
205 | ✗ | std::cerr << "Failure on 3th test." << std::endl; | |
206 | ✗ | return r; | |
207 | } | ||
208 | |||
209 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | std::cout << " ----- Test both again -----" << std::endl; |
210 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | s.setIdentity(); |
211 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | sd.setIdentity(); |
212 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | sd.translation()[2] = 2.0; |
213 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | vd.setConstant(1.); |
214 | 1 | gain = 3.0; | |
215 | |||
216 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
|
1 | if ((r = testFeaturePoint6d.runTest(s, sd, vd, gain)) < 0) { |
217 | ✗ | std::cerr << "Failure on 4th test." << std::endl; | |
218 | ✗ | return r; | |
219 | } | ||
220 | |||
221 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | std::cout << "Test successfull !" << std::endl; |
222 | 1 | return 0; | |
223 | 1 | } | |
224 |