Skip to content

Latest commit

 

History

History
60 lines (53 loc) · 3.51 KB

README.md

File metadata and controls

60 lines (53 loc) · 3.51 KB

LS-MCPP

This repository is the benchmark and implementation of the algorithms for the graph-based multi-robot coverage path planning problem from the following two papers:

  • Branch master: *Jingtao Tang, Zining Mao, and Hang Ma. "Large-Scale Multi-Robot Coverage Path Planning on Grids with Path Deconfliction." [paper], [project]

  • Branch aaai24: Jingtao Tang and Hang Ma. "Large-Scale Multi-Robot Coverage Path Planning via Local Search." AAAI 2024. [paper], [simulation], [project]

Please cite us if you use this code for the multi-robot coverage path planning problem.

Installation

pip install -r requirements.txt

Usage

python main.py [-h] [--init_sol_type INIT_SOL_TYPE] [--prio_type PRIO_TYPE] [--M M] [--S S] [--gamma GAMMA] [--tf TF] [--scale SCALE] [--write WRITE] [--verbose VERBOSE] istc
  • Required:
    • istc: the instance name stored in directory 'data/instances' or 'MIP-MCPP/data/instances'.
  • Optional:
    • --init_sol_type INIT_SOL_TYPE: Initial solution type. Choose from {VOR, MFC, MSTCStar, MIP} (default=MFC)
    • -prio_type PRIO_TYPE: Operator sampling type. Choose from {Heur, Rand} (default=Heur)
    • --M M: Max iteration (default=3e3)
    • --S S: Forced deduplication step size (default=100)
    • --gamma GAMMA: Pool weight decaying factor (default=1e-2)
    • --tf TF: The final temperature used to calculate the temperature decaying factor
    • --scale SCALE: Plot scaling factor
    • --verbose VERBOSE: Is verbose printing
    • --write WRITE: Is writing the solution
    • --record RECORD: Is recording the path costs of each iteration
    • --draw DRAW: Is drawing the final solution
    • --random_remove RANDOM_REMOVE: Is randomly making 20 percentage of terrain vertices incomplete

File Structure

  • benchmark/
    • gridmaps: the 2d grid maps (partly from https://movingai.com/benchmarks/grids.html)
    • instances: the MCPP instances with roots and weights specified
    • instance.py: the class of MCPP instance
    • plans.py: the class of plan (trajectories) for the robots
    • simulation.py: a simple visualizer for MCPP execution animation
  • conflict_solver/
    • high_level_planner.py: the high-level planner of priority-based search
    • low_level_planner.py: the chaining, holistic (multi-label), and adaptive approaches for the low-level planner
    • reservation_table.py: the reservation table of time intervals (for safe-interval path planning)
    • states.py: state representations for the low-level planner
  • data[optinal]: the accompanying simulation exp results for the paper (download link).
  • LS_MCPP/
    • estc.py: the Extended STC algorithm
    • graph.py: class of the decomposed graph
    • local_search.py: the proposed local search framework for MCPP
    • operator.py: the three boundary editing operators
    • pool.py: class of operator pool
    • solution.py: class of the MCPP solution
    • utils.py: other ultility functions
  • MIP-MCPP: repo of the work "Mixed Integer Programming for Time-Optimal Multi-Robot Coverage Path Planning With Efficient Heuristics"
  • demo.ipynb: a demo code for a small MCPP instance
  • exp_runner.py: the experiment runner
  • plot.py: plot functions for the experiments

License

LS-MCPP is released under the GPL version 3. See LICENSE.txt for further details.