Directory: | ./ |
---|---|
File: | include/tsid/bindings/python/formulations/formulation.hpp |
Date: | 2025-01-10 01:13:27 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 69 | 111 | 62.2% |
Branches: | 74 | 146 | 50.7% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | // | ||
2 | // Copyright (c) 2018 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 | #ifndef __tsid_python_HQPOutput_hpp__ | ||
19 | #define __tsid_python_HQPOutput_hpp__ | ||
20 | |||
21 | #include "tsid/bindings/python/fwd.hpp" | ||
22 | |||
23 | #include <pinocchio/bindings/python/utils/deprecation.hpp> | ||
24 | |||
25 | #include "tsid/formulations/inverse-dynamics-formulation-acc-force.hpp" | ||
26 | #include "tsid/bindings/python/solvers/HQPData.hpp" | ||
27 | #include "tsid/contacts/contact-6d.hpp" | ||
28 | #include "tsid/contacts/contact-point.hpp" | ||
29 | #include "tsid/contacts/contact-two-frame-positions.hpp" | ||
30 | #include "tsid/tasks/task-joint-posture.hpp" | ||
31 | #include "tsid/tasks/task-se3-equality.hpp" | ||
32 | #include "tsid/tasks/task-com-equality.hpp" | ||
33 | #include "tsid/tasks/task-cop-equality.hpp" | ||
34 | #include "tsid/tasks/task-actuation-bounds.hpp" | ||
35 | #include "tsid/tasks/task-joint-bounds.hpp" | ||
36 | #include "tsid/tasks/task-joint-posVelAcc-bounds.hpp" | ||
37 | #include "tsid/tasks/task-angular-momentum-equality.hpp" | ||
38 | #include "tsid/tasks/task-two-frames-equality.hpp" | ||
39 | |||
40 | namespace tsid { | ||
41 | namespace python { | ||
42 | namespace bp = boost::python; | ||
43 | |||
44 | template <typename T> | ||
45 | struct InvDynPythonVisitor | ||
46 | : public boost::python::def_visitor<InvDynPythonVisitor<T> > { | ||
47 | template <class PyClass> | ||
48 | |||
49 | 7 | void visit(PyClass& cl) const { | |
50 |
2/4✓ Branch 2 taken 7 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 7 times.
✗ Branch 6 not taken.
|
7 | cl.def(bp::init<std::string, robots::RobotWrapper&, bool>( |
51 | (bp::args("name", "robot", "verbose")))) | ||
52 |
1/2✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
|
7 | .def("data", &InvDynPythonVisitor::data) |
53 | 14 | .add_property("nVar", &T::nVar) | |
54 |
1/2✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
|
7 | .add_property("nEq", &T::nEq) |
55 |
1/2✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
|
7 | .add_property("nIn", &T::nIn) |
56 | |||
57 |
3/6✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 7 times.
✗ Branch 8 not taken.
|
14 | .def("addMotionTask", &InvDynPythonVisitor::addMotionTask_SE3, |
58 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
59 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", &InvDynPythonVisitor::addMotionTask_COM, |
60 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
61 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", &InvDynPythonVisitor::addMotionTask_Joint, |
62 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
63 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", &InvDynPythonVisitor::addMotionTask_JointBounds, |
64 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
65 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", |
66 | &InvDynPythonVisitor::addMotionTask_JointPosVelAccBounds, | ||
67 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
68 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", &InvDynPythonVisitor::addMotionTask_AM, |
69 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
70 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addMotionTask", |
71 | &InvDynPythonVisitor::addMotionTask_TwoFramesEquality, | ||
72 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
73 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addForceTask", &InvDynPythonVisitor::addForceTask_COP, |
74 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
75 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addActuationTask", &InvDynPythonVisitor::addActuationTask_Bounds, |
76 | bp::args("task", "weight", "priorityLevel", "transition duration")) | ||
77 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("updateTaskWeight", &InvDynPythonVisitor::updateTaskWeight, |
78 | bp::args("task_name", "weight")) | ||
79 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("updateRigidContactWeights", |
80 | &InvDynPythonVisitor::updateRigidContactWeights, | ||
81 | bp::args("contact_name", "force_regularization_weight")) | ||
82 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("updateRigidContactWeights", |
83 | &InvDynPythonVisitor::updateRigidContactWeightsWithMotionWeight, | ||
84 | bp::args("contact_name", "force_regularization_weight", | ||
85 | "motion_weight")) | ||
86 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
7 | .def("addRigidContact", |
87 | &InvDynPythonVisitor::addRigidContact6dDeprecated, | ||
88 | bp::args("contact"), | ||
89 |
2/4✓ Branch 2 taken 7 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 7 times.
✗ Branch 6 not taken.
|
14 | pinocchio::python::deprecated_function<>( |
90 | "Method addRigidContact(ContactBase) is deprecated. You " | ||
91 | "should use addRigidContact(ContactBase, double) instead")) | ||
92 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", &InvDynPythonVisitor::addRigidContact6d, |
93 | bp::args("contact", "force_reg_weight")) | ||
94 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", |
95 | &InvDynPythonVisitor::addRigidContact6dWithPriorityLevel, | ||
96 | bp::args("contact", "force_reg_weight", "motion_weight", | ||
97 | "priority_level")) | ||
98 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", &InvDynPythonVisitor::addRigidContactPoint, |
99 | bp::args("contact", "force_reg_weight")) | ||
100 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", |
101 | &InvDynPythonVisitor::addRigidContactPointWithPriorityLevel, | ||
102 | bp::args("contact", "force_reg_weight", "motion_weight", | ||
103 | "priority_level")) | ||
104 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", |
105 | &InvDynPythonVisitor::addRigidContactTwoFramePositions, | ||
106 | bp::args("contact", "force_reg_weight")) | ||
107 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("addRigidContact", |
108 | &InvDynPythonVisitor:: | ||
109 | addRigidContactTwoFramePositionsWithPriorityLevel, | ||
110 | bp::args("contact", "force_reg_weight", "motion_weight", | ||
111 | "priority_level")) | ||
112 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("removeTask", &InvDynPythonVisitor::removeTask, |
113 | bp::args("task_name", "duration")) | ||
114 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("removeRigidContact", &InvDynPythonVisitor::removeRigidContact, |
115 | bp::args("contact_name", "duration")) | ||
116 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("removeFromHqpData", &InvDynPythonVisitor::removeFromHqpData, |
117 | bp::args("constraint_name")) | ||
118 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("computeProblemData", &InvDynPythonVisitor::computeProblemData, |
119 | bp::args("time", "q", "v")) | ||
120 | |||
121 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("getActuatorForces", &InvDynPythonVisitor::getActuatorForces, |
122 | bp::args("HQPOutput")) | ||
123 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("getAccelerations", &InvDynPythonVisitor::getAccelerations, |
124 | bp::args("HQPOutput")) | ||
125 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("getContactForces", &InvDynPythonVisitor::getContactForces, |
126 | bp::args("HQPOutput")) | ||
127 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
14 | .def("checkContact", &InvDynPythonVisitor::checkContact, |
128 | bp::args("name", "HQPOutput")) | ||
129 |
2/4✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 7 times.
✗ Branch 5 not taken.
|
7 | .def("getContactForce", &InvDynPythonVisitor::getContactForce, |
130 | bp::args("name", "HQPOutput")); | ||
131 | 7 | } | |
132 | 2 | static pinocchio::Data data(T& self) { | |
133 | 2 | pinocchio::Data data = self.data(); | |
134 | 2 | return data; | |
135 | } | ||
136 | 1 | static bool addMotionTask_SE3(T& self, tasks::TaskSE3Equality& task, | |
137 | double weight, unsigned int priorityLevel, | ||
138 | double transition_duration) { | ||
139 | 1 | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
140 | } | ||
141 | 1 | static bool addMotionTask_COM(T& self, tasks::TaskComEquality& task, | |
142 | double weight, unsigned int priorityLevel, | ||
143 | double transition_duration) { | ||
144 | 1 | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
145 | } | ||
146 | 1 | static bool addMotionTask_Joint(T& self, tasks::TaskJointPosture& task, | |
147 | double weight, unsigned int priorityLevel, | ||
148 | double transition_duration) { | ||
149 | 1 | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
150 | } | ||
151 | ✗ | static bool addMotionTask_JointBounds(T& self, tasks::TaskJointBounds& task, | |
152 | double weight, | ||
153 | unsigned int priorityLevel, | ||
154 | double transition_duration) { | ||
155 | ✗ | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
156 | } | ||
157 | ✗ | static bool addMotionTask_JointPosVelAccBounds( | |
158 | T& self, tasks::TaskJointPosVelAccBounds& task, double weight, | ||
159 | unsigned int priorityLevel, double transition_duration) { | ||
160 | ✗ | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
161 | } | ||
162 | ✗ | static bool addMotionTask_AM(T& self, tasks::TaskAMEquality& task, | |
163 | double weight, unsigned int priorityLevel, | ||
164 | double transition_duration) { | ||
165 | ✗ | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
166 | } | ||
167 | ✗ | static bool addMotionTask_TwoFramesEquality( | |
168 | T& self, tasks::TaskTwoFramesEquality& task, double weight, | ||
169 | unsigned int priorityLevel, double transition_duration) { | ||
170 | ✗ | return self.addMotionTask(task, weight, priorityLevel, transition_duration); | |
171 | } | ||
172 | ✗ | static bool addForceTask_COP(T& self, tasks::TaskCopEquality& task, | |
173 | double weight, unsigned int priorityLevel, | ||
174 | double transition_duration) { | ||
175 | ✗ | return self.addForceTask(task, weight, priorityLevel, transition_duration); | |
176 | } | ||
177 | ✗ | static bool addActuationTask_Bounds(T& self, tasks::TaskActuationBounds& task, | |
178 | double weight, unsigned int priorityLevel, | ||
179 | double transition_duration) { | ||
180 | ✗ | return self.addActuationTask(task, weight, priorityLevel, | |
181 | ✗ | transition_duration); | |
182 | } | ||
183 | ✗ | static bool updateTaskWeight(T& self, const std::string& task_name, | |
184 | double weight) { | ||
185 | ✗ | return self.updateTaskWeight(task_name, weight); | |
186 | } | ||
187 | ✗ | static bool updateRigidContactWeights(T& self, | |
188 | const std::string& contact_name, | ||
189 | double force_regularization_weight) { | ||
190 | ✗ | return self.updateRigidContactWeights(contact_name, | |
191 | ✗ | force_regularization_weight); | |
192 | } | ||
193 | ✗ | static bool updateRigidContactWeightsWithMotionWeight( | |
194 | T& self, const std::string& contact_name, | ||
195 | double force_regularization_weight, double motion_weight) { | ||
196 | ✗ | return self.updateRigidContactWeights( | |
197 | ✗ | contact_name, force_regularization_weight, motion_weight); | |
198 | } | ||
199 | 2 | static bool addRigidContact6dDeprecated(T& self, | |
200 | contacts::Contact6d& contact) { | ||
201 | 2 | return self.addRigidContact(contact, 1e-5); | |
202 | } | ||
203 | ✗ | static bool addRigidContact6d(T& self, contacts::Contact6d& contact, | |
204 | double force_regularization_weight) { | ||
205 | ✗ | return self.addRigidContact(contact, force_regularization_weight); | |
206 | } | ||
207 | ✗ | static bool addRigidContact6dWithPriorityLevel( | |
208 | T& self, contacts::Contact6d& contact, double force_regularization_weight, | ||
209 | double motion_weight, const bool priority_level) { | ||
210 | ✗ | return self.addRigidContact(contact, force_regularization_weight, | |
211 | ✗ | motion_weight, priority_level); | |
212 | } | ||
213 | ✗ | static bool addRigidContactPoint(T& self, contacts::ContactPoint& contact, | |
214 | double force_regularization_weight) { | ||
215 | ✗ | return self.addRigidContact(contact, force_regularization_weight); | |
216 | } | ||
217 | ✗ | static bool addRigidContactPointWithPriorityLevel( | |
218 | T& self, contacts::ContactPoint& contact, | ||
219 | double force_regularization_weight, double motion_weight, | ||
220 | const bool priority_level) { | ||
221 | ✗ | return self.addRigidContact(contact, force_regularization_weight, | |
222 | ✗ | motion_weight, priority_level); | |
223 | } | ||
224 | ✗ | static bool addRigidContactTwoFramePositions( | |
225 | T& self, contacts::ContactTwoFramePositions& contact, | ||
226 | double force_regularization_weight) { | ||
227 | ✗ | return self.addRigidContact(contact, force_regularization_weight); | |
228 | } | ||
229 | ✗ | static bool addRigidContactTwoFramePositionsWithPriorityLevel( | |
230 | T& self, contacts::ContactTwoFramePositions& contact, | ||
231 | double force_regularization_weight, double motion_weight, | ||
232 | const bool priority_level) { | ||
233 | ✗ | return self.addRigidContact(contact, force_regularization_weight, | |
234 | ✗ | motion_weight, priority_level); | |
235 | } | ||
236 | ✗ | static bool removeTask(T& self, const std::string& task_name, | |
237 | double transition_duration) { | ||
238 | ✗ | return self.removeTask(task_name, transition_duration); | |
239 | } | ||
240 | 1 | static bool removeRigidContact(T& self, const std::string& contactName, | |
241 | double transition_duration) { | ||
242 | 1 | return self.removeRigidContact(contactName, transition_duration); | |
243 | } | ||
244 | ✗ | static bool removeFromHqpData(T& self, const std::string& constraintName) { | |
245 | ✗ | return self.removeFromHqpData(constraintName); | |
246 | } | ||
247 | 1001 | static HQPDatas computeProblemData(T& self, double time, | |
248 | const Eigen::VectorXd& q, | ||
249 | const Eigen::VectorXd& v) { | ||
250 | 1001 | HQPDatas Hqp; | |
251 |
4/8✓ Branch 1 taken 1001 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1001 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1001 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1001 times.
✗ Branch 11 not taken.
|
1001 | Hqp.set(self.computeProblemData(time, q, v)); |
252 | 1001 | return Hqp; | |
253 | } | ||
254 | 1000 | static Eigen::VectorXd getActuatorForces(T& self, | |
255 | const solvers::HQPOutput& sol) { | ||
256 | 1000 | return self.getActuatorForces(sol); | |
257 | } | ||
258 | 1000 | static Eigen::VectorXd getAccelerations(T& self, | |
259 | const solvers::HQPOutput& sol) { | ||
260 | 1000 | return self.getAccelerations(sol); | |
261 | } | ||
262 | ✗ | static Eigen::VectorXd getContactForces(T& self, | |
263 | const solvers::HQPOutput& sol) { | ||
264 | ✗ | return self.getContactForces(sol); | |
265 | } | ||
266 | 18 | static bool checkContact(T& self, const std::string& name, | |
267 | const solvers::HQPOutput& sol) { | ||
268 |
1/2✓ Branch 1 taken 18 times.
✗ Branch 2 not taken.
|
18 | tsid::math::Vector f = self.getContactForces(name, sol); |
269 |
2/2✓ Branch 1 taken 10 times.
✓ Branch 2 taken 8 times.
|
18 | if (f.size() > 0) return true; |
270 | 8 | return false; | |
271 | 18 | } | |
272 | 10 | static Eigen::VectorXd getContactForce(T& self, const std::string& name, | |
273 | const solvers::HQPOutput& sol) { | ||
274 | 10 | return self.getContactForces(name, sol); | |
275 | } | ||
276 | |||
277 | 7 | static void expose(const std::string& class_name) { | |
278 |
1/2✓ Branch 2 taken 7 times.
✗ Branch 3 not taken.
|
7 | std::string doc = "InvDyn info."; |
279 |
1/2✓ Branch 3 taken 7 times.
✗ Branch 4 not taken.
|
7 | bp::class_<T>(class_name.c_str(), doc.c_str(), bp::no_init) |
280 |
1/2✓ Branch 1 taken 7 times.
✗ Branch 2 not taken.
|
7 | .def(InvDynPythonVisitor<T>()); |
281 | 7 | } | |
282 | }; | ||
283 | } // namespace python | ||
284 | } // namespace tsid | ||
285 | |||
286 | #endif // ifndef __tsid_python_HQPOutput_hpp__ | ||
287 |