Directory: | ./ |
---|---|
File: | tests/tsid-formulation.cpp |
Date: | 2025-01-10 01:13:27 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 380 | 409 | 92.9% |
Branches: | 1730 | 3802 | 45.5% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | // | ||
2 | // Copyright (c) 2017 CNRS, NYU, MPI Tübingen | ||
3 | // | ||
4 | // This file is part of tsid | ||
5 | // tsid is free software: you can redistribute it | ||
6 | // and/or modify it under the terms of the GNU Lesser General Public | ||
7 | // License as published by the Free Software Foundation, either version | ||
8 | // 3 of the License, or (at your option) any later version. | ||
9 | // tsid is distributed in the hope that it will be | ||
10 | // useful, but WITHOUT ANY WARRANTY; without even the implied warranty | ||
11 | // of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
12 | // General Lesser Public License for more details. You should have | ||
13 | // received a copy of the GNU Lesser General Public License along with | ||
14 | // tsid If not, see | ||
15 | // <http://www.gnu.org/licenses/>. | ||
16 | // | ||
17 | |||
18 | #include <iostream> | ||
19 | |||
20 | #include <boost/test/unit_test.hpp> | ||
21 | #include <boost/utility/binary.hpp> | ||
22 | |||
23 | #include <tsid/contacts/contact-6d.hpp> | ||
24 | #include <tsid/contacts/contact-point.hpp> | ||
25 | #include <tsid/formulations/inverse-dynamics-formulation-acc-force.hpp> | ||
26 | #include <tsid/tasks/task-com-equality.hpp> | ||
27 | #include <tsid/tasks/task-se3-equality.hpp> | ||
28 | #include <tsid/tasks/task-joint-posture.hpp> | ||
29 | #include <tsid/tasks/task-joint-bounds.hpp> | ||
30 | #include <tsid/trajectories/trajectory-euclidian.hpp> | ||
31 | #include <tsid/solvers/solver-HQP-factory.hxx> | ||
32 | #include <tsid/solvers/utils.hpp> | ||
33 | #include <tsid/utils/stop-watch.hpp> | ||
34 | #include <tsid/utils/statistics.hpp> | ||
35 | #include <tsid/math/utils.hpp> | ||
36 | |||
37 | #include <pinocchio/algorithm/joint-configuration.hpp> // integrate | ||
38 | #include <pinocchio/parsers/srdf.hpp> | ||
39 | |||
40 | using namespace tsid; | ||
41 | using namespace tsid::trajectories; | ||
42 | using namespace tsid::math; | ||
43 | using namespace tsid::contacts; | ||
44 | using namespace tsid::tasks; | ||
45 | using namespace tsid::solvers; | ||
46 | using namespace tsid::robots; | ||
47 | using namespace std; | ||
48 | |||
49 | #define REQUIRE_FINITE(A) BOOST_REQUIRE_MESSAGE(isFinite(A), #A << ": " << A) | ||
50 | #define CHECK_LESS_THAN(A, B) \ | ||
51 | BOOST_CHECK_MESSAGE(A < B, #A << ": " << A << ">" << B) | ||
52 | |||
53 | #define REQUIRE_TASK_FINITE(task) \ | ||
54 | REQUIRE_FINITE(task.getConstraint().matrix()); \ | ||
55 | REQUIRE_FINITE(task.getConstraint().vector()) | ||
56 | |||
57 | #define REQUIRE_CONTACT_FINITE(contact) \ | ||
58 | REQUIRE_FINITE(contact.getMotionConstraint().matrix()); \ | ||
59 | REQUIRE_FINITE(contact.getMotionConstraint().vector()); \ | ||
60 | REQUIRE_FINITE(contact.getForceConstraint().matrix()); \ | ||
61 | REQUIRE_FINITE(contact.getForceConstraint().lowerBound()); \ | ||
62 | REQUIRE_FINITE(contact.getForceConstraint().upperBound()); \ | ||
63 | REQUIRE_FINITE(contact.getForceRegularizationTask().matrix()); \ | ||
64 | REQUIRE_FINITE(contact.getForceRegularizationTask().vector()) | ||
65 | |||
66 | const string romeo_model_path = TSID_SOURCE_DIR "/models/romeo"; | ||
67 | const string quadruped_model_path = TSID_SOURCE_DIR "/models/quadruped"; | ||
68 | |||
69 | #ifndef NDEBUG | ||
70 | const int max_it = 10; | ||
71 | #else | ||
72 | const int max_it = 10; | ||
73 | #endif | ||
74 | |||
75 | BOOST_AUTO_TEST_SUITE(BOOST_TEST_MODULE) | ||
76 | |||
77 | class StandardRomeoInvDynCtrl { | ||
78 | public: | ||
79 | static const double lxp; | ||
80 | static const double lxn; | ||
81 | static const double lyp; | ||
82 | static const double lyn; | ||
83 | static const double lz; | ||
84 | static const double mu; | ||
85 | static const double fMin; | ||
86 | static const double fMax; | ||
87 | static const std::string rf_frame_name; | ||
88 | static const std::string lf_frame_name; | ||
89 | static const Vector3 contactNormal; | ||
90 | static const double w_com; | ||
91 | static const double w_posture; | ||
92 | static const double w_forceReg; | ||
93 | static const double kp_contact; | ||
94 | static const double kp_com; | ||
95 | static const double kp_posture; | ||
96 | double t; | ||
97 | |||
98 | std::shared_ptr<RobotWrapper> robot; | ||
99 | std::shared_ptr<InverseDynamicsFormulationAccForce> tsid; | ||
100 | std::shared_ptr<Contact6d> contactRF; | ||
101 | std::shared_ptr<Contact6d> contactLF; | ||
102 | std::shared_ptr<TaskComEquality> comTask; | ||
103 | std::shared_ptr<TaskJointPosture> postureTask; | ||
104 | std::shared_ptr<TaskJointBounds> jointBoundsTask; | ||
105 | Vector q; | ||
106 | Vector v; | ||
107 | pinocchio::SE3 H_rf_ref; | ||
108 | pinocchio::SE3 H_lf_ref; | ||
109 | |||
110 |
4/8✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 3 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 3 times.
✗ Branch 18 not taken.
|
3 | StandardRomeoInvDynCtrl(double dt) : t(0.) { |
111 | 3 | vector<string> package_dirs; | |
112 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
3 | package_dirs.push_back(romeo_model_path); |
113 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | const string urdfFileName = package_dirs[0] + "/urdf/romeo.urdf"; |
114 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
6 | robot = std::make_shared<RobotWrapper>(urdfFileName, package_dirs, |
115 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
6 | pinocchio::JointModelFreeFlyer()); |
116 | |||
117 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | const string srdfFileName = package_dirs[0] + "/srdf/romeo_collision.srdf"; |
118 | |||
119 |
2/4✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
|
3 | pinocchio::srdf::loadReferenceConfigurations(robot->model(), srdfFileName, |
120 | false); | ||
121 | |||
122 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | const unsigned int nv{static_cast<unsigned int>(robot->nv())}; |
123 |
2/4✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
|
3 | q = neutral(robot->model()); |
124 |
4/8✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 3 times.
✗ Branch 11 not taken.
|
3 | std::cout << "q: " << q.transpose() << std::endl; |
125 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
3 | q(2) += 0.84; |
126 |
2/4✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3 times.
✗ Branch 5 not taken.
|
3 | v = Vector::Zero(nv); |
127 |
8/16✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 3 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 3 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 3 times.
✗ Branch 25 not taken.
✗ Branch 29 not taken.
✓ Branch 30 taken 3 times.
|
3 | BOOST_REQUIRE(robot->model().existFrame(rf_frame_name)); |
128 |
8/16✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 3 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 3 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 3 times.
✗ Branch 25 not taken.
✗ Branch 29 not taken.
✓ Branch 30 taken 3 times.
|
3 | BOOST_REQUIRE(robot->model().existFrame(lf_frame_name)); |
129 | |||
130 | // Create the inverse-dynamics formulation | ||
131 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | tsid = std::make_shared<InverseDynamicsFormulationAccForce>("tsid", *robot); |
132 |
3/6✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
|
3 | tsid->computeProblemData(t, q, v); |
133 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | pinocchio::Data &data = tsid->data(); |
134 | |||
135 | // Add the contact constraints | ||
136 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
3 | Matrix3x contactPoints(3, 4); |
137 |
11/22✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 3 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 3 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 3 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 3 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 3 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 3 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 3 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 3 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 3 times.
✗ Branch 32 not taken.
|
6 | contactPoints << -lxn, -lxn, +lxp, +lxp, -lyn, +lyp, -lyn, +lyp, lz, lz, lz, |
138 |
1/2✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
|
3 | lz; |
139 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
6 | contactRF = std::make_shared<Contact6d>("contact_rfoot", *robot, |
140 | rf_frame_name, contactPoints, | ||
141 | 3 | contactNormal, mu, fMin, fMax); | |
142 |
4/8✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
|
3 | contactRF->Kp(kp_contact * Vector::Ones(6)); |
143 |
5/10✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
|
3 | contactRF->Kd(2.0 * contactRF->Kp().cwiseSqrt()); |
144 |
4/8✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
|
3 | H_rf_ref = robot->position(data, robot->model().getJointId(rf_frame_name)); |
145 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | contactRF->setReference(H_rf_ref); |
146 |
1/2✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
|
3 | tsid->addRigidContact(*contactRF, w_forceReg); |
147 | |||
148 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
6 | contactLF = std::make_shared<Contact6d>("contact_lfoot", *robot, |
149 | lf_frame_name, contactPoints, | ||
150 | 3 | contactNormal, mu, fMin, fMax); | |
151 |
4/8✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
|
3 | contactLF->Kp(kp_contact * Vector::Ones(6)); |
152 |
5/10✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
|
3 | contactLF->Kd(2.0 * contactLF->Kp().cwiseSqrt()); |
153 |
4/8✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
|
3 | H_lf_ref = robot->position(data, robot->model().getJointId(lf_frame_name)); |
154 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | contactLF->setReference(H_lf_ref); |
155 |
1/2✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
|
3 | tsid->addRigidContact(*contactLF, w_forceReg); |
156 | |||
157 | // Add the com task | ||
158 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | comTask = std::make_shared<TaskComEquality>("task-com", *robot); |
159 |
4/8✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
|
3 | comTask->Kp(kp_com * Vector::Ones(3)); |
160 |
5/10✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
|
3 | comTask->Kd(2.0 * comTask->Kp().cwiseSqrt()); |
161 |
1/2✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
|
3 | tsid->addMotionTask(*comTask, w_com, 1); |
162 | |||
163 | // Add the posture task | ||
164 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | postureTask = std::make_shared<TaskJointPosture>("task-posture", *robot); |
165 |
4/8✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
|
3 | postureTask->Kp(kp_posture * Vector::Ones(nv - 6)); |
166 |
5/10✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 3 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 3 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 3 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 3 times.
✗ Branch 16 not taken.
|
3 | postureTask->Kd(2.0 * postureTask->Kp().cwiseSqrt()); |
167 |
1/2✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
|
3 | tsid->addMotionTask(*postureTask, w_posture, 1); |
168 | |||
169 | // Add the joint bounds task | ||
170 | jointBoundsTask = | ||
171 |
1/2✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
|
3 | std::make_shared<TaskJointBounds>("task-joint-bounds", *robot, dt); |
172 |
4/8✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3 times.
✗ Branch 12 not taken.
|
3 | Vector dq_max = 10 * Vector::Ones(robot->na()); |
173 |
2/4✓ Branch 1 taken 3 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3 times.
✗ Branch 5 not taken.
|
3 | Vector dq_min = -dq_max; |
174 |
3/6✓ Branch 2 taken 3 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 3 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3 times.
✗ Branch 9 not taken.
|
3 | jointBoundsTask->setVelocityBounds(dq_min, dq_max); |
175 |
1/2✓ Branch 3 taken 3 times.
✗ Branch 4 not taken.
|
3 | tsid->addMotionTask(*jointBoundsTask, 1.0, 0); |
176 | 3 | } | |
177 | }; | ||
178 | |||
179 | const double StandardRomeoInvDynCtrl::lxp = 0.14; | ||
180 | const double StandardRomeoInvDynCtrl::lxn = 0.077; | ||
181 | const double StandardRomeoInvDynCtrl::lyp = 0.069; | ||
182 | const double StandardRomeoInvDynCtrl::lyn = 0.069; | ||
183 | const double StandardRomeoInvDynCtrl::lz = 0.105; | ||
184 | const double StandardRomeoInvDynCtrl::mu = 0.3; | ||
185 | const double StandardRomeoInvDynCtrl::fMin = 5.0; | ||
186 | const double StandardRomeoInvDynCtrl::fMax = 1000.0; | ||
187 | const std::string StandardRomeoInvDynCtrl::rf_frame_name = "RAnkleRoll"; | ||
188 | const std::string StandardRomeoInvDynCtrl::lf_frame_name = "LAnkleRoll"; | ||
189 | const Vector3 StandardRomeoInvDynCtrl::contactNormal = Vector3::UnitZ(); | ||
190 | const double StandardRomeoInvDynCtrl::w_com = 1.0; | ||
191 | const double StandardRomeoInvDynCtrl::w_posture = 1e-2; | ||
192 | const double StandardRomeoInvDynCtrl::w_forceReg = 1e-5; | ||
193 | const double StandardRomeoInvDynCtrl::kp_contact = 100.0; | ||
194 | const double StandardRomeoInvDynCtrl::kp_com = 30.0; | ||
195 | const double StandardRomeoInvDynCtrl::kp_posture = 30.0; | ||
196 | |||
197 |
33/66✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
✓ Branch 33 taken 1 times.
✗ Branch 34 not taken.
✓ Branch 36 taken 1 times.
✗ Branch 37 not taken.
✓ Branch 41 taken 1 times.
✗ Branch 42 not taken.
✓ Branch 45 taken 1 times.
✗ Branch 46 not taken.
✓ Branch 48 taken 1 times.
✗ Branch 49 not taken.
✓ Branch 52 taken 1 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 1 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 1 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 1 times.
✗ Branch 62 not taken.
✓ Branch 66 taken 1 times.
✗ Branch 67 not taken.
✓ Branch 70 taken 1 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 1 times.
✗ Branch 74 not taken.
✓ Branch 77 taken 1 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 1 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 1 times.
✗ Branch 84 not taken.
✓ Branch 86 taken 1 times.
✗ Branch 87 not taken.
✓ Branch 91 taken 1 times.
✗ Branch 92 not taken.
✓ Branch 95 taken 1 times.
✗ Branch 96 not taken.
✓ Branch 98 taken 1 times.
✗ Branch 99 not taken.
✓ Branch 102 taken 1 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 1 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 1 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 1 times.
✗ Branch 112 not taken.
✓ Branch 116 taken 1 times.
✗ Branch 117 not taken.
|
4 | BOOST_AUTO_TEST_CASE(test_invdyn_formulation_acc_force_remove_contact) { |
198 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n*** test_invdyn_formulation_acc_force_remove_contact ***\n"; |
199 | 2 | const double dt = 0.01; | |
200 | 2 | const unsigned int PRINT_N = 10; | |
201 | 2 | const unsigned int REMOVE_CONTACT_N = 100; | |
202 | 2 | const double CONTACT_TRANSITION_TIME = 1.0; | |
203 | 2 | const double kp_RF = 100.0; | |
204 | 2 | const double w_RF = 1e3; | |
205 | 2 | double t = 0.0; | |
206 | |||
207 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | StandardRomeoInvDynCtrl romeo_inv_dyn(dt); |
208 | 2 | RobotWrapper &robot = *(romeo_inv_dyn.robot); | |
209 | 2 | auto tsid = romeo_inv_dyn.tsid; | |
210 | 2 | Contact6d &contactRF = *(romeo_inv_dyn.contactRF); | |
211 | 2 | Contact6d &contactLF = *(romeo_inv_dyn.contactLF); | |
212 | 2 | TaskComEquality &comTask = *(romeo_inv_dyn.comTask); | |
213 | 2 | TaskJointPosture &postureTask = *(romeo_inv_dyn.postureTask); | |
214 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector q = romeo_inv_dyn.q; |
215 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector v = romeo_inv_dyn.v; |
216 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | const int nv = robot.model().nv; |
217 | |||
218 | // Add the right foot task | ||
219 | auto rightFootTask = std::make_shared<TaskSE3Equality>( | ||
220 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | "task-right-foot", robot, romeo_inv_dyn.rf_frame_name); |
221 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
|
2 | rightFootTask->Kp(kp_RF * Vector::Ones(6)); |
222 |
5/10✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
|
2 | rightFootTask->Kd(2.0 * rightFootTask->Kp().cwiseSqrt()); |
223 | 8 | pinocchio::SE3 H_rf_ref = robot.position( | |
224 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
|
2 | tsid->data(), robot.model().getJointId(romeo_inv_dyn.rf_frame_name)); |
225 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
2 | tsid->addMotionTask(*rightFootTask, w_RF, 1); |
226 | |||
227 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | rightFootTask->setReference(H_rf_ref); |
228 | |||
229 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
2 | Vector3 com_ref = robot.com(tsid->data()); |
230 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | com_ref(1) += 0.1; |
231 | auto trajCom = | ||
232 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_com", com_ref); |
233 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample sampleCom(3); |
234 | |||
235 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector q_ref = q.tail(nv - 6); |
236 | auto trajPosture = | ||
237 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_posture", q_ref); |
238 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample samplePosture(nv - 6); |
239 | |||
240 | // Create an HQP solver | ||
241 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPBase *solver = SolverHQPFactory::createNewSolver( |
242 | SOLVER_HQP_EIQUADPROG, "solver-eiquadprog"); | ||
243 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
|
2 | solver->resize(tsid->nVar(), tsid->nEq(), tsid->nIn()); |
244 | |||
245 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector tau_old(nv - 6); |
246 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 1 times.
|
22 | for (int i = 0; i < max_it; i++) { |
247 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
20 | if (i == REMOVE_CONTACT_N) { |
248 | ✗ | cout << "Start breaking contact right foot\n"; | |
249 | ✗ | tsid->removeRigidContact(contactRF.name(), CONTACT_TRANSITION_TIME); | |
250 | } | ||
251 | |||
252 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | sampleCom = trajCom->computeNext(); |
253 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | comTask.setReference(sampleCom); |
254 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | samplePosture = trajPosture->computeNext(); |
255 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | postureTask.setReference(samplePosture); |
256 | |||
257 |
3/6✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | const HQPData &HQPData = tsid->computeProblemData(t, q, v); |
258 |
5/8✓ Branch 0 taken 1 times.
✓ Branch 1 taken 9 times.
✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
20 | if (i == 0) cout << HQPDataToString(HQPData, false) << endl; |
259 | |||
260 |
26/52✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
|
20 | REQUIRE_TASK_FINITE(postureTask); |
261 |
26/52✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
|
20 | REQUIRE_TASK_FINITE(comTask); |
262 |
91/182✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
✓ Branch 93 taken 10 times.
✗ Branch 94 not taken.
✓ Branch 97 taken 10 times.
✗ Branch 98 not taken.
✓ Branch 102 taken 10 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 10 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 10 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 10 times.
✗ Branch 112 not taken.
✓ Branch 114 taken 10 times.
✗ Branch 115 not taken.
✓ Branch 117 taken 10 times.
✗ Branch 118 not taken.
✓ Branch 120 taken 10 times.
✗ Branch 121 not taken.
✓ Branch 123 taken 10 times.
✗ Branch 124 not taken.
✓ Branch 126 taken 10 times.
✗ Branch 127 not taken.
✓ Branch 129 taken 10 times.
✗ Branch 130 not taken.
✗ Branch 136 not taken.
✓ Branch 137 taken 10 times.
✓ Branch 139 taken 10 times.
✗ Branch 140 not taken.
✓ Branch 143 taken 10 times.
✗ Branch 144 not taken.
✓ Branch 148 taken 10 times.
✗ Branch 149 not taken.
✓ Branch 151 taken 10 times.
✗ Branch 152 not taken.
✓ Branch 154 taken 10 times.
✗ Branch 155 not taken.
✓ Branch 157 taken 10 times.
✗ Branch 158 not taken.
✓ Branch 160 taken 10 times.
✗ Branch 161 not taken.
✓ Branch 163 taken 10 times.
✗ Branch 164 not taken.
✓ Branch 166 taken 10 times.
✗ Branch 167 not taken.
✓ Branch 169 taken 10 times.
✗ Branch 170 not taken.
✓ Branch 172 taken 10 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 10 times.
✗ Branch 176 not taken.
✗ Branch 182 not taken.
✓ Branch 183 taken 10 times.
✓ Branch 185 taken 10 times.
✗ Branch 186 not taken.
✓ Branch 189 taken 10 times.
✗ Branch 190 not taken.
✓ Branch 194 taken 10 times.
✗ Branch 195 not taken.
✓ Branch 197 taken 10 times.
✗ Branch 198 not taken.
✓ Branch 200 taken 10 times.
✗ Branch 201 not taken.
✓ Branch 203 taken 10 times.
✗ Branch 204 not taken.
✓ Branch 206 taken 10 times.
✗ Branch 207 not taken.
✓ Branch 209 taken 10 times.
✗ Branch 210 not taken.
✓ Branch 212 taken 10 times.
✗ Branch 213 not taken.
✓ Branch 215 taken 10 times.
✗ Branch 216 not taken.
✓ Branch 218 taken 10 times.
✗ Branch 219 not taken.
✓ Branch 221 taken 10 times.
✗ Branch 222 not taken.
✗ Branch 228 not taken.
✓ Branch 229 taken 10 times.
✓ Branch 231 taken 10 times.
✗ Branch 232 not taken.
✓ Branch 235 taken 10 times.
✗ Branch 236 not taken.
✓ Branch 240 taken 10 times.
✗ Branch 241 not taken.
✓ Branch 243 taken 10 times.
✗ Branch 244 not taken.
✓ Branch 246 taken 10 times.
✗ Branch 247 not taken.
✓ Branch 249 taken 10 times.
✗ Branch 250 not taken.
✓ Branch 252 taken 10 times.
✗ Branch 253 not taken.
✓ Branch 255 taken 10 times.
✗ Branch 256 not taken.
✓ Branch 258 taken 10 times.
✗ Branch 259 not taken.
✓ Branch 261 taken 10 times.
✗ Branch 262 not taken.
✓ Branch 264 taken 10 times.
✗ Branch 265 not taken.
✓ Branch 267 taken 10 times.
✗ Branch 268 not taken.
✗ Branch 274 not taken.
✓ Branch 275 taken 10 times.
✓ Branch 277 taken 10 times.
✗ Branch 278 not taken.
✓ Branch 281 taken 10 times.
✗ Branch 282 not taken.
✓ Branch 286 taken 10 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 10 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 10 times.
✗ Branch 293 not taken.
✓ Branch 295 taken 10 times.
✗ Branch 296 not taken.
✓ Branch 298 taken 10 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 10 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 10 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 10 times.
✗ Branch 308 not taken.
✓ Branch 310 taken 10 times.
✗ Branch 311 not taken.
✓ Branch 313 taken 10 times.
✗ Branch 314 not taken.
✗ Branch 320 not taken.
✓ Branch 321 taken 10 times.
|
20 | REQUIRE_CONTACT_FINITE(contactRF); |
263 |
91/182✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
✓ Branch 93 taken 10 times.
✗ Branch 94 not taken.
✓ Branch 97 taken 10 times.
✗ Branch 98 not taken.
✓ Branch 102 taken 10 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 10 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 10 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 10 times.
✗ Branch 112 not taken.
✓ Branch 114 taken 10 times.
✗ Branch 115 not taken.
✓ Branch 117 taken 10 times.
✗ Branch 118 not taken.
✓ Branch 120 taken 10 times.
✗ Branch 121 not taken.
✓ Branch 123 taken 10 times.
✗ Branch 124 not taken.
✓ Branch 126 taken 10 times.
✗ Branch 127 not taken.
✓ Branch 129 taken 10 times.
✗ Branch 130 not taken.
✗ Branch 136 not taken.
✓ Branch 137 taken 10 times.
✓ Branch 139 taken 10 times.
✗ Branch 140 not taken.
✓ Branch 143 taken 10 times.
✗ Branch 144 not taken.
✓ Branch 148 taken 10 times.
✗ Branch 149 not taken.
✓ Branch 151 taken 10 times.
✗ Branch 152 not taken.
✓ Branch 154 taken 10 times.
✗ Branch 155 not taken.
✓ Branch 157 taken 10 times.
✗ Branch 158 not taken.
✓ Branch 160 taken 10 times.
✗ Branch 161 not taken.
✓ Branch 163 taken 10 times.
✗ Branch 164 not taken.
✓ Branch 166 taken 10 times.
✗ Branch 167 not taken.
✓ Branch 169 taken 10 times.
✗ Branch 170 not taken.
✓ Branch 172 taken 10 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 10 times.
✗ Branch 176 not taken.
✗ Branch 182 not taken.
✓ Branch 183 taken 10 times.
✓ Branch 185 taken 10 times.
✗ Branch 186 not taken.
✓ Branch 189 taken 10 times.
✗ Branch 190 not taken.
✓ Branch 194 taken 10 times.
✗ Branch 195 not taken.
✓ Branch 197 taken 10 times.
✗ Branch 198 not taken.
✓ Branch 200 taken 10 times.
✗ Branch 201 not taken.
✓ Branch 203 taken 10 times.
✗ Branch 204 not taken.
✓ Branch 206 taken 10 times.
✗ Branch 207 not taken.
✓ Branch 209 taken 10 times.
✗ Branch 210 not taken.
✓ Branch 212 taken 10 times.
✗ Branch 213 not taken.
✓ Branch 215 taken 10 times.
✗ Branch 216 not taken.
✓ Branch 218 taken 10 times.
✗ Branch 219 not taken.
✓ Branch 221 taken 10 times.
✗ Branch 222 not taken.
✗ Branch 228 not taken.
✓ Branch 229 taken 10 times.
✓ Branch 231 taken 10 times.
✗ Branch 232 not taken.
✓ Branch 235 taken 10 times.
✗ Branch 236 not taken.
✓ Branch 240 taken 10 times.
✗ Branch 241 not taken.
✓ Branch 243 taken 10 times.
✗ Branch 244 not taken.
✓ Branch 246 taken 10 times.
✗ Branch 247 not taken.
✓ Branch 249 taken 10 times.
✗ Branch 250 not taken.
✓ Branch 252 taken 10 times.
✗ Branch 253 not taken.
✓ Branch 255 taken 10 times.
✗ Branch 256 not taken.
✓ Branch 258 taken 10 times.
✗ Branch 259 not taken.
✓ Branch 261 taken 10 times.
✗ Branch 262 not taken.
✓ Branch 264 taken 10 times.
✗ Branch 265 not taken.
✓ Branch 267 taken 10 times.
✗ Branch 268 not taken.
✗ Branch 274 not taken.
✓ Branch 275 taken 10 times.
✓ Branch 277 taken 10 times.
✗ Branch 278 not taken.
✓ Branch 281 taken 10 times.
✗ Branch 282 not taken.
✓ Branch 286 taken 10 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 10 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 10 times.
✗ Branch 293 not taken.
✓ Branch 295 taken 10 times.
✗ Branch 296 not taken.
✓ Branch 298 taken 10 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 10 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 10 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 10 times.
✗ Branch 308 not taken.
✓ Branch 310 taken 10 times.
✗ Branch 311 not taken.
✓ Branch 313 taken 10 times.
✗ Branch 314 not taken.
✗ Branch 320 not taken.
✓ Branch 321 taken 10 times.
|
20 | REQUIRE_CONTACT_FINITE(contactLF); |
264 | |||
265 |
16/32✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 10 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 10 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 10 times.
✗ Branch 47 not taken.
✗ Branch 55 not taken.
✓ Branch 56 taken 10 times.
|
20 | CHECK_LESS_THAN(contactRF.getMotionTask().position_error().norm(), 1e-3); |
266 |
16/32✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 10 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 10 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 10 times.
✗ Branch 47 not taken.
✗ Branch 55 not taken.
✓ Branch 56 taken 10 times.
|
20 | CHECK_LESS_THAN(contactLF.getMotionTask().position_error().norm(), 1e-3); |
267 | |||
268 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | const HQPOutput &sol = solver->solve(HQPData); |
269 | |||
270 |
8/16✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✗ Branch 29 not taken.
✓ Branch 30 taken 10 times.
|
20 | BOOST_CHECK_MESSAGE(sol.status == HQP_STATUS_OPTIMAL, |
271 | "Status " + toString(sol.status)); | ||
272 | |||
273 |
1/2✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
|
20 | const Vector &tau = tsid->getActuatorForces(sol); |
274 |
1/2✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
|
20 | const Vector &dv = tsid->getAccelerations(sol); |
275 | |||
276 |
2/2✓ Branch 0 taken 9 times.
✓ Branch 1 taken 1 times.
|
20 | if (i > 0) { |
277 |
14/28✓ Branch 1 taken 9 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 9 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 9 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 9 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 9 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 9 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 9 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 9 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 9 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 9 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 9 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 9 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 9 times.
✗ Branch 41 not taken.
✗ Branch 49 not taken.
✓ Branch 50 taken 9 times.
|
18 | CHECK_LESS_THAN((tau - tau_old).norm(), 2e1); |
278 |
3/6✓ Branch 1 taken 9 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 9 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 9 times.
|
18 | if ((tau - tau_old).norm() > 2e1) // || (i>=197 && i<=200)) |
279 | { | ||
280 | // contactRF.computeMotionTask(t, q, v, tsid->data()); | ||
281 | // rightFootTask->compute(t, q, v, tsid->data()); | ||
282 | ✗ | cout << "Time " << i << endl; | |
283 | ✗ | cout << "tau:\n" | |
284 | ✗ | << tau.transpose() << "\ntauOld:\n" | |
285 | ✗ | << tau_old.transpose() << "\n"; | |
286 | // cout << "RF contact task des acc: | ||
287 | // "<<contactRF.getMotionTask().getDesiredAcceleration().transpose()<<endl; | ||
288 | // cout << "RF contact task acc: | ||
289 | // "<<contactRF.getMotionTask().getAcceleration(dv).transpose()<<endl; | ||
290 | // cout << "RF motion task des acc: | ||
291 | // "<<rightFootTask->getDesiredAcceleration().transpose()<<endl; | ||
292 | ✗ | cout << endl; | |
293 | } | ||
294 | } | ||
295 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | tau_old = tau; |
296 | |||
297 |
2/2✓ Branch 0 taken 1 times.
✓ Branch 1 taken 9 times.
|
20 | if (i % PRINT_N == 0) { |
298 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | cout << "Time " << i << endl; |
299 | |||
300 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Eigen::Matrix<double, 12, 1> f; |
301 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
|
2 | if (tsid->getContactForces(contactRF.name(), sol, f)) |
302 | 4 | cout << " " << contactRF.name() | |
303 |
8/16✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 1 times.
✗ Branch 23 not taken.
|
2 | << " force: " << contactRF.getNormalForce(f) << " \t"; |
304 | |||
305 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
|
2 | if (tsid->getContactForces(contactLF.name(), sol, f)) |
306 | 4 | cout << " " << contactLF.name() | |
307 |
8/16✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 1 times.
✗ Branch 23 not taken.
|
2 | << " force: " << contactLF.getNormalForce(f) << " \t"; |
308 | |||
309 |
6/12✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
|
2 | cout << comTask.name() << " err: " << comTask.position_error().norm() |
310 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << " \t"; |
311 |
7/14✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
|
2 | cout << "v=" << v.norm() << "\t dv=" << dv.norm() << endl; |
312 | } | ||
313 | |||
314 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | v += dt * dv; |
315 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
|
20 | q = pinocchio::integrate(robot.model(), q, dt * v); |
316 | 20 | t += dt; | |
317 | |||
318 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(dv.transpose()); |
319 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(v.transpose()); |
320 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(q.transpose()); |
321 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(dv.norm(), 1e6); |
322 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(v.norm(), 1e6); |
323 | } | ||
324 | |||
325 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver; |
326 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n### TEST FINISHED ###\n"; |
327 |
10/20✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 1 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 1 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 1 times.
✗ Branch 25 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
|
2 | PRINT_VECTOR(v); |
328 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
|
2 | cout << "Final CoM position: " << robot.com(tsid->data()).transpose() |
329 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << endl; |
330 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
|
2 | cout << "Desired CoM position: " << com_ref.transpose() << endl; |
331 | 2 | } | |
332 | |||
333 |
33/66✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
✓ Branch 33 taken 1 times.
✗ Branch 34 not taken.
✓ Branch 36 taken 1 times.
✗ Branch 37 not taken.
✓ Branch 41 taken 1 times.
✗ Branch 42 not taken.
✓ Branch 45 taken 1 times.
✗ Branch 46 not taken.
✓ Branch 48 taken 1 times.
✗ Branch 49 not taken.
✓ Branch 52 taken 1 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 1 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 1 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 1 times.
✗ Branch 62 not taken.
✓ Branch 66 taken 1 times.
✗ Branch 67 not taken.
✓ Branch 70 taken 1 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 1 times.
✗ Branch 74 not taken.
✓ Branch 77 taken 1 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 1 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 1 times.
✗ Branch 84 not taken.
✓ Branch 86 taken 1 times.
✗ Branch 87 not taken.
✓ Branch 91 taken 1 times.
✗ Branch 92 not taken.
✓ Branch 95 taken 1 times.
✗ Branch 96 not taken.
✓ Branch 98 taken 1 times.
✗ Branch 99 not taken.
✓ Branch 102 taken 1 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 1 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 1 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 1 times.
✗ Branch 112 not taken.
✓ Branch 116 taken 1 times.
✗ Branch 117 not taken.
|
4 | BOOST_AUTO_TEST_CASE(test_invdyn_formulation_acc_force) { |
334 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n*** test_invdyn_formulation_acc_force ***\n"; |
335 | |||
336 | 2 | const double dt = 0.001; | |
337 | 2 | const unsigned int PRINT_N = 100; | |
338 | 2 | double t = 0.0; | |
339 | |||
340 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | StandardRomeoInvDynCtrl romeo_inv_dyn(dt); |
341 | 2 | RobotWrapper &robot = *(romeo_inv_dyn.robot); | |
342 | 2 | auto tsid = romeo_inv_dyn.tsid; | |
343 | 2 | Contact6d &contactRF = *(romeo_inv_dyn.contactRF); | |
344 | 2 | Contact6d &contactLF = *(romeo_inv_dyn.contactLF); | |
345 | 2 | TaskComEquality &comTask = *(romeo_inv_dyn.comTask); | |
346 | 2 | TaskJointPosture &postureTask = *(romeo_inv_dyn.postureTask); | |
347 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector q = romeo_inv_dyn.q; |
348 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector v = romeo_inv_dyn.v; |
349 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | const int nv = robot.model().nv; |
350 | |||
351 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
2 | Vector3 com_ref = robot.com(tsid->data()); |
352 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | com_ref(1) += 0.1; |
353 | auto trajCom = | ||
354 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_com", com_ref); |
355 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample sampleCom(3); |
356 | |||
357 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector q_ref = q.tail(nv - 6); |
358 | auto trajPosture = | ||
359 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_posture", q_ref); |
360 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample samplePosture(nv - 6); |
361 | |||
362 | // Create an HQP solver | ||
363 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPBase *solver = SolverHQPFactory::createNewSolver( |
364 | SOLVER_HQP_EIQUADPROG, "solver-eiquadprog"); | ||
365 | |||
366 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
|
2 | solver->resize(tsid->nVar(), tsid->nEq(), tsid->nIn()); |
367 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
|
2 | cout << "nVar " << tsid->nVar() << endl; |
368 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
|
2 | cout << "nEq " << tsid->nEq() << endl; |
369 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
|
2 | cout << "nIn " << tsid->nIn() << endl; |
370 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
|
2 | cout << "Initial CoM position: " << robot.com(tsid->data()).transpose() |
371 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << endl; |
372 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | cout << "Initial RF position: " << romeo_inv_dyn.H_rf_ref << endl; |
373 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | cout << "Initial LF position: " << romeo_inv_dyn.H_lf_ref << endl; |
374 | |||
375 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector dv = Vector::Zero(nv); |
376 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | Vector f_RF(12), f_LF(12), f(24); |
377 | 2 | vector<ContactBase *> contacts; | |
378 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | contacts.push_back(&contactRF); |
379 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | contacts.push_back(&contactLF); |
380 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Matrix Jc(24, nv); |
381 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 1 times.
|
22 | for (int i = 0; i < max_it; i++) { |
382 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | sampleCom = trajCom->computeNext(); |
383 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | comTask.setReference(sampleCom); |
384 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | samplePosture = trajPosture->computeNext(); |
385 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | postureTask.setReference(samplePosture); |
386 | |||
387 |
3/6✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | const HQPData &HQPData = tsid->computeProblemData(t, q, v); |
388 |
5/8✓ Branch 0 taken 1 times.
✓ Branch 1 taken 9 times.
✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
20 | if (i == 0) cout << HQPDataToString(HQPData, false) << endl; |
389 | |||
390 |
26/52✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
|
20 | REQUIRE_TASK_FINITE(postureTask); |
391 |
26/52✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
|
20 | REQUIRE_TASK_FINITE(comTask); |
392 |
91/182✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
✓ Branch 93 taken 10 times.
✗ Branch 94 not taken.
✓ Branch 97 taken 10 times.
✗ Branch 98 not taken.
✓ Branch 102 taken 10 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 10 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 10 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 10 times.
✗ Branch 112 not taken.
✓ Branch 114 taken 10 times.
✗ Branch 115 not taken.
✓ Branch 117 taken 10 times.
✗ Branch 118 not taken.
✓ Branch 120 taken 10 times.
✗ Branch 121 not taken.
✓ Branch 123 taken 10 times.
✗ Branch 124 not taken.
✓ Branch 126 taken 10 times.
✗ Branch 127 not taken.
✓ Branch 129 taken 10 times.
✗ Branch 130 not taken.
✗ Branch 136 not taken.
✓ Branch 137 taken 10 times.
✓ Branch 139 taken 10 times.
✗ Branch 140 not taken.
✓ Branch 143 taken 10 times.
✗ Branch 144 not taken.
✓ Branch 148 taken 10 times.
✗ Branch 149 not taken.
✓ Branch 151 taken 10 times.
✗ Branch 152 not taken.
✓ Branch 154 taken 10 times.
✗ Branch 155 not taken.
✓ Branch 157 taken 10 times.
✗ Branch 158 not taken.
✓ Branch 160 taken 10 times.
✗ Branch 161 not taken.
✓ Branch 163 taken 10 times.
✗ Branch 164 not taken.
✓ Branch 166 taken 10 times.
✗ Branch 167 not taken.
✓ Branch 169 taken 10 times.
✗ Branch 170 not taken.
✓ Branch 172 taken 10 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 10 times.
✗ Branch 176 not taken.
✗ Branch 182 not taken.
✓ Branch 183 taken 10 times.
✓ Branch 185 taken 10 times.
✗ Branch 186 not taken.
✓ Branch 189 taken 10 times.
✗ Branch 190 not taken.
✓ Branch 194 taken 10 times.
✗ Branch 195 not taken.
✓ Branch 197 taken 10 times.
✗ Branch 198 not taken.
✓ Branch 200 taken 10 times.
✗ Branch 201 not taken.
✓ Branch 203 taken 10 times.
✗ Branch 204 not taken.
✓ Branch 206 taken 10 times.
✗ Branch 207 not taken.
✓ Branch 209 taken 10 times.
✗ Branch 210 not taken.
✓ Branch 212 taken 10 times.
✗ Branch 213 not taken.
✓ Branch 215 taken 10 times.
✗ Branch 216 not taken.
✓ Branch 218 taken 10 times.
✗ Branch 219 not taken.
✓ Branch 221 taken 10 times.
✗ Branch 222 not taken.
✗ Branch 228 not taken.
✓ Branch 229 taken 10 times.
✓ Branch 231 taken 10 times.
✗ Branch 232 not taken.
✓ Branch 235 taken 10 times.
✗ Branch 236 not taken.
✓ Branch 240 taken 10 times.
✗ Branch 241 not taken.
✓ Branch 243 taken 10 times.
✗ Branch 244 not taken.
✓ Branch 246 taken 10 times.
✗ Branch 247 not taken.
✓ Branch 249 taken 10 times.
✗ Branch 250 not taken.
✓ Branch 252 taken 10 times.
✗ Branch 253 not taken.
✓ Branch 255 taken 10 times.
✗ Branch 256 not taken.
✓ Branch 258 taken 10 times.
✗ Branch 259 not taken.
✓ Branch 261 taken 10 times.
✗ Branch 262 not taken.
✓ Branch 264 taken 10 times.
✗ Branch 265 not taken.
✓ Branch 267 taken 10 times.
✗ Branch 268 not taken.
✗ Branch 274 not taken.
✓ Branch 275 taken 10 times.
✓ Branch 277 taken 10 times.
✗ Branch 278 not taken.
✓ Branch 281 taken 10 times.
✗ Branch 282 not taken.
✓ Branch 286 taken 10 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 10 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 10 times.
✗ Branch 293 not taken.
✓ Branch 295 taken 10 times.
✗ Branch 296 not taken.
✓ Branch 298 taken 10 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 10 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 10 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 10 times.
✗ Branch 308 not taken.
✓ Branch 310 taken 10 times.
✗ Branch 311 not taken.
✓ Branch 313 taken 10 times.
✗ Branch 314 not taken.
✗ Branch 320 not taken.
✓ Branch 321 taken 10 times.
|
20 | REQUIRE_CONTACT_FINITE(contactRF); |
393 |
91/182✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 10 times.
✓ Branch 47 taken 10 times.
✗ Branch 48 not taken.
✓ Branch 51 taken 10 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 10 times.
✗ Branch 57 not taken.
✓ Branch 59 taken 10 times.
✗ Branch 60 not taken.
✓ Branch 62 taken 10 times.
✗ Branch 63 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 10 times.
✗ Branch 75 not taken.
✓ Branch 77 taken 10 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 10 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 10 times.
✗ Branch 84 not taken.
✗ Branch 90 not taken.
✓ Branch 91 taken 10 times.
✓ Branch 93 taken 10 times.
✗ Branch 94 not taken.
✓ Branch 97 taken 10 times.
✗ Branch 98 not taken.
✓ Branch 102 taken 10 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 10 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 10 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 10 times.
✗ Branch 112 not taken.
✓ Branch 114 taken 10 times.
✗ Branch 115 not taken.
✓ Branch 117 taken 10 times.
✗ Branch 118 not taken.
✓ Branch 120 taken 10 times.
✗ Branch 121 not taken.
✓ Branch 123 taken 10 times.
✗ Branch 124 not taken.
✓ Branch 126 taken 10 times.
✗ Branch 127 not taken.
✓ Branch 129 taken 10 times.
✗ Branch 130 not taken.
✗ Branch 136 not taken.
✓ Branch 137 taken 10 times.
✓ Branch 139 taken 10 times.
✗ Branch 140 not taken.
✓ Branch 143 taken 10 times.
✗ Branch 144 not taken.
✓ Branch 148 taken 10 times.
✗ Branch 149 not taken.
✓ Branch 151 taken 10 times.
✗ Branch 152 not taken.
✓ Branch 154 taken 10 times.
✗ Branch 155 not taken.
✓ Branch 157 taken 10 times.
✗ Branch 158 not taken.
✓ Branch 160 taken 10 times.
✗ Branch 161 not taken.
✓ Branch 163 taken 10 times.
✗ Branch 164 not taken.
✓ Branch 166 taken 10 times.
✗ Branch 167 not taken.
✓ Branch 169 taken 10 times.
✗ Branch 170 not taken.
✓ Branch 172 taken 10 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 10 times.
✗ Branch 176 not taken.
✗ Branch 182 not taken.
✓ Branch 183 taken 10 times.
✓ Branch 185 taken 10 times.
✗ Branch 186 not taken.
✓ Branch 189 taken 10 times.
✗ Branch 190 not taken.
✓ Branch 194 taken 10 times.
✗ Branch 195 not taken.
✓ Branch 197 taken 10 times.
✗ Branch 198 not taken.
✓ Branch 200 taken 10 times.
✗ Branch 201 not taken.
✓ Branch 203 taken 10 times.
✗ Branch 204 not taken.
✓ Branch 206 taken 10 times.
✗ Branch 207 not taken.
✓ Branch 209 taken 10 times.
✗ Branch 210 not taken.
✓ Branch 212 taken 10 times.
✗ Branch 213 not taken.
✓ Branch 215 taken 10 times.
✗ Branch 216 not taken.
✓ Branch 218 taken 10 times.
✗ Branch 219 not taken.
✓ Branch 221 taken 10 times.
✗ Branch 222 not taken.
✗ Branch 228 not taken.
✓ Branch 229 taken 10 times.
✓ Branch 231 taken 10 times.
✗ Branch 232 not taken.
✓ Branch 235 taken 10 times.
✗ Branch 236 not taken.
✓ Branch 240 taken 10 times.
✗ Branch 241 not taken.
✓ Branch 243 taken 10 times.
✗ Branch 244 not taken.
✓ Branch 246 taken 10 times.
✗ Branch 247 not taken.
✓ Branch 249 taken 10 times.
✗ Branch 250 not taken.
✓ Branch 252 taken 10 times.
✗ Branch 253 not taken.
✓ Branch 255 taken 10 times.
✗ Branch 256 not taken.
✓ Branch 258 taken 10 times.
✗ Branch 259 not taken.
✓ Branch 261 taken 10 times.
✗ Branch 262 not taken.
✓ Branch 264 taken 10 times.
✗ Branch 265 not taken.
✓ Branch 267 taken 10 times.
✗ Branch 268 not taken.
✗ Branch 274 not taken.
✓ Branch 275 taken 10 times.
✓ Branch 277 taken 10 times.
✗ Branch 278 not taken.
✓ Branch 281 taken 10 times.
✗ Branch 282 not taken.
✓ Branch 286 taken 10 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 10 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 10 times.
✗ Branch 293 not taken.
✓ Branch 295 taken 10 times.
✗ Branch 296 not taken.
✓ Branch 298 taken 10 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 10 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 10 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 10 times.
✗ Branch 308 not taken.
✓ Branch 310 taken 10 times.
✗ Branch 311 not taken.
✓ Branch 313 taken 10 times.
✗ Branch 314 not taken.
✗ Branch 320 not taken.
✓ Branch 321 taken 10 times.
|
20 | REQUIRE_CONTACT_FINITE(contactLF); |
394 | |||
395 |
16/32✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 10 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 10 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 10 times.
✗ Branch 47 not taken.
✗ Branch 55 not taken.
✓ Branch 56 taken 10 times.
|
20 | CHECK_LESS_THAN(contactRF.getMotionTask().position_error().norm(), 1e-3); |
396 |
16/32✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 10 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 10 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 10 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 10 times.
✗ Branch 47 not taken.
✗ Branch 55 not taken.
✓ Branch 56 taken 10 times.
|
20 | CHECK_LESS_THAN(contactLF.getMotionTask().position_error().norm(), 1e-3); |
397 | |||
398 |
4/8✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 10 times.
|
20 | if (contactRF.getMotionTask().position_error().norm() > 1e-2) { |
399 | ✗ | PRINT_VECTOR(v); | |
400 | ✗ | PRINT_VECTOR(dv); | |
401 | ✗ | Vector rf_pos = contactRF.getMotionTask().position(); | |
402 | ✗ | Vector rf_pos_ref = contactRF.getMotionTask().position_ref(); | |
403 | ✗ | pinocchio::SE3 M_rf, M_rf_ref; | |
404 | ✗ | vectorToSE3(rf_pos, M_rf); | |
405 | ✗ | vectorToSE3(rf_pos_ref, M_rf_ref); | |
406 | ✗ | cout << "RF pos: " << rf_pos.transpose() << endl; | |
407 | ✗ | cout << "RF pos ref: " << rf_pos_ref.transpose() << endl; | |
408 | } | ||
409 | |||
410 |
2/2✓ Branch 0 taken 1 times.
✓ Branch 1 taken 9 times.
|
20 | if (i % PRINT_N == 0) { |
411 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | cout << "Time " << i << endl; |
412 | 4 | cout << " " << contactRF.name() | |
413 |
8/16✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 1 times.
✗ Branch 23 not taken.
|
2 | << " err: " << contactRF.getMotionTask().position_error().norm() |
414 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << " \t"; |
415 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << contactLF.name() |
416 |
6/12✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
|
2 | << " err: " << contactLF.getMotionTask().position_error().norm() |
417 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << " \t"; |
418 |
6/12✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
|
2 | cout << comTask.name() << " err: " << comTask.position_error().norm() |
419 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << " \t"; |
420 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << postureTask.name() |
421 |
6/12✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
|
2 | << " err: " << postureTask.position_error().norm() << " \t"; |
422 |
7/14✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
|
2 | cout << "v=" << v.norm() << "\t dv=" << dv.norm() << endl; |
423 | // PRINT_VECTOR(postureTask.getConstraint().vector()); | ||
424 | // PRINT_VECTOR(postureTask.position_error()); | ||
425 |
11/22✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 1 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 1 times.
✗ Branch 27 not taken.
✓ Branch 29 taken 1 times.
✗ Branch 30 not taken.
✓ Branch 32 taken 1 times.
✗ Branch 33 not taken.
|
2 | if (i < 20) PRINT_VECTOR(dv); |
426 | } | ||
427 | |||
428 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | const HQPOutput &sol = solver->solve(HQPData); |
429 | |||
430 |
8/16✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✗ Branch 29 not taken.
✓ Branch 30 taken 10 times.
|
20 | BOOST_CHECK_MESSAGE(sol.status == HQP_STATUS_OPTIMAL, |
431 | "Status " + toString(sol.status)); | ||
432 | |||
433 | 20 | for (ConstraintLevel::const_iterator it = HQPData[0].begin(); | |
434 |
2/2✓ Branch 4 taken 60 times.
✓ Branch 5 taken 10 times.
|
140 | it != HQPData[0].end(); it++) { |
435 | 120 | auto constr = it->second; | |
436 |
3/6✓ Branch 2 taken 60 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 60 times.
✗ Branch 6 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 60 times.
|
120 | if (constr->checkConstraint(sol.x) == false) { |
437 | ✗ | if (constr->isEquality()) { | |
438 | ✗ | BOOST_CHECK_MESSAGE( | |
439 | false, | ||
440 | "Equality " + constr->name() + " violated: " + | ||
441 | toString( | ||
442 | (constr->matrix() * sol.x - constr->vector()).norm())); | ||
443 | ✗ | } else if (constr->isInequality()) { | |
444 | ✗ | BOOST_CHECK_MESSAGE( | |
445 | false, | ||
446 | "Inequality " + constr->name() + " violated: " + | ||
447 | toString((constr->matrix() * sol.x - constr->lowerBound()) | ||
448 | .minCoeff()) + | ||
449 | "\n" + | ||
450 | toString((constr->upperBound() - constr->matrix() * sol.x) | ||
451 | .minCoeff())); | ||
452 | ✗ | } else if (constr->isBound()) { | |
453 | ✗ | BOOST_CHECK_MESSAGE( | |
454 | false, "Bound " + constr->name() + " violated: " + | ||
455 | toString((sol.x - constr->lowerBound()).minCoeff()) + | ||
456 | "\n" + | ||
457 | toString((constr->upperBound() - sol.x).minCoeff())); | ||
458 | } | ||
459 | } | ||
460 | 120 | } | |
461 | |||
462 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | dv = sol.x.head(nv); |
463 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | f_RF = sol.x.segment<12>(nv); |
464 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | f_LF = sol.x.segment<12>(nv + 12); |
465 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | f = sol.x.tail(24); |
466 | |||
467 |
9/18✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 10 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 10 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 10 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 10 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 10 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 10 times.
✗ Branch 27 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 10 times.
|
20 | BOOST_CHECK(contactRF.getMotionConstraint().checkConstraint(dv)); |
468 |
9/18✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 10 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 10 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 10 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 10 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 10 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 10 times.
✗ Branch 27 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 10 times.
|
20 | BOOST_CHECK(contactRF.getForceConstraint().checkConstraint(f_RF)); |
469 |
9/18✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 10 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 10 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 10 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 10 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 10 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 10 times.
✗ Branch 27 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 10 times.
|
20 | BOOST_CHECK(contactLF.getMotionConstraint().checkConstraint(dv)); |
470 |
9/18✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 10 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 10 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 10 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 10 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 10 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 10 times.
✗ Branch 27 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 10 times.
|
20 | BOOST_CHECK(contactLF.getForceConstraint().checkConstraint(f_LF)); |
471 | |||
472 | // unsigned int index = 0; | ||
473 | // for(vector<ContactBase*>::iterator it=contacts.begin(); | ||
474 | // it!=contacts.end(); it++) | ||
475 | // { | ||
476 | // unsigned int m = (*it)->n_force(); | ||
477 | // const Matrix & T = (*it)->getForceGeneratorMatrix(); // 6x12 | ||
478 | // Jc.middleRows(index, m) = | ||
479 | // T.transpose()*(*it)->getMotionConstraint().matrix(); index += m; | ||
480 | // } | ||
481 | // const Matrix & M_u = robot.mass(data).topRows<6>(); | ||
482 | // const Vector & h_u = robot.nonLinearEffects(data).head<6>(); | ||
483 | // const Matrix & J_u = Jc.leftCols<6>(); | ||
484 | // CHECK_LESS_THAN((M_u*dv + h_u - J_u.transpose()*f).norm(), 1e-6); | ||
485 | |||
486 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | v += dt * dv; |
487 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
|
20 | q = pinocchio::integrate(robot.model(), q, dt * v); |
488 | 20 | t += dt; | |
489 | |||
490 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(dv.transpose()); |
491 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(v.transpose()); |
492 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(q.transpose()); |
493 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(dv.norm(), 1e6); |
494 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(v.norm(), 1e6); |
495 | } | ||
496 | |||
497 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver; |
498 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n### TEST FINISHED ###\n"; |
499 |
10/20✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 1 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 1 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 1 times.
✗ Branch 25 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
|
2 | PRINT_VECTOR(v); |
500 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
|
2 | cout << "Final CoM position: " << robot.com(tsid->data()).transpose() |
501 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << endl; |
502 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
|
2 | cout << "Desired CoM position: " << com_ref.transpose() << endl; |
503 | 2 | } | |
504 | |||
505 |
33/66✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
✓ Branch 33 taken 1 times.
✗ Branch 34 not taken.
✓ Branch 36 taken 1 times.
✗ Branch 37 not taken.
✓ Branch 41 taken 1 times.
✗ Branch 42 not taken.
✓ Branch 45 taken 1 times.
✗ Branch 46 not taken.
✓ Branch 48 taken 1 times.
✗ Branch 49 not taken.
✓ Branch 52 taken 1 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 1 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 1 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 1 times.
✗ Branch 62 not taken.
✓ Branch 66 taken 1 times.
✗ Branch 67 not taken.
✓ Branch 70 taken 1 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 1 times.
✗ Branch 74 not taken.
✓ Branch 77 taken 1 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 1 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 1 times.
✗ Branch 84 not taken.
✓ Branch 86 taken 1 times.
✗ Branch 87 not taken.
✓ Branch 91 taken 1 times.
✗ Branch 92 not taken.
✓ Branch 95 taken 1 times.
✗ Branch 96 not taken.
✓ Branch 98 taken 1 times.
✗ Branch 99 not taken.
✓ Branch 102 taken 1 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 1 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 1 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 1 times.
✗ Branch 112 not taken.
✓ Branch 116 taken 1 times.
✗ Branch 117 not taken.
|
4 | BOOST_AUTO_TEST_CASE(test_contact_point_invdyn_formulation_acc_force) { |
506 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n*** test_contact_point_invdyn_formulation_acc_force ***\n"; |
507 | |||
508 | 2 | const double mu = 0.3; | |
509 | 2 | const double fMin = 0.0; | |
510 | 2 | const double fMax = 10.0; | |
511 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | const std::string frameName = "base_link"; |
512 | 2 | const double dt = 1e-3; | |
513 | |||
514 | 2 | double t = 0.; | |
515 | |||
516 | 2 | double w_com = 1.0; // weight of center of mass task | |
517 | 2 | double w_forceReg = 1e-5; // weight of force regularization task | |
518 | 2 | double kp_contact = 100.0; // proportional gain of contact constraint | |
519 | 2 | double kp_com = 1.0; // proportional gain of center of mass task | |
520 | |||
521 | 2 | vector<string> package_dirs; | |
522 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | package_dirs.push_back(quadruped_model_path); |
523 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | string urdfFileName = package_dirs[0] + "/urdf/quadruped.urdf"; |
524 | RobotWrapper robot(urdfFileName, package_dirs, | ||
525 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
4 | pinocchio::JointModelFreeFlyer(), false); |
526 | |||
527 |
8/16✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 1 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✗ Branch 28 not taken.
✓ Branch 29 taken 1 times.
|
2 | BOOST_REQUIRE(robot.model().existFrame(frameName)); |
528 | |||
529 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector q = neutral(robot.model()); |
530 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | Vector v = Vector::Zero(robot.nv()); |
531 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | const unsigned int nv = robot.nv(); |
532 | |||
533 | // Create initial posture. | ||
534 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | q(0) = 0.1; |
535 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | q(2) = 0.5; |
536 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | q(6) = 1.; |
537 |
2/2✓ Branch 0 taken 4 times.
✓ Branch 1 taken 1 times.
|
10 | for (int i = 0; i < 4; i++) { |
538 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | q(7 + 2 * i) = -0.4; |
539 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | q(8 + 2 * i) = 0.8; |
540 | } | ||
541 | |||
542 | // Create the inverse-dynamics formulation | ||
543 | auto tsid = | ||
544 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<InverseDynamicsFormulationAccForce>("tsid", robot); |
545 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
2 | tsid->computeProblemData(t, q, v); |
546 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | pinocchio::Data &data = tsid->data(); |
547 | |||
548 | // Place the robot onto the ground. | ||
549 | |||
550 | pinocchio::SE3 fl_contact = | ||
551 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
|
2 | robot.framePosition(data, robot.model().getFrameId("FL_contact")); |
552 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
2 | q[2] -= fl_contact.translation()(2); |
553 | |||
554 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
2 | tsid->computeProblemData(t, q, v); |
555 | |||
556 | // Add task for the COM. | ||
557 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | auto comTask = std::make_shared<TaskComEquality>("task-com", robot); |
558 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
|
2 | comTask->Kp(kp_com * Vector::Ones(3)); |
559 |
5/10✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
|
2 | comTask->Kd(2.0 * comTask->Kp().cwiseSqrt()); |
560 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
2 | tsid->addMotionTask(*comTask, w_com, 1); |
561 | |||
562 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector3 com_ref = robot.com(data); |
563 | auto trajCom = | ||
564 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_com", com_ref); |
565 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample sampleCom(3); |
566 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | sampleCom = trajCom->computeNext(); |
567 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | comTask->setReference(sampleCom); |
568 | |||
569 | // Add contact constraints. | ||
570 | std::string contactFrames[] = {"BL_contact", "BR_contact", "FL_contact", | ||
571 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
|
12 | "FR_contact"}; |
572 | |||
573 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector3 contactNormal = Vector3::UnitZ(); |
574 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | std::vector<std::shared_ptr<ContactPoint>> contacts(4); |
575 | |||
576 |
2/2✓ Branch 0 taken 4 times.
✓ Branch 1 taken 1 times.
|
10 | for (int i = 0; i < 4; i++) { |
577 | ✗ | auto cp = std::make_shared<ContactPoint>("contact_" + contactFrames[i], | |
578 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | robot, contactFrames[i], |
579 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | contactNormal, mu, fMin, fMax); |
580 |
4/8✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 4 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 4 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 4 times.
✗ Branch 12 not taken.
|
8 | cp->Kp(kp_contact * Vector::Ones(3)); |
581 |
4/8✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 4 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 4 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 4 times.
✗ Branch 12 not taken.
|
8 | cp->Kd(2.0 * sqrt(kp_contact) * Vector::Ones(3)); |
582 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
16 | cp->setReference( |
583 |
3/6✓ 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.
|
16 | robot.framePosition(data, robot.model().getFrameId(contactFrames[i]))); |
584 |
1/2✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
|
8 | cp->useLocalFrame(false); |
585 |
1/2✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
|
8 | tsid->addRigidContact(*cp, w_forceReg, 1.0, 1); |
586 | |||
587 | 8 | contacts[i] = cp; | |
588 | 8 | } | |
589 | |||
590 | // Create an HQP solver | ||
591 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPBase *solver = SolverHQPFactory::createNewSolver( |
592 | SOLVER_HQP_EIQUADPROG, "solver-eiquadprog"); | ||
593 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
|
2 | solver->resize(tsid->nVar(), tsid->nEq(), tsid->nIn()); |
594 | |||
595 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector dv = Vector::Zero(nv); |
596 | const HQPOutput *sol; | ||
597 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 1 times.
|
22 | for (int i = 0; i < max_it; i++) { |
598 |
3/6✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | const HQPData &HQPData = tsid->computeProblemData(t, q, v); |
599 | |||
600 |
26/52✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 17 taken 10 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 10 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 10 times.
✗ Branch 24 not taken.
✓ Branch 27 taken 10 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 10 times.
✗ Branch 31 not taken.
✓ Branch 33 taken 10 times.
✗ Branch 34 not taken.
✓ Branch 36 taken 10 times.
✗ Branch 37 not taken.
✓ Branch 39 taken 10 times.
✗ Branch 40 not taken.
✗ Branch 46 not taken.
✓ Branch 47 taken 10 times.
✓ Branch 49 taken 10 times.
✗ Branch 50 not taken.
✓ Branch 53 taken 10 times.
✗ Branch 54 not taken.
✓ Branch 58 taken 10 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 10 times.
✗ Branch 62 not taken.
✓ Branch 65 taken 10 times.
✗ Branch 66 not taken.
✓ Branch 68 taken 10 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 10 times.
✗ Branch 72 not taken.
✓ Branch 75 taken 10 times.
✗ Branch 76 not taken.
✓ Branch 78 taken 10 times.
✗ Branch 79 not taken.
✓ Branch 81 taken 10 times.
✗ Branch 82 not taken.
✓ Branch 84 taken 10 times.
✗ Branch 85 not taken.
✓ Branch 87 taken 10 times.
✗ Branch 88 not taken.
✗ Branch 94 not taken.
✓ Branch 95 taken 10 times.
|
20 | REQUIRE_TASK_FINITE((*comTask)); |
601 | |||
602 |
2/2✓ Branch 1 taken 40 times.
✓ Branch 2 taken 10 times.
|
100 | for (unsigned int i = 0; i < contacts.size(); i++) { |
603 |
91/182✓ Branch 1 taken 40 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 40 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 40 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 40 times.
✗ Branch 14 not taken.
✓ Branch 18 taken 40 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 40 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 40 times.
✗ Branch 25 not taken.
✓ Branch 29 taken 40 times.
✗ Branch 30 not taken.
✓ Branch 32 taken 40 times.
✗ Branch 33 not taken.
✓ Branch 35 taken 40 times.
✗ Branch 36 not taken.
✓ Branch 38 taken 40 times.
✗ Branch 39 not taken.
✓ Branch 41 taken 40 times.
✗ Branch 42 not taken.
✗ Branch 48 not taken.
✓ Branch 49 taken 40 times.
✓ Branch 51 taken 40 times.
✗ Branch 52 not taken.
✓ Branch 55 taken 40 times.
✗ Branch 56 not taken.
✓ Branch 60 taken 40 times.
✗ Branch 61 not taken.
✓ Branch 63 taken 40 times.
✗ Branch 64 not taken.
✓ Branch 68 taken 40 times.
✗ Branch 69 not taken.
✓ Branch 71 taken 40 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 40 times.
✗ Branch 75 not taken.
✓ Branch 79 taken 40 times.
✗ Branch 80 not taken.
✓ Branch 82 taken 40 times.
✗ Branch 83 not taken.
✓ Branch 85 taken 40 times.
✗ Branch 86 not taken.
✓ Branch 88 taken 40 times.
✗ Branch 89 not taken.
✓ Branch 91 taken 40 times.
✗ Branch 92 not taken.
✗ Branch 98 not taken.
✓ Branch 99 taken 40 times.
✓ Branch 101 taken 40 times.
✗ Branch 102 not taken.
✓ Branch 105 taken 40 times.
✗ Branch 106 not taken.
✓ Branch 110 taken 40 times.
✗ Branch 111 not taken.
✓ Branch 113 taken 40 times.
✗ Branch 114 not taken.
✓ Branch 118 taken 40 times.
✗ Branch 119 not taken.
✓ Branch 121 taken 40 times.
✗ Branch 122 not taken.
✓ Branch 124 taken 40 times.
✗ Branch 125 not taken.
✓ Branch 129 taken 40 times.
✗ Branch 130 not taken.
✓ Branch 132 taken 40 times.
✗ Branch 133 not taken.
✓ Branch 135 taken 40 times.
✗ Branch 136 not taken.
✓ Branch 138 taken 40 times.
✗ Branch 139 not taken.
✓ Branch 141 taken 40 times.
✗ Branch 142 not taken.
✗ Branch 148 not taken.
✓ Branch 149 taken 40 times.
✓ Branch 151 taken 40 times.
✗ Branch 152 not taken.
✓ Branch 155 taken 40 times.
✗ Branch 156 not taken.
✓ Branch 160 taken 40 times.
✗ Branch 161 not taken.
✓ Branch 163 taken 40 times.
✗ Branch 164 not taken.
✓ Branch 168 taken 40 times.
✗ Branch 169 not taken.
✓ Branch 171 taken 40 times.
✗ Branch 172 not taken.
✓ Branch 174 taken 40 times.
✗ Branch 175 not taken.
✓ Branch 179 taken 40 times.
✗ Branch 180 not taken.
✓ Branch 182 taken 40 times.
✗ Branch 183 not taken.
✓ Branch 185 taken 40 times.
✗ Branch 186 not taken.
✓ Branch 188 taken 40 times.
✗ Branch 189 not taken.
✓ Branch 191 taken 40 times.
✗ Branch 192 not taken.
✗ Branch 198 not taken.
✓ Branch 199 taken 40 times.
✓ Branch 201 taken 40 times.
✗ Branch 202 not taken.
✓ Branch 205 taken 40 times.
✗ Branch 206 not taken.
✓ Branch 210 taken 40 times.
✗ Branch 211 not taken.
✓ Branch 213 taken 40 times.
✗ Branch 214 not taken.
✓ Branch 218 taken 40 times.
✗ Branch 219 not taken.
✓ Branch 221 taken 40 times.
✗ Branch 222 not taken.
✓ Branch 224 taken 40 times.
✗ Branch 225 not taken.
✓ Branch 229 taken 40 times.
✗ Branch 230 not taken.
✓ Branch 232 taken 40 times.
✗ Branch 233 not taken.
✓ Branch 235 taken 40 times.
✗ Branch 236 not taken.
✓ Branch 238 taken 40 times.
✗ Branch 239 not taken.
✓ Branch 241 taken 40 times.
✗ Branch 242 not taken.
✗ Branch 248 not taken.
✓ Branch 249 taken 40 times.
✓ Branch 251 taken 40 times.
✗ Branch 252 not taken.
✓ Branch 255 taken 40 times.
✗ Branch 256 not taken.
✓ Branch 260 taken 40 times.
✗ Branch 261 not taken.
✓ Branch 263 taken 40 times.
✗ Branch 264 not taken.
✓ Branch 268 taken 40 times.
✗ Branch 269 not taken.
✓ Branch 271 taken 40 times.
✗ Branch 272 not taken.
✓ Branch 274 taken 40 times.
✗ Branch 275 not taken.
✓ Branch 279 taken 40 times.
✗ Branch 280 not taken.
✓ Branch 282 taken 40 times.
✗ Branch 283 not taken.
✓ Branch 285 taken 40 times.
✗ Branch 286 not taken.
✓ Branch 288 taken 40 times.
✗ Branch 289 not taken.
✓ Branch 291 taken 40 times.
✗ Branch 292 not taken.
✗ Branch 298 not taken.
✓ Branch 299 taken 40 times.
✓ Branch 301 taken 40 times.
✗ Branch 302 not taken.
✓ Branch 305 taken 40 times.
✗ Branch 306 not taken.
✓ Branch 310 taken 40 times.
✗ Branch 311 not taken.
✓ Branch 313 taken 40 times.
✗ Branch 314 not taken.
✓ Branch 318 taken 40 times.
✗ Branch 319 not taken.
✓ Branch 321 taken 40 times.
✗ Branch 322 not taken.
✓ Branch 324 taken 40 times.
✗ Branch 325 not taken.
✓ Branch 329 taken 40 times.
✗ Branch 330 not taken.
✓ Branch 332 taken 40 times.
✗ Branch 333 not taken.
✓ Branch 335 taken 40 times.
✗ Branch 336 not taken.
✓ Branch 338 taken 40 times.
✗ Branch 339 not taken.
✓ Branch 341 taken 40 times.
✗ Branch 342 not taken.
✗ Branch 348 not taken.
✓ Branch 349 taken 40 times.
|
80 | REQUIRE_CONTACT_FINITE((*(contacts[i]))); |
604 | } | ||
605 | |||
606 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | sol = &(solver->solve(HQPData)); |
607 | |||
608 |
8/16✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✗ Branch 29 not taken.
✓ Branch 30 taken 10 times.
|
20 | BOOST_CHECK_MESSAGE(sol->status == HQP_STATUS_OPTIMAL, |
609 | "Status " + toString(sol->status)); | ||
610 | |||
611 | 20 | for (ConstraintLevel::const_iterator it = HQPData[0].begin(); | |
612 |
2/2✓ Branch 4 taken 50 times.
✓ Branch 5 taken 10 times.
|
120 | it != HQPData[0].end(); it++) { |
613 | 100 | auto constr = it->second; | |
614 |
3/6✓ Branch 2 taken 50 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 50 times.
✗ Branch 6 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 50 times.
|
100 | if (constr->checkConstraint(sol->x) == false) { |
615 | ✗ | if (constr->isEquality()) { | |
616 | ✗ | BOOST_CHECK_MESSAGE( | |
617 | false, | ||
618 | "Equality " + constr->name() + " violated: " + | ||
619 | toString( | ||
620 | (constr->matrix() * sol->x - constr->vector()).norm())); | ||
621 | ✗ | } else if (constr->isInequality()) { | |
622 | ✗ | BOOST_CHECK_MESSAGE( | |
623 | false, | ||
624 | "Inequality " + constr->name() + " violated: " + | ||
625 | toString((constr->matrix() * sol->x - constr->lowerBound()) | ||
626 | .minCoeff()) + | ||
627 | "\n" + | ||
628 | toString((constr->upperBound() - constr->matrix() * sol->x) | ||
629 | .minCoeff())); | ||
630 | ✗ | } else if (constr->isBound()) { | |
631 | ✗ | BOOST_CHECK_MESSAGE( | |
632 | false, "Bound " + constr->name() + " violated: " + | ||
633 | toString((sol->x - constr->lowerBound()).minCoeff()) + | ||
634 | "\n" + | ||
635 | toString((constr->upperBound() - sol->x).minCoeff())); | ||
636 | } | ||
637 | } | ||
638 | 100 | } | |
639 | |||
640 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | dv = sol->x.head(nv); |
641 | |||
642 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | v += dt * dv; |
643 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
|
20 | q = pinocchio::integrate(robot.model(), q, dt * v); |
644 | 20 | t += dt; | |
645 | |||
646 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(dv.transpose()); |
647 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(v.transpose()); |
648 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(q.transpose()); |
649 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(dv.norm(), 1e6); |
650 |
12/24✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 10 times.
✗ Branch 35 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 10 times.
|
20 | CHECK_LESS_THAN(v.norm(), 1e6); |
651 | } | ||
652 | |||
653 |
2/2✓ Branch 0 taken 4 times.
✓ Branch 1 taken 1 times.
|
10 | for (int i = 0; i < 4; i++) { |
654 |
1/2✓ Branch 1 taken 4 times.
✗ Branch 2 not taken.
|
8 | Eigen::Matrix<double, 3, 1> f; |
655 |
3/6✓ Branch 2 taken 4 times.
✗ Branch 3 not taken.
✓ Branch 7 taken 4 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 4 times.
✗ Branch 11 not taken.
|
8 | tsid->getContactForces(contacts[i]->name(), *sol, f); |
656 |
6/12✓ Branch 3 taken 4 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 4 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 4 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 4 times.
✗ Branch 13 not taken.
✓ Branch 15 taken 4 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 4 times.
✗ Branch 19 not taken.
|
8 | cout << contacts[i]->name() << " force:" << f.transpose() << endl; |
657 | } | ||
658 | |||
659 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver; |
660 | |||
661 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n### TEST FINISHED ###\n"; |
662 |
10/20✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
✓ Branch 18 taken 1 times.
✗ Branch 19 not taken.
✓ Branch 21 taken 1 times.
✗ Branch 22 not taken.
✓ Branch 24 taken 1 times.
✗ Branch 25 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
|
2 | PRINT_VECTOR(v); |
663 |
5/10✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
|
2 | cout << "Final CoM position: " << robot.com(tsid->data()).transpose() |
664 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | << endl; |
665 |
4/8✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
|
2 | cout << "Desired CoM position: " << com_ref.transpose() << endl; |
666 |
2/4✓ Branch 2 taken 4 times.
✓ Branch 3 taken 1 times.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
|
14 | } |
667 | |||
668 | #define PROFILE_CONTROL_CYCLE "Control cycle" | ||
669 | #define PROFILE_PROBLEM_FORMULATION "Problem formulation" | ||
670 | #define PROFILE_HQP "HQP" | ||
671 | #define PROFILE_HQP_FAST "HQP_FAST" | ||
672 | #define PROFILE_HQP_RT "HQP_RT" | ||
673 | |||
674 |
33/66✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 1 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 23 taken 1 times.
✗ Branch 24 not taken.
✓ Branch 27 taken 1 times.
✗ Branch 28 not taken.
✓ Branch 30 taken 1 times.
✗ Branch 31 not taken.
✓ Branch 33 taken 1 times.
✗ Branch 34 not taken.
✓ Branch 36 taken 1 times.
✗ Branch 37 not taken.
✓ Branch 41 taken 1 times.
✗ Branch 42 not taken.
✓ Branch 45 taken 1 times.
✗ Branch 46 not taken.
✓ Branch 48 taken 1 times.
✗ Branch 49 not taken.
✓ Branch 52 taken 1 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 1 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 1 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 1 times.
✗ Branch 62 not taken.
✓ Branch 66 taken 1 times.
✗ Branch 67 not taken.
✓ Branch 70 taken 1 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 1 times.
✗ Branch 74 not taken.
✓ Branch 77 taken 1 times.
✗ Branch 78 not taken.
✓ Branch 80 taken 1 times.
✗ Branch 81 not taken.
✓ Branch 83 taken 1 times.
✗ Branch 84 not taken.
✓ Branch 86 taken 1 times.
✗ Branch 87 not taken.
✓ Branch 91 taken 1 times.
✗ Branch 92 not taken.
✓ Branch 95 taken 1 times.
✗ Branch 96 not taken.
✓ Branch 98 taken 1 times.
✗ Branch 99 not taken.
✓ Branch 102 taken 1 times.
✗ Branch 103 not taken.
✓ Branch 105 taken 1 times.
✗ Branch 106 not taken.
✓ Branch 108 taken 1 times.
✗ Branch 109 not taken.
✓ Branch 111 taken 1 times.
✗ Branch 112 not taken.
✓ Branch 116 taken 1 times.
✗ Branch 117 not taken.
|
4 | BOOST_AUTO_TEST_CASE(test_invdyn_formulation_acc_force_computation_time) { |
675 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n*** test_invdyn_formulation_acc_force_computation_time ***\n"; |
676 | |||
677 | 2 | const double dt = 0.001; | |
678 | 2 | double t = 0.0; | |
679 | |||
680 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | StandardRomeoInvDynCtrl romeo_inv_dyn(dt); |
681 | 2 | RobotWrapper &robot = *(romeo_inv_dyn.robot); | |
682 | 2 | auto tsid = romeo_inv_dyn.tsid; | |
683 | 2 | TaskComEquality &comTask = *(romeo_inv_dyn.comTask); | |
684 | 2 | TaskJointPosture &postureTask = *(romeo_inv_dyn.postureTask); | |
685 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector q = romeo_inv_dyn.q; |
686 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | Vector v = romeo_inv_dyn.v; |
687 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | const int nv = robot.model().nv; |
688 | |||
689 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
2 | Vector3 com_ref = robot.com(tsid->data()); |
690 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | com_ref(1) += 0.1; |
691 | auto trajCom = | ||
692 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_com", com_ref); |
693 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample sampleCom(3); |
694 | |||
695 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector q_ref = q.tail(nv - 6); |
696 | auto trajPosture = | ||
697 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | std::make_shared<TrajectoryEuclidianConstant>("traj_posture", q_ref); |
698 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | TrajectorySample samplePosture(nv - 6); |
699 | |||
700 | // Create an HQP solver | ||
701 | SolverHQPBase *solver = | ||
702 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPFactory::createNewSolver(SOLVER_HQP_EIQUADPROG, "eiquadprog"); |
703 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPBase *solver_fast = SolverHQPFactory::createNewSolver( |
704 | SOLVER_HQP_EIQUADPROG_FAST, "eiquadprog-fast"); | ||
705 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | SolverHQPBase *solver_rt = SolverHQPFactory::createNewSolver<61, 18, 71>( |
706 | SOLVER_HQP_EIQUADPROG_RT, "eiquadprog-rt"); | ||
707 | |||
708 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
|
2 | solver->resize(tsid->nVar(), tsid->nEq(), tsid->nIn()); |
709 |
4/8✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
|
2 | solver_fast->resize(tsid->nVar(), tsid->nEq(), tsid->nIn()); |
710 | |||
711 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | Vector dv = Vector::Zero(nv); |
712 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 1 times.
|
22 | for (int i = 0; i < max_it; i++) { |
713 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().start(PROFILE_CONTROL_CYCLE); |
714 | |||
715 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | sampleCom = trajCom->computeNext(); |
716 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | comTask.setReference(sampleCom); |
717 |
2/4✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
|
20 | samplePosture = trajPosture->computeNext(); |
718 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | postureTask.setReference(samplePosture); |
719 | |||
720 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().start(PROFILE_PROBLEM_FORMULATION); |
721 |
3/6✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | const HQPData &HQPData = tsid->computeProblemData(t, q, v); |
722 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().stop(PROFILE_PROBLEM_FORMULATION); |
723 | |||
724 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().start(PROFILE_HQP); |
725 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | const HQPOutput &sol = solver->solve(HQPData); |
726 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().stop(PROFILE_HQP); |
727 | |||
728 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().stop(PROFILE_CONTROL_CYCLE); |
729 | |||
730 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().start(PROFILE_HQP_FAST); |
731 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | const HQPOutput &sol_fast = solver_fast->solve(HQPData); |
732 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().stop(PROFILE_HQP_FAST); |
733 | |||
734 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().start(PROFILE_HQP_RT); |
735 |
1/2✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
|
20 | solver_rt->solve(HQPData); |
736 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getProfiler().stop(PROFILE_HQP_RT); |
737 | |||
738 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
|
40 | getStatistics().store("active inequalities", |
739 | 20 | static_cast<double>(sol_fast.activeSet.size())); | |
740 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 10 times.
✗ Branch 9 not taken.
|
20 | getStatistics().store("solver iterations", sol_fast.iterations); |
741 | |||
742 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | dv = sol.x.head(nv); |
743 |
2/4✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
20 | v += dt * dv; |
744 |
3/6✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
|
20 | q = pinocchio::integrate(robot.model(), q, dt * v); |
745 | 20 | t += dt; | |
746 | |||
747 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(dv.transpose()); |
748 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(v.transpose()); |
749 |
11/22✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 10 times.
✗ Branch 6 not taken.
✓ Branch 10 taken 10 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 10 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 10 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 10 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 10 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 10 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 10 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 10 times.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 10 times.
|
20 | REQUIRE_FINITE(q.transpose()); |
750 | } | ||
751 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver; |
752 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver_fast; |
753 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
2 | delete solver_rt; |
754 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | cout << "\n### TEST FINISHED ###\n"; |
755 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | getProfiler().report_all(3, cout); |
756 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | getStatistics().report_all(1, cout); |
757 | 2 | } | |
758 | |||
759 | BOOST_AUTO_TEST_SUITE_END() | ||
760 |