Skip to main content

A collection of algorithms for the (Resource) Constrained Shortest Path Problem

Project description

A collection of algorithms for the (resource) Constrained Shortest Path (CSP) problem.

The CSP problem was popularised by Inrich 2005. It was initially introduced as a subproblem for the bus driver scheduling problem, and has since then widely studied in a variety of different settings including: the vehicle routing problem with time windows (VRPTW), the technician routing and scheduling problem, the capacitated arc-routing problem, on-demand transportation systems, and, airport ground movement; among others.

More generally, in the applied column generation framework, particularly in the scheduling related literature, the CSP problem is commonly employed to generate columns.

Therefore, this library is of interest to the operational research community, students and academics alike, that wish to solve an instance of the CSP problem.

Algorithms

Currently, the algorithms implemented include:

  • Monodirectional forward labeling algorithm;

  • Monodirectional backward labeling algorithm;

  • Bidirectional labeling algorithm with static halfway point;

  • Bidirectional labeling algorithm with dynamic halfway point Tilk et al 2017;

  • Heuristic Tabu search;

  • Greedy elimination procedure;

  • Greedy Randomised Adaptive Search Procedure (GRASP). Adapted from Ferone et al 2019;

  • Particle Swarm Optimization with combined Local and Global Expanding Neighborhood Topology (PSOLGET) (Marinakis et al 2017).

The first algorithm BiDirectional, is the only exact algorithm in the library. This means that it provides an exact (optimal) solution to the resource CSP problem. For this reason, it sometimes takes longer than the others. The remaining algorithms are metaheuristics, i.e. they provide fast and approximate solutions to the CSP problem.

Features

  • Generic resource extension functions (Inrich 2005) (not restricted to additive resources);

  • Generic resource consumptions (not restricted to non-negative values).

Prerequisites

Conceptual background and input formatting is discussed in the docs.

Examples

For complex examples see:

vrpy: (under development) external vehicle routing framework which uses cspy to solve different variants of the vehicle routing problem using column generation.

jpath : Simple example showing the necessary graph adptations and the use of custom resource extension functions. Also discussed below.

cgar: Complex example using cspy for column generation applied to the aircraft recovery problem.

All of can be found under examples.

Contributing

Feel free to contribute to this project either by either working trough some of issues flagged as help wanted, or raise a new issue with any bugs/improvements.

If you have a question or need help, feel free to raise an issue explaining it.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cspy-0.1.1.tar.gz (23.7 kB view hashes)

Uploaded Source

Built Distribution

cspy-0.1.1-py3-none-any.whl (31.6 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page