WanderingEvents.cpp
Go to the documentation of this file.
00001 /*
00002  * Filename: WanderingEvents.cpp
00003  *   Author: Igor Makhtes
00004  *     Date: Jan 8, 2014
00005  *
00006  * The MIT License (MIT)
00007  *
00008  * Copyright (c) 2014 Cogniteam Ltd.
00009  *
00010  * Permission is hereby granted, free of charge, to any person obtaining a copy
00011  * of this software and associated documentation files (the "Software"), to deal
00012  * in the Software without restriction, including without limitation the rights
00013  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
00014  * copies of the Software, and to permit persons to whom the Software is
00015  * furnished to do so, subject to the following conditions:
00016  *
00017  * The above copyright notice and this permission notice shall be included in
00018  * all copies or substantial portions of the Software.
00019  *
00020  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
00021  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
00022  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
00023  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
00024  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
00025  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
00026  * THE SOFTWARE.
00027  */
00028 
00029 #include <iostream>
00030 #include <boost/bind.hpp>
00031 #include <boost/thread.hpp>
00032 #include <boost/foreach.hpp>
00033 
00034 #include <ros/ros.h>
00035 #include <random_numbers/random_numbers.h>
00036 #include <sensor_msgs/LaserScan.h>
00037 #include <geometry_msgs/Twist.h>
00038 
00039 using namespace std;
00040 
00041 #define foreach BOOST_FOREACH
00042 
00043 void publishRandomLaserScan(ros::Publisher& laserScanPublisher) {
00044     static random_numbers::RandomNumberGenerator randomizer;
00045     sensor_msgs::LaserScan scan;
00046     scan.angle_min = 0;
00047     scan.angle_increment = 0.05;
00048     scan.header.frame_id = "/map";
00049     scan.header.stamp  = ros::Time::now();
00050     scan.range_min = 0.001;
00051     scan.range_max = 30;
00052 
00053     static double first = randomizer.uniformReal(0.1, 1.5);
00054 
00055     for (int i = 0; i < 50; ++i) {
00056         first += randomizer.gaussian(0, 0.03);
00057         first = fmin(1.5, fmax(0.1, first));
00058         scan.ranges.push_back(first);
00059     }
00060 
00061     laserScanPublisher.publish(scan);
00062 }
00063 
00064 int main(int argc, char **argv) {
00065     ros::init(argc, argv, "fsm_wandering_events");
00066     ros::Publisher laserScanPublisher = ros::NodeHandle().advertise<sensor_msgs::LaserScan>("/fsm_wandering/scan", 1, false);
00067 
00068     ROS_INFO("Starting wandering events publisher...");
00069 
00070     while (ros::ok()) {
00071         publishRandomLaserScan(laserScanPublisher);
00072         boost::this_thread::sleep(boost::posix_time::milliseconds(100));
00073     }
00074         return 0;
00075 }


decision_making_examples
Author(s):
autogenerated on Wed Aug 26 2015 11:17:01