Optimizing an urban meal delivery platform
Find a file
Alexander Hess 1c19da2f70
Solve all issues detected by PyCharm
- as of September 2021, PyCharm is used to write some of the code
- PyCharm's built-in code styler, linter, and type checker issued
  some warnings that are resolved in this commit
  + spelling mistakes
  + all instance attributes must be specified explicitly
    in a class's __init__() method
    => use `functools.cached_property` for caching
  + make `tuple`s explicit with `(...)`
  + one test failed randomly although everything is ok
    => adjust the fixture's return value (stub for Google Directions API)
  + reformulate SQL so that PyCharm can understand the symbols
2021-09-12 16:51:12 +02:00
.github/workflows Add rpy2 to the dependencies 2021-01-11 16:06:58 +01:00
docs Remove pylint from the project 2021-01-09 17:47:45 +01:00
migrations Add DistanceMatrix class 2021-09-12 16:51:10 +02:00
research Merge branch 'main' into develop 2021-03-01 14:45:24 +01:00
src/urban_meal_delivery Solve all issues detected by PyCharm 2021-09-12 16:51:12 +02:00
tests Solve all issues detected by PyCharm 2021-09-12 16:51:12 +02:00
.gitignore Ignore PyCharm's .idea/ folder 2021-09-12 16:51:10 +02:00
.gitmodules Move submodule with demand-forecasting paper into research folder 2020-12-14 16:21:12 +01:00
.pre-commit-config.yaml Adjust the branch reference fixer's logic 2020-09-30 12:16:00 +02:00
alembic.ini Add database migrations 2020-08-11 10:29:58 +02:00
LICENSE.txt Initial commit 2020-08-03 20:19:42 +02:00
noxfile.py Remove pytest-randomly from the dev dependencies 2021-09-12 16:51:11 +02:00
poetry.lock Pin the dependencies ... 2021-09-12 16:51:12 +02:00
pyproject.toml Remove pytest-randomly from the dev dependencies 2021-09-12 16:51:11 +02:00
README.md Merge branch 'main' into develop 2021-03-01 14:45:24 +01:00
setup.cfg Solve all issues detected by PyCharm 2021-09-12 16:51:12 +02:00

Urban Meal Delivery

This repository holds code analyzing the data of an undisclosed urban meal delivery platform (UDP) operating in France from January 2016 to January 2017. The goal is to optimize the platform's delivery process involving independent couriers.

Structure

The analysis is structured into the following stages that iteratively build on each other.

Data Cleaning

The UDP provided its raw data as a PostgreSQL dump. This notebook cleans the data extensively and maps them onto the ORM models defined in the urban-meal-delivery package that is developed in the src/ folder and contains all source code to drive the analyses.

Due to a non-disclosure agreement with the UDP, neither the raw nor the cleaned data are published as of now. However, previews of the data can be seen throughout the research/ folder.

Tactical Demand Forecasting

Before any optimizations of the UDP's operations are done, a demand forecasting system for tactical purposes is implemented. To achieve that, the cities first undergo a gridification step where each pickup location is assigned into a pixel on a "checker board"-like grid. The main part of the source code that implements that is in this file. Visualizations of the various grids can be found in the visualizations/ folder and in this notebook.

Then, demand is aggregated on a per-pixel level and different kinds of order time series are generated. The latter are the input to different kinds of forecasting *Models. They all have in common that they predict demand into the short-term future (e.g., one hour) and are thus used for tactical purposes, in particular predictive routing (cf., next section). The details of how this works can be found in the first academic paper published in the context of this research project and titled "Real-time Demand Forecasting for an Urban Delivery Platform" (cf., the repository with the LaTeX files). All demand forecasting related code is in the forecasts/ sub-package.

Predictive Routing

Shift & Capacity Planning

Installation & Contribution

To play with the code developed for the analyses, you can clone the project with git and install the contained urban-meal-delivery package and all its dependencies in a virtual environment with poetry:

git clone https://github.com/webartifex/urban-meal-delivery.git

and

poetry install --extras research

The --extras option is necessary as the non-develop dependencies are structured in the pyproject.toml file into dependencies related to only the urban-meal-delivery source code package and dependencies used to run the Jupyter environment with the analyses.

Contributions are welcome. Use the issues tab. The project is licensed under the MIT license.