Directory: | ./ |
---|---|
File: | src/path-projector/global.cc |
Date: | 2024-12-13 16:14:03 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 326 | 361 | 90.3% |
Branches: | 307 | 568 | 54.0% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | // Copyright (c) 2015, Joseph Mirabel | ||
2 | // Authors: Joseph Mirabel (joseph.mirabel@laas.fr) | ||
3 | // | ||
4 | |||
5 | // Redistribution and use in source and binary forms, with or without | ||
6 | // modification, are permitted provided that the following conditions are | ||
7 | // met: | ||
8 | // | ||
9 | // 1. Redistributions of source code must retain the above copyright | ||
10 | // notice, this list of conditions and the following disclaimer. | ||
11 | // | ||
12 | // 2. Redistributions in binary form must reproduce the above copyright | ||
13 | // notice, this list of conditions and the following disclaimer in the | ||
14 | // documentation and/or other materials provided with the distribution. | ||
15 | // | ||
16 | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
17 | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
18 | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||
19 | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||
20 | // HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||
21 | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||
22 | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
23 | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
24 | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
25 | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
26 | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH | ||
27 | // DAMAGE. | ||
28 | |||
29 | #include "hpp/core/path-projector/global.hh" | ||
30 | |||
31 | #include <hpp/constraints/solver/by-substitution.hh> | ||
32 | #include <hpp/core/config-projector.hh> | ||
33 | #include <hpp/core/interpolated-path.hh> | ||
34 | #include <hpp/core/path-vector.hh> | ||
35 | #include <hpp/core/problem.hh> | ||
36 | #include <hpp/core/steering-method.hh> | ||
37 | #include <hpp/core/steering-method/straight.hh> | ||
38 | #include <hpp/pinocchio/configuration.hh> | ||
39 | #include <hpp/pinocchio/liegroup.hh> | ||
40 | #include <hpp/util/debug.hh> | ||
41 | #include <hpp/util/timer.hh> | ||
42 | #include <limits> | ||
43 | #include <queue> | ||
44 | #include <stack> | ||
45 | |||
46 | namespace hpp { | ||
47 | namespace core { | ||
48 | namespace pathProjector { | ||
49 | namespace { | ||
50 | HPP_DEFINE_TIMECOUNTER(globalPathProjector_initCfgList); | ||
51 | HPP_DEFINE_TIMECOUNTER(globalPathProjector_projOneStep); | ||
52 | HPP_DEFINE_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
53 | HPP_DEFINE_TIMECOUNTER(globalPathProjector_createPath); | ||
54 | } // namespace | ||
55 | |||
56 | 4 | GlobalPtr_t Global::create(const DistancePtr_t& distance, | |
57 | const SteeringMethodPtr_t& steeringMethod, | ||
58 | value_type step) { | ||
59 | 4 | value_type hessianBound = steeringMethod->problem() | |
60 |
2/4✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
|
8 | ->getParameter("PathProjection/HessianBound") |
61 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | .floatValue(); |
62 | 4 | value_type thr_min = steeringMethod->problem() | |
63 |
2/4✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
|
8 | ->getParameter("PathProjection/MinimalDist") |
64 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
4 | .floatValue(); |
65 | hppDout(info, "Hessian bound is " << hessianBound); | ||
66 | hppDout(info, "Min Dist is " << thr_min); | ||
67 | return GlobalPtr_t( | ||
68 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
4 | new Global(distance, steeringMethod, step, thr_min, hessianBound)); |
69 | } | ||
70 | |||
71 | 4 | GlobalPtr_t Global::create(const ProblemConstPtr_t& problem, | |
72 | const value_type& step) { | ||
73 |
1/2✓ Branch 5 taken 4 times.
✗ Branch 6 not taken.
|
8 | return create(problem->distance(), problem->steeringMethod(), step); |
74 | } | ||
75 | |||
76 | 4 | Global::Global(const DistancePtr_t& distance, | |
77 | const SteeringMethodPtr_t& steeringMethod, value_type step, | ||
78 | 4 | value_type threshold, value_type hessianBound) | |
79 | : PathProjector(distance, steeringMethod), | ||
80 | 4 | step_(step), | |
81 | 4 | hessianBound_(hessianBound), | |
82 |
2/4✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 4 times.
✗ Branch 6 not taken.
|
4 | thresholdMin_(threshold) { |
83 | // TODO Only steeringMethod::Straight has been tested so far. | ||
84 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 4 times.
|
4 | assert(HPP_DYNAMIC_PTR_CAST(hpp::core::steeringMethod::Straight, |
85 | steeringMethod)); | ||
86 | 4 | } | |
87 | |||
88 | 64 | bool Global::impl_apply(const PathPtr_t& path, PathPtr_t& proj) const { | |
89 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 64 times.
|
64 | assert(path); |
90 | 64 | bool success = false; | |
91 | 64 | PathVectorPtr_t pv = HPP_DYNAMIC_PTR_CAST(PathVector, path); | |
92 |
1/2✓ Branch 1 taken 64 times.
✗ Branch 2 not taken.
|
64 | if (!pv) { |
93 |
4/10✓ Branch 3 taken 64 times.
✗ Branch 4 not taken.
✓ Branch 9 taken 64 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 64 times.
✗ Branch 13 not taken.
✗ Branch 15 not taken.
✓ Branch 16 taken 64 times.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
|
192 | if (!path->constraints() || !path->constraints()->configProjector() || |
94 |
5/12✓ Branch 4 taken 64 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 64 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 64 times.
✓ Branch 12 taken 64 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 64 times.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
|
128 | path->constraints()->configProjector()->dimension() == 0) { |
95 | ✗ | proj = path; | |
96 | ✗ | success = true; | |
97 | } else { | ||
98 |
2/2✓ Branch 0 taken 32 times.
✓ Branch 1 taken 32 times.
|
64 | if (hessianBound_ <= 0) |
99 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | success = project(path, proj); |
100 | else | ||
101 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | success = project2(path, proj); |
102 | } | ||
103 | } else { | ||
104 | PathVectorPtr_t res = | ||
105 | ✗ | PathVector::create(pv->outputSize(), pv->outputDerivativeSize()); | |
106 | ✗ | PathPtr_t part; | |
107 | ✗ | success = true; | |
108 | ✗ | for (size_t i = 0; i < pv->numberPaths(); i++) { | |
109 | ✗ | if (!apply(pv->pathAtRank(i), part)) { | |
110 | // We add the path only if part is not NULL and: | ||
111 | // - either its length is not zero, | ||
112 | // - or it's not the first one. | ||
113 | ✗ | if (part && (part->length() > 0 || i == 0)) { | |
114 | ✗ | res->appendPath(part); | |
115 | } | ||
116 | ✗ | success = false; | |
117 | ✗ | break; | |
118 | } | ||
119 | ✗ | res->appendPath(part); | |
120 | } | ||
121 | ✗ | proj = res; | |
122 | } | ||
123 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 64 times.
|
64 | assert(proj); |
124 |
5/10✓ Branch 2 taken 64 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 64 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 64 times.
✗ Branch 10 not taken.
✓ Branch 13 taken 64 times.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
✓ Branch 16 taken 64 times.
|
64 | assert((proj->initial() - path->initial()).isZero()); |
125 |
11/20✓ Branch 0 taken 26 times.
✓ Branch 1 taken 38 times.
✓ Branch 4 taken 26 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 26 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 26 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 26 times.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✓ Branch 18 taken 26 times.
✓ Branch 20 taken 26 times.
✓ Branch 21 taken 38 times.
✓ Branch 23 taken 26 times.
✓ Branch 24 taken 38 times.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
|
64 | assert(!success || (proj->end() - path->end()).isZero()); |
126 | 64 | return success; | |
127 | 64 | } | |
128 | |||
129 | 32 | bool Global::project(const PathPtr_t& path, PathPtr_t& proj) const { | |
130 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | Configs_t cfgs; |
131 |
1/2✓ Branch 4 taken 32 times.
✗ Branch 5 not taken.
|
32 | ConfigProjector& p = *path->constraints()->configProjector(); |
132 | HPP_START_TIMECOUNTER(globalPathProjector_initCfgList); | ||
133 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | initialConfigList(path, cfgs); |
134 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 32 times.
|
32 | if (cfgs.size() == 2) { // Shorter than step_ |
135 | ✗ | proj = path; | |
136 | ✗ | return true; | |
137 | } | ||
138 |
4/8✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 32 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 32 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 32 times.
|
32 | assert((cfgs.back() - path->end()).isZero()); |
139 | HPP_STOP_AND_DISPLAY_TIMECOUNTER(globalPathProjector_initCfgList); | ||
140 | |||
141 |
1/2✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
|
32 | Bools_t projected(cfgs.size() - 2, false); |
142 |
2/4✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 32 times.
✗ Branch 7 not taken.
|
32 | Alphas_t alphas(cfgs.size() - 2, LineSearch_t()); |
143 |
1/2✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
|
32 | Lengths_t lengths(cfgs.size() - 1, 0); |
144 | 32 | Configs_t::iterator last = --(cfgs.end()); | |
145 | |||
146 | 32 | std::size_t nbIter = 0; | |
147 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | const std::size_t maxIter = p.maxIterations(); |
148 |
1/2✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
|
32 | const std::size_t maxCfgNum = 2 + (std::size_t)(10 * path->length() / step_); |
149 | |||
150 | hppDout(info, "start with " << cfgs.size() << " configs"); | ||
151 |
3/4✓ Branch 1 taken 168 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 136 times.
✓ Branch 4 taken 32 times.
|
168 | while (!projectOneStep(p, cfgs, last, projected, lengths, alphas)) { |
152 |
4/8✓ Branch 2 taken 136 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 136 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 136 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 136 times.
|
136 | assert((cfgs.back() - path->end()).isZero()); |
153 |
1/2✓ Branch 1 taken 136 times.
✗ Branch 2 not taken.
|
136 | if (cfgs.size() < maxCfgNum) { |
154 |
1/2✓ Branch 1 taken 136 times.
✗ Branch 2 not taken.
|
136 | const size_type newCs = reinterpolate(p.robot(), cfgs, last, projected, |
155 | 136 | lengths, alphas, step_); | |
156 |
2/2✓ Branch 0 taken 32 times.
✓ Branch 1 taken 104 times.
|
136 | if (newCs > 0) { |
157 | 32 | nbIter = 0; | |
158 | hppDout(info, "Added " << newCs << " configs. Cur / Max = " | ||
159 | << cfgs.size() << '/' << maxCfgNum); | ||
160 | } else if (newCs < 0) { | ||
161 | hppDout(info, "Removed " << -newCs << " configs. Cur / Max = " | ||
162 | << cfgs.size() << '/' << maxCfgNum); | ||
163 | } | ||
164 | } | ||
165 | |||
166 | 136 | nbIter++; | |
167 | |||
168 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 136 times.
|
136 | if (nbIter > maxIter) break; |
169 | } | ||
170 | HPP_DISPLAY_TIMECOUNTER(globalPathProjector_projOneStep); | ||
171 | HPP_DISPLAY_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
172 | |||
173 | // Build the projection | ||
174 | HPP_START_TIMECOUNTER(globalPathProjector_createPath); | ||
175 |
1/2✓ Branch 4 taken 32 times.
✗ Branch 5 not taken.
|
32 | bool ret = createPath(p.robot(), path->constraints(), cfgs, last, projected, |
176 | lengths, proj); | ||
177 | HPP_STOP_AND_DISPLAY_TIMECOUNTER(globalPathProjector_createPath); | ||
178 | 32 | return ret; | |
179 | 32 | } | |
180 | |||
181 | 32 | bool Global::project2(const PathPtr_t& path, PathPtr_t& proj) const { | |
182 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | Configs_t cfgs; |
183 |
1/2✓ Branch 4 taken 32 times.
✗ Branch 5 not taken.
|
32 | ConfigProjector& p = *path->constraints()->configProjector(); |
184 |
2/4✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 32 times.
✗ Branch 7 not taken.
|
32 | q_.resize(p.robot()->configSize()); |
185 |
2/4✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 32 times.
✗ Branch 7 not taken.
|
32 | dq_.resize(p.robot()->numberDof()); |
186 | |||
187 | HPP_START_TIMECOUNTER(globalPathProjector_initCfgList); | ||
188 | |||
189 | 32 | Datas_t datas; | |
190 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | initialConfigList(path, p, datas); |
191 | 32 | Datas_t::iterator last = datas.end(); | |
192 |
1/2✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
|
32 | reinterpolate(p.robot(), p, datas, last); |
193 |
2/2✓ Branch 1 taken 14 times.
✓ Branch 2 taken 18 times.
|
32 | if (datas.size() == 2) { // Shorter than step_ |
194 | 14 | proj = path; | |
195 | #if HPP_ENABLE_BENCHMARK | ||
196 | hppBenchmark("Interpolated path (global - with hessian): " | ||
197 | << 0 << ", [ " << 0 << ", " << 0 << ", " << 0 << "]"); | ||
198 | #endif | ||
199 | 14 | return true; | |
200 | } | ||
201 |
4/8✓ Branch 2 taken 18 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 18 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 18 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 18 times.
|
18 | assert((datas.back().q - path->end()).isZero()); |
202 | HPP_STOP_AND_DISPLAY_TIMECOUNTER(globalPathProjector_initCfgList); | ||
203 | |||
204 | 18 | std::size_t nbIter = 0; | |
205 |
1/2✓ Branch 1 taken 18 times.
✗ Branch 2 not taken.
|
18 | const std::size_t maxIter = 2 * p.maxIterations(); |
206 |
1/2✓ Branch 2 taken 18 times.
✗ Branch 3 not taken.
|
18 | const std::size_t maxCfgNum = 2 + (std::size_t)(10 * path->length() / step_); |
207 | |||
208 | hppDout(info, "start with " << datas.size() << " configs"); | ||
209 | 18 | bool repeat = true; | |
210 |
2/2✓ Branch 0 taken 194 times.
✓ Branch 1 taken 18 times.
|
212 | while (repeat) { |
211 |
1/2✓ Branch 1 taken 194 times.
✗ Branch 2 not taken.
|
194 | repeat = !projectOneStep(p, datas, last); |
212 |
4/8✓ Branch 2 taken 194 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 194 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 194 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 194 times.
|
194 | assert((datas.back().q - path->end()).isZero()); |
213 |
2/6✗ Branch 1 not taken.
✓ Branch 2 taken 194 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 194 times.
✗ Branch 6 not taken.
|
194 | if (datas.size() < maxCfgNum || !repeat) { |
214 |
1/2✓ Branch 2 taken 194 times.
✗ Branch 3 not taken.
|
194 | const size_type newCs = reinterpolate(p.robot(), p, datas, last); |
215 |
2/2✓ Branch 0 taken 16 times.
✓ Branch 1 taken 178 times.
|
194 | if (newCs > 0) { |
216 | 16 | nbIter = 0; | |
217 | hppDout(info, "Added " << newCs << " configs. Cur / Max = " | ||
218 | << datas.size() << '/' << maxCfgNum); | ||
219 | 16 | repeat = true; | |
220 | } else if (newCs < 0) { | ||
221 | hppDout(info, "Removed " << -newCs << " configs. Cur / Max = " | ||
222 | << datas.size() << '/' << maxCfgNum); | ||
223 | } | ||
224 | } | ||
225 | |||
226 | 194 | nbIter++; | |
227 | |||
228 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 194 times.
|
194 | assert(datas.size() >= 2); |
229 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 194 times.
|
194 | if (nbIter > maxIter) break; |
230 | } | ||
231 | HPP_DISPLAY_TIMECOUNTER(globalPathProjector_projOneStep); | ||
232 | HPP_DISPLAY_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
233 | |||
234 | // Build the projection | ||
235 | HPP_START_TIMECOUNTER(globalPathProjector_createPath); | ||
236 |
1/2✓ Branch 4 taken 18 times.
✗ Branch 5 not taken.
|
18 | bool ret = createPath(p.robot(), path->constraints(), datas, last, proj); |
237 | HPP_STOP_AND_DISPLAY_TIMECOUNTER(globalPathProjector_createPath); | ||
238 | 18 | return ret; | |
239 | 32 | } | |
240 | |||
241 | 168 | bool Global::projectOneStep(ConfigProjector& p, Configs_t& q, | |
242 | Configs_t::iterator& last, Bools_t& b, Lengths_t& l, | ||
243 | Alphas_t& a) const { | ||
244 | HPP_START_TIMECOUNTER(globalPathProjector_projOneStep); | ||
245 | /// First and last should not be updated | ||
246 | 168 | const Configs_t::iterator begin = ++(q.begin()); | |
247 | 168 | const Configs_t::iterator end = --(q.end()); | |
248 | 168 | Bools_t ::iterator itB = (b.begin()); | |
249 | 168 | Alphas_t ::iterator itA = (a.begin()); | |
250 | 168 | Lengths_t::iterator itL = (l.begin()); | |
251 | 168 | Configs_t::iterator itCp = (q.begin()); | |
252 | 168 | bool allAreSatisfied = true; | |
253 | 168 | bool curUpdated = false, prevUpdated = false; | |
254 | /// Eigen matrices storage order defaults to column major. | ||
255 |
2/4✓ Branch 3 taken 168 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 168 times.
✗ Branch 7 not taken.
|
168 | Eigen::Matrix<value_type, Eigen::Dynamic, 2> oldQ(p.robot()->configSize(), 2); |
256 |
2/4✓ Branch 3 taken 168 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 168 times.
✗ Branch 7 not taken.
|
168 | Eigen::Matrix<value_type, Eigen::Dynamic, 2> dq(p.robot()->numberDof(), 2); |
257 |
1/2✓ Branch 1 taken 168 times.
✗ Branch 2 not taken.
|
168 | dq.setZero(); |
258 |
2/4✓ Branch 3 taken 168 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 168 times.
✗ Branch 7 not taken.
|
168 | vector_t qMinusQPrev(p.robot()->numberDof()); |
259 | 168 | size_type iCol = 0; | |
260 | 168 | size_type iNCol = (iCol + 1) % 2; | |
261 |
2/2✓ Branch 2 taken 4056 times.
✓ Branch 3 taken 148 times.
|
4204 | for (Configs_t::iterator it = begin; it != last; ++it) { |
262 |
2/2✓ Branch 2 taken 3402 times.
✓ Branch 3 taken 654 times.
|
4056 | if (!*itB) { |
263 |
2/4✓ Branch 2 taken 3402 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3402 times.
✗ Branch 6 not taken.
|
3402 | oldQ.col(iCol) = *it; |
264 |
2/4✓ Branch 4 taken 3402 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3402 times.
✗ Branch 8 not taken.
|
3402 | *itB = p.solver().oneStep(*it, *itA); |
265 |
2/4✓ Branch 3 taken 3402 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3402 times.
✗ Branch 7 not taken.
|
3402 | dq.col(iCol) = p.solver().lastStep(); |
266 | // *itA = alphaMax - 0.8 * (alphaMax - *itA); | ||
267 |
4/4✓ Branch 0 taken 762 times.
✓ Branch 1 taken 2640 times.
✓ Branch 4 taken 626 times.
✓ Branch 5 taken 136 times.
|
3402 | allAreSatisfied = allAreSatisfied && *itB; |
268 | 3402 | curUpdated = true; | |
269 |
2/2✓ Branch 0 taken 3206 times.
✓ Branch 1 taken 196 times.
|
3402 | if (prevUpdated) { |
270 | /// Detect large increase in size | ||
271 |
6/12✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3206 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3206 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 3206 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 3206 times.
✗ Branch 14 not taken.
✓ Branch 17 taken 3206 times.
✗ Branch 18 not taken.
|
3206 | hpp::pinocchio::difference(p.robot(), oldQ.col(iCol), oldQ.col(iNCol), |
272 | qMinusQPrev); | ||
273 |
4/8✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3206 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3206 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 3206 times.
✗ Branch 11 not taken.
|
3206 | const vector_t deltaDQ = dq.col(iCol) - dq.col(iNCol); |
274 |
1/2✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
|
3206 | const value_type N2 = qMinusQPrev.squaredNorm(); |
275 |
1/2✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
|
3206 | if (sqrt(N2) < Eigen::NumTraits<value_type>::dummy_precision()) { |
276 | hppDout(error, "The two config should be removed:" | ||
277 | << "\noldQ = " << oldQ.transpose() | ||
278 | << "\nqMinusQPrev = " << qMinusQPrev.transpose() | ||
279 | << "\nDistance is " | ||
280 | << d(oldQ.col(iCol), oldQ.col(iNCol)) | ||
281 | << "\nand in mem " << *itL); | ||
282 | } else { | ||
283 |
1/2✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
|
3206 | const value_type alphaSquare = 1 - 2 * qMinusQPrev.dot(deltaDQ) / N2 + |
284 |
1/2✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
|
3206 | qMinusQPrev.squaredNorm() / N2; |
285 | // alpha > 4 => the distance between the two points has been | ||
286 | // mutiplied by more than 4. | ||
287 |
2/2✓ Branch 0 taken 20 times.
✓ Branch 1 taken 3186 times.
|
3206 | if (alphaSquare > 16) { |
288 | hppDout(error, "alpha^2 = " | ||
289 | << alphaSquare | ||
290 | << "\nqMinusQPrev = " << qMinusQPrev.transpose() | ||
291 | << "\ndeltaDQ = " << deltaDQ.transpose()); | ||
292 | 20 | last = it; | |
293 | 20 | --last; | |
294 | 20 | return false; | |
295 | } | ||
296 | } | ||
297 | |||
298 | 3186 | const value_type limitCos = 0.5; | |
299 | vector_t dots = | ||
300 |
6/12✓ Branch 1 taken 3186 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3186 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3186 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 3186 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 3186 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 3186 times.
✗ Branch 17 not taken.
|
3186 | dq.colwise().normalized().transpose() * qMinusQPrev.normalized(); |
301 | // Check if both updates are pointing outward | ||
302 |
6/10✓ Branch 1 taken 3186 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 268 times.
✓ Branch 4 taken 2918 times.
✓ Branch 6 taken 268 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 268 times.
✗ Branch 10 not taken.
✓ Branch 11 taken 3186 times.
|
3186 | if (dots[iCol] > limitCos && dots[iNCol] < -limitCos) { |
303 | hppDout(error, "Descent step is going in opposite direction: " | ||
304 | << dots << ". It is likely a discontinuity."); | ||
305 | ✗ | last = it; | |
306 | ✗ | --last; | |
307 | ✗ | return false; | |
308 | } | ||
309 | 3186 | iNCol = iCol; | |
310 | 3186 | iCol = (iCol + 1) % 2; | |
311 |
3/4✓ Branch 1 taken 3186 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3186 times.
✓ Branch 5 taken 20 times.
|
3206 | } |
312 | } | ||
313 |
7/10✓ Branch 0 taken 790 times.
✓ Branch 1 taken 3246 times.
✓ Branch 2 taken 196 times.
✓ Branch 3 taken 594 times.
✓ Branch 6 taken 3442 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 3442 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 3442 times.
✗ Branch 14 not taken.
|
4036 | if (prevUpdated || curUpdated) *itL = d(*itCp, *it); |
314 | 4036 | prevUpdated = curUpdated; | |
315 | 4036 | curUpdated = false; | |
316 | 4036 | ++itCp; | |
317 | 4036 | ++itB; | |
318 | 4036 | ++itL; | |
319 | } | ||
320 |
5/8✓ Branch 0 taken 116 times.
✓ Branch 1 taken 32 times.
✓ Branch 4 taken 116 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 116 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 116 times.
✗ Branch 12 not taken.
|
148 | if (prevUpdated) *itL = d(*itCp, *end); |
321 | HPP_STOP_TIMECOUNTER(globalPathProjector_projOneStep); | ||
322 | 148 | return allAreSatisfied; | |
323 | 168 | } | |
324 | |||
325 | 194 | bool Global::projectOneStep(ConfigProjector& p, Datas_t& ds, | |
326 | const Datas_t::iterator& last) const { | ||
327 | HPP_START_TIMECOUNTER(globalPathProjector_projOneStep); | ||
328 | 194 | Datas_t::iterator _dPrev = ds.begin(); | |
329 | 194 | Datas_t::iterator _d = ++(ds.begin()); | |
330 | 194 | bool allAreSatisfied = true; | |
331 | 194 | bool curUpdated = false, prevUpdated = false; | |
332 | |||
333 |
2/2✓ Branch 2 taken 1994 times.
✓ Branch 3 taken 194 times.
|
2188 | for (; _d != last; ++_d) { |
334 |
2/2✓ Branch 1 taken 1778 times.
✓ Branch 2 taken 216 times.
|
1994 | if (!_d->projected) { |
335 |
2/4✓ Branch 4 taken 1778 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1778 times.
✗ Branch 8 not taken.
|
1778 | _d->projected = p.solver().oneStep(_d->q, _d->alpha); |
336 | // dq_ = p.solver().lastStep(); | ||
337 |
1/2✓ Branch 1 taken 1778 times.
✗ Branch 2 not taken.
|
1778 | _d->sigma = p.sigma(); |
338 | 1778 | ++_d->Niter; | |
339 |
4/4✓ Branch 0 taken 324 times.
✓ Branch 1 taken 1454 times.
✓ Branch 3 taken 148 times.
✓ Branch 4 taken 176 times.
|
1778 | allAreSatisfied = allAreSatisfied && _d->projected; |
340 | 1778 | curUpdated = true; | |
341 | } | ||
342 |
7/10✓ Branch 0 taken 408 times.
✓ Branch 1 taken 1586 times.
✓ Branch 2 taken 220 times.
✓ Branch 3 taken 188 times.
✓ Branch 6 taken 1806 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1806 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1806 times.
✗ Branch 14 not taken.
|
1994 | if (prevUpdated || curUpdated) _d->length = d(_dPrev->q, _d->q); |
343 | 1994 | prevUpdated = curUpdated; | |
344 | 1994 | curUpdated = false; | |
345 | 1994 | ++_dPrev; | |
346 | } | ||
347 |
5/8✓ Branch 0 taken 192 times.
✓ Branch 1 taken 2 times.
✓ Branch 4 taken 192 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 192 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 192 times.
✗ Branch 12 not taken.
|
194 | if (prevUpdated) _d->length = d(_dPrev->q, _d->q); |
348 | HPP_STOP_TIMECOUNTER(globalPathProjector_projOneStep); | ||
349 | 194 | return allAreSatisfied; | |
350 | } | ||
351 | |||
352 | 136 | size_type Global::reinterpolate(const DevicePtr_t& robot, Configs_t& q, | |
353 | const Configs_t::iterator& last, Bools_t& b, | ||
354 | Lengths_t& l, Alphas_t& a, | ||
355 | const value_type& maxDist) const { | ||
356 | HPP_START_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
357 | 136 | Configs_t::iterator begin = ++(q.begin()); | |
358 | 136 | Configs_t::iterator end = last; | |
359 | 136 | ++end; | |
360 | 136 | Bools_t ::iterator itB = (b.begin()); | |
361 | 136 | Alphas_t ::iterator itA = (a.begin()); | |
362 | 136 | Lengths_t::iterator itL = (l.begin()); | |
363 | 136 | Configs_t::iterator itCp = (q.begin()); | |
364 |
2/4✓ Branch 2 taken 136 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 136 times.
✗ Branch 6 not taken.
|
136 | Configuration_t newQ(robot->configSize()); |
365 | 136 | size_type nbNewC = 0; | |
366 |
2/2✓ Branch 2 taken 4146 times.
✓ Branch 3 taken 136 times.
|
4282 | for (Configs_t::iterator it = begin; it != last; ++it) { |
367 |
2/2✓ Branch 1 taken 472 times.
✓ Branch 2 taken 3674 times.
|
4146 | if (*itL > maxDist) { |
368 | 472 | ++nbNewC; | |
369 |
4/8✓ Branch 1 taken 472 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 472 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 472 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 472 times.
✗ Branch 12 not taken.
|
944 | pinocchio::interpolate<pinocchio::RnxSOnLieGroupMap>(robot, *itCp, *it, |
370 | 472 | 0.5, newQ); | |
371 | // FIXME: make sure the iterator are valid after insertion | ||
372 | // Insert new respective elements | ||
373 |
1/2✓ Branch 2 taken 472 times.
✗ Branch 3 not taken.
|
472 | it = q.insert(it, newQ); |
374 |
1/2✓ Branch 2 taken 472 times.
✗ Branch 3 not taken.
|
472 | itB = b.insert(itB, false); |
375 |
2/4✓ Branch 1 taken 472 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 472 times.
✗ Branch 6 not taken.
|
472 | itA = a.insert(itA, LineSearch_t()); |
376 |
4/8✓ Branch 2 taken 472 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 472 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 472 times.
✗ Branch 10 not taken.
✓ Branch 13 taken 472 times.
✗ Branch 14 not taken.
|
472 | itL = l.insert(itL, d(*itCp, *it)); |
377 | // Update length after | ||
378 | 472 | Configs_t::iterator itNC = it; | |
379 | 472 | ++itNC; | |
380 | 472 | Lengths_t::iterator itNL = itL; | |
381 | 472 | ++itNL; | |
382 |
3/6✓ Branch 2 taken 472 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 472 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 472 times.
✗ Branch 10 not taken.
|
472 | *itNL = d(*it, *itNC); |
383 | // FIXME: End has changed ? | ||
384 | 472 | end = q.end(); | |
385 | 472 | it = itCp; | |
386 | 472 | continue; | |
387 |
2/2✓ Branch 1 taken 28 times.
✓ Branch 2 taken 3646 times.
|
4146 | } else if (*itL < maxDist * 1e-2) { |
388 | 28 | nbNewC--; | |
389 | hppDout(warning, "Removing configuration: " << it->transpose() | ||
390 | << "\nToo close to: " | ||
391 | << itCp->transpose()); | ||
392 | // The distance to the previous point is very small. | ||
393 | // This point can safely be removed. | ||
394 | 28 | it = q.erase(it); | |
395 |
1/2✓ Branch 2 taken 28 times.
✗ Branch 3 not taken.
|
28 | itB = b.erase(itB); |
396 | 28 | itA = a.erase(itA); | |
397 | 28 | itL = l.erase(itL); | |
398 | // Update length | ||
399 |
3/6✓ Branch 2 taken 28 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 28 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 28 times.
✗ Branch 10 not taken.
|
28 | *itL = d(*itCp, *it); |
400 | 28 | it = itCp; | |
401 | 28 | continue; | |
402 | } | ||
403 | 3646 | ++itCp; | |
404 | 3646 | ++itB; | |
405 | 3646 | ++itA; | |
406 | 3646 | ++itL; | |
407 | } | ||
408 | HPP_STOP_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
409 | 136 | return nbNewC; | |
410 | 136 | } | |
411 | |||
412 | 226 | size_type Global::reinterpolate(const DevicePtr_t& robot, ConfigProjector& p, | |
413 | Datas_t& ds, Datas_t::iterator& last) const { | ||
414 | HPP_START_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
415 | 226 | Datas_t::iterator begin = ++(ds.begin()); | |
416 | 226 | Datas_t::iterator _dPrev = ds.begin(); | |
417 | 226 | size_type nbNewC = 0; | |
418 |
1/2✓ Branch 1 taken 226 times.
✗ Branch 2 not taken.
|
226 | Data newD; |
419 |
2/4✓ Branch 2 taken 226 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 226 times.
✗ Branch 6 not taken.
|
226 | newD.q.resize(robot->configSize()); |
420 |
1/2✓ Branch 1 taken 226 times.
✗ Branch 2 not taken.
|
226 | const std::size_t maxIter = p.maxIterations(); |
421 | 226 | const value_type K = hessianBound_, dist_min = thresholdMin_, | |
422 | 226 | sigma_min = dist_min * K; | |
423 |
2/2✓ Branch 2 taken 2216 times.
✓ Branch 3 taken 208 times.
|
2424 | for (Datas_t::iterator _d = begin; _d != last; ++_d) { |
424 |
5/6✓ Branch 1 taken 2198 times.
✓ Branch 2 taken 18 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2198 times.
✓ Branch 6 taken 18 times.
✓ Branch 7 taken 2198 times.
|
2216 | if (_dPrev->sigma < sigma_min || _dPrev->Niter >= maxIter) { |
425 | hppDout(info, "Rejected sigma " << _d->sigma); | ||
426 | 18 | last = _dPrev; | |
427 | 18 | break; | |
428 | } | ||
429 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 2198 times.
|
2198 | if (_d->sigma < sigma_min) { |
430 | hppDout(info, "Rejected sigma " << _d->sigma); | ||
431 | ✗ | last = _d; | |
432 | ✗ | break; | |
433 | } | ||
434 | 2198 | const value_type delta = _dPrev->sigma + _d->sigma; | |
435 |
2/2✓ Branch 1 taken 190 times.
✓ Branch 2 taken 2008 times.
|
2198 | if (_d->length > delta / K) { |
436 | 190 | ++nbNewC; | |
437 | // const value_type t = ( 1 + (_dPrev->sigma - _d->sigma) / (K * | ||
438 | // _d->length) ) / 2; | ||
439 | 190 | const value_type t = _dPrev->sigma / (K * _d->length); | |
440 |
2/4✓ Branch 0 taken 190 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 190 times.
✗ Branch 3 not taken.
|
190 | assert(t < 1 && t > 0); |
441 |
3/6✓ Branch 1 taken 190 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 190 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 190 times.
✗ Branch 9 not taken.
|
380 | pinocchio::interpolate<pinocchio::RnxSOnLieGroupMap>(robot, _dPrev->q, |
442 |
1/2✓ Branch 2 taken 190 times.
✗ Branch 3 not taken.
|
190 | _d->q, t, newD.q); |
443 | hppDout(info, "Add config " << newD.q.transpose()); | ||
444 | |||
445 | // Insert new respective elements | ||
446 |
1/2✓ Branch 2 taken 190 times.
✗ Branch 3 not taken.
|
190 | initData(newD, newD.q, p, true, false, _dPrev->q); |
447 |
1/2✓ Branch 2 taken 190 times.
✗ Branch 3 not taken.
|
190 | _d = ds.insert(_d, newD); |
448 | // Update length after | ||
449 | 190 | Datas_t::iterator _dNext = _d; | |
450 | 190 | ++_dNext; | |
451 |
3/6✓ Branch 2 taken 190 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 190 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 190 times.
✗ Branch 10 not taken.
|
190 | _dNext->length = d(_d->q, _dNext->q); |
452 | 190 | _dPrev = _d; | |
453 | 190 | continue; | |
454 | 190 | } | |
455 | 2008 | ++_dPrev; | |
456 | } | ||
457 | HPP_STOP_TIMECOUNTER(globalPathProjector_reinterpolate); | ||
458 | 226 | return nbNewC; | |
459 | 226 | } | |
460 | |||
461 | 32 | bool Global::createPath(const DevicePtr_t& robot, | |
462 | const ConstraintSetPtr_t& constraint, | ||
463 | const Configs_t& q, const Configs_t::iterator&, | ||
464 | const Bools_t& b, const Lengths_t& l, | ||
465 | PathPtr_t& result) const { | ||
466 | /// Compute total length | ||
467 | 32 | value_type length = 0; | |
468 | 32 | value_type min = std::numeric_limits<value_type>::max(), max = 0; | |
469 | 32 | size_type nbWaypoints = 0; | |
470 | 32 | Lengths_t::const_iterator itL = (l.begin()); | |
471 | 32 | Bools_t ::const_iterator itB = (b.begin()); | |
472 | 32 | Configs_t::const_iterator itCl = (q.begin()); | |
473 | 32 | bool fullyProjected = true; | |
474 |
2/2✓ Branch 3 taken 834 times.
✓ Branch 4 taken 12 times.
|
846 | for (; itB != b.end(); ++itB) { |
475 |
5/6✓ Branch 1 taken 814 times.
✓ Branch 2 taken 20 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 814 times.
✓ Branch 6 taken 20 times.
✓ Branch 7 taken 814 times.
|
834 | if (!*itB || *itL > step_) { |
476 | 20 | fullyProjected = false; | |
477 | 20 | break; | |
478 | } | ||
479 | 814 | length += *itL; | |
480 | |||
481 | 814 | ++nbWaypoints; | |
482 | 814 | min = std::min(min, *itL); | |
483 | 814 | max = std::max(max, *itL); | |
484 | |||
485 | 814 | ++itCl; | |
486 | 814 | ++itL; | |
487 | } | ||
488 |
2/2✓ Branch 0 taken 12 times.
✓ Branch 1 taken 20 times.
|
32 | if (fullyProjected) { |
489 | 12 | length += *itL; | |
490 | |||
491 | 12 | ++nbWaypoints; | |
492 | 12 | min = std::min(min, *itL); | |
493 | 12 | max = std::max(max, *itL); | |
494 | |||
495 | 12 | ++itCl; | |
496 | 12 | ++itL; | |
497 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 12 times.
|
12 | assert(itL == l.end()); |
498 | } | ||
499 | #if HPP_ENABLE_BENCHMARK | ||
500 | value_type avg = (nbWaypoints == 0 ? 0 : length / (value_type)nbWaypoints); | ||
501 | hppBenchmark("Interpolated path (global - non hessian): " | ||
502 | << nbWaypoints << ", [ " << min << ", " << avg << ", " << max | ||
503 | << "]"); | ||
504 | #endif | ||
505 | |||
506 | InterpolatedPathPtr_t out = | ||
507 |
3/6✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
✓ Branch 7 taken 32 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 32 times.
✗ Branch 11 not taken.
|
64 | InterpolatedPath::create(robot, q.front(), *itCl, length, constraint); |
508 | |||
509 |
2/2✓ Branch 2 taken 28 times.
✓ Branch 3 taken 4 times.
|
32 | if (itCl != q.begin()) { |
510 | 28 | length = 0; | |
511 | 28 | Lengths_t::const_iterator itL = (l.begin()); | |
512 | 28 | Configs_t::const_iterator begin = ++(q.begin()); | |
513 |
2/2✓ Branch 2 taken 798 times.
✓ Branch 3 taken 28 times.
|
826 | for (Configs_t::const_iterator it = begin; it != itCl; ++it) { |
514 | 798 | length += *itL; | |
515 |
2/4✓ Branch 3 taken 798 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 798 times.
✗ Branch 7 not taken.
|
798 | out->insert(length, *it); |
516 | 798 | ++itL; | |
517 | } | ||
518 | } else { | ||
519 | hppDout(info, "Path of length 0"); | ||
520 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 4 times.
|
4 | assert(!fullyProjected); |
521 | } | ||
522 | 32 | result = out; | |
523 | hppDout(info, "Projection succeeded ? " << fullyProjected); | ||
524 | 32 | return fullyProjected; | |
525 | 32 | } | |
526 | |||
527 | 18 | bool Global::createPath(const DevicePtr_t& robot, | |
528 | const ConstraintSetPtr_t& constraint, const Datas_t& ds, | ||
529 | const Datas_t::iterator& last, | ||
530 | PathPtr_t& result) const { | ||
531 | /// Compute total length | ||
532 | 18 | value_type length = 0; | |
533 | 18 | value_type min = std::numeric_limits<value_type>::max(), max = 0; | |
534 | 18 | size_type nbWaypoints = 0; | |
535 | 18 | const Datas_t::const_iterator begin = ++(ds.begin()); | |
536 | 18 | Datas_t::const_iterator _dLast = ds.begin(); | |
537 | 18 | bool fullyProjected = (last == ds.end()); | |
538 |
2/2✓ Branch 2 taken 172 times.
✓ Branch 3 taken 18 times.
|
190 | for (Datas_t::const_iterator _d = begin; _d != last; ++_d) { |
539 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 172 times.
|
172 | if (!_d->projected) { |
540 | ✗ | fullyProjected = false; | |
541 | ✗ | break; | |
542 | } | ||
543 | 172 | length += _d->length; | |
544 | 172 | ++_dLast; | |
545 | |||
546 | 172 | ++nbWaypoints; | |
547 | 172 | min = std::min(min, _d->length); | |
548 | 172 | max = std::max(max, _d->length); | |
549 | } | ||
550 | #if HPP_ENABLE_BENCHMARK | ||
551 | value_type avg = (nbWaypoints == 0 ? 0 : length / (value_type)nbWaypoints); | ||
552 | hppBenchmark("Interpolated path (global - with hessian): " | ||
553 | << nbWaypoints << ", [ " << min << ", " << avg << ", " << max | ||
554 | << "]"); | ||
555 | #endif | ||
556 | |||
557 | InterpolatedPathPtr_t out = InterpolatedPath::create( | ||
558 |
3/6✓ Branch 3 taken 18 times.
✗ Branch 4 not taken.
✓ Branch 7 taken 18 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 18 times.
✗ Branch 11 not taken.
|
36 | robot, ds.front().q, _dLast->q, length, constraint); |
559 | |||
560 |
2/2✓ Branch 2 taken 16 times.
✓ Branch 3 taken 2 times.
|
18 | if (_dLast != ds.begin()) { |
561 | 16 | length = 0; | |
562 |
2/2✓ Branch 1 taken 156 times.
✓ Branch 2 taken 16 times.
|
172 | for (Datas_t::const_iterator _d = begin; _d != _dLast; ++_d) { |
563 | 156 | length += _d->length; | |
564 |
2/4✓ Branch 3 taken 156 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 156 times.
✗ Branch 7 not taken.
|
156 | out->insert(length, _d->q); |
565 | } | ||
566 | } else { | ||
567 | hppDout(info, "Path of length 0"); | ||
568 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
|
2 | assert(!fullyProjected); |
569 | } | ||
570 | 18 | result = out; | |
571 | hppDout(info, "Projection succeeded ? " << fullyProjected); | ||
572 | 18 | return fullyProjected; | |
573 | 18 | } | |
574 | |||
575 | 32 | void Global::initialConfigList(const PathPtr_t& path, Configs_t& cfgs) const { | |
576 | 32 | InterpolatedPathPtr_t ip = HPP_DYNAMIC_PTR_CAST(InterpolatedPath, path); | |
577 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 32 times.
|
32 | if (ip) { |
578 | // Get the waypoint of ip | ||
579 | const InterpolatedPath::InterpolationPoints_t& ips = | ||
580 | ✗ | ip->interpolationPoints(); | |
581 | ✗ | for (InterpolatedPath::InterpolationPoints_t::const_iterator it = | |
582 | ✗ | ips.begin(); | |
583 | ✗ | it != ips.end(); ++it) { | |
584 | ✗ | cfgs.push_back(it->second); | |
585 | } | ||
586 | } else { | ||
587 |
1/2✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
|
32 | const value_type L = path->length(); |
588 |
1/2✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
|
32 | Configuration_t q(path->outputSize()); |
589 |
2/4✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 32 times.
✗ Branch 6 not taken.
|
32 | cfgs.push_back(path->initial()); |
590 | // Factor 0.99 is to ensure that the distance between two consecutives | ||
591 | // configurations will be smaller that step_ | ||
592 |
2/2✓ Branch 0 taken 660 times.
✓ Branch 1 taken 32 times.
|
692 | for (value_type t = step_; t < L; t += step_ * 0.99) { |
593 | // Interpolate without taking care of the constraints | ||
594 | // FIXME: Path must not be a PathVector otherwise the constraints | ||
595 | // are applied. | ||
596 |
2/4✓ Branch 2 taken 660 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 660 times.
✗ Branch 6 not taken.
|
660 | path->at(t, q); |
597 |
1/2✓ Branch 1 taken 660 times.
✗ Branch 2 not taken.
|
660 | cfgs.push_back(q); |
598 | } | ||
599 |
2/4✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 32 times.
✗ Branch 6 not taken.
|
32 | cfgs.push_back(path->end()); |
600 | 32 | } | |
601 | 32 | } | |
602 | |||
603 | 32 | void Global::initialConfigList(const PathPtr_t& path, ConfigProjector& p, | |
604 | Datas_t& ds) const { | ||
605 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | Data newD; |
606 | |||
607 | // Set initial point. | ||
608 |
3/6✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 32 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 32 times.
✗ Branch 9 not taken.
|
32 | initData(newD, path->initial(), p, true, true); |
609 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | ds.push_back(newD); |
610 | |||
611 | 32 | InterpolatedPathPtr_t ip = HPP_DYNAMIC_PTR_CAST(InterpolatedPath, path); | |
612 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 32 times.
|
32 | if (ip) { |
613 | // Get the waypoint of ip | ||
614 | const InterpolatedPath::InterpolationPoints_t& ips = | ||
615 | ✗ | ip->interpolationPoints(); | |
616 | InterpolatedPath::InterpolationPoints_t::const_iterator _ipPrev = | ||
617 | ✗ | ips.begin(); | |
618 | ✗ | for (InterpolatedPath::InterpolationPoints_t::const_iterator _ip = | |
619 | ✗ | ++(ips.begin()); | |
620 | ✗ | _ip != ips.end(); ++_ip) { | |
621 | ✗ | initData(newD, _ip->second, p, true, false, _ipPrev->second); | |
622 | ✗ | ds.push_back(newD); | |
623 | ✗ | ++_ipPrev; | |
624 | } | ||
625 | } else { | ||
626 |
3/6✓ Branch 2 taken 32 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 32 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 32 times.
✗ Branch 10 not taken.
|
32 | initData(newD, path->end(), p, true, true, path->initial()); |
627 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | ds.push_back(newD); |
628 | } | ||
629 | 32 | } | |
630 | |||
631 | 254 | void Global::initData(Data& data, const Configuration_t& q, ConfigProjector& p, | |
632 | bool computeSigma, bool projected, | ||
633 | const Configuration_t& qLength) const { | ||
634 | 254 | data.q = q; | |
635 |
1/2✓ Branch 0 taken 254 times.
✗ Branch 1 not taken.
|
254 | if (computeSigma) { |
636 |
1/2✓ Branch 1 taken 254 times.
✗ Branch 2 not taken.
|
254 | q_ = q; |
637 |
1/2✓ Branch 1 taken 254 times.
✗ Branch 2 not taken.
|
254 | LineSearch_t ls; |
638 |
2/4✓ Branch 2 taken 254 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 254 times.
✗ Branch 6 not taken.
|
254 | p.solver().oneStep(q_, ls); |
639 | // dq_ = p.solver().lastStep(); | ||
640 |
1/2✓ Branch 1 taken 254 times.
✗ Branch 2 not taken.
|
254 | data.sigma = p.sigma(); |
641 | } | ||
642 | 254 | data.projected = projected; | |
643 | 254 | data.alpha = LineSearch_t(); | |
644 | 254 | data.Niter = 0; | |
645 |
2/2✓ Branch 2 taken 222 times.
✓ Branch 3 taken 32 times.
|
254 | if (qLength.size() == q.size()) |
646 |
2/4✓ Branch 2 taken 222 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 222 times.
✗ Branch 6 not taken.
|
222 | data.length = d(qLength, q); |
647 | else | ||
648 | 32 | data.length = 0; | |
649 | 254 | } | |
650 | } // namespace pathProjector | ||
651 | } // namespace core | ||
652 | } // namespace hpp | ||
653 |