Directory: | ./ |
---|---|
File: | src/tools/device.cpp |
Date: | 2025-01-13 12:33:34 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 188 | 309 | 60.8% |
Branches: | 263 | 868 | 30.3% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * Copyright 2010, | ||
3 | * Nicolas Mansard, Olivier Stasse, François Bleibel, Florent Lamiraux | ||
4 | * | ||
5 | * CNRS | ||
6 | * | ||
7 | */ | ||
8 | |||
9 | /* --------------------------------------------------------------------- */ | ||
10 | /* --- INCLUDE --------------------------------------------------------- */ | ||
11 | /* --------------------------------------------------------------------- */ | ||
12 | |||
13 | /* SOT */ | ||
14 | #define ENABLE_RT_LOG | ||
15 | |||
16 | #include "sot/core/device.hh" | ||
17 | |||
18 | #include <iostream> | ||
19 | #include <sot/core/debug.hh> | ||
20 | #include <sot/core/macros.hh> | ||
21 | using namespace std; | ||
22 | |||
23 | #include <dynamic-graph/all-commands.h> | ||
24 | #include <dynamic-graph/factory.h> | ||
25 | #include <dynamic-graph/linear-algebra.h> | ||
26 | #include <dynamic-graph/real-time-logger.h> | ||
27 | |||
28 | #include <Eigen/Geometry> | ||
29 | #include <pinocchio/multibody/liegroup/special-euclidean.hpp> | ||
30 | #include <sot/core/matrix-geometry.hh> | ||
31 | using namespace dynamicgraph::sot; | ||
32 | using namespace dynamicgraph; | ||
33 | |||
34 | const std::string Device::CLASS_NAME = "Device"; | ||
35 | |||
36 | /* --------------------------------------------------------------------- */ | ||
37 | /* --- CLASS ----------------------------------------------------------- */ | ||
38 | /* --------------------------------------------------------------------- */ | ||
39 | |||
40 | 2000 | void Device::integrateRollPitchYaw(Vector &state, const Vector &control, | |
41 | double dt) { | ||
42 | using Eigen::AngleAxisd; | ||
43 | using Eigen::QuaternionMapd; | ||
44 | using Eigen::Vector3d; | ||
45 | |||
46 | typedef pinocchio::SpecialEuclideanOperationTpl<3, double> SE3; | ||
47 |
2/4✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
|
2000 | Eigen::Matrix<double, 7, 1> qin, qout; |
48 |
3/6✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
|
2000 | qin.head<3>() = state.head<3>(); |
49 | |||
50 |
2/4✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 2000 times.
✗ Branch 6 not taken.
|
2000 | QuaternionMapd quat(qin.tail<4>().data()); |
51 |
4/8✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
|
2000 | quat = AngleAxisd(state(5), Vector3d::UnitZ()) * |
52 |
4/8✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
|
4000 | AngleAxisd(state(4), Vector3d::UnitY()) * |
53 |
4/8✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
|
4000 | AngleAxisd(state(3), Vector3d::UnitX()); |
54 | |||
55 |
4/8✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
|
2000 | SE3().integrate(qin, control.head<6>() * dt, qout); |
56 | |||
57 | // Update freeflyer pose | ||
58 |
3/6✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
|
2000 | ffPose_.translation() = qout.head<3>(); |
59 |
3/6✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
|
2000 | state.head<3>() = qout.head<3>(); |
60 | |||
61 |
5/10✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 2000 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 2000 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 2000 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 2000 times.
✗ Branch 15 not taken.
|
2000 | ffPose_.linear() = QuaternionMapd(qout.tail<4>().data()).toRotationMatrix(); |
62 |
5/10✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 2000 times.
✗ Branch 14 not taken.
|
2000 | state.segment<3>(3) = ffPose_.linear().eulerAngles(2, 1, 0).reverse(); |
63 | 2000 | } | |
64 | |||
65 | ✗ | const MatrixHomogeneous &Device::freeFlyerPose() const { return ffPose_; } | |
66 | |||
67 | 4 | Device::~Device() { | |
68 |
2/2✓ Branch 0 taken 8 times.
✓ Branch 1 taken 2 times.
|
20 | for (unsigned int i = 0; i < 4; ++i) { |
69 |
1/2✓ Branch 0 taken 8 times.
✗ Branch 1 not taken.
|
16 | delete forcesSOUT[i]; |
70 | } | ||
71 | } | ||
72 | |||
73 | 2 | Device::Device(const std::string &n) | |
74 | : Entity(n), | ||
75 | ✗ | state_(6), | |
76 | 2 | sanityCheck_(true), | |
77 | 2 | controlInputType_(CONTROL_INPUT_ONE_INTEGRATION), | |
78 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | controlSIN(NULL, "Device(" + n + ")::input(double)::control"), |
79 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | attitudeSIN(NULL, "Device(" + n + ")::input(vector3)::attitudeIN"), |
80 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | zmpSIN(NULL, "Device(" + n + ")::input(vector3)::zmp"), |
81 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | stateSOUT("Device(" + n + ")::output(vector)::state") |
82 | //,attitudeSIN(NULL,"Device::input(matrixRot)::attitudeIN") | ||
83 | , | ||
84 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | velocitySOUT("Device(" + n + ")::output(vector)::velocity"), |
85 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | attitudeSOUT("Device(" + n + ")::output(matrixRot)::attitude"), |
86 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | motorcontrolSOUT("Device(" + n + ")::output(vector)::motorcontrol"), |
87 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | previousControlSOUT("Device(" + n + ")::output(vector)::previousControl"), |
88 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | ZMPPreviousControllerSOUT("Device(" + n + |
89 | ")::output(vector)::zmppreviouscontroller"), | ||
90 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | robotState_("Device(" + n + ")::output(vector)::robotState"), |
91 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | robotVelocity_("Device(" + n + ")::output(vector)::robotVelocity"), |
92 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | pseudoTorqueSOUT("Device(" + n + ")::output(vector)::ptorque") |
93 | |||
94 | , | ||
95 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | ffPose_(), |
96 |
12/24✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 2 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✓ Branch 20 taken 2 times.
✗ Branch 21 not taken.
✓ Branch 23 taken 2 times.
✗ Branch 24 not taken.
✓ Branch 26 taken 2 times.
✗ Branch 27 not taken.
✓ Branch 29 taken 2 times.
✗ Branch 30 not taken.
✓ Branch 32 taken 2 times.
✗ Branch 33 not taken.
✓ Branch 35 taken 2 times.
✗ Branch 36 not taken.
|
4 | forceZero6(6) { |
97 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | forceZero6.fill(0); |
98 | /* --- SIGNALS --- */ | ||
99 |
2/2✓ Branch 0 taken 8 times.
✓ Branch 1 taken 2 times.
|
10 | for (int i = 0; i < 4; ++i) { |
100 | 8 | withForceSignals[i] = false; | |
101 | } | ||
102 | 4 | forcesSOUT[0] = | |
103 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
2 | new Signal<Vector, int>("Device(" + n + ")::output(vector6)::forceRLEG"); |
104 | 4 | forcesSOUT[1] = | |
105 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
2 | new Signal<Vector, int>("Device(" + n + ")::output(vector6)::forceLLEG"); |
106 | 4 | forcesSOUT[2] = | |
107 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
2 | new Signal<Vector, int>("Device(" + n + ")::output(vector6)::forceRARM"); |
108 | 4 | forcesSOUT[3] = | |
109 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
2 | new Signal<Vector, int>("Device(" + n + ")::output(vector6)::forceLARM"); |
110 | |||
111 | 4 | signalRegistration( | |
112 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
4 | controlSIN << stateSOUT << robotState_ << robotVelocity_ << velocitySOUT |
113 |
4/8✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
|
2 | << attitudeSOUT << attitudeSIN << zmpSIN << *forcesSOUT[0] |
114 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | << *forcesSOUT[1] << *forcesSOUT[2] << *forcesSOUT[3] |
115 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
|
2 | << previousControlSOUT << pseudoTorqueSOUT << motorcontrolSOUT |
116 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | << ZMPPreviousControllerSOUT); |
117 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | state_.fill(.0); |
118 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | stateSOUT.setConstant(state_); |
119 | |||
120 |
1/2✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
|
2 | velocity_.resize(state_.size()); |
121 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | velocity_.setZero(); |
122 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | velocitySOUT.setConstant(velocity_); |
123 | |||
124 | /* --- Commands --- */ | ||
125 | { | ||
126 | 2 | std::string docstring; | |
127 | /* Command setStateSize. */ | ||
128 | docstring = | ||
129 | "\n" | ||
130 | " Set size of state vector\n" | ||
131 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
132 |
2/4✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
|
2 | addCommand("resize", new command::Setter<Device, unsigned int>( |
133 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | *this, &Device::setStateSize, docstring)); |
134 | docstring = | ||
135 | "\n" | ||
136 | " Set state vector value\n" | ||
137 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
138 |
2/4✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
|
2 | addCommand("set", new command::Setter<Device, Vector>( |
139 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | *this, &Device::setState, docstring)); |
140 | |||
141 | docstring = | ||
142 | "\n" | ||
143 | " Set velocity vector value\n" | ||
144 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
145 |
2/4✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
|
2 | addCommand("setVelocity", new command::Setter<Device, Vector>( |
146 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | *this, &Device::setVelocity, docstring)); |
147 | |||
148 | 2 | void (Device::*setRootPtr)(const Matrix &) = &Device::setRoot; | |
149 |
3/6✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
|
4 | docstring = command::docCommandVoid1("Set the root position.", |
150 | 2 | "matrix homogeneous"); | |
151 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("setRoot", |
152 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeCommandVoid1(*this, setRootPtr, docstring)); |
153 | |||
154 | /* Second Order Integration set. */ | ||
155 | docstring = | ||
156 | "\n" | ||
157 | " Set the position calculous starting from \n" | ||
158 | " acceleration measure instead of velocity \n" | ||
159 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
160 | |||
161 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("setSecondOrderIntegration", |
162 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeCommandVoid0( |
163 | *this, &Device::setSecondOrderIntegration, docstring)); | ||
164 | |||
165 | /* Display information */ | ||
166 | docstring = | ||
167 | "\n" | ||
168 | " Display information on device \n" | ||
169 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
170 |
3/6✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
|
2 | addCommand("display", command::makeCommandVoid0(*this, &Device::cmdDisplay, |
171 | docstring)); | ||
172 | |||
173 | /* SET of control input type. */ | ||
174 | docstring = | ||
175 | "\n" | ||
176 | " Set the type of control input which can be \n" | ||
177 | " acceleration, velocity, or position\n" | ||
178 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
179 | |||
180 |
2/4✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
|
2 | addCommand("setControlInputType", |
181 | new command::Setter<Device, string>( | ||
182 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | *this, &Device::setControlInputType, docstring)); |
183 | |||
184 | docstring = | ||
185 | "\n" | ||
186 | " Enable/Disable sanity checks\n" | ||
187 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | "\n"; |
188 |
2/4✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
|
2 | addCommand("setSanityCheck", |
189 | new command::Setter<Device, bool>(*this, &Device::setSanityCheck, | ||
190 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | docstring)); |
191 | |||
192 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("setPositionBounds", |
193 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeCommandVoid2( |
194 | *this, &Device::setPositionBounds, | ||
195 |
4/8✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
|
4 | command::docCommandVoid2("Set robot position bounds", |
196 | "vector: lower bounds", | ||
197 | "vector: upper bounds"))); | ||
198 | |||
199 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("setVelocityBounds", |
200 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeCommandVoid2( |
201 | *this, &Device::setVelocityBounds, | ||
202 |
4/8✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
|
4 | command::docCommandVoid2("Set robot velocity bounds", |
203 | "vector: lower bounds", | ||
204 | "vector: upper bounds"))); | ||
205 | |||
206 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("setTorqueBounds", |
207 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeCommandVoid2( |
208 | *this, &Device::setTorqueBounds, | ||
209 |
4/8✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
|
4 | command::docCommandVoid2("Set robot torque bounds", |
210 | "vector: lower bounds", | ||
211 | "vector: upper bounds"))); | ||
212 | |||
213 |
2/4✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
|
2 | addCommand("getTimeStep", |
214 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | command::makeDirectGetter( |
215 | *this, &this->timestep_, | ||
216 |
3/6✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
|
4 | command::docDirectGetter("Time step", "double"))); |
217 | 2 | } | |
218 | 2 | } | |
219 | |||
220 | 1 | void Device::setStateSize(const unsigned int &size) { | |
221 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | state_.resize(size); |
222 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | state_.fill(.0); |
223 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | stateSOUT.setConstant(state_); |
224 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | previousControlSOUT.setConstant(state_); |
225 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | pseudoTorqueSOUT.setConstant(state_); |
226 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | motorcontrolSOUT.setConstant(state_); |
227 | |||
228 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | Device::setVelocitySize(size); |
229 | |||
230 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | Vector zmp(3); |
231 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | zmp.fill(.0); |
232 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | ZMPPreviousControllerSOUT.setConstant(zmp); |
233 | 1 | } | |
234 | |||
235 | 2 | void Device::setVelocitySize(const unsigned int &size) { | |
236 | 2 | velocity_.resize(size); | |
237 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | velocity_.fill(.0); |
238 | 2 | velocitySOUT.setConstant(velocity_); | |
239 | 2 | } | |
240 | |||
241 | 1 | void Device::setState(const Vector &st) { | |
242 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
1 | if (sanityCheck_) { |
243 | 1 | const Vector::Index &s = st.size(); | |
244 | SOT_CORE_DISABLE_WARNING_PUSH | ||
245 | SOT_CORE_DISABLE_WARNING_FALLTHROUGH | ||
246 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
1 | switch (controlInputType_) { |
247 | ✗ | case CONTROL_INPUT_TWO_INTEGRATION: | |
248 | ✗ | dgRTLOG() | |
249 | << "Sanity check for this control is not well supported. " | ||
250 | "In order to make it work, use pinocchio and the contact forces " | ||
251 | ✗ | "to estimate the joint torques for the given acceleration.\n"; | |
252 | ✗ | if (s != lowerTorque_.size() || s != upperTorque_.size()) { | |
253 | ✗ | std::ostringstream os; | |
254 | os << "dynamicgraph::sot::Device::setState: upper and/or lower torque" | ||
255 | ✗ | "bounds do not match state size. Input State size = " | |
256 | ✗ | << st.size() << ", lowerTorque_.size() = " << lowerTorque_.size() | |
257 | ✗ | << ", upperTorque_.size() = " << upperTorque_.size() | |
258 | ✗ | << ". Set them first with setTorqueBounds."; | |
259 | ✗ | throw std::invalid_argument(os.str().c_str()); | |
260 | // fall through | ||
261 | } | ||
262 | case CONTROL_INPUT_ONE_INTEGRATION: | ||
263 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
|
1 | if (s != lowerVelocity_.size() || s != upperVelocity_.size()) { |
264 | ✗ | std::ostringstream os; | |
265 | os << "dynamicgraph::sot::Device::setState: upper and/or lower " | ||
266 | "velocity" | ||
267 | ✗ | " bounds do not match state size. Input State size = " | |
268 | ✗ | << st.size() | |
269 | ✗ | << ", lowerVelocity_.size() = " << lowerVelocity_.size() | |
270 | ✗ | << ", upperVelocity_.size() = " << upperVelocity_.size() | |
271 | ✗ | << ". Set them first with setVelocityBounds."; | |
272 | ✗ | throw std::invalid_argument(os.str().c_str()); | |
273 | } | ||
274 | // fall through | ||
275 | case CONTROL_INPUT_NO_INTEGRATION: | ||
276 | 1 | break; | |
277 | ✗ | default: | |
278 | ✗ | throw std::invalid_argument("Invalid control mode type."); | |
279 | } | ||
280 | SOT_CORE_DISABLE_WARNING_POP | ||
281 | } | ||
282 | 1 | state_ = st; | |
283 | 1 | stateSOUT.setConstant(state_); | |
284 | 1 | motorcontrolSOUT.setConstant(state_); | |
285 | 1 | } | |
286 | |||
287 | 1 | void Device::setVelocity(const Vector &vel) { | |
288 | 1 | velocity_ = vel; | |
289 | 1 | velocitySOUT.setConstant(velocity_); | |
290 | 1 | } | |
291 | |||
292 | ✗ | void Device::setRoot(const Matrix &root) { | |
293 | ✗ | Eigen::Matrix4d _matrix4d(root); | |
294 | ✗ | MatrixHomogeneous _root(_matrix4d); | |
295 | ✗ | setRoot(_root); | |
296 | } | ||
297 | |||
298 | ✗ | void Device::setRoot(const MatrixHomogeneous &worldMwaist) { | |
299 | ✗ | VectorRollPitchYaw r = (worldMwaist.linear().eulerAngles(2, 1, 0)).reverse(); | |
300 | ✗ | Vector q = state_; | |
301 | ✗ | q = worldMwaist.translation(); // abusive ... but working. | |
302 | ✗ | for (unsigned int i = 0; i < 3; ++i) q(i + 3) = r(i); | |
303 | } | ||
304 | |||
305 | ✗ | void Device::setSecondOrderIntegration() { | |
306 | ✗ | controlInputType_ = CONTROL_INPUT_TWO_INTEGRATION; | |
307 | ✗ | velocity_.resize(state_.size()); | |
308 | ✗ | velocity_.setZero(); | |
309 | ✗ | velocitySOUT.setConstant(velocity_); | |
310 | } | ||
311 | |||
312 | ✗ | void Device::setNoIntegration() { | |
313 | ✗ | controlInputType_ = CONTROL_INPUT_NO_INTEGRATION; | |
314 | ✗ | velocity_.resize(state_.size()); | |
315 | ✗ | velocity_.setZero(); | |
316 | ✗ | velocitySOUT.setConstant(velocity_); | |
317 | } | ||
318 | |||
319 | ✗ | void Device::setControlInputType(const std::string &cit) { | |
320 | ✗ | for (int i = 0; i < CONTROL_INPUT_SIZE; i++) | |
321 | ✗ | if (cit == ControlInput_s[i]) { | |
322 | ✗ | controlInputType_ = (ControlInput)i; | |
323 | sotDEBUG(25) << "Control input type: " << ControlInput_s[i] << endl; | ||
324 | ✗ | return; | |
325 | } | ||
326 | sotDEBUG(25) << "Unrecognized control input type: " << cit << endl; | ||
327 | } | ||
328 | |||
329 | ✗ | void Device::setSanityCheck(const bool &enableCheck) { | |
330 | ✗ | if (enableCheck) { | |
331 | ✗ | const Vector::Index &s = state_.size(); | |
332 | SOT_CORE_DISABLE_WARNING_PUSH | ||
333 | SOT_CORE_DISABLE_WARNING_FALLTHROUGH | ||
334 | ✗ | switch (controlInputType_) { | |
335 | ✗ | case CONTROL_INPUT_TWO_INTEGRATION: | |
336 | ✗ | dgRTLOG() | |
337 | << "Sanity check for this control is not well supported. " | ||
338 | "In order to make it work, use pinocchio and the contact forces " | ||
339 | ✗ | "to estimate the joint torques for the given acceleration.\n"; | |
340 | ✗ | if (s != lowerTorque_.size() || s != upperTorque_.size()) | |
341 | ✗ | throw std::invalid_argument( | |
342 | "Upper and/or lower torque bounds " | ||
343 | ✗ | "do not match state size. Set them first with setTorqueBounds"); | |
344 | // fall through | ||
345 | case CONTROL_INPUT_ONE_INTEGRATION: | ||
346 | ✗ | if (s != lowerVelocity_.size() || s != upperVelocity_.size()) | |
347 | ✗ | throw std::invalid_argument( | |
348 | "Upper and/or lower velocity bounds " | ||
349 | ✗ | "do not match state size. Set them first with setVelocityBounds"); | |
350 | // fall through | ||
351 | case CONTROL_INPUT_NO_INTEGRATION: | ||
352 | ✗ | if (s != lowerPosition_.size() || s != upperPosition_.size()) | |
353 | ✗ | throw std::invalid_argument( | |
354 | "Upper and/or lower position bounds " | ||
355 | ✗ | "do not match state size. Set them first with setPositionBounds"); | |
356 | ✗ | break; | |
357 | ✗ | default: | |
358 | ✗ | throw std::invalid_argument("Invalid control mode type."); | |
359 | } | ||
360 | SOT_CORE_DISABLE_WARNING_POP | ||
361 | } | ||
362 | ✗ | sanityCheck_ = enableCheck; | |
363 | } | ||
364 | |||
365 | 1 | void Device::setPositionBounds(const Vector &lower, const Vector &upper) { | |
366 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | std::ostringstream oss; |
367 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 1 times.
|
1 | if (lower.size() != state_.size()) { |
368 | ✗ | oss << "Lower bound size should be " << state_.size() << ", got " | |
369 | ✗ | << lower.size(); | |
370 | ✗ | throw std::invalid_argument(oss.str()); | |
371 | } | ||
372 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 1 times.
|
1 | if (upper.size() != state_.size()) { |
373 | ✗ | oss << "Upper bound size should be " << state_.size() << ", got " | |
374 | ✗ | << upper.size(); | |
375 | ✗ | throw std::invalid_argument(oss.str()); | |
376 | } | ||
377 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | lowerPosition_ = lower; |
378 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | upperPosition_ = upper; |
379 | 1 | } | |
380 | |||
381 | 1 | void Device::setVelocityBounds(const Vector &lower, const Vector &upper) { | |
382 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | std::ostringstream oss; |
383 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 1 times.
|
1 | if (lower.size() != velocity_.size()) { |
384 | ✗ | oss << "Lower bound size should be " << velocity_.size() << ", got " | |
385 | ✗ | << lower.size(); | |
386 | ✗ | throw std::invalid_argument(oss.str()); | |
387 | } | ||
388 |
1/2✗ Branch 2 not taken.
✓ Branch 3 taken 1 times.
|
1 | if (upper.size() != velocity_.size()) { |
389 | ✗ | oss << "Upper bound size should be " << velocity_.size() << ", got " | |
390 | ✗ | << upper.size(); | |
391 | ✗ | throw std::invalid_argument(oss.str()); | |
392 | } | ||
393 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | lowerVelocity_ = lower; |
394 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | upperVelocity_ = upper; |
395 | 1 | } | |
396 | |||
397 | ✗ | void Device::setTorqueBounds(const Vector &lower, const Vector &upper) { | |
398 | // TODO I think the torque bounds size are state_.size()-6... | ||
399 | ✗ | std::ostringstream oss; | |
400 | ✗ | if (lower.size() != state_.size()) { | |
401 | ✗ | oss << "Lower bound size should be " << state_.size() << ", got " | |
402 | ✗ | << lower.size(); | |
403 | ✗ | throw std::invalid_argument(oss.str()); | |
404 | } | ||
405 | ✗ | if (upper.size() != state_.size()) { | |
406 | ✗ | oss << "Lower bound size should be " << state_.size() << ", got " | |
407 | ✗ | << upper.size(); | |
408 | ✗ | throw std::invalid_argument(oss.str()); | |
409 | } | ||
410 | ✗ | lowerTorque_ = lower; | |
411 | ✗ | upperTorque_ = upper; | |
412 | } | ||
413 | |||
414 | 2000 | void Device::increment(const double &dt) { | |
415 | 2000 | int time = stateSOUT.getTime(); | |
416 | sotDEBUG(25) << "Time : " << time << std::endl; | ||
417 | |||
418 | // Run Synchronous commands and evaluate signals outside the main | ||
419 | // connected component of the graph. | ||
420 | try { | ||
421 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | periodicCallBefore_.run(time + 1); |
422 | ✗ | } catch (std::exception &e) { | |
423 | ✗ | dgRTLOG() << "exception caught while running periodical commands (before): " | |
424 | ✗ | << e.what() << std::endl; | |
425 | ✗ | } catch (const char *str) { | |
426 | ✗ | dgRTLOG() << "exception caught while running periodical commands (before): " | |
427 | ✗ | << str << std::endl; | |
428 | ✗ | } catch (...) { | |
429 | ✗ | dgRTLOG() << "unknown exception caught while" | |
430 | ✗ | << " running periodical commands (before)" << std::endl; | |
431 | } | ||
432 | |||
433 | /* Force the recomputation of the control. */ | ||
434 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | controlSIN(time); |
435 | sotDEBUG(25) << "u" << time << " = " << controlSIN.accessCopy() << endl; | ||
436 | |||
437 | /* Integration of numerical values. This function is virtual. */ | ||
438 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | integrate(dt); |
439 | sotDEBUG(25) << "q" << time << " = " << state_ << endl; | ||
440 | |||
441 | /* Position the signals corresponding to sensors. */ | ||
442 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | stateSOUT.setConstant(state_); |
443 | 2000 | stateSOUT.setTime(time + 1); | |
444 | // computation of the velocity signal | ||
445 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 2000 times.
|
2000 | if (controlInputType_ == CONTROL_INPUT_TWO_INTEGRATION) { |
446 | ✗ | velocitySOUT.setConstant(velocity_); | |
447 | ✗ | velocitySOUT.setTime(time + 1); | |
448 |
1/2✓ Branch 0 taken 2000 times.
✗ Branch 1 not taken.
|
2000 | } else if (controlInputType_ == CONTROL_INPUT_ONE_INTEGRATION) { |
449 |
2/4✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
|
2000 | velocitySOUT.setConstant(controlSIN.accessCopy()); |
450 | 2000 | velocitySOUT.setTime(time + 1); | |
451 | } | ||
452 |
2/2✓ Branch 0 taken 8000 times.
✓ Branch 1 taken 2000 times.
|
10000 | for (int i = 0; i < 4; ++i) { |
453 |
2/4✓ Branch 0 taken 8000 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 8000 times.
✗ Branch 4 not taken.
|
8000 | if (!withForceSignals[i]) forcesSOUT[i]->setConstant(forceZero6); |
454 | } | ||
455 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | Vector zmp(3); |
456 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | zmp.fill(.0); |
457 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | ZMPPreviousControllerSOUT.setConstant(zmp); |
458 | |||
459 | // Run Synchronous commands and evaluate signals outside the main | ||
460 | // connected component of the graph. | ||
461 | try { | ||
462 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | periodicCallAfter_.run(time + 1); |
463 | ✗ | } catch (std::exception &e) { | |
464 | ✗ | dgRTLOG() << "exception caught while running periodical commands (after): " | |
465 | ✗ | << e.what() << std::endl; | |
466 | ✗ | } catch (const char *str) { | |
467 | ✗ | dgRTLOG() << "exception caught while running periodical commands (after): " | |
468 | ✗ | << str << std::endl; | |
469 | ✗ | } catch (...) { | |
470 | ✗ | dgRTLOG() << "unknown exception caught while" | |
471 | ✗ | << " running periodical commands (after)" << std::endl; | |
472 | } | ||
473 | |||
474 | // Others signals. | ||
475 |
1/2✓ Branch 1 taken 2000 times.
✗ Branch 2 not taken.
|
2000 | motorcontrolSOUT.setConstant(state_); |
476 | 2000 | } | |
477 | |||
478 | // Return true if it saturates. | ||
479 | 152000 | inline bool saturateBounds(double &val, const double &lower, | |
480 | const double &upper) { | ||
481 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 152000 times.
|
152000 | assert(lower <= upper); |
482 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 152000 times.
|
152000 | if (val < lower) { |
483 | ✗ | val = lower; | |
484 | ✗ | return true; | |
485 | } | ||
486 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 152000 times.
|
152000 | if (upper < val) { |
487 | ✗ | val = upper; | |
488 | ✗ | return true; | |
489 | } | ||
490 | 152000 | return false; | |
491 | } | ||
492 | |||
493 | #define CHECK_BOUNDS(val, lower, upper, what) \ | ||
494 | for (int i = 0; i < val.size(); ++i) { \ | ||
495 | double old = val(i); \ | ||
496 | if (saturateBounds(val(i), lower(i), upper(i))) { \ | ||
497 | std::ostringstream oss; \ | ||
498 | oss << "Robot " what " bound violation at DoF " << i << ": requested " \ | ||
499 | << old << " but set " << val(i) << '\n'; \ | ||
500 | SEND_ERROR_STREAM_MSG(oss.str()); \ | ||
501 | } \ | ||
502 | } | ||
503 | |||
504 | 2000 | void Device::integrate(const double &dt) { | |
505 | 2000 | const Vector &controlIN = controlSIN.accessCopy(); | |
506 | |||
507 |
3/6✓ Branch 0 taken 2000 times.
✗ Branch 1 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 2000 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2000 times.
|
2000 | if (sanityCheck_ && controlIN.hasNaN()) { |
508 | ✗ | dgRTLOG() << "Device::integrate: Control has NaN values: " << '\n' | |
509 | ✗ | << controlIN.transpose() << '\n'; | |
510 | ✗ | return; | |
511 | } | ||
512 | |||
513 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 2000 times.
|
2000 | if (controlInputType_ == CONTROL_INPUT_NO_INTEGRATION) { |
514 | ✗ | state_.tail(controlIN.size()) = controlIN; | |
515 | ✗ | return; | |
516 | } | ||
517 | |||
518 |
3/4✓ Branch 1 taken 1 times.
✓ Branch 2 taken 1999 times.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
|
2000 | if (vel_control_.size() == 0) vel_control_ = Vector::Zero(controlIN.size()); |
519 | |||
520 | // If control size is state size - 6, integrate joint angles, | ||
521 | // if control and state are of same size, integrate 6 first degrees of | ||
522 | // freedom as a translation and roll pitch yaw. | ||
523 | |||
524 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 2000 times.
|
2000 | if (controlInputType_ == CONTROL_INPUT_TWO_INTEGRATION) { |
525 | // TODO check acceleration | ||
526 | // Position increment | ||
527 | ✗ | vel_control_ = velocity_.tail(controlIN.size()) + (0.5 * dt) * controlIN; | |
528 | // Velocity integration. | ||
529 | ✗ | velocity_.tail(controlIN.size()) += controlIN * dt; | |
530 | } else { | ||
531 | 2000 | vel_control_ = controlIN; | |
532 | } | ||
533 | |||
534 | // Velocity bounds check | ||
535 |
1/2✓ Branch 0 taken 2000 times.
✗ Branch 1 not taken.
|
2000 | if (sanityCheck_) { |
536 |
3/28✗ Branch 5 not taken.
✓ Branch 6 taken 76000 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 20 not taken.
✗ Branch 21 not taken.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
✗ Branch 36 not taken.
✗ Branch 37 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✓ Branch 49 taken 76000 times.
✓ Branch 50 taken 2000 times.
|
78000 | CHECK_BOUNDS(velocity_, lowerVelocity_, upperVelocity_, "velocity"); |
537 | } | ||
538 | |||
539 |
1/2✓ Branch 2 taken 2000 times.
✗ Branch 3 not taken.
|
2000 | if (vel_control_.size() == state_.size()) { |
540 | // Freeflyer integration | ||
541 | 2000 | integrateRollPitchYaw(state_, vel_control_, dt); | |
542 | // Joints integration | ||
543 |
3/6✓ Branch 3 taken 2000 times.
✗ Branch 4 not taken.
✓ Branch 7 taken 2000 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 2000 times.
✗ Branch 11 not taken.
|
2000 | state_.tail(state_.size() - 6) += vel_control_.tail(state_.size() - 6) * dt; |
544 | } else { | ||
545 | // Position integration | ||
546 | ✗ | state_.tail(controlIN.size()) += vel_control_ * dt; | |
547 | } | ||
548 | |||
549 | // Position bounds check | ||
550 |
1/2✓ Branch 0 taken 2000 times.
✗ Branch 1 not taken.
|
2000 | if (sanityCheck_) { |
551 |
3/28✗ Branch 5 not taken.
✓ Branch 6 taken 76000 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 20 not taken.
✗ Branch 21 not taken.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
✗ Branch 36 not taken.
✗ Branch 37 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✓ Branch 49 taken 76000 times.
✓ Branch 50 taken 2000 times.
|
78000 | CHECK_BOUNDS(state_, lowerPosition_, upperPosition_, "position"); |
552 | } | ||
553 | } | ||
554 | |||
555 | /* --- DISPLAY ------------------------------------------------------------ */ | ||
556 | |||
557 | 1 | void Device::display(std::ostream &os) const { | |
558 | 1 | os << name << ": " << state_ << endl | |
559 | 1 | << "sanityCheck: " << sanityCheck_ << endl | |
560 | 1 | << "controlInputType:" << controlInputType_ << endl; | |
561 | 1 | } | |
562 | |||
563 | 1 | void Device::cmdDisplay() { | |
564 | 1 | std::cout << name << ": " << state_ << endl | |
565 | 1 | << "sanityCheck: " << sanityCheck_ << endl | |
566 | 1 | << "controlInputType:" << controlInputType_ << endl; | |
567 | 1 | } | |
568 |