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]
48  {
49  threadFunction();
50  }));
51 }
52 
54 {
55  if (!monitorThread_)
56  return;
57  shouldMonitor_ = false;
58  monitorThread_->join();
59  monitorThread_.reset();
60 }
61 
62 void ompl::tools::PlannerMonitor::threadFunction()
63 {
64  time::point startTime = time::now();
65  time::point lastOutputTime = startTime;
66 
67  while (shouldMonitor_)
68  {
69  double timeSinceOutput = time::seconds(time::now() - lastOutputTime);
70  if (timeSinceOutput < period_)
71  {
72  std::this_thread::sleep_for(time::seconds(0.01));
73  continue;
74  }
75  out_.seekp(0);
76  out_ << "[T = " << static_cast<unsigned int>(time::seconds(time::now() - startTime) + 0.5) << " s]" << std::endl
77  << std::endl;
78  out_ << "Planner " << planner_->getName() << ":" << std::endl;
79  if (!planner_->isSetup())
80  {
81  out_ << "Not yet set up." << std::endl;
82  return;
83  }
84  const base::Planner::PlannerProgressProperties &props = planner_->getPlannerProgressProperties();
85  for (const auto &prop : props)
86  {
87  out_ << " \t * " << prop.first << " \t : " << prop.second() << std::endl;
88  }
89  out_ << std::endl;
90  out_.flush();
91  lastOutputTime = time::now();
92  std::this_thread::sleep_for(time::seconds(0.01));
93  }
94 }
std::chrono::system_clock::time_point point
Representation of a point in time.
Definition: Time.h:116
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:417
point now()
Get the current time point.
Definition: Time.h:122
void stopMonitor()
Stop the monitoring thread (automatically stopped by the destructor).
void startMonitor()
Start the monitoring thread.
duration seconds(double sec)
Return the time duration representing a given number of seconds.
Definition: Time.h:128