speed_test.cpp
Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2010, Willow Garage, Inc.
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions are met:
00007  *
00008  *     * Redistributions of source code must retain the above copyright
00009  *       notice, this list of conditions and the following disclaimer.
00010  *     * Redistributions in binary form must reproduce the above copyright
00011  *       notice, this list of conditions and the following disclaimer in the
00012  *       documentation and/or other materials provided with the distribution.
00013  *     * Neither the name of the Willow Garage, Inc. nor the names of its
00014  *       contributors may be used to endorse or promote products derived from
00015  *       this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00018  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00021  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00022  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00023  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00024  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00025  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00026  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00027  * POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 
00030 #include <rve_properties/property_node.h>
00031 #include <ros/time.h>
00032 #include <ros/assert.h>
00033 
00034 using namespace rve_properties;
00035 
00036 struct Timer
00037 {
00038   Timer(const std::string& msg)
00039   : msg(msg)
00040   , start(ros::WallTime::now())
00041   {}
00042 
00043   ~Timer()
00044   {
00045     ros::WallTime end = ros::WallTime::now();
00046     ros::WallDuration dur = end - start;
00047     ROS_INFO("%s: %f", msg.c_str(), dur.toSec());
00048   }
00049 
00050   std::string msg;
00051   ros::WallTime start;
00052 };
00053 
00054 int main(int argc, char** argv)
00055 {
00056   PropertyNodePtr node(new PropertyNode);
00057 
00058   {
00059     Timer t("Creation of 300000 property nodes");
00060     for (uint32_t i = 0; i < 10000; ++i)
00061     {
00062       std::stringstream ss;
00063       ss << i << "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y/z/1/2/3/4";
00064       node->getNode(ss.str());
00065     }
00066   }
00067 
00068   {
00069     Timer t("Setting an integer value on 10000 30-deep properties");
00070     for (uint32_t i = 0; i < 10000; ++i)
00071     {
00072       std::stringstream ss;
00073       ss << i << "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y/z/1/2/3/4";
00074       node->set<uint32_t>(ss.str(), 5);
00075     }
00076   }
00077 
00078   {
00079     Timer t("Getting an integer value from 10000 30-deep properties");
00080     for (uint32_t i = 0; i < 10000; ++i)
00081     {
00082       std::stringstream ss;
00083       ss << i << "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y/z/1/2/3/4";
00084       uint32_t val = 0;
00085       node->get(ss.str(), val);
00086       ROS_ASSERT(val == 5);
00087     }
00088   }
00089 
00090   {
00091     Timer t("Setting a string value on 10000 30-deep properties");
00092     std::string hello("hello");
00093     for (uint32_t i = 0; i < 10000; ++i)
00094     {
00095       std::stringstream ss;
00096       ss << i << "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y/z/1/2/3/4";
00097       node->set(ss.str(), hello);
00098     }
00099   }
00100 
00101   {
00102     Timer t("Getting a string value from 10000 30-deep properties");
00103     for (uint32_t i = 0; i < 10000; ++i)
00104     {
00105       std::stringstream ss;
00106       ss << i << "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y/z/1/2/3/4";
00107       std::string hello;
00108       node->get(ss.str(), hello);
00109       ROS_ASSERT(hello == "hello");
00110     }
00111   }
00112 }


rve_properties
Author(s): Josh Faust
autogenerated on Wed Dec 11 2013 14:31:27