00001 """autogenerated by genpy from srs_leg_detector/DetectLegsRequest.msg. Do not edit."""
00002 import sys
00003 python3 = True if sys.hexversion > 0x03000000 else False
00004 import genpy
00005 import struct
00006 
00007 
00008 class DetectLegsRequest(genpy.Message):
00009   _md5sum = "d41d8cd98f00b204e9800998ecf8427e"
00010   _type = "srs_leg_detector/DetectLegsRequest"
00011   _has_header = False 
00012   _full_text = """
00013 
00014 """
00015   __slots__ = []
00016   _slot_types = []
00017 
00018   def __init__(self, *args, **kwds):
00019     """
00020     Constructor. Any message fields that are implicitly/explicitly
00021     set to None will be assigned a default value. The recommend
00022     use is keyword arguments as this is more robust to future message
00023     changes.  You cannot mix in-order arguments and keyword arguments.
00024 
00025     The available fields are:
00026        
00027 
00028     :param args: complete set of field values, in .msg order
00029     :param kwds: use keyword arguments corresponding to message field names
00030     to set specific fields.
00031     """
00032     if args or kwds:
00033       super(DetectLegsRequest, self).__init__(*args, **kwds)
00034 
00035   def _get_types(self):
00036     """
00037     internal API method
00038     """
00039     return self._slot_types
00040 
00041   def serialize(self, buff):
00042     """
00043     serialize message into buffer
00044     :param buff: buffer, ``StringIO``
00045     """
00046     try:
00047       pass
00048     except struct.error as se: self._check_types(se)
00049     except TypeError as te: self._check_types(te)
00050 
00051   def deserialize(self, str):
00052     """
00053     unpack serialized message in str into this message instance
00054     :param str: byte array of serialized message, ``str``
00055     """
00056     try:
00057       end = 0
00058       return self
00059     except struct.error as e:
00060       raise genpy.DeserializationError(e) 
00061 
00062 
00063   def serialize_numpy(self, buff, numpy):
00064     """
00065     serialize message with numpy array types into buffer
00066     :param buff: buffer, ``StringIO``
00067     :param numpy: numpy python module
00068     """
00069     try:
00070       pass
00071     except struct.error as se: self._check_types(se)
00072     except TypeError as te: self._check_types(te)
00073 
00074   def deserialize_numpy(self, str, numpy):
00075     """
00076     unpack serialized message in str into this message instance using numpy for array types
00077     :param str: byte array of serialized message, ``str``
00078     :param numpy: numpy python module
00079     """
00080     try:
00081       end = 0
00082       return self
00083     except struct.error as e:
00084       raise genpy.DeserializationError(e) 
00085 
00086 _struct_I = genpy.struct_I
00087 """autogenerated by genpy from srs_leg_detector/DetectLegsResponse.msg. Do not edit."""
00088 import sys
00089 python3 = True if sys.hexversion > 0x03000000 else False
00090 import genpy
00091 import struct
00092 
00093 import geometry_msgs.msg
00094 import std_msgs.msg
00095 import sensor_msgs.msg
00096 
00097 class DetectLegsResponse(genpy.Message):
00098   _md5sum = "941854f3e81fd64b94eaa0d5b1ad95e1"
00099   _type = "srs_leg_detector/DetectLegsResponse"
00100   _has_header = False 
00101   _full_text = """
00102 sensor_msgs/PointCloud leg_list
00103 
00104 
00105 ================================================================================
00106 MSG: sensor_msgs/PointCloud
00107 # This message holds a collection of 3d points, plus optional additional
00108 # information about each point.
00109 
00110 # Time of sensor data acquisition, coordinate frame ID.
00111 Header header
00112 
00113 # Array of 3d points. Each Point32 should be interpreted as a 3d point
00114 # in the frame given in the header.
00115 geometry_msgs/Point32[] points
00116 
00117 # Each channel should have the same number of elements as points array,
00118 # and the data in each channel should correspond 1:1 with each point.
00119 # Channel names in common practice are listed in ChannelFloat32.msg.
00120 ChannelFloat32[] channels
00121 
00122 ================================================================================
00123 MSG: std_msgs/Header
00124 # Standard metadata for higher-level stamped data types.
00125 # This is generally used to communicate timestamped data 
00126 # in a particular coordinate frame.
00127 # 
00128 # sequence ID: consecutively increasing ID 
00129 uint32 seq
00130 #Two-integer timestamp that is expressed as:
00131 # * stamp.secs: seconds (stamp_secs) since epoch
00132 # * stamp.nsecs: nanoseconds since stamp_secs
00133 # time-handling sugar is provided by the client library
00134 time stamp
00135 #Frame this data is associated with
00136 # 0: no frame
00137 # 1: global frame
00138 string frame_id
00139 
00140 ================================================================================
00141 MSG: geometry_msgs/Point32
00142 # This contains the position of a point in free space(with 32 bits of precision).
00143 # It is recommeded to use Point wherever possible instead of Point32.  
00144 # 
00145 # This recommendation is to promote interoperability.  
00146 #
00147 # This message is designed to take up less space when sending
00148 # lots of points at once, as in the case of a PointCloud.  
00149 
00150 float32 x
00151 float32 y
00152 float32 z
00153 ================================================================================
00154 MSG: sensor_msgs/ChannelFloat32
00155 # This message is used by the PointCloud message to hold optional data
00156 # associated with each point in the cloud. The length of the values
00157 # array should be the same as the length of the points array in the
00158 # PointCloud, and each value should be associated with the corresponding
00159 # point.
00160 
00161 # Channel names in existing practice include:
00162 #   "u", "v" - row and column (respectively) in the left stereo image.
00163 #              This is opposite to usual conventions but remains for
00164 #              historical reasons. The newer PointCloud2 message has no
00165 #              such problem.
00166 #   "rgb" - For point clouds produced by color stereo cameras. uint8
00167 #           (R,G,B) values packed into the least significant 24 bits,
00168 #           in order.
00169 #   "intensity" - laser or pixel intensity.
00170 #   "distance"
00171 
00172 # The channel name should give semantics of the channel (e.g.
00173 # "intensity" instead of "value").
00174 string name
00175 
00176 # The values array should be 1-1 with the elements of the associated
00177 # PointCloud.
00178 float32[] values
00179 
00180 """
00181   __slots__ = ['leg_list']
00182   _slot_types = ['sensor_msgs/PointCloud']
00183 
00184   def __init__(self, *args, **kwds):
00185     """
00186     Constructor. Any message fields that are implicitly/explicitly
00187     set to None will be assigned a default value. The recommend
00188     use is keyword arguments as this is more robust to future message
00189     changes.  You cannot mix in-order arguments and keyword arguments.
00190 
00191     The available fields are:
00192        leg_list
00193 
00194     :param args: complete set of field values, in .msg order
00195     :param kwds: use keyword arguments corresponding to message field names
00196     to set specific fields.
00197     """
00198     if args or kwds:
00199       super(DetectLegsResponse, self).__init__(*args, **kwds)
00200       #message fields cannot be None, assign default values for those that are
00201       if self.leg_list is None:
00202         self.leg_list = sensor_msgs.msg.PointCloud()
00203     else:
00204       self.leg_list = sensor_msgs.msg.PointCloud()
00205 
00206   def _get_types(self):
00207     """
00208     internal API method
00209     """
00210     return self._slot_types
00211 
00212   def serialize(self, buff):
00213     """
00214     serialize message into buffer
00215     :param buff: buffer, ``StringIO``
00216     """
00217     try:
00218       _x = self
00219       buff.write(_struct_3I.pack(_x.leg_list.header.seq, _x.leg_list.header.stamp.secs, _x.leg_list.header.stamp.nsecs))
00220       _x = self.leg_list.header.frame_id
00221       length = len(_x)
00222       if python3 or type(_x) == unicode:
00223         _x = _x.encode('utf-8')
00224         length = len(_x)
00225       buff.write(struct.pack('<I%ss'%length, length, _x))
00226       length = len(self.leg_list.points)
00227       buff.write(_struct_I.pack(length))
00228       for val1 in self.leg_list.points:
00229         _x = val1
00230         buff.write(_struct_3f.pack(_x.x, _x.y, _x.z))
00231       length = len(self.leg_list.channels)
00232       buff.write(_struct_I.pack(length))
00233       for val1 in self.leg_list.channels:
00234         _x = val1.name
00235         length = len(_x)
00236         if python3 or type(_x) == unicode:
00237           _x = _x.encode('utf-8')
00238           length = len(_x)
00239         buff.write(struct.pack('<I%ss'%length, length, _x))
00240         length = len(val1.values)
00241         buff.write(_struct_I.pack(length))
00242         pattern = '<%sf'%length
00243         buff.write(struct.pack(pattern, *val1.values))
00244     except struct.error as se: self._check_types(se)
00245     except TypeError as te: self._check_types(te)
00246 
00247   def deserialize(self, str):
00248     """
00249     unpack serialized message in str into this message instance
00250     :param str: byte array of serialized message, ``str``
00251     """
00252     try:
00253       if self.leg_list is None:
00254         self.leg_list = sensor_msgs.msg.PointCloud()
00255       end = 0
00256       _x = self
00257       start = end
00258       end += 12
00259       (_x.leg_list.header.seq, _x.leg_list.header.stamp.secs, _x.leg_list.header.stamp.nsecs,) = _struct_3I.unpack(str[start:end])
00260       start = end
00261       end += 4
00262       (length,) = _struct_I.unpack(str[start:end])
00263       start = end
00264       end += length
00265       if python3:
00266         self.leg_list.header.frame_id = str[start:end].decode('utf-8')
00267       else:
00268         self.leg_list.header.frame_id = str[start:end]
00269       start = end
00270       end += 4
00271       (length,) = _struct_I.unpack(str[start:end])
00272       self.leg_list.points = []
00273       for i in range(0, length):
00274         val1 = geometry_msgs.msg.Point32()
00275         _x = val1
00276         start = end
00277         end += 12
00278         (_x.x, _x.y, _x.z,) = _struct_3f.unpack(str[start:end])
00279         self.leg_list.points.append(val1)
00280       start = end
00281       end += 4
00282       (length,) = _struct_I.unpack(str[start:end])
00283       self.leg_list.channels = []
00284       for i in range(0, length):
00285         val1 = sensor_msgs.msg.ChannelFloat32()
00286         start = end
00287         end += 4
00288         (length,) = _struct_I.unpack(str[start:end])
00289         start = end
00290         end += length
00291         if python3:
00292           val1.name = str[start:end].decode('utf-8')
00293         else:
00294           val1.name = str[start:end]
00295         start = end
00296         end += 4
00297         (length,) = _struct_I.unpack(str[start:end])
00298         pattern = '<%sf'%length
00299         start = end
00300         end += struct.calcsize(pattern)
00301         val1.values = struct.unpack(pattern, str[start:end])
00302         self.leg_list.channels.append(val1)
00303       return self
00304     except struct.error as e:
00305       raise genpy.DeserializationError(e) #most likely buffer underfill
00306 
00307 
00308   def serialize_numpy(self, buff, numpy):
00309     """
00310     serialize message with numpy array types into buffer
00311     :param buff: buffer, ``StringIO``
00312     :param numpy: numpy python module
00313     """
00314     try:
00315       _x = self
00316       buff.write(_struct_3I.pack(_x.leg_list.header.seq, _x.leg_list.header.stamp.secs, _x.leg_list.header.stamp.nsecs))
00317       _x = self.leg_list.header.frame_id
00318       length = len(_x)
00319       if python3 or type(_x) == unicode:
00320         _x = _x.encode('utf-8')
00321         length = len(_x)
00322       buff.write(struct.pack('<I%ss'%length, length, _x))
00323       length = len(self.leg_list.points)
00324       buff.write(_struct_I.pack(length))
00325       for val1 in self.leg_list.points:
00326         _x = val1
00327         buff.write(_struct_3f.pack(_x.x, _x.y, _x.z))
00328       length = len(self.leg_list.channels)
00329       buff.write(_struct_I.pack(length))
00330       for val1 in self.leg_list.channels:
00331         _x = val1.name
00332         length = len(_x)
00333         if python3 or type(_x) == unicode:
00334           _x = _x.encode('utf-8')
00335           length = len(_x)
00336         buff.write(struct.pack('<I%ss'%length, length, _x))
00337         length = len(val1.values)
00338         buff.write(_struct_I.pack(length))
00339         pattern = '<%sf'%length
00340         buff.write(val1.values.tostring())
00341     except struct.error as se: self._check_types(se)
00342     except TypeError as te: self._check_types(te)
00343 
00344   def deserialize_numpy(self, str, numpy):
00345     """
00346     unpack serialized message in str into this message instance using numpy for array types
00347     :param str: byte array of serialized message, ``str``
00348     :param numpy: numpy python module
00349     """
00350     try:
00351       if self.leg_list is None:
00352         self.leg_list = sensor_msgs.msg.PointCloud()
00353       end = 0
00354       _x = self
00355       start = end
00356       end += 12
00357       (_x.leg_list.header.seq, _x.leg_list.header.stamp.secs, _x.leg_list.header.stamp.nsecs,) = _struct_3I.unpack(str[start:end])
00358       start = end
00359       end += 4
00360       (length,) = _struct_I.unpack(str[start:end])
00361       start = end
00362       end += length
00363       if python3:
00364         self.leg_list.header.frame_id = str[start:end].decode('utf-8')
00365       else:
00366         self.leg_list.header.frame_id = str[start:end]
00367       start = end
00368       end += 4
00369       (length,) = _struct_I.unpack(str[start:end])
00370       self.leg_list.points = []
00371       for i in range(0, length):
00372         val1 = geometry_msgs.msg.Point32()
00373         _x = val1
00374         start = end
00375         end += 12
00376         (_x.x, _x.y, _x.z,) = _struct_3f.unpack(str[start:end])
00377         self.leg_list.points.append(val1)
00378       start = end
00379       end += 4
00380       (length,) = _struct_I.unpack(str[start:end])
00381       self.leg_list.channels = []
00382       for i in range(0, length):
00383         val1 = sensor_msgs.msg.ChannelFloat32()
00384         start = end
00385         end += 4
00386         (length,) = _struct_I.unpack(str[start:end])
00387         start = end
00388         end += length
00389         if python3:
00390           val1.name = str[start:end].decode('utf-8')
00391         else:
00392           val1.name = str[start:end]
00393         start = end
00394         end += 4
00395         (length,) = _struct_I.unpack(str[start:end])
00396         pattern = '<%sf'%length
00397         start = end
00398         end += struct.calcsize(pattern)
00399         val1.values = numpy.frombuffer(str[start:end], dtype=numpy.float32, count=length)
00400         self.leg_list.channels.append(val1)
00401       return self
00402     except struct.error as e:
00403       raise genpy.DeserializationError(e) #most likely buffer underfill
00404 
00405 _struct_I = genpy.struct_I
00406 _struct_3I = struct.Struct("<3I")
00407 _struct_3f = struct.Struct("<3f")
00408 class DetectLegs(object):
00409   _type          = 'srs_leg_detector/DetectLegs'
00410   _md5sum = '941854f3e81fd64b94eaa0d5b1ad95e1'
00411   _request_class  = DetectLegsRequest
00412   _response_class = DetectLegsResponse