00001
00002 #ifndef CALIBRATION_MSGS_MESSAGE_LASERMEASUREMENT_H
00003 #define CALIBRATION_MSGS_MESSAGE_LASERMEASUREMENT_H
00004 #include <string>
00005 #include <vector>
00006 #include <ostream>
00007 #include "ros/serialization.h"
00008 #include "ros/builtin_message_traits.h"
00009 #include "ros/message_operations.h"
00010 #include "ros/message.h"
00011 #include "ros/time.h"
00012
00013 #include "std_msgs/Header.h"
00014 #include "sensor_msgs/JointState.h"
00015 #include "calibration_msgs/DenseLaserSnapshot.h"
00016 #include "sensor_msgs/Image.h"
00017 #include "calibration_msgs/CalibrationPattern.h"
00018 #include "calibration_msgs/JointStateCalibrationPattern.h"
00019
00020 namespace calibration_msgs
00021 {
00022 template <class ContainerAllocator>
00023 struct LaserMeasurement_ : public ros::Message
00024 {
00025 typedef LaserMeasurement_<ContainerAllocator> Type;
00026
00027 LaserMeasurement_()
00028 : header()
00029 , laser_id()
00030 , joint_points()
00031 , verbose(false)
00032 , snapshot()
00033 , laser_image()
00034 , image_features()
00035 , joint_features()
00036 {
00037 }
00038
00039 LaserMeasurement_(const ContainerAllocator& _alloc)
00040 : header(_alloc)
00041 , laser_id(_alloc)
00042 , joint_points(_alloc)
00043 , verbose(false)
00044 , snapshot(_alloc)
00045 , laser_image(_alloc)
00046 , image_features(_alloc)
00047 , joint_features(_alloc)
00048 {
00049 }
00050
00051 typedef ::std_msgs::Header_<ContainerAllocator> _header_type;
00052 ::std_msgs::Header_<ContainerAllocator> header;
00053
00054 typedef std::basic_string<char, std::char_traits<char>, typename ContainerAllocator::template rebind<char>::other > _laser_id_type;
00055 std::basic_string<char, std::char_traits<char>, typename ContainerAllocator::template rebind<char>::other > laser_id;
00056
00057 typedef std::vector< ::sensor_msgs::JointState_<ContainerAllocator> , typename ContainerAllocator::template rebind< ::sensor_msgs::JointState_<ContainerAllocator> >::other > _joint_points_type;
00058 std::vector< ::sensor_msgs::JointState_<ContainerAllocator> , typename ContainerAllocator::template rebind< ::sensor_msgs::JointState_<ContainerAllocator> >::other > joint_points;
00059
00060 typedef uint8_t _verbose_type;
00061 uint8_t verbose;
00062
00063 typedef ::calibration_msgs::DenseLaserSnapshot_<ContainerAllocator> _snapshot_type;
00064 ::calibration_msgs::DenseLaserSnapshot_<ContainerAllocator> snapshot;
00065
00066 typedef ::sensor_msgs::Image_<ContainerAllocator> _laser_image_type;
00067 ::sensor_msgs::Image_<ContainerAllocator> laser_image;
00068
00069 typedef ::calibration_msgs::CalibrationPattern_<ContainerAllocator> _image_features_type;
00070 ::calibration_msgs::CalibrationPattern_<ContainerAllocator> image_features;
00071
00072 typedef ::calibration_msgs::JointStateCalibrationPattern_<ContainerAllocator> _joint_features_type;
00073 ::calibration_msgs::JointStateCalibrationPattern_<ContainerAllocator> joint_features;
00074
00075
00076 ROS_DEPRECATED uint32_t get_joint_points_size() const { return (uint32_t)joint_points.size(); }
00077 ROS_DEPRECATED void set_joint_points_size(uint32_t size) { joint_points.resize((size_t)size); }
00078 ROS_DEPRECATED void get_joint_points_vec(std::vector< ::sensor_msgs::JointState_<ContainerAllocator> , typename ContainerAllocator::template rebind< ::sensor_msgs::JointState_<ContainerAllocator> >::other > & vec) const { vec = this->joint_points; }
00079 ROS_DEPRECATED void set_joint_points_vec(const std::vector< ::sensor_msgs::JointState_<ContainerAllocator> , typename ContainerAllocator::template rebind< ::sensor_msgs::JointState_<ContainerAllocator> >::other > & vec) { this->joint_points = vec; }
00080 private:
00081 static const char* __s_getDataType_() { return "calibration_msgs/LaserMeasurement"; }
00082 public:
00083 ROS_DEPRECATED static const std::string __s_getDataType() { return __s_getDataType_(); }
00084
00085 ROS_DEPRECATED const std::string __getDataType() const { return __s_getDataType_(); }
00086
00087 private:
00088 static const char* __s_getMD5Sum_() { return "03ce2d57df2a0cedc1a91dc4b40d7729"; }
00089 public:
00090 ROS_DEPRECATED static const std::string __s_getMD5Sum() { return __s_getMD5Sum_(); }
00091
00092 ROS_DEPRECATED const std::string __getMD5Sum() const { return __s_getMD5Sum_(); }
00093
00094 private:
00095 static const char* __s_getMessageDefinition_() { return "Header header\n\
00096 string laser_id\n\
00097 sensor_msgs/JointState[] joint_points\n\
00098 \n\
00099 # True -> The extra debugging fields are populated\n\
00100 bool verbose\n\
00101 \n\
00102 # Extra, partially processed data. Only needed for debugging\n\
00103 calibration_msgs/DenseLaserSnapshot snapshot\n\
00104 sensor_msgs/Image laser_image\n\
00105 calibration_msgs/CalibrationPattern image_features\n\
00106 calibration_msgs/JointStateCalibrationPattern joint_features\n\
00107 \n\
00108 ================================================================================\n\
00109 MSG: std_msgs/Header\n\
00110 # Standard metadata for higher-level stamped data types.\n\
00111 # This is generally used to communicate timestamped data \n\
00112 # in a particular coordinate frame.\n\
00113 # \n\
00114 # sequence ID: consecutively increasing ID \n\
00115 uint32 seq\n\
00116 #Two-integer timestamp that is expressed as:\n\
00117 # * stamp.secs: seconds (stamp_secs) since epoch\n\
00118 # * stamp.nsecs: nanoseconds since stamp_secs\n\
00119 # time-handling sugar is provided by the client library\n\
00120 time stamp\n\
00121 #Frame this data is associated with\n\
00122 # 0: no frame\n\
00123 # 1: global frame\n\
00124 string frame_id\n\
00125 \n\
00126 ================================================================================\n\
00127 MSG: sensor_msgs/JointState\n\
00128 # This is a message that holds data to describe the state of a set of torque controlled joints. \n\
00129 #\n\
00130 # The state of each joint (revolute or prismatic) is defined by:\n\
00131 # * the position of the joint (rad or m),\n\
00132 # * the velocity of the joint (rad/s or m/s) and \n\
00133 # * the effort that is applied in the joint (Nm or N).\n\
00134 #\n\
00135 # Each joint is uniquely identified by its name\n\
00136 # The header specifies the time at which the joint states were recorded. All the joint states\n\
00137 # in one message have to be recorded at the same time.\n\
00138 #\n\
00139 # This message consists of a multiple arrays, one for each part of the joint state. \n\
00140 # The goal is to make each of the fields optional. When e.g. your joints have no\n\
00141 # effort associated with them, you can leave the effort array empty. \n\
00142 #\n\
00143 # All arrays in this message should have the same size, or be empty.\n\
00144 # This is the only way to uniquely associate the joint name with the correct\n\
00145 # states.\n\
00146 \n\
00147 \n\
00148 Header header\n\
00149 \n\
00150 string[] name\n\
00151 float64[] position\n\
00152 float64[] velocity\n\
00153 float64[] effort\n\
00154 \n\
00155 ================================================================================\n\
00156 MSG: calibration_msgs/DenseLaserSnapshot\n\
00157 # Provides all the state & sensor information for\n\
00158 # a single sweep of laser attached to some mechanism.\n\
00159 # Most likely, this will be used with PR2's tilting laser mechanism\n\
00160 Header header\n\
00161 \n\
00162 # Store the laser intrinsics. This is very similar to the\n\
00163 # intrinsics commonly stored in \n\
00164 float32 angle_min # start angle of the scan [rad]\n\
00165 float32 angle_max # end angle of the scan [rad]\n\
00166 float32 angle_increment # angular distance between measurements [rad]\n\
00167 float32 time_increment # time between measurements [seconds]\n\
00168 float32 range_min # minimum range value [m]\n\
00169 float32 range_max # maximum range value [m]\n\
00170 \n\
00171 # Define the size of the binary data\n\
00172 uint32 readings_per_scan # (Width)\n\
00173 uint32 num_scans # (Height)\n\
00174 \n\
00175 # 2D Arrays storing laser data.\n\
00176 # We can think of each type data as being a single channel image.\n\
00177 # Each row of the image has data from a single scan, and scans are\n\
00178 # concatenated to form the entire 'image'.\n\
00179 float32[] ranges # (Image data)\n\
00180 float32[] intensities # (Image data)\n\
00181 \n\
00182 # Store the start time of each scan\n\
00183 time[] scan_start\n\
00184 \n\
00185 ================================================================================\n\
00186 MSG: sensor_msgs/Image\n\
00187 # This message contains an uncompressed image\n\
00188 # (0, 0) is at top-left corner of image\n\
00189 #\n\
00190 \n\
00191 Header header # Header timestamp should be acquisition time of image\n\
00192 # Header frame_id should be optical frame of camera\n\
00193 # origin of frame should be optical center of cameara\n\
00194 # +x should point to the right in the image\n\
00195 # +y should point down in the image\n\
00196 # +z should point into to plane of the image\n\
00197 # If the frame_id here and the frame_id of the CameraInfo\n\
00198 # message associated with the image conflict\n\
00199 # the behavior is undefined\n\
00200 \n\
00201 uint32 height # image height, that is, number of rows\n\
00202 uint32 width # image width, that is, number of columns\n\
00203 \n\
00204 # The legal values for encoding are in file src/image_encodings.cpp\n\
00205 # If you want to standardize a new string format, join\n\
00206 # ros-users@lists.sourceforge.net and send an email proposing a new encoding.\n\
00207 \n\
00208 string encoding # Encoding of pixels -- channel meaning, ordering, size\n\
00209 # taken from the list of strings in src/image_encodings.cpp\n\
00210 \n\
00211 uint8 is_bigendian # is this data bigendian?\n\
00212 uint32 step # Full row length in bytes\n\
00213 uint8[] data # actual matrix data, size is (step * rows)\n\
00214 \n\
00215 ================================================================================\n\
00216 MSG: calibration_msgs/CalibrationPattern\n\
00217 Header header\n\
00218 geometry_msgs/Point32[] object_points\n\
00219 ImagePoint[] image_points\n\
00220 uint8 success\n\
00221 \n\
00222 ================================================================================\n\
00223 MSG: geometry_msgs/Point32\n\
00224 # This contains the position of a point in free space(with 32 bits of precision).\n\
00225 # It is recommeded to use Point wherever possible instead of Point32. \n\
00226 # \n\
00227 # This recommendation is to promote interoperability. \n\
00228 #\n\
00229 # This message is designed to take up less space when sending\n\
00230 # lots of points at once, as in the case of a PointCloud. \n\
00231 \n\
00232 float32 x\n\
00233 float32 y\n\
00234 float32 z\n\
00235 ================================================================================\n\
00236 MSG: calibration_msgs/ImagePoint\n\
00237 float32 x\n\
00238 float32 y\n\
00239 \n\
00240 ================================================================================\n\
00241 MSG: calibration_msgs/JointStateCalibrationPattern\n\
00242 Header header\n\
00243 geometry_msgs/Point32[] object_points\n\
00244 sensor_msgs/JointState[] joint_points\n\
00245 \n\
00246 \n\
00247 "; }
00248 public:
00249 ROS_DEPRECATED static const std::string __s_getMessageDefinition() { return __s_getMessageDefinition_(); }
00250
00251 ROS_DEPRECATED const std::string __getMessageDefinition() const { return __s_getMessageDefinition_(); }
00252
00253 ROS_DEPRECATED virtual uint8_t *serialize(uint8_t *write_ptr, uint32_t seq) const
00254 {
00255 ros::serialization::OStream stream(write_ptr, 1000000000);
00256 ros::serialization::serialize(stream, header);
00257 ros::serialization::serialize(stream, laser_id);
00258 ros::serialization::serialize(stream, joint_points);
00259 ros::serialization::serialize(stream, verbose);
00260 ros::serialization::serialize(stream, snapshot);
00261 ros::serialization::serialize(stream, laser_image);
00262 ros::serialization::serialize(stream, image_features);
00263 ros::serialization::serialize(stream, joint_features);
00264 return stream.getData();
00265 }
00266
00267 ROS_DEPRECATED virtual uint8_t *deserialize(uint8_t *read_ptr)
00268 {
00269 ros::serialization::IStream stream(read_ptr, 1000000000);
00270 ros::serialization::deserialize(stream, header);
00271 ros::serialization::deserialize(stream, laser_id);
00272 ros::serialization::deserialize(stream, joint_points);
00273 ros::serialization::deserialize(stream, verbose);
00274 ros::serialization::deserialize(stream, snapshot);
00275 ros::serialization::deserialize(stream, laser_image);
00276 ros::serialization::deserialize(stream, image_features);
00277 ros::serialization::deserialize(stream, joint_features);
00278 return stream.getData();
00279 }
00280
00281 ROS_DEPRECATED virtual uint32_t serializationLength() const
00282 {
00283 uint32_t size = 0;
00284 size += ros::serialization::serializationLength(header);
00285 size += ros::serialization::serializationLength(laser_id);
00286 size += ros::serialization::serializationLength(joint_points);
00287 size += ros::serialization::serializationLength(verbose);
00288 size += ros::serialization::serializationLength(snapshot);
00289 size += ros::serialization::serializationLength(laser_image);
00290 size += ros::serialization::serializationLength(image_features);
00291 size += ros::serialization::serializationLength(joint_features);
00292 return size;
00293 }
00294
00295 typedef boost::shared_ptr< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > Ptr;
00296 typedef boost::shared_ptr< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> const> ConstPtr;
00297 };
00298 typedef ::calibration_msgs::LaserMeasurement_<std::allocator<void> > LaserMeasurement;
00299
00300 typedef boost::shared_ptr< ::calibration_msgs::LaserMeasurement> LaserMeasurementPtr;
00301 typedef boost::shared_ptr< ::calibration_msgs::LaserMeasurement const> LaserMeasurementConstPtr;
00302
00303
00304 template<typename ContainerAllocator>
00305 std::ostream& operator<<(std::ostream& s, const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> & v)
00306 {
00307 ros::message_operations::Printer< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> >::stream(s, "", v);
00308 return s;}
00309
00310 }
00311
00312 namespace ros
00313 {
00314 namespace message_traits
00315 {
00316 template<class ContainerAllocator>
00317 struct MD5Sum< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > {
00318 static const char* value()
00319 {
00320 return "03ce2d57df2a0cedc1a91dc4b40d7729";
00321 }
00322
00323 static const char* value(const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> &) { return value(); }
00324 static const uint64_t static_value1 = 0x03ce2d57df2a0cedULL;
00325 static const uint64_t static_value2 = 0xc1a91dc4b40d7729ULL;
00326 };
00327
00328 template<class ContainerAllocator>
00329 struct DataType< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > {
00330 static const char* value()
00331 {
00332 return "calibration_msgs/LaserMeasurement";
00333 }
00334
00335 static const char* value(const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> &) { return value(); }
00336 };
00337
00338 template<class ContainerAllocator>
00339 struct Definition< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > {
00340 static const char* value()
00341 {
00342 return "Header header\n\
00343 string laser_id\n\
00344 sensor_msgs/JointState[] joint_points\n\
00345 \n\
00346 # True -> The extra debugging fields are populated\n\
00347 bool verbose\n\
00348 \n\
00349 # Extra, partially processed data. Only needed for debugging\n\
00350 calibration_msgs/DenseLaserSnapshot snapshot\n\
00351 sensor_msgs/Image laser_image\n\
00352 calibration_msgs/CalibrationPattern image_features\n\
00353 calibration_msgs/JointStateCalibrationPattern joint_features\n\
00354 \n\
00355 ================================================================================\n\
00356 MSG: std_msgs/Header\n\
00357 # Standard metadata for higher-level stamped data types.\n\
00358 # This is generally used to communicate timestamped data \n\
00359 # in a particular coordinate frame.\n\
00360 # \n\
00361 # sequence ID: consecutively increasing ID \n\
00362 uint32 seq\n\
00363 #Two-integer timestamp that is expressed as:\n\
00364 # * stamp.secs: seconds (stamp_secs) since epoch\n\
00365 # * stamp.nsecs: nanoseconds since stamp_secs\n\
00366 # time-handling sugar is provided by the client library\n\
00367 time stamp\n\
00368 #Frame this data is associated with\n\
00369 # 0: no frame\n\
00370 # 1: global frame\n\
00371 string frame_id\n\
00372 \n\
00373 ================================================================================\n\
00374 MSG: sensor_msgs/JointState\n\
00375 # This is a message that holds data to describe the state of a set of torque controlled joints. \n\
00376 #\n\
00377 # The state of each joint (revolute or prismatic) is defined by:\n\
00378 # * the position of the joint (rad or m),\n\
00379 # * the velocity of the joint (rad/s or m/s) and \n\
00380 # * the effort that is applied in the joint (Nm or N).\n\
00381 #\n\
00382 # Each joint is uniquely identified by its name\n\
00383 # The header specifies the time at which the joint states were recorded. All the joint states\n\
00384 # in one message have to be recorded at the same time.\n\
00385 #\n\
00386 # This message consists of a multiple arrays, one for each part of the joint state. \n\
00387 # The goal is to make each of the fields optional. When e.g. your joints have no\n\
00388 # effort associated with them, you can leave the effort array empty. \n\
00389 #\n\
00390 # All arrays in this message should have the same size, or be empty.\n\
00391 # This is the only way to uniquely associate the joint name with the correct\n\
00392 # states.\n\
00393 \n\
00394 \n\
00395 Header header\n\
00396 \n\
00397 string[] name\n\
00398 float64[] position\n\
00399 float64[] velocity\n\
00400 float64[] effort\n\
00401 \n\
00402 ================================================================================\n\
00403 MSG: calibration_msgs/DenseLaserSnapshot\n\
00404 # Provides all the state & sensor information for\n\
00405 # a single sweep of laser attached to some mechanism.\n\
00406 # Most likely, this will be used with PR2's tilting laser mechanism\n\
00407 Header header\n\
00408 \n\
00409 # Store the laser intrinsics. This is very similar to the\n\
00410 # intrinsics commonly stored in \n\
00411 float32 angle_min # start angle of the scan [rad]\n\
00412 float32 angle_max # end angle of the scan [rad]\n\
00413 float32 angle_increment # angular distance between measurements [rad]\n\
00414 float32 time_increment # time between measurements [seconds]\n\
00415 float32 range_min # minimum range value [m]\n\
00416 float32 range_max # maximum range value [m]\n\
00417 \n\
00418 # Define the size of the binary data\n\
00419 uint32 readings_per_scan # (Width)\n\
00420 uint32 num_scans # (Height)\n\
00421 \n\
00422 # 2D Arrays storing laser data.\n\
00423 # We can think of each type data as being a single channel image.\n\
00424 # Each row of the image has data from a single scan, and scans are\n\
00425 # concatenated to form the entire 'image'.\n\
00426 float32[] ranges # (Image data)\n\
00427 float32[] intensities # (Image data)\n\
00428 \n\
00429 # Store the start time of each scan\n\
00430 time[] scan_start\n\
00431 \n\
00432 ================================================================================\n\
00433 MSG: sensor_msgs/Image\n\
00434 # This message contains an uncompressed image\n\
00435 # (0, 0) is at top-left corner of image\n\
00436 #\n\
00437 \n\
00438 Header header # Header timestamp should be acquisition time of image\n\
00439 # Header frame_id should be optical frame of camera\n\
00440 # origin of frame should be optical center of cameara\n\
00441 # +x should point to the right in the image\n\
00442 # +y should point down in the image\n\
00443 # +z should point into to plane of the image\n\
00444 # If the frame_id here and the frame_id of the CameraInfo\n\
00445 # message associated with the image conflict\n\
00446 # the behavior is undefined\n\
00447 \n\
00448 uint32 height # image height, that is, number of rows\n\
00449 uint32 width # image width, that is, number of columns\n\
00450 \n\
00451 # The legal values for encoding are in file src/image_encodings.cpp\n\
00452 # If you want to standardize a new string format, join\n\
00453 # ros-users@lists.sourceforge.net and send an email proposing a new encoding.\n\
00454 \n\
00455 string encoding # Encoding of pixels -- channel meaning, ordering, size\n\
00456 # taken from the list of strings in src/image_encodings.cpp\n\
00457 \n\
00458 uint8 is_bigendian # is this data bigendian?\n\
00459 uint32 step # Full row length in bytes\n\
00460 uint8[] data # actual matrix data, size is (step * rows)\n\
00461 \n\
00462 ================================================================================\n\
00463 MSG: calibration_msgs/CalibrationPattern\n\
00464 Header header\n\
00465 geometry_msgs/Point32[] object_points\n\
00466 ImagePoint[] image_points\n\
00467 uint8 success\n\
00468 \n\
00469 ================================================================================\n\
00470 MSG: geometry_msgs/Point32\n\
00471 # This contains the position of a point in free space(with 32 bits of precision).\n\
00472 # It is recommeded to use Point wherever possible instead of Point32. \n\
00473 # \n\
00474 # This recommendation is to promote interoperability. \n\
00475 #\n\
00476 # This message is designed to take up less space when sending\n\
00477 # lots of points at once, as in the case of a PointCloud. \n\
00478 \n\
00479 float32 x\n\
00480 float32 y\n\
00481 float32 z\n\
00482 ================================================================================\n\
00483 MSG: calibration_msgs/ImagePoint\n\
00484 float32 x\n\
00485 float32 y\n\
00486 \n\
00487 ================================================================================\n\
00488 MSG: calibration_msgs/JointStateCalibrationPattern\n\
00489 Header header\n\
00490 geometry_msgs/Point32[] object_points\n\
00491 sensor_msgs/JointState[] joint_points\n\
00492 \n\
00493 \n\
00494 ";
00495 }
00496
00497 static const char* value(const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> &) { return value(); }
00498 };
00499
00500 template<class ContainerAllocator> struct HasHeader< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > : public TrueType {};
00501 template<class ContainerAllocator> struct HasHeader< const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> > : public TrueType {};
00502 }
00503 }
00504
00505 namespace ros
00506 {
00507 namespace serialization
00508 {
00509
00510 template<class ContainerAllocator> struct Serializer< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> >
00511 {
00512 template<typename Stream, typename T> inline static void allInOne(Stream& stream, T m)
00513 {
00514 stream.next(m.header);
00515 stream.next(m.laser_id);
00516 stream.next(m.joint_points);
00517 stream.next(m.verbose);
00518 stream.next(m.snapshot);
00519 stream.next(m.laser_image);
00520 stream.next(m.image_features);
00521 stream.next(m.joint_features);
00522 }
00523
00524 ROS_DECLARE_ALLINONE_SERIALIZER;
00525 };
00526 }
00527 }
00528
00529 namespace ros
00530 {
00531 namespace message_operations
00532 {
00533
00534 template<class ContainerAllocator>
00535 struct Printer< ::calibration_msgs::LaserMeasurement_<ContainerAllocator> >
00536 {
00537 template<typename Stream> static void stream(Stream& s, const std::string& indent, const ::calibration_msgs::LaserMeasurement_<ContainerAllocator> & v)
00538 {
00539 s << indent << "header: ";
00540 s << std::endl;
00541 Printer< ::std_msgs::Header_<ContainerAllocator> >::stream(s, indent + " ", v.header);
00542 s << indent << "laser_id: ";
00543 Printer<std::basic_string<char, std::char_traits<char>, typename ContainerAllocator::template rebind<char>::other > >::stream(s, indent + " ", v.laser_id);
00544 s << indent << "joint_points[]" << std::endl;
00545 for (size_t i = 0; i < v.joint_points.size(); ++i)
00546 {
00547 s << indent << " joint_points[" << i << "]: ";
00548 s << std::endl;
00549 s << indent;
00550 Printer< ::sensor_msgs::JointState_<ContainerAllocator> >::stream(s, indent + " ", v.joint_points[i]);
00551 }
00552 s << indent << "verbose: ";
00553 Printer<uint8_t>::stream(s, indent + " ", v.verbose);
00554 s << indent << "snapshot: ";
00555 s << std::endl;
00556 Printer< ::calibration_msgs::DenseLaserSnapshot_<ContainerAllocator> >::stream(s, indent + " ", v.snapshot);
00557 s << indent << "laser_image: ";
00558 s << std::endl;
00559 Printer< ::sensor_msgs::Image_<ContainerAllocator> >::stream(s, indent + " ", v.laser_image);
00560 s << indent << "image_features: ";
00561 s << std::endl;
00562 Printer< ::calibration_msgs::CalibrationPattern_<ContainerAllocator> >::stream(s, indent + " ", v.image_features);
00563 s << indent << "joint_features: ";
00564 s << std::endl;
00565 Printer< ::calibration_msgs::JointStateCalibrationPattern_<ContainerAllocator> >::stream(s, indent + " ", v.joint_features);
00566 }
00567 };
00568
00569
00570 }
00571 }
00572
00573 #endif // CALIBRATION_MSGS_MESSAGE_LASERMEASUREMENT_H
00574