3 #include <SimoxUtility/json.h>
4 #include <SimoxUtility/math/compare/is_equal.h>
5 #include <SimoxUtility/math/convert/mat4f_to_pos.h>
6 #include <SimoxUtility/math/convert/mat4f_to_quat.h>
7 #include <VirtualRobot/MathTools.h>
8 #include <VirtualRobot/Nodes/RobotNode.h>
9 #include <VirtualRobot/Nodes/Sensor.h>
10 #include <VirtualRobot/RobotNodeSet.h>
27 ARMARX_INFO <<
"Initializing force torque sensor " <<
c.sensorName;
28 const SensorValueBase* svlf = robotUnit->getSensorDevice(
c.sensorName)->getSensorValue();
32 sensorNode = rns->getRobot()->getSensor(
c.sensorName)->getRobotNode();
34 if (
c.sensorName ==
"FT R")
39 else if (
c.sensorName ==
"FT L")
47 filteredForce.setZero();
48 filteredTorque.setZero();
49 filteredForceInRoot.setZero();
50 filteredTorqueInRoot.setZero();
52 tcpGravityCompensation.setZero();
53 tcpGravForceVec.setZero();
54 tcpGravTorqueVec.setZero();
97 forceOffset.setZero();
98 torqueOffset.setZero();
102 timeForCalibration = 0.0f;
104 safeGuardForceOffset.setZero();
105 safeGuardTorqueOffset.setZero();
107 safeGuardEnabledForce.store(
false);
108 safeGuardEnabledTorque.store(
false);
110 resetForceGuard.store(
true);
111 resetTorqueGuard.store(
true);
129 sensorOriInRoot = sensorNode->getOrientationInRootFrame();
130 rawForce = forceSensor->
force;
131 rawTorque = forceSensor->
torque;
156 if (
c.enableSafeGuardForce and resetForceGuard.load())
158 safeGuardForceOffset = filteredForceInRoot;
159 ARMARX_INFO <<
"Resetting force safe guard with baseline "
160 <<
VAROUT(filteredForceInRoot);
161 safeGuardEnabledForce.store(
true);
162 resetForceGuard.store(
false);
164 if (
c.enableSafeGuardTorque and resetTorqueGuard.load())
166 safeGuardTorqueOffset = filteredTorqueInRoot;
167 safeGuardEnabledTorque.store(
true);
168 resetTorqueGuard.store(
false);
175 if (enableForceGuard)
177 resetForceGuard.store(
true);
179 if (enableTorqueGuard)
181 resetTorqueGuard.store(
true);
188 return safeGuardEnabledForce.load();
194 return safeGuardEnabledTorque.load();
201 (
c.enableSafeGuardForce and
202 (filteredForceInRoot - safeGuardForceOffset).norm() >
c.safeGuardForceThreshold) or
203 (
c.enableSafeGuardTorque and
204 (filteredTorqueInRoot - safeGuardTorqueOffset).norm() >
c.safeGuardTorqueThreshold);
205 ftSafe.store(not unsafeFlag);
215 forceOffset = (1 -
c.ftFilter) * forceOffset +
216 c.ftFilter * (forceSensor->
force -
217 sensorOriInRoot.transpose() * tcpGravityCompensation.head<3>());
218 torqueOffset = (1 -
c.ftFilter) * torqueOffset +
219 c.ftFilter * (forceSensor->
torque - sensorOriInRoot.transpose() *
220 tcpGravityCompensation.tail<3>());
222 timeForCalibration = timeForCalibration + deltaT;
223 if (timeForCalibration >
c.timeLimit)
228 "FT calibration done \n"
229 "-- force offset: [%.2f, %.2f, %.2f] \n"
230 "-- torque offset: [%.2f, %.2f, %.2f] \n"
231 "-- gravity compensation: [%.2f, %.2f, %.2f, %.2f, %.2f, %.2f]",
238 tcpGravityCompensation(0),
239 tcpGravityCompensation(1),
240 tcpGravityCompensation(2),
241 tcpGravityCompensation(3),
242 tcpGravityCompensation(4),
243 tcpGravityCompensation(5));
271 if (
c.enableTCPGravityCompensation)
274 tcpGravForceVec = tcpMass * gravity.head<3>();
275 tcpGravTorqueVec = (sensorOriInRoot * tcpCoMInFTSensorFrame).
cross(tcpGravForceVec);
282 tcpGravityCompensation.head<3>() = tcpGravForceVec;
283 tcpGravityCompensation.tail<3>() = tcpGravTorqueVec;
287 tcpGravityCompensation.setZero();
289 return tcpGravityCompensation;
295 filteredForce = (1 -
c.ftFilter) * filteredForce +
c.ftFilter * rawForce;
296 filteredTorque = (1 -
c.ftFilter) * filteredTorque +
c.ftFilter * rawTorque;
298 filteredForceInRoot = sensorOriInRoot * (filteredForce - forceOffset) -
299 tcpGravityCompensation.head<3>() -
c.forceBaseline;
300 filteredTorqueInRoot = sensorOriInRoot * (filteredTorque - torqueOffset) -
301 tcpGravityCompensation.tail<3>() -
c.torqueBaseline;
303 for (
size_t i = 0; i < 3; ++i)
305 if (fabs(filteredForceInRoot(i)) >
c.deadZoneForce)
307 filteredForceInRoot(i) -=
308 (filteredForceInRoot(i) / fabs(filteredForceInRoot(i))) *
c.deadZoneForce;
312 filteredForceInRoot(i) = 0;
315 if (fabs(filteredTorqueInRoot(i)) >
c.deadZoneTorque)
317 filteredTorqueInRoot(i) -=
318 (filteredTorqueInRoot(i) / fabs(filteredTorqueInRoot(i))) *
c.deadZoneTorque;
322 filteredTorqueInRoot(i) = 0;
326 ft.head<3>() = filteredForceInRoot;
327 ft.tail<3>() = filteredTorqueInRoot;
334 return safeGuardForceOffset;