Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 import threading
00036 import time
00037
00038 import rospy
00039
00040
00041 class ParamUpdater(threading.Thread):
00042 '''
00043 Using dynamic_reconfigure that is passed in __init__, this thread updates
00044 the Dynamic Reconfigure server's value.
00045
00046 This class works for a single element in a single parameter.
00047 '''
00048
00049
00050
00051 def __init__(self, reconf):
00052 """
00053 :type reconf: dynamic_reconfigure
00054 """
00055 super(ParamUpdater, self).__init__()
00056 self.setDaemon(True)
00057
00058 self._reconf = reconf
00059 self._condition_variable = threading.Condition()
00060 self._configs_pending = {}
00061 self._timestamp_last_pending = None
00062 self._stop_flag = False
00063
00064 def run(self):
00065 _timestamp_last_commit = None
00066
00067 rospy.logdebug(' ParamUpdater started')
00068
00069 while not self._stop_flag:
00070 if _timestamp_last_commit >= self._timestamp_last_pending:
00071 with self._condition_variable:
00072 rospy.logdebug(' ParamUpdater loop 1.1')
00073 self._condition_variable.wait()
00074 rospy.logdebug(' ParamUpdater loop 1.2')
00075 rospy.logdebug(' ParamUpdater loop 2')
00076
00077 if self._stop_flag:
00078 return
00079
00080 _timestamp_last_commit = time.time()
00081 configs_tobe_updated = self._configs_pending.copy()
00082 self._configs_pending = {}
00083
00084 rospy.logdebug(' run last_commit={}, last_pend={}'.format(
00085 _timestamp_last_commit, self._timestamp_last_pending))
00086
00087 try:
00088 self._reconf.update_configuration(configs_tobe_updated)
00089 except rospy.ServiceException as ex:
00090 rospy.logdebug('Could not update configs due to {}'.format(
00091 ex.value))
00092 except Exception as exc:
00093 raise exc
00094
00095 def update(self, config):
00096 with self._condition_variable:
00097 for name, value in config.items():
00098 self._configs_pending[name] = value
00099
00100 self._timestamp_last_pending = time.time()
00101
00102 self._condition_variable.notify()
00103
00104 def stop(self):
00105 self._stop_flag = True
00106 with self._condition_variable:
00107 self._condition_variable.notify()