catchrobo2022 / Mbed 2 deprecated catchrobo2022_mbed

Dependencies:   mbed

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers ModelCoefficientsArray.h Source File

ModelCoefficientsArray.h

00001 #ifndef _ROS_jsk_recognition_msgs_ModelCoefficientsArray_h
00002 #define _ROS_jsk_recognition_msgs_ModelCoefficientsArray_h
00003 
00004 #include <stdint.h>
00005 #include <string.h>
00006 #include <stdlib.h>
00007 #include "ros/msg.h"
00008 #include "std_msgs/Header.h"
00009 #include "pcl_msgs/ModelCoefficients.h"
00010 
00011 namespace jsk_recognition_msgs
00012 {
00013 
00014   class ModelCoefficientsArray : public ros::Msg
00015   {
00016     public:
00017       typedef std_msgs::Header _header_type;
00018       _header_type header;
00019       uint32_t coefficients_length;
00020       typedef pcl_msgs::ModelCoefficients _coefficients_type;
00021       _coefficients_type st_coefficients;
00022       _coefficients_type * coefficients;
00023 
00024     ModelCoefficientsArray():
00025       header(),
00026       coefficients_length(0), coefficients(NULL)
00027     {
00028     }
00029 
00030     virtual int serialize(unsigned char *outbuffer) const
00031     {
00032       int offset = 0;
00033       offset += this->header.serialize(outbuffer + offset);
00034       *(outbuffer + offset + 0) = (this->coefficients_length >> (8 * 0)) & 0xFF;
00035       *(outbuffer + offset + 1) = (this->coefficients_length >> (8 * 1)) & 0xFF;
00036       *(outbuffer + offset + 2) = (this->coefficients_length >> (8 * 2)) & 0xFF;
00037       *(outbuffer + offset + 3) = (this->coefficients_length >> (8 * 3)) & 0xFF;
00038       offset += sizeof(this->coefficients_length);
00039       for( uint32_t i = 0; i < coefficients_length; i++){
00040       offset += this->coefficients[i].serialize(outbuffer + offset);
00041       }
00042       return offset;
00043     }
00044 
00045     virtual int deserialize(unsigned char *inbuffer)
00046     {
00047       int offset = 0;
00048       offset += this->header.deserialize(inbuffer + offset);
00049       uint32_t coefficients_lengthT = ((uint32_t) (*(inbuffer + offset))); 
00050       coefficients_lengthT |= ((uint32_t) (*(inbuffer + offset + 1))) << (8 * 1); 
00051       coefficients_lengthT |= ((uint32_t) (*(inbuffer + offset + 2))) << (8 * 2); 
00052       coefficients_lengthT |= ((uint32_t) (*(inbuffer + offset + 3))) << (8 * 3); 
00053       offset += sizeof(this->coefficients_length);
00054       if(coefficients_lengthT > coefficients_length)
00055         this->coefficients = (pcl_msgs::ModelCoefficients*)realloc(this->coefficients, coefficients_lengthT * sizeof(pcl_msgs::ModelCoefficients));
00056       coefficients_length = coefficients_lengthT;
00057       for( uint32_t i = 0; i < coefficients_length; i++){
00058       offset += this->st_coefficients.deserialize(inbuffer + offset);
00059         memcpy( &(this->coefficients[i]), &(this->st_coefficients), sizeof(pcl_msgs::ModelCoefficients));
00060       }
00061      return offset;
00062     }
00063 
00064     virtual const char * getType(){ return "jsk_recognition_msgs/ModelCoefficientsArray"; };
00065     virtual const char * getMD5(){ return "059efee897c3f4ae027a493e30c4c26b"; };
00066 
00067   };
00068 
00069 }
00070 #endif