Skip to main content

Simple osm routing engine.

Project description

routor

PyPI GitHub Workflow Status (master) Coveralls github branch PyPI - Python Version PyPI - License

Simple osm routing engine.

Requirements

  • Python 3.6.1 or newer

Installation

pip install routor

Usage

CLI

The CLI offers multiple commands, use routor --help to find out more.

Download map

Downloads a compatible map from OSM, eg.

routor download "Bristol, England" ./bristol.graphml

Calculate route

Determine the optimal route between two points using the given weight function and print the route as JSON to stdout.

routor route -- ./bristol.graphml  "51.47967237816338,-2.6174926757812496" "51.45422084861252,-2.564105987548828" "routor.weights.length"

Web API

Configuration

The configuration is either read from a .env file or the environment. Before you are able to run the server, you have to set the variables mentioned in routor/api/config.py.

Run the API

The api is served using uvicorn. To start the server run

uvicorn routor.api:app

The API will be available at http://127.0.0.1:8000 and the docs at http://127.0.0.1:8000/docs.

Register a new weight function

Existing weight functions are defined in routor/weights.py. To add a new weight functon, you have to create a new project and add routor as dependency. Create a new file, eg. main.py and add the following content, which will become the entrypoint for uvicorn.

# main.py
from typing import Optional

from routor.api.main import app  # noqa
from routor.weights import register
from routor import models


def my_weight_func(prev_edge: Optional[models.Edge], edge: models.Edge) -> float:
    ...
    return ...


register(my_weight_func, "weight_func")

Start the server with uvicorn main:app and the weight function will be available as weight_func when calling the api.

As library

You can also use the engine as a library. To calculate a route from A to B you can do

from routor.engine import Engine
from routor import models, weights

...
map_path = Path(...)
engine = Engine(map_path)

origin = models.Location(latitude=51.47967237816338, longitude=-2.6174926757812496)
destination = models.Location(latitude=51.45422084861252, longitude=-2.564105987548828)

route = engine.route(origin, destination, weights.length)  # shortest distance

Available weight-functions

"length" / routor.weights.length

Calculates the shortest path from A to B, only the length of an edge is taken into account.

"travel_time" / routor.weight.travel_time

Calculates the fastest route based on travel time.

Development

This project uses poetry for packaging and managing all dependencies and pre-commit to run flake8, isort, mypy and black.

Clone this repository and run

poetry install
poetry run pre-commit install

to create a virtual enviroment containing all dependencies. Afterwards, You can run the test suite using

poetry run pytest

This repository follows the Conventional Commits style.

Cookiecutter template

This project was created using cruft and the cookiecutter-pyproject template. In order to update this repository to the latest template version run

cruft update

in the root of this repository.

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

routor-0.1.0.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

routor-0.1.0-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file routor-0.1.0.tar.gz.

File metadata

  • Download URL: routor-0.1.0.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.1.2 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.7

File hashes

Hashes for routor-0.1.0.tar.gz
Algorithm Hash digest
SHA256 f8d17384c1e313528d9146f7e538f16abc7c076a2f98080cc8f43a8d7c0601a1
MD5 ddefc2a01375f07e0f15d3dbe19f9d24
BLAKE2b-256 5c81f46bc07175658a876287df0b9d2b5bad92710ab4faffb879f23a23e184b1

See more details on using hashes here.

File details

Details for the file routor-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: routor-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 12.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/51.1.2 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.7

File hashes

Hashes for routor-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 76a15a3c9d0fe59ed40cac115ba7abe6033705674797b92e2bf760e7f726c2e3
MD5 4b199b8aec2c4879eb53b107fe4615b0
BLAKE2b-256 6e56085b96762e90045fcbdb46dda7229bf33e8054df899cfbcf45aebbb87634

See more details on using hashes here.

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