| Directory: | ./ |
|---|---|
| File: | src/task/task.cpp |
| Date: | 2025-05-13 12:28:21 |
| Exec | Total | Coverage | |
|---|---|---|---|
| Lines: | 117 | 156 | 75.0% |
| Branches: | 114 | 268 | 42.5% |
| Line | Branch | Exec | Source |
|---|---|---|---|
| 1 | /* | ||
| 2 | * Copyright 2010, | ||
| 3 | * François Bleibel, | ||
| 4 | * Olivier Stasse, | ||
| 5 | * | ||
| 6 | * CNRS/AIST | ||
| 7 | * | ||
| 8 | */ | ||
| 9 | |||
| 10 | /* --------------------------------------------------------------------- */ | ||
| 11 | /* --- INCLUDE --------------------------------------------------------- */ | ||
| 12 | /* --------------------------------------------------------------------- */ | ||
| 13 | |||
| 14 | /* SOT */ | ||
| 15 | #include <dynamic-graph/all-commands.h> | ||
| 16 | |||
| 17 | #include <sot/core/debug.hh> | ||
| 18 | #include <sot/core/pool.hh> | ||
| 19 | #include <sot/core/task.hh> | ||
| 20 | |||
| 21 | #include "../src/task/task-command.h" | ||
| 22 | |||
| 23 | using namespace std; | ||
| 24 | using namespace dynamicgraph::sot; | ||
| 25 | using namespace dynamicgraph; | ||
| 26 | |||
| 27 | #include <sot/core/factory.hh> | ||
| 28 | ✗ | DYNAMICGRAPH_FACTORY_ENTITY_PLUGIN(Task, "Task"); | |
| 29 | |||
| 30 | /* --------------------------------------------------------------------- */ | ||
| 31 | /* --- CLASS ----------------------------------------------------------- */ | ||
| 32 | /* --------------------------------------------------------------------- */ | ||
| 33 | |||
| 34 | 8 | Task::Task(const std::string &n) | |
| 35 | : TaskAbstract(n), | ||
| 36 | 8 | featureList(), | |
| 37 | 8 | withDerivative(false), | |
| 38 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | controlGainSIN(NULL, "sotTask(" + n + ")::input(double)::controlGain"), |
| 39 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | dampingGainSINOUT(NULL, "sotTask(" + n + ")::in/output(double)::damping") |
| 40 | // TODO As far as I understand, this is not used in this class. | ||
| 41 | , | ||
| 42 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | controlSelectionSIN(NULL, |
| 43 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
16 | "sotTask(" + n + ")::input(flag)::controlSelec"), |
| 44 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | errorSOUT(boost::bind(&Task::computeError, this, _1, _2), sotNOSIGNAL, |
| 45 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
16 | "sotTask(" + n + ")::output(vector)::error"), |
| 46 |
4/8✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 8 times.
✗ Branch 11 not taken.
|
8 | errorTimeDerivativeSOUT( |
| 47 | boost::bind(&Task::computeErrorTimeDerivative, this, _1, _2), | ||
| 48 | errorSOUT, | ||
| 49 |
2/4✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 8 times.
✗ Branch 7 not taken.
|
24 | "sotTask(" + n + ")::output(vector)::errorTimeDerivative") { |
| 50 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | taskSOUT.setFunction( |
| 51 | boost::bind(&Task::computeTaskExponentialDecrease, this, _1, _2)); | ||
| 52 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | jacobianSOUT.setFunction(boost::bind(&Task::computeJacobian, this, _1, _2)); |
| 53 | |||
| 54 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | taskSOUT.addDependency(controlGainSIN); |
| 55 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | taskSOUT.addDependency(errorSOUT); |
| 56 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | taskSOUT.addDependency(errorTimeDerivativeSOUT); |
| 57 | |||
| 58 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | jacobianSOUT.addDependency(controlSelectionSIN); |
| 59 | |||
| 60 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
8 | controlSelectionSIN = true; |
| 61 | |||
| 62 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
16 | signalRegistration(controlGainSIN << dampingGainSINOUT << controlSelectionSIN |
| 63 |
3/6✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 8 times.
✗ Branch 8 not taken.
|
8 | << errorSOUT << errorTimeDerivativeSOUT); |
| 64 | |||
| 65 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | initCommands(); |
| 66 | 8 | } | |
| 67 | |||
| 68 | 8 | void Task::initCommands(void) { | |
| 69 | using namespace dynamicgraph::command; | ||
| 70 | // | ||
| 71 | // Commands | ||
| 72 | // | ||
| 73 | 8 | std::string docstring; | |
| 74 | // AddFeature | ||
| 75 | docstring = | ||
| 76 | " \n" | ||
| 77 | " Add a feature to the task\n" | ||
| 78 | " \n" | ||
| 79 | " Input:\n" | ||
| 80 | " - name of the feature\n" | ||
| 81 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | " \n"; |
| 82 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
8 | addCommand("add", |
| 83 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | makeCommandVoid1(*this, &Task::addFeatureFromName, docstring)); |
| 84 | |||
| 85 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
8 | addCommand("setWithDerivative", |
| 86 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | makeDirectSetter(*this, &withDerivative, |
| 87 |
3/6✓ Branch 2 taken 8 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 8 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 8 times.
✗ Branch 10 not taken.
|
16 | docDirectSetter("withDerivative", "bool"))); |
| 88 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
8 | addCommand("getWithDerivative", |
| 89 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | makeDirectGetter(*this, &withDerivative, |
| 90 |
3/6✓ Branch 2 taken 8 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 8 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 8 times.
✗ Branch 10 not taken.
|
16 | docDirectGetter("withDerivative", "bool"))); |
| 91 | // ClearFeatureList | ||
| 92 | docstring = | ||
| 93 | " \n" | ||
| 94 | " Clear the list of features of the task\n" | ||
| 95 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | " \n"; |
| 96 | |||
| 97 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
|
8 | addCommand("clear", |
| 98 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | makeCommandVoid0(*this, &Task::clearFeatureList, docstring)); |
| 99 | // List features | ||
| 100 | docstring = | ||
| 101 | " \n" | ||
| 102 | " Returns the list of features of the task\n" | ||
| 103 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | " \n"; |
| 104 | |||
| 105 |
4/8✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 8 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 8 times.
✗ Branch 12 not taken.
|
8 | addCommand("list", new command::task::ListFeatures(*this, docstring)); |
| 106 | 8 | } | |
| 107 | |||
| 108 | 9 | void Task::addFeature(FeatureAbstract &s) { | |
| 109 |
1/2✓ Branch 1 taken 9 times.
✗ Branch 2 not taken.
|
9 | featureList.push_back(&s); |
| 110 | 9 | jacobianSOUT.addDependency(s.jacobianSOUT); | |
| 111 | 9 | errorSOUT.addDependency(s.errorSOUT); | |
| 112 | 9 | errorTimeDerivativeSOUT.addDependency(s.getErrorDot()); | |
| 113 | 9 | } | |
| 114 | |||
| 115 | ✗ | void Task::addFeatureFromName(const std::string &featureName) { | |
| 116 | FeatureAbstract &feature = | ||
| 117 | ✗ | PoolStorage::getInstance()->getFeature(featureName); | |
| 118 | ✗ | addFeature(feature); | |
| 119 | } | ||
| 120 | |||
| 121 | ✗ | void Task::clearFeatureList(void) { | |
| 122 | ✗ | for (FeatureList_t::iterator iter = featureList.begin(); | |
| 123 | ✗ | iter != featureList.end(); ++iter) { | |
| 124 | ✗ | FeatureAbstract &s = **iter; | |
| 125 | ✗ | jacobianSOUT.removeDependency(s.jacobianSOUT); | |
| 126 | ✗ | errorSOUT.removeDependency(s.errorSOUT); | |
| 127 | ✗ | errorTimeDerivativeSOUT.removeDependency(s.getErrorDot()); | |
| 128 | } | ||
| 129 | |||
| 130 | ✗ | featureList.clear(); | |
| 131 | } | ||
| 132 | |||
| 133 | ✗ | void Task::setControlSelection(const Flags &act) { controlSelectionSIN = act; } | |
| 134 | ✗ | void Task::addControlSelection(const Flags &act) { | |
| 135 | ✗ | Flags fl = controlSelectionSIN.accessCopy(); | |
| 136 | ✗ | fl &= act; | |
| 137 | ✗ | controlSelectionSIN = fl; | |
| 138 | } | ||
| 139 | ✗ | void Task::clearControlSelection(void) { controlSelectionSIN = Flags(false); } | |
| 140 | |||
| 141 | 6 | void Task::setWithDerivative(const bool &s) { withDerivative = s; } | |
| 142 | ✗ | bool Task::getWithDerivative(void) { return withDerivative; } | |
| 143 | |||
| 144 | /* --- COMPUTATION ---------------------------------------------------------- */ | ||
| 145 | /* --- COMPUTATION ---------------------------------------------------------- */ | ||
| 146 | /* --- COMPUTATION ---------------------------------------------------------- */ | ||
| 147 | |||
| 148 | 606 | dynamicgraph::Vector &Task::computeError(dynamicgraph::Vector &error, | |
| 149 | int time) { | ||
| 150 | sotDEBUG(15) << "# In " << getName() << " {" << endl; | ||
| 151 | |||
| 152 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 606 times.
|
606 | if (featureList.empty()) { |
| 153 | ✗ | throw(ExceptionTask(ExceptionTask::EMPTY_LIST, "Empty feature list")); | |
| 154 | } | ||
| 155 | |||
| 156 | try { | ||
| 157 | /* The vector dimensions are not known before the affectation loop. | ||
| 158 | * They thus should be allocated on the flight, in the loop. | ||
| 159 | * The first assumption is that the size has not changed. A double | ||
| 160 | * reallocation (realloc(dim*2)) is done if necessary. In particulary, | ||
| 161 | * [log_2(dim)+1] reallocations are done for the first error computation. | ||
| 162 | * If the allocated size is too large, a correction is done after the loop. | ||
| 163 | * The algotithmic cost is linear in affectation, logarthmic in allocation | ||
| 164 | * numbers and linear in allocation size. | ||
| 165 | * No assumptions are made concerning size of each vector: they are | ||
| 166 | * not said equal, and could be different. | ||
| 167 | */ | ||
| 168 | |||
| 169 | /* First assumption: vector dimensions have not changed. If 0, they are | ||
| 170 | * initialized to dim 1.*/ | ||
| 171 | 606 | dynamicgraph::Vector::Index dimError = error.size(); | |
| 172 |
2/2✓ Branch 0 taken 12 times.
✓ Branch 1 taken 594 times.
|
606 | if (0 == dimError) { |
| 173 | 12 | dimError = 1; | |
| 174 |
1/2✓ Branch 1 taken 12 times.
✗ Branch 2 not taken.
|
12 | error.resize(dimError); |
| 175 |
1/2✓ Branch 1 taken 12 times.
✗ Branch 2 not taken.
|
12 | error.setZero(); |
| 176 | } | ||
| 177 | |||
| 178 |
1/2✓ Branch 1 taken 606 times.
✗ Branch 2 not taken.
|
606 | dynamicgraph::Vector vectTmp; |
| 179 | 606 | int cursorError = 0; | |
| 180 | |||
| 181 | /* For each cell of the list, recopy value of s, s_star and error. */ | ||
| 182 | 606 | for (FeatureList_t::iterator iter = featureList.begin(); | |
| 183 |
2/2✓ Branch 3 taken 606 times.
✓ Branch 4 taken 606 times.
|
1212 | iter != featureList.end(); ++iter) { |
| 184 | 606 | FeatureAbstract &feature = **iter; | |
| 185 | |||
| 186 | /* Get s, and store it in the s vector. */ | ||
| 187 | sotDEBUG(45) << "Feature <" << feature.getName() << ">." << std::endl; | ||
| 188 |
1/2✓ Branch 1 taken 606 times.
✗ Branch 2 not taken.
|
606 | const dynamicgraph::Vector &partialError = feature.errorSOUT(time); |
| 189 | |||
| 190 | 606 | const dynamicgraph::Vector::Index dim = partialError.size(); | |
| 191 |
2/2✓ Branch 0 taken 36 times.
✓ Branch 1 taken 606 times.
|
642 | while (cursorError + dim > dimError) // DEBUG It was >= |
| 192 | { | ||
| 193 | 36 | dimError *= 2; | |
| 194 |
1/2✓ Branch 1 taken 36 times.
✗ Branch 2 not taken.
|
36 | error.resize(dimError); |
| 195 |
1/2✓ Branch 1 taken 36 times.
✗ Branch 2 not taken.
|
36 | error.setZero(); |
| 196 | } | ||
| 197 | |||
| 198 |
2/2✓ Branch 0 taken 3636 times.
✓ Branch 1 taken 606 times.
|
4242 | for (int k = 0; k < dim; ++k) { |
| 199 |
2/4✓ Branch 1 taken 3636 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3636 times.
✗ Branch 5 not taken.
|
3636 | error(cursorError++) = partialError(k); |
| 200 | } | ||
| 201 | sotDEBUG(35) << "feature: " << partialError << std::endl; | ||
| 202 | sotDEBUG(35) << "error: " << error << std::endl; | ||
| 203 | } | ||
| 204 | |||
| 205 | /* If too much memory has been allocated, resize. */ | ||
| 206 |
1/2✓ Branch 1 taken 606 times.
✗ Branch 2 not taken.
|
606 | error.conservativeResize(cursorError); |
| 207 |
0/4✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
|
606 | } catch SOT_RETHROW; |
| 208 | |||
| 209 | sotDEBUG(35) << "error_final: " << error << std::endl; | ||
| 210 | sotDEBUG(15) << "# Out }" << endl; | ||
| 211 | 606 | return error; | |
| 212 | } | ||
| 213 | |||
| 214 | 126 | dynamicgraph::Vector &Task::computeErrorTimeDerivative( | |
| 215 | dynamicgraph::Vector &res, int time) { | ||
| 216 | 126 | res.resize(errorSOUT(time).size()); | |
| 217 | 126 | dynamicgraph::Vector::Index cursor = 0; | |
| 218 | |||
| 219 | 126 | for (FeatureList_t::iterator iter = featureList.begin(); | |
| 220 |
2/2✓ Branch 2 taken 126 times.
✓ Branch 3 taken 126 times.
|
252 | iter != featureList.end(); ++iter) { |
| 221 | 126 | FeatureAbstract &feature = **iter; | |
| 222 | |||
| 223 |
2/4✓ Branch 1 taken 126 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 126 times.
✗ Branch 5 not taken.
|
126 | const dynamicgraph::Vector &partialErrorDot = feature.getErrorDot()(time); |
| 224 | 126 | const dynamicgraph::Vector::Index dim = partialErrorDot.size(); | |
| 225 |
2/4✓ Branch 1 taken 126 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 126 times.
✗ Branch 5 not taken.
|
126 | res.segment(cursor, dim) = partialErrorDot; |
| 226 | 126 | cursor += dim; | |
| 227 | } | ||
| 228 | |||
| 229 | 126 | return res; | |
| 230 | } | ||
| 231 | |||
| 232 | 126 | VectorMultiBound &Task::computeTaskExponentialDecrease( | |
| 233 | VectorMultiBound &errorRef, int time) { | ||
| 234 | sotDEBUG(15) << "# In {" << endl; | ||
| 235 | 126 | const dynamicgraph::Vector &errSingleBound = errorSOUT(time); | |
| 236 | 126 | const double &gain = controlGainSIN(time); | |
| 237 | 126 | errorRef.resize(errSingleBound.size()); | |
| 238 | |||
| 239 |
2/2✓ Branch 1 taken 756 times.
✓ Branch 2 taken 126 times.
|
882 | for (unsigned int i = 0; i < errorRef.size(); ++i) |
| 240 | 756 | errorRef[i] = -errSingleBound(i) * gain; | |
| 241 | |||
| 242 |
1/2✓ Branch 0 taken 126 times.
✗ Branch 1 not taken.
|
126 | if (withDerivative) { |
| 243 | 126 | const dynamicgraph::Vector &de = errorTimeDerivativeSOUT(time); | |
| 244 |
2/2✓ Branch 1 taken 756 times.
✓ Branch 2 taken 126 times.
|
882 | for (unsigned int i = 0; i < errorRef.size(); ++i) |
| 245 | 756 | errorRef[i] = errorRef[i].getSingleBound() - de(i); | |
| 246 | } | ||
| 247 | |||
| 248 | sotDEBUG(15) << "# Out }" << endl; | ||
| 249 | 126 | return errorRef; | |
| 250 | } | ||
| 251 | |||
| 252 | 32 | dynamicgraph::Matrix &Task::computeJacobian(dynamicgraph::Matrix &J, int time) { | |
| 253 | sotDEBUG(15) << "# In {" << endl; | ||
| 254 | |||
| 255 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 32 times.
|
32 | if (featureList.empty()) { |
| 256 | ✗ | throw(ExceptionTask(ExceptionTask::EMPTY_LIST, "Empty feature list")); | |
| 257 | } | ||
| 258 | |||
| 259 | try { | ||
| 260 | 32 | dynamicgraph::Matrix::Index dimJ = J.rows(); | |
| 261 | 32 | dynamicgraph::Matrix::Index nbc = J.cols(); | |
| 262 |
2/2✓ Branch 0 taken 8 times.
✓ Branch 1 taken 24 times.
|
32 | if (0 == dimJ) { |
| 263 | 8 | dimJ = 1; | |
| 264 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | J.resize(dimJ, nbc); |
| 265 | } | ||
| 266 | |||
| 267 | 32 | dynamicgraph::Matrix::Index cursorJ = 0; | |
| 268 | // const Flags& selection = controlSelectionSIN(time); | ||
| 269 | |||
| 270 | /* For each cell of the list, recopy value of s, s_star and error. */ | ||
| 271 | 32 | for (FeatureList_t::iterator iter = featureList.begin(); | |
| 272 |
2/2✓ Branch 2 taken 32 times.
✓ Branch 3 taken 32 times.
|
64 | iter != featureList.end(); ++iter) { |
| 273 | 32 | FeatureAbstract &feature = **iter; | |
| 274 | sotDEBUG(25) << "Feature <" << feature.getName() << ">" << endl; | ||
| 275 | |||
| 276 | /* Get s, and store it in the s vector. */ | ||
| 277 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | const dynamicgraph::Matrix &partialJacobian = feature.jacobianSOUT(time); |
| 278 | 32 | const dynamicgraph::Matrix::Index nbr = partialJacobian.rows(); | |
| 279 | sotDEBUG(25) << "Jp =" << endl << partialJacobian << endl; | ||
| 280 | |||
| 281 |
2/2✓ Branch 0 taken 8 times.
✓ Branch 1 taken 24 times.
|
32 | if (0 == nbc) { |
| 282 | 8 | nbc = partialJacobian.cols(); | |
| 283 |
1/2✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
|
8 | J.resize(nbc, dimJ); |
| 284 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 24 times.
|
24 | } else if (partialJacobian.cols() != nbc) |
| 285 | ✗ | throw ExceptionTask( | |
| 286 | ✗ | ExceptionTask::NON_ADEQUATE_FEATURES, | |
| 287 | ✗ | "Features from the list don't have compatible-size jacobians."); | |
| 288 | |||
| 289 |
2/2✓ Branch 0 taken 48 times.
✓ Branch 1 taken 32 times.
|
80 | while (cursorJ + nbr >= dimJ) { |
| 290 | 48 | dimJ *= 2; | |
| 291 |
1/2✓ Branch 1 taken 48 times.
✗ Branch 2 not taken.
|
48 | J.conservativeResize(dimJ, nbc); |
| 292 | } | ||
| 293 | // TODO If controlSelectionSIN is really to be removed, | ||
| 294 | // then the following loop is equivalent to: | ||
| 295 | // J.middleRows (cursorJ, nbr) = partialJacobian; | ||
| 296 |
2/2✓ Branch 0 taken 1088 times.
✓ Branch 1 taken 32 times.
|
1120 | for (int kc = 0; kc < nbc; ++kc) { |
| 297 | // if( selection(kc) ) | ||
| 298 |
2/2✓ Branch 0 taken 6528 times.
✓ Branch 1 taken 1088 times.
|
7616 | for (unsigned int k = 0; k < nbr; ++k) { |
| 299 |
2/4✓ Branch 1 taken 6528 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 6528 times.
✗ Branch 5 not taken.
|
6528 | J(cursorJ + k, kc) = partialJacobian(k, kc); |
| 300 | } | ||
| 301 | // else | ||
| 302 | // for( unsigned int k=0;k<nbr;++k ) J(cursorJ+k,kc) = 0.; | ||
| 303 | } | ||
| 304 | 32 | cursorJ += nbr; | |
| 305 | } | ||
| 306 | |||
| 307 | /* If too much memory has been allocated, resize. */ | ||
| 308 |
1/2✓ Branch 1 taken 32 times.
✗ Branch 2 not taken.
|
32 | J.conservativeResize(cursorJ, nbc); |
| 309 | ✗ | } catch SOT_RETHROW; | |
| 310 | |||
| 311 | sotDEBUG(15) << "# Out }" << endl; | ||
| 312 | 32 | return J; | |
| 313 | } | ||
| 314 | |||
| 315 | /* --- DISPLAY ------------------------------------------------------------ */ | ||
| 316 | /* --- DISPLAY ------------------------------------------------------------ */ | ||
| 317 | /* --- DISPLAY ------------------------------------------------------------ */ | ||
| 318 | |||
| 319 | ✗ | void Task::display(std::ostream &os) const { | |
| 320 | ✗ | os << "Task " << name << ": " << endl; | |
| 321 | ✗ | os << "--- LIST --- " << std::endl; | |
| 322 | |||
| 323 | ✗ | for (FeatureList_t::const_iterator iter = featureList.begin(); | |
| 324 | ✗ | iter != featureList.end(); ++iter) { | |
| 325 | ✗ | os << "-> " << (*iter)->getName() << endl; | |
| 326 | } | ||
| 327 | } | ||
| 328 | |||
| 329 | ✗ | std::ostream &Task::writeGraph(std::ostream &os) const { | |
| 330 | ✗ | FeatureList_t::const_iterator itFeatureAbstract; | |
| 331 | ✗ | itFeatureAbstract = featureList.begin(); | |
| 332 | ✗ | while (itFeatureAbstract != featureList.end()) { | |
| 333 | ✗ | os << "\t\"" << (*itFeatureAbstract)->getName() << "\" -> \"" << getName() | |
| 334 | ✗ | << "\"" << endl; | |
| 335 | ✗ | itFeatureAbstract++; | |
| 336 | } | ||
| 337 | ✗ | return os; | |
| 338 | } | ||
| 339 |