ObjectCollisionAvoidanceVelCore.h
Go to the documentation of this file.
1// namespace armarx::control::njoint_controller::core
2/*
3 * This file is part of ArmarX.
4 *
5 * ArmarX is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
8 *
9 * ArmarX is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 *
17 * @package ...
18 * @author Jianfeng Gao ( jianfeng dot gao at kit dot edu )
19 * @date 2024
20 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
21 * GNU General Public License
22 */
23
24#pragma once
25
26#include <VirtualRobot/Robot.h>
27
28#include <simox/control/dynamics/RBDLModel.h>
29#include <simox/control/environment/CollisionRobotInterface.h>
30#include <simox/control/environment/fwd.h>
31#include <simox/control/impl/simox/robot/Robot.h>
32#include <simox/control/robot/RobotInterface.h>
33
35
37#include <armarx/control/common/control_law/aron/ObjectCollisionAvoidanceVelConfig.aron.generated.h>
38
40{
41
42 namespace law = armarx::control::common::control_law;
43
44 /**
45 * @defgroup Library-ObjectCollisionAvoidanceVelBase ObjectCollisionAvoidanceVelBase
46 * @ingroup Library-RobotUnit-NJointControllers
47 * A description of the library ObjectCollisionAvoidanceVelBase.
48 *
49 * @class ObjectCollisionAvoidanceVelBase
50 * @ingroup Library-CollisionAvoidanceBase
51 * @brief Brief description of class ObjectCollisionAvoidanceVelBase.
52 *
53 * Detailed description of class ObjectCollisionAvoidanceVelBase.
54 */
56 {
57
58 public:
59 using SCRobot = law::CollisionAvoidanceVelController::SCRobot;
60 using DistanceResults = law::CollisionAvoidanceVelController::DistanceResults;
61 using CollisionRobotIndices = law::CollisionAvoidanceVelController::CollisionRobotIndices;
62 using CtrlConfig = law::arondto::ObjectCollisionAvoidanceVelConfig;
63 using Config = law::arondto::ObjectCollisionAvoidanceVelConfigDict;
64 using RtStatus = law::CollisionAvoidanceVelController::RtStatusForSafetyStrategy;
65 using RecoveryState = law::CollisionAvoidanceVelController::RecoveryState;
66 using CollisionRobot = simox::control::environment::CollisionRobotInterface;
67 using DynamicsModel = simox::control::dynamics::RBDLModel;
68
70 {
71 std::string nodeSetName;
72
73 /// !!!!!!! Note that, all the data below should only be accessed in rt thread !!!!!!!
74 VirtualRobot::RobotNodeSetPtr rtRNS;
75
76 /// controller (maths)
77 law::ObjectCollisionAvoidanceVelController controller;
78 RtStatus rts; // should only be used in rt thread
79
80 /// recovery strategy
83
86
87 /// self-collision avoidance
88 std::unique_ptr<DynamicsModel> dynamicsModel;
91
93 const std::string& robotNodeSetName,
94 const SCRobot& scRobot,
96 const Config& c);
97
98 void reset(const Config& c);
99 };
100
103
104 virtual void rtCollisionChecking();
105 void rtLimbControllerRun(const std::string& robotNodeSetName,
106 const Eigen::VectorXf& qpos,
107 const Eigen::VectorXf& qvelFiltered,
108 float velocityLimit,
109 const Eigen::VectorXf& trajFollowJointVel,
110 double deltaT);
111 void rtPreActivate();
112 void rtPostDeactivate();
114
115 std::vector<hpp::fcl::CollisionObject> userCollisionObjects;
117 void updateUserCollisionObjects(const std::vector<hpp::fcl::CollisionObject>&);
120
121 std::map<std::string, NodeSetData> collLimb;
122 Config userCfg; // used in nonRT
124
125 void validateConfigData(const Config& cfg);
126 void setUserCfg(const Config& cfg);
127
128 // TODO make protected again, publish collision geometry
129 std::unique_ptr<CollisionRobot> collisionRobot;
131
132
133 protected:
135 std::unique_ptr<SCRobot> scRobot;
136 VirtualRobot::RobotNodeSetPtr scRobotNodeSet;
137
141
142 std::vector<std::string> actuatedJointNames;
143 Eigen::VectorXd qposActuatedJoints;
144
145 std::vector<unsigned int> translationJointIndex;
146 //int qposActuatedJointsIndex;
147
148 /// !!! individualColObjects has to be set to true !!!
149 /// if not set to true, the body and the arms become attractive, be aware
150 const simox::control::environment::CompDistArgs compDistArgs =
151 simox::control::environment::CompDistArgs{.nearestPoints = true,
152 .individualColObjects = true};
153
154 Config rtCfg; // used in RT
155
156 private:
157 float preFilterDistance = 0.6; // in meter
158 // int maxCollisionPairs = 100;
159
160 const bool reduceModel = false; // TODO check here! not needed anymore for a7, but for a6
161
162 simox::control::environment::CompDistArgs selfColAvoidanceArgs;
163
165 std::vector<hpp::fcl::CollisionObject> rtCollisionObjects;
166 VirtualRobot::RobotNodeSetPtr rtRobotNodeSet;
167 };
168
169 using ObjectCollisionAvoidanceVelBasePtr = std::shared_ptr<ObjectCollisionAvoidanceVelBase>;
170} // namespace armarx::control::njoint_controller::core
constexpr T c
A simple triple buffer for lockfree comunication between a single writer and a single reader.
law::CollisionAvoidanceVelController::CollisionRobotIndices CollisionRobotIndices
law::CollisionAvoidanceVelController::RtStatusForSafetyStrategy RtStatus
ObjectCollisionAvoidanceVelBase(const VirtualRobot::RobotPtr &rtRobot, const Config &cfg)
armarx::TripleBuffer< std::tuple< DistanceResults, std::vector< hpp::fcl::CollisionObject > > > bufferCollisionObjectsUserToRt
void rtLimbControllerRun(const std::string &robotNodeSetName, const Eigen::VectorXf &qpos, const Eigen::VectorXf &qvelFiltered, float velocityLimit, const Eigen::VectorXf &trajFollowJointVel, double deltaT)
std::shared_ptr< class Robot > RobotPtr
Definition Bus.h:19
std::shared_ptr< ObjectCollisionAvoidanceVelBase > ObjectCollisionAvoidanceVelBasePtr
VirtualRobot::RobotNodeSetPtr rtRNS
!!!!!!! Note that, all the data below should only be accessed in rt thread !!!!!!!
NodeSetData(const VirtualRobot::RobotPtr &rtRobot, const std::string &robotNodeSetName, const SCRobot &scRobot, const DistanceResults &collisionPairs, const Config &c)