self_mask_urdf_robot.h
Go to the documentation of this file.
1 #ifndef JSK_PCL_ROS_SELF_MASK_URDF_ROBOT_
2 #define JSK_PCL_ROS_SELF_MASK_URDF_ROBOT_
3 
5 #include <kdl/tree.hpp>
6 #include <kdl/chainjnttojacsolver.hpp>
7 #include <kdl/chainfksolverpos_recursive.hpp>
10 #include <tf_conversions/tf_kdl.h>
12 #include <sensor_msgs/JointState.h>
13 #include <geometry_msgs/PoseStamped.h>
14 
15 namespace robot_self_filter
16 {
17  class SelfMaskUrdfRobot : public SelfMask<pcl::PointXYZ>
18  {
19  public:
22  const std::vector<LinkInfo> &links,
23  const urdf::Model &urdf_model,
24  std::string root_link_id = "BODY",
25  std::string world_frame_id = "map",
26  bool set_foot_pose = false)
27  : SelfMask<pcl::PointXYZ>(tfl, links),
28  tf_broadcaster_(tfb),
29  urdf_model_(urdf_model),
30  root_link_id_(root_link_id),
31  world_frame_id_(world_frame_id)
32  {
33  ros::NodeHandle pnh("~");
34  pnh.param("publish_tf", publish_tf_, false);
36  }
37 
39  {
40  // generate kdl tree
42  ROS_FATAL("Failed to load robot_description");
43  return false;
44  }
45  // generate kdl tree
46  for(unsigned int i = 0 ; i < bodies_.size() ; i++) {
47  std::string name = bodies_[i].name;
48  tree_.getChain(root_link_id_, name, chain_map_[name]);
49  for(size_t j = 0; j < chain_map_[name].getNrOfSegments(); j++) {
50  ROS_DEBUG_STREAM("kdl_chain(" << j << ") "
51  << chain_map_[name].getSegment(j).getJoint().getName().c_str());
52  }
53  }
54  return true;
55  }
56 
57  void updateChain(std::map<std::string, double>& joint_angles,
58  KDL::Chain& chain,
59  tf::Pose& output_pose)
60  {
61  // solve forward kinematics
62  KDL::JntArray jnt_pos(chain.getNrOfJoints());
63  for (int i = 0, j = 0; i < chain.getNrOfSegments(); i++) {
64  std::string joint_name = chain.getSegment(i).getJoint().getName();
65  if (joint_angles.find(joint_name) != joint_angles.end()) {
66  jnt_pos(j++) = joint_angles[joint_name];
67  }
68  }
69  KDL::ChainFkSolverPos_recursive fk_solver(chain);
70  KDL::Frame pose;
71  if (fk_solver.JntToCart(jnt_pos, pose) < 0) {
72  ROS_FATAL("Failed to compute FK");
73  }
74  tf::poseKDLToTF(pose, output_pose);
75  }
76 
77  void updateRobotModel(std::map<std::string, double>& joint_angles, const tf::Pose& root_pose)
78  {
79  // for debug
80  /* std::map<std::string, double> joint_angles; */
81  /* for(std::map<std::string, boost::shared_ptr<urdf::Joint> >::iterator it = urdf_model_.joints_.begin(); it != urdf_model_.joints_.end(); ++it) { */
82  /* joint_angles[it->first] = 0.0; */
83  /* } */
84 
85  for(std::map<std::string, double>::iterator it = joint_angles.begin(); it != joint_angles.end(); ++it) {
86  ROS_DEBUG_STREAM("joint " << it->first << " : " << it->second);
87  }
88 
89  for(unsigned int i = 0 ; i < bodies_.size() ; i++) {
90  std::string name = bodies_[i].name;
91  updateChain(joint_angles, chain_map_[name], pose_map_[name]);
92  pose_map_[name] = root_pose * pose_map_[name];
93  }
94 
95  // publish tf of all links
96  if(publish_tf_) {
97  std::vector<tf::StampedTransform> link_transforms;
98  for(unsigned int i = 0 ; i < bodies_.size() ; i++) {
99  std::string name = bodies_[i].name;
100  tf::Pose link_trans = pose_map_[name];
102  link_transforms.push_back(tf::StampedTransform(link_trans, stamp, world_frame_id_, "collision_detector/"+name));
103  ROS_DEBUG_STREAM("link trans [" << name <<
104  "] pos=( " << link_trans.getOrigin().getX() << ", " << link_trans.getOrigin().getY() << ", " << link_trans.getOrigin().getZ() <<
105  ") rot=( " << link_trans.getRotation().getW() << ", " << link_trans.getRotation().getX() << ", " << link_trans.getRotation().getY() << ", " << link_trans.getRotation().getZ() << ")");
106  }
107  tf_broadcaster_.sendTransform(link_transforms);
108  }
109  }
110 
111  void assumeFrameFromJointAngle(const sensor_msgs::JointState& joint, const geometry_msgs::PoseStamped& pose)
112  {
113  std::map<std::string, double> joint_angles;
114  for (size_t i = 0; i < joint.name.size(); i++) {
115  joint_angles[joint.name[i]] = joint.position[i];
116  }
117  tf::Pose tf_pose;
118  tf::poseMsgToTF(pose.pose, tf_pose);
119  updateRobotModel(joint_angles, tf_pose);
120 
121  // update pose of all links
122  for(int i = 0; i < bodies_.size(); i++) {
123  std::string name = bodies_[i].name;
124  // pose_map_ should be the transformation from world frame to link frame.
125  bodies_[i].body->setPose(pose_map_[name] * bodies_[i].constTransf);
126  bodies_[i].unscaledBody->setPose(pose_map_[name] * bodies_[i].constTransf);
127  }
128 
130  }
131 
132  protected:
134  KDL::Tree tree_;
135  std::map<std::string, KDL::Chain> chain_map_;
136  std::map<std::string, tf::Pose> pose_map_;
138  std::string world_frame_id_;
139  std::string root_link_id_;
141  };
142 
143 }
144 
145 #endif
tf::Transform::getRotation
Quaternion getRotation() const
pcl
robot_self_filter::SelfMaskUrdfRobot::updateChain
void updateChain(std::map< std::string, double > &joint_angles, KDL::Chain &chain, tf::Pose &output_pose)
Definition: self_mask_urdf_robot.h:57
robot_self_filter::SelfMask< pcl::PointXYZ >::computeBoundingSpheres
void computeBoundingSpheres(void)
robot_self_filter::SelfMaskUrdfRobot::pose_map_
std::map< std::string, tf::Pose > pose_map_
Definition: self_mask_urdf_robot.h:136
tf::TransformBroadcaster::sendTransform
void sendTransform(const geometry_msgs::TransformStamped &transform)
tf::poseMsgToTF
static void poseMsgToTF(const geometry_msgs::Pose &msg, Pose &bt)
robot_self_filter::SelfMaskUrdfRobot::tree_
KDL::Tree tree_
Definition: self_mask_urdf_robot.h:134
i
int i
attention_pose_set.stamp
stamp
Definition: attention_pose_set.py:15
robot_self_filter::SelfMaskUrdfRobot::initKdlConfigure
bool initKdlConfigure()
Definition: self_mask_urdf_robot.h:38
getName
ROSCONSOLE_CONSOLE_IMPL_DECL std::string getName(void *handle)
robot_self_filter::SelfMaskUrdfRobot::root_link_id_
std::string root_link_id_
Definition: self_mask_urdf_robot.h:139
urdf::Model
tf::StampedTransform
ROS_DEBUG_STREAM
#define ROS_DEBUG_STREAM(args)
kdl_parser::treeFromUrdfModel
KDL_PARSER_PUBLIC bool treeFromUrdfModel(const urdf::ModelInterface &robot_model, KDL::Tree &tree)
robot_self_filter::SelfMaskUrdfRobot::publish_tf_
bool publish_tf_
Definition: self_mask_urdf_robot.h:140
transform_broadcaster.h
pose
pose
name
std::string name
tf::TransformBroadcaster
tf::poseKDLToTF
void poseKDLToTF(const KDL::Frame &k, tf::Pose &t)
robot_self_filter::SelfMaskUrdfRobot::SelfMaskUrdfRobot
SelfMaskUrdfRobot(tf::TransformListener &tfl, tf::TransformBroadcaster &tfb, const std::vector< LinkInfo > &links, const urdf::Model &urdf_model, std::string root_link_id="BODY", std::string world_frame_id="map", bool set_foot_pose=false)
Definition: self_mask_urdf_robot.h:20
robot_self_filter::SelfMaskUrdfRobot::urdf_model_
urdf::Model urdf_model_
Definition: self_mask_urdf_robot.h:133
kdl_msg.h
robot_self_filter::SelfMask< pcl::PointXYZ >::bodies_
std::vector< SeeLink > bodies_
robot_self_filter
robot_self_filter::SelfMaskUrdfRobot::world_frame_id_
std::string world_frame_id_
Definition: self_mask_urdf_robot.h:138
tf::Quaternion::getW
const TFSIMD_FORCE_INLINE tfScalar & getW() const
robot_self_filter::SelfMaskUrdfRobot::tf_broadcaster_
tf::TransformBroadcaster & tf_broadcaster_
Definition: self_mask_urdf_robot.h:137
tf::Transform
ROS_FATAL
#define ROS_FATAL(...)
kdl_parser.hpp
robot_self_filter::SelfMaskUrdfRobot::chain_map_
std::map< std::string, KDL::Chain > chain_map_
Definition: self_mask_urdf_robot.h:135
ros::Time
robot_self_filter::SelfMaskUrdfRobot
Definition: self_mask_urdf_robot.h:17
robot_self_filter::SelfMaskUrdfRobot::updateRobotModel
void updateRobotModel(std::map< std::string, double > &joint_angles, const tf::Pose &root_pose)
Definition: self_mask_urdf_robot.h:77
tf_kdl.h
tf::TransformListener
ros::NodeHandle::param
T param(const std::string &param_name, const T &default_val) const
self_mask.h
robot_self_filter::SelfMaskUrdfRobot::assumeFrameFromJointAngle
void assumeFrameFromJointAngle(const sensor_msgs::JointState &joint, const geometry_msgs::PoseStamped &pose)
Definition: self_mask_urdf_robot.h:111
robot_self_filter::SelfMask
tf::Transform::getOrigin
TFSIMD_FORCE_INLINE Vector3 & getOrigin()
ros::NodeHandle
ros::Time::now
static Time now()


jsk_pcl_ros
Author(s): Yohei Kakiuchi
autogenerated on Tue Jan 7 2025 04:05:45