Class BenchmarkExecutor
Defined in File BenchmarkExecutor.h
Nested Relationships
Nested Types
Class Documentation
-
class BenchmarkExecutor
A class that executes motion plan requests and aggregates data across multiple runs Note: This class operates outside of MoveGroup and does NOT use PlanningRequestAdapters
Public Types
-
typedef std::map<std::string, std::string> PlannerRunData
Structure to hold information for a single run of a planner.
-
typedef std::vector<PlannerRunData> PlannerBenchmarkData
Structure to hold information for a single planner’s benchmark data.
-
typedef std::function<void(const moveit_msgs::msg::MotionPlanRequest &request, planning_scene::PlanningScenePtr)> QueryStartEventFunction
Definition of a query-start benchmark event function. Invoked before a new query is benchmarked.
-
typedef std::function<void(const moveit_msgs::msg::MotionPlanRequest &request, planning_scene::PlanningScenePtr)> QueryCompletionEventFunction
Definition of a query-end benchmark event function. Invoked after a query has finished benchmarking.
-
typedef std::function<void(const moveit_msgs::msg::MotionPlanRequest &request, PlannerBenchmarkData &benchmark_data)> PlannerStartEventFunction
Definition of a planner-switch benchmark event function. Invoked before a planner starts any runs for a particular query.
-
typedef std::function<void(const moveit_msgs::msg::MotionPlanRequest &request, PlannerBenchmarkData &benchmark_data)> PlannerCompletionEventFunction
Definition of a planner-switch benchmark event function. Invoked after a planner completes all runs for a particular query.
-
typedef std::function<void(moveit_msgs::msg::MotionPlanRequest &request)> PreRunEventFunction
Definition of a pre-run benchmark event function. Invoked immediately before each planner calls solve().
-
typedef std::function<void(const moveit_msgs::msg::MotionPlanRequest &request, const planning_interface::MotionPlanDetailedResponse &response, PlannerRunData &run_data)> PostRunEventFunction
Definition of a post-run benchmark event function. Invoked immediately after each planner calls solve().
Public Functions
-
virtual ~BenchmarkExecutor()
-
bool initialize(const std::vector<std::string> &plugin_classes)
-
void addPreRunEvent(const PreRunEventFunction &func)
-
void addPostRunEvent(const PostRunEventFunction &func)
-
void addPlannerStartEvent(const PlannerStartEventFunction &func)
-
void addPlannerCompletionEvent(const PlannerCompletionEventFunction &func)
-
void addQueryStartEvent(const QueryStartEventFunction &func)
-
void addQueryCompletionEvent(const QueryCompletionEventFunction &func)
-
virtual void clear()
-
virtual bool runBenchmarks(const BenchmarkOptions &options)
Protected Functions
-
virtual bool initializeBenchmarks(const BenchmarkOptions &options, moveit_msgs::msg::PlanningScene &scene_msg, std::vector<BenchmarkRequest> &queries)
-
virtual bool loadBenchmarkQueryData(const BenchmarkOptions &options, moveit_msgs::msg::PlanningScene &scene_msg, std::vector<StartState> &start_states, std::vector<PathConstraints> &path_constraints, std::vector<PathConstraints> &goal_constraints, std::vector<TrajectoryConstraints> &traj_constraints, std::vector<BenchmarkRequest> &queries)
Initialize benchmark query data from start states and constraints.
-
virtual void collectMetrics(PlannerRunData &metrics, const planning_interface::MotionPlanDetailedResponse &motion_plan_response, bool solved, double total_time)
-
void computeAveragePathSimilarities(PlannerBenchmarkData &planner_data, const std::vector<planning_interface::MotionPlanDetailedResponse> &responses, const std::vector<bool> &solved)
Compute the similarity of each (final) trajectory to all other (final) trajectories in the experiment and write the results to planner_data metrics
-
bool computeTrajectoryDistance(const robot_trajectory::RobotTrajectory &traj_first, const robot_trajectory::RobotTrajectory &traj_second, double &result_distance)
Helper function used by computeAveragePathSimilarities() for computing a heuristic distance metric between two robot trajectories. This function aligns both trajectories in a greedy fashion and computes the mean waypoint distance averaged over all aligned waypoints. Using a greedy approach is more efficient than dynamic time warping, and seems to be sufficient for similar trajectories.
-
virtual void writeOutput(const BenchmarkRequest &benchmark_request, const std::string &start_time, double benchmark_duration, const BenchmarkOptions &options)
-
void shiftConstraintsByOffset(moveit_msgs::msg::Constraints &constraints, const std::vector<double> &offset)
-
bool pipelinesExist(const std::map<std::string, std::vector<std::string>> &planners)
Check that the desired planning pipelines exist.
-
bool loadPlanningScene(const std::string &scene_name, moveit_msgs::msg::PlanningScene &scene_msg)
Load the planning scene with the given name from the warehouse.
-
bool loadStates(const std::string ®ex, std::vector<StartState> &start_states)
Load all states matching the given regular expression from the warehouse.
-
bool loadPathConstraints(const std::string ®ex, std::vector<PathConstraints> &constraints)
Load all constraints matching the given regular expression from the warehouse.
-
bool loadTrajectoryConstraints(const std::string ®ex, std::vector<TrajectoryConstraints> &constraints)
Load all trajectory constraints from the warehouse that match the given regular expression.
-
bool loadQueries(const std::string ®ex, const std::string &scene_name, std::vector<BenchmarkRequest> &queries)
Load all motion plan requests matching the given regular expression from the warehouse.
-
void createRequestCombinations(const BenchmarkRequest &benchmark_request, const std::vector<StartState> &start_states, const std::vector<PathConstraints> &path_constraints, std::vector<BenchmarkRequest> &combos)
Duplicate the given benchmark request for all combinations of start states and path constraints.
-
void runBenchmark(moveit_msgs::msg::MotionPlanRequest request, const BenchmarkOptions &options)
Execute the given motion plan request on the set of planners for the set number of runs.
Protected Attributes
-
std::shared_ptr<planning_scene_monitor::PlanningSceneMonitor> planning_scene_monitor_
-
std::shared_ptr<moveit_warehouse::PlanningSceneStorage> planning_scene_storage_
-
std::shared_ptr<moveit_warehouse::PlanningSceneWorldStorage> planning_scene_world_storage_
-
std::shared_ptr<moveit_warehouse::RobotStateStorage> robot_state_storage_
-
std::shared_ptr<moveit_warehouse::ConstraintsStorage> constraints_storage_
-
std::shared_ptr<moveit_warehouse::TrajectoryConstraintsStorage> trajectory_constraints_storage_
-
rclcpp::Node::SharedPtr node_
-
warehouse_ros::DatabaseLoader db_loader_
-
planning_scene::PlanningScenePtr planning_scene_
-
std::shared_ptr<moveit_cpp::MoveItCpp> moveit_cpp_
-
std::vector<PlannerBenchmarkData> benchmark_data_
-
std::vector<PreRunEventFunction> pre_event_functions_
-
std::vector<PostRunEventFunction> post_event_functions_
-
std::vector<PlannerStartEventFunction> planner_start_functions_
-
std::vector<PlannerCompletionEventFunction> planner_completion_functions_
-
std::vector<QueryStartEventFunction> query_start_functions_
-
std::vector<QueryCompletionEventFunction> query_end_functions_
-
struct BenchmarkRequest
-
struct PathConstraints
-
struct StartState
-
struct TrajectoryConstraints
-
typedef std::map<std::string, std::string> PlannerRunData