python_node.py
Go to the documentation of this file.
00001 #!/usr/bin/env python
00002 # Software License Agreement (BSD License)
00003 #
00004 #  Copyright (c) 2011, UC Regents
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 University of California 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 import roslib
00035 roslib.load_manifest('starmac_templates') # change this to your package name
00036 import rospy
00037 from starmac_roslib.timers import Timer
00038 # Message imports:
00039 # Make sure corresponding packages are listed as dependencies in package manifest!
00040 from std_msgs.msg import Bool, Float64
00041 
00042 class PythonNodeExample(object):
00043     """
00044     Example python node including reading parameters, publishers and subscribers, and timer.
00045     """
00046     def __init__(self):
00047         # Remember that init_node hasn't been called yet so only do stuff here that
00048         # doesn't require node handles etc.
00049         pass
00050 
00051     def start(self):
00052         rospy.init_node('python_node_example')
00053         self.init_params()
00054         self.init_vars()
00055         self.init_publishers()
00056         self.init_subscribers()
00057         self.init_timers()
00058         rospy.spin()
00059         
00060     def init_params(self):
00061         self.param_one = rospy.get_param("~param_one", 100.0)
00062         self.param_two = rospy.get_param("~param_two", False)
00063     
00064     def init_vars(self):
00065         self.some_variable = 42.0
00066         self.latest_input = None
00067 
00068     def init_publishers(self):
00069         self.bool_topic_pub = rospy.Publisher('bool_topic', Bool)
00070         
00071     def init_subscribers(self):
00072         self.some_input_sub = rospy.Subscriber('input_topic', Float64, self.some_input_callback)
00073       
00074     def init_timers(self):
00075         self.heartbeat_timer = Timer(rospy.Duration(1/10.0), self.heartbeat_timer_callback) # Call at 10 Hz
00076                                       
00077     def some_input_callback(self, msg):
00078         rospy.logdebug('Got input: ' + str(msg))
00079         self.latest_input = msg
00080         if self.latest_input.data > self.param_one:
00081             self.bool_topic_pub.publish(Bool(True))
00082         else:
00083             self.bool_topic_pub.publish(Bool(False))
00084     
00085     def heartbeat_timer_callback(self, event):
00086         if event.last_real is not None:
00087             dt = (event.current_real - event.last_real).to_sec()
00088             rospy.loginfo('Heartbeat. dt = %f' % dt)
00089         
00090         
00091 if __name__ == "__main__":
00092     self = PythonNodeExample()
00093     self.start()


starmac_templates
Author(s): bouffard
autogenerated on Sun Jan 5 2014 11:39:05