pathfinding

Current Version Documentation License: Apache-2.0/MIT

This crate implements several pathfinding, flow, and graph algorithms in Rust.

Algorithms

The algorithms are generic over their arguments.

Directed graphs

Undirected graphs

Matching

Miscellaneous structures

Using this crate

In your Cargo.toml, put:

ini [dependencies] pathfinding = "3.0.14"

You can then pull your preferred algorithm (BFS in this example) using:

``` rust extern crate pathfinding;

use pathfinding::prelude::bfs; ```

Example

We will search the shortest path on a chess board to go from (1, 1) to (4, 6) doing only knight moves.

``` rust use pathfinding::prelude::bfs;

[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]

struct Pos(i32, i32);

impl Pos { fn successors(&self) -> Vec { let &Pos(x, y) = self; vec![Pos(x+1,y+2), Pos(x+1,y-2), Pos(x-1,y+2), Pos(x-1,y-2), Pos(x+2,y+1), Pos(x+2,y-1), Pos(x-2,y+1), Pos(x-2,y-1)] } }

static GOAL: Pos = Pos(4, 6); let result = bfs(&Pos(1, 1), |p| p.successors(), |p| *p == GOAL); assert_eq!(result.expect("no path found").len(), 5); ```

Note

Several algorithms require that the numerical types used to describe edges weights implement Ord. If you wish to use Rust builtin floating-point types (such as f32) which implement PartialOrd in this context, you can wrap them into compliant types using the ordered-float crate.

The minimum supported Rust version (MSRV) is Rust 1.62.1.

License

This code is released under a dual Apache 2.0 / MIT free software license.

Contributing

You are welcome to contribute by opening issues or submitting pull requests. Please open an issue before implementing a new feature, in case it is a work in progress already or it is fit for this repository.

In order to pass the continuous integration tests, your code must be formatted using the latest rustfmt with the nightly rust toolchain (available as the rustfmt-preview component of rustup).

This repository use the imperative mode in commit messages, such as "Add IDDFS", "Fix #xxx". This style is preferred over "Added IDDFS" or "Fixed #xxx".