hz_measure_nodelet.cpp
Go to the documentation of this file.
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2014, JSK Lab
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the following
15  * disclaimer in the documentation and/o2r other materials provided
16  * with the distribution.
17  * * Neither the name of the JSK Lab nor the names of its
18  * contributors may be used to endorse or promote products derived
19  * from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *********************************************************************/
34 
37 
38 #include "std_msgs/Float32.h"
39 
40 namespace jsk_topic_tools
41 {
43  {
45  if (!pnh_.getParam("message_num", average_message_num_)) {
46  average_message_num_ = 10; // defaults to 10
47  }
48  hz_pub_ = pnh_.advertise<std_msgs::Float32>("output", 1);
51  }
52 
54  {
55  ros::Time now = ros::Time::now();
56  buffer_.push(now);
57  if (buffer_.size() > average_message_num_) {
58  ros::Time oldest = buffer_.front();
59  double whole_time = (now - oldest).toSec();
60  double average_time = whole_time / (buffer_.size() - 1);
61  std_msgs::Float32 output;
62  output.data = 1.0 / average_time;
63  hz_pub_.publish(output);
64  buffer_.pop();
65  }
66  else {
67  NODELET_DEBUG("there is no enough messages yet");
68  }
69  }
70 
71 }
72 
void publish(const boost::shared_ptr< M > &message) const
Subscriber subscribe(const std::string &topic, uint32_t queue_size, void(T::*fp)(M), T *obj, const TransportHints &transport_hints=TransportHints())
PLUGINLIB_EXPORT_CLASS(jsk_topic_tools::Snapshot, nodelet::Nodelet)
jsk_topic_tools::HzMeasure HzMeasure
ros::NodeHandle & getPrivateNodeHandle() const
std::queue< ros::Time > buffer_
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
virtual void inputCallback(const boost::shared_ptr< topic_tools::ShapeShifter const > &msg)
bool getParam(const std::string &key, std::string &s) const
static Time now()
#define NODELET_DEBUG(...)


jsk_topic_tools
Author(s): Kei Okada , Yusuke Furuta
autogenerated on Tue Feb 6 2018 03:45:19