object_detectors_manager.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 
3 '''
4 Copyright (c) 2016, Allgeyer Tobias, Aumann Florian, Borella Jocelyn, Hutmacher Robin, Karrenbauer Oliver, Marek Felix, Meissner Pascal, Trautmann Jeremias, Wittenbeck Valerij
5 
6 All rights reserved.
7 
8 Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
9 
10 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
11 
12 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
13 
14 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
15 
16 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
17 '''
18 
19 import roslib
20 import rospy
21 from asr_msgs.msg import AsrObject
22 from asr_world_model.srv import PushFoundObject, PushFoundObjectList
23 import asr_aruco_marker_recognition.srv
24 import asr_fake_object_recognition.srv
25 from asr_world_model.srv import GetRecognizerName
26 import asr_descriptor_surface_based_recognition.srv
27 
29 
30  def __init__(self):
31  pass
32 
33  def start_recognizers_descriptor(self, searched_object_types):
34  try:
35  rospy.wait_for_service(
36  '/asr_descriptor_surface_based_recognition/get_recognizer',
37  timeout=3)
38  descriptor_recognizer = rospy.ServiceProxy(
39  '/asr_descriptor_surface_based_recognition/get_recognizer',
40  asr_descriptor_surface_based_recognition.srv.GetRecognizer)
41  except (rospy.exceptions.ROSException, rospy.ServiceException) as e:
42  rospy.logwarn("Service error with descriptor recognizer")
43  return 'aborted'
44  descriptor_recognizer(searched_object_types, 1, False)
45  rospy.loginfo('Descriptor_surface_recognition started for ' + str(searched_object_types))
46  return 'succeeded'
47 
48  def start_markers(self):
49  try:
50  rospy.wait_for_service(
51  '/asr_aruco_marker_recognition/get_recognizer',
52  timeout=3)
53  marker_recognizer = rospy.ServiceProxy(
54  '/asr_aruco_marker_recognition/get_recognizer',
55  asr_aruco_marker_recognition.srv.GetRecognizer)
56  marker_recognizer()
57  except (rospy.exceptions.ROSException, rospy.ServiceException) as e:
58  rospy.logwarn("Service error with marker recognizer")
59  return 'aborted'
60  rospy.loginfo('Marker recognition started')
61  return 'succeeded'
62 
63  def stop_recognizers_descriptor(self, searched_object_types):
64  release_descriptor_recognizer = None
65  try:
66  release_descriptor_recognizer = rospy.ServiceProxy(
67  '/asr_descriptor_surface_based_recognition/release_recognizer',
68  asr_descriptor_surface_based_recognition.srv.ReleaseRecognizer)
69  except rospy.ServiceException, e:
70  rospy.logwarn("Error calling the release recognizer services for descriptor recognition.")
71  return 'aborted'
72  release_descriptor_recognizer(searched_object_types)
73  rospy.loginfo("Recognition of "+str(searched_object_types)+" released for descriptor_surface_based.")
74  return 'succeeded'
75 
76  def stop_markers(self):
77  try:
78  release_marker_recognizer = rospy.ServiceProxy(
79  '/asr_aruco_marker_recognition/release_recognizer',
80  asr_aruco_marker_recognition.srv.ReleaseRecognizer)
81  except rospy.ServiceException, e:
82  rospy.logwarn("Error calling the release recognizer services for marker recognition.")
83  return 'aborted'
84  release_marker_recognizer()
85  rospy.loginfo("Marker recognition released.")
86  return 'succeeded'
87 
88  def start_recognizers_sim(self,searched_object_types):
89  fake_recognizer = None
90  try:
91  fake_recognizer = rospy.ServiceProxy(
92  '/asr_fake_object_recognition/get_recognizer',
93  asr_fake_object_recognition.srv.GetRecognizer)
94 
95  except rospy.ServiceException, e:
96  rospy.logwarn("Error calling \'get\' fake based recognizer service.")
97  return 'aborted'
98  for object in searched_object_types:
99  fake_recognizer(str(object))
100  rospy.loginfo('Fake_object_recognition started for ' + str(searched_object_types))
101  return 'succeeded'
102 
103 
104  def stop_recognizers_sim(self,searched_object_types):
105  fake_recognizer = None
106  try:
107  fake_recognizer = rospy.ServiceProxy(
108  '/asr_fake_object_recognition/release_recognizer',
109  asr_fake_object_recognition.srv.ReleaseRecognizer)
110 
111  except rospy.ServiceException, e:
112  rospy.logwarn("Error calling \'release\' fake based recognizer service.")
113  return 'aborted'
114  for object in searched_object_types:
115  fake_recognizer(str(object))
116  rospy.loginfo("Recognition of "+str(searched_object_types)+" released for asr_fake_object_recognition.")
117  return 'succeeded'
118 
119 
120  def start_recognizers(self,searched_object_types):
121 
122  rospy.loginfo('Preparing to start recognizers for objects ' + str(searched_object_types))
123  if rospy.get_param("/scene_exploration_sm/use_sensors") is True:
124  try:
125  recognizer_name_call = rospy.ServiceProxy(
126  '/env/asr_world_model/get_recognizer_name',
127  GetRecognizerName)
128  except rospy.ServiceException, e:
129  rospy.logwarn("Error calling get recognizer name service.")
130  return 'aborted'
131 
132  marker_started = False
133  for object in searched_object_types:
134  if 'marker' in object:
135  if marker_started is False:
136  rospy.loginfo('Calling start marker recognition.')
137  self.start_markers()
138  marker_started = True
139  else:
140  recognizer_name = recognizer_name_call(str(object)).recognizer_name
141  if str(recognizer_name) == 'descriptor':
142  rospy.loginfo('Calling descriptor recognition for object ' + object)
143  self.start_recognizers_descriptor(object)
144  else:
145  rospy.logwarn("Error using unknown recognizer name " + str(recognizer_name))
146  return 'aborted'
147  else:
148  return self.start_recognizers_sim(searched_object_types)
149 
150  def stop_recognizers(self,searched_object_types):
151 
152  rospy.loginfo('Preparing to stop recognizers for objects ' + str(searched_object_types))
153  if rospy.get_param("/scene_exploration_sm/use_sensors") is True:
154  try:
155  recognizer_name_call = rospy.ServiceProxy(
156  '/env/asr_world_model/get_recognizer_name',
157  GetRecognizerName)
158  except rospy.ServiceException, e:
159  rospy.logwarn("Error calling get recognizer name service.")
160  return 'aborted'
161 
162  marker_stopped = False
163  for object in searched_object_types:
164  if 'marker' in object:
165  if marker_stopped is False:
166  rospy.loginfo('Calling stop marker recognition.')
167  self.stop_markers()
168  marker_stopped = True
169  else:
170  recognizer_name = recognizer_name_call(str(object)).recognizer_name
171  if str(recognizer_name) == 'descriptor':
172  rospy.loginfo("Calling release descriptor for object " + object)
173  self.stop_recognizers_descriptor(object)
174  else:
175  rospy.loginfo("aborted")
176  return 'aborted'
177  else:
178  return self.stop_recognizers_sim(searched_object_types)


asr_state_machine
Author(s): Allgeyer Tobias, Aumann Florian, Borella Jocelyn, Hutmacher Robin, Karrenbauer Oliver, Marek Felix, Meißner Pascal, Trautmann Jeremias, Wittenbeck Valerij
autogenerated on Mon Feb 28 2022 21:53:50