00001 #!/usr/bin/python 00002 # Software License Agreement (BSD License) 00003 # 00004 # Copyright (c) 2014, PAL Robotics SL. 00005 # All rights reserved. 00006 # 00007 # Redistribution and use in source and binary forms, with or without 00008 # modification, are permitted provided that the following conditions 00009 # are met: 00010 # 00011 # * Redistributions of source code must retain the above copyright 00012 # notice, this list of conditions and the following disclaimer. 00013 # * Redistributions in binary form must reproduce the above 00014 # copyright notice, this list of conditions and the following 00015 # disclaimer in the documentation and/or other materials provided 00016 # with the distribution. 00017 # * Neither the name of the PAL Robotics nor the names of its 00018 # contributors may be used to endorse or promote products derived 00019 # from this software without specific prior written permission. 00020 # 00021 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00022 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00023 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00024 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 00025 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00026 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00027 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00028 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00029 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00030 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 00031 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00032 # POSSIBILITY OF SUCH DAMAGE. 00033 # 00034 # author: Bence Magyar 00035 00036 #Offers a service to find the principal directions and bounding box of a point cluster 00037 00038 import rospy 00039 import tf 00040 from object_recognition_msgs.msg import RecognizedObjectArray 00041 import object_recognition_clusters.cluster_bounding_box_finder as cluster_bounding_box_finder 00042 #import object_recognition_clusters.cluster_bounding_box_finder_3d as cluster_bounding_box_finder_3d 00043 00044 class ClusterToPose: 00045 00046 def __init__(self): 00047 self.tf_listener = tf.TransformListener() 00048 self.tf_broadcaster = tf.TransformBroadcaster() 00049 self.cbbf = cluster_bounding_box_finder.ClusterBoundingBoxFinder(self.tf_listener, self.tf_broadcaster) 00050 # self.cbbf3d = cluster_bounding_box_finder_3d.ClusterBoundingBoxFinder3D(self.tf_listener) 00051 00052 rospy.Subscriber("/recognized_object_array", RecognizedObjectArray, self.callback) 00053 00054 def callback(self, data): 00055 rospy.loginfo(rospy.get_name() + ": This message contains %d objects." % len(data.objects)) 00056 # for myobject in data.objects: 00057 #print object.point_clouds[0] 00058 myobject = data.objects[0] 00059 self.cbbf.find_object_frame_and_bounding_box(myobject.point_clouds[0]) 00060 00061 if __name__ == '__main__': 00062 rospy.init_node('clusters_to_pose', anonymous=True) 00063 clusters_to_pose = ClusterToPose() 00064 rospy.loginfo("cluster bounding box finder is ready for queries") 00065 rospy.spin() 00066