Loading...
Searching...
No Matches
PlannerMonitor.cpp
1/*********************************************************************
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2011, Rice University
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/or other materials provided
16 * with the distribution.
17 * * Neither the name of Rice University 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
35/* Author Ioan Sucan */
36
37#include "ompl/tools/debug/PlannerMonitor.h"
38#include "ompl/util/Time.h"
39#include <limits>
40#include <functional>
41
43{
44 if (monitorThread_)
45 return;
46 shouldMonitor_ = true;
47 monitorThread_.reset(new std::thread([this] { threadFunction(); }));
48}
49
51{
52 if (!monitorThread_)
53 return;
54 shouldMonitor_ = false;
55 monitorThread_->join();
56 monitorThread_.reset();
57}
58
59void ompl::tools::PlannerMonitor::threadFunction()
60{
61 time::point startTime = time::now();
62 time::point lastOutputTime = startTime;
63
64 while (shouldMonitor_)
65 {
66 double timeSinceOutput = time::seconds(time::now() - lastOutputTime);
67 if (timeSinceOutput < period_)
68 {
69 std::this_thread::sleep_for(time::seconds(0.01));
70 continue;
71 }
72 out_.seekp(0);
73 out_ << "[T = " << static_cast<unsigned int>(time::seconds(time::now() - startTime) + 0.5) << " s]" << std::endl
74 << std::endl;
75 out_ << "Planner " << planner_->getName() << ":" << std::endl;
76 if (!planner_->isSetup())
77 {
78 out_ << "Not yet set up." << std::endl;
79 return;
80 }
81 const base::Planner::PlannerProgressProperties &props = planner_->getPlannerProgressProperties();
82 for (const auto &prop : props)
83 {
84 out_ << " \t * " << prop.first << " \t : " << prop.second() << std::endl;
85 }
86 out_ << std::endl;
87 out_.flush();
88 lastOutputTime = time::now();
89 std::this_thread::sleep_for(time::seconds(0.01));
90 }
91}
std::map< std::string, PlannerProgressProperty > PlannerProgressProperties
A dictionary which maps the name of a progress property to the function to be used for querying that ...
Definition Planner.h:353
void startMonitor()
Start the monitoring thread.
void stopMonitor()
Stop the monitoring thread (automatically stopped by the destructor).
std::chrono::system_clock::time_point point
Representation of a point in time.
Definition Time.h:52
point now()
Get the current time point.
Definition Time.h:58
duration seconds(double sec)
Return the time duration representing a given number of seconds.
Definition Time.h:64