Skip to main content

Simulator and Digital Twin of an Automatic Warehouse.

Project description

Simulator Automatic Warehouse

PyPI - Python Version GitHub Release PyPI - Version GitHub Actions Workflow Status Read the Docs codecov

Go to the complete documentation: Simulator Automatic Warehouse doc.

Table of Contents


Description

The Simulator Automatic Warehouse is a Python library that provides two main functions: a digital twin of an automatic warehouse and a simulator of an automatic warehouse.

What is an Automatic Warehouse?

An Automatic Warehouse, or rather an Automatic Vertical Storage System, is a storage system designed to simplify the storage of materials. It is generally used in industrial environments and is designed according to the goods-to-man principle: the products are brought directly to the picking area (called bay).

How it was born

This repository was created in 2022 for a bachelor thesis project at the University of Verona, Italy (Università di Verona). After the creator graduated, he continued to improve the project in order to publish it.

The inspiration came from the Vertimag by Ferretto, an Italian company based in Vicenza. The logic of the digitalized warehouse is therefore the same as that of the real Vertimag.

The digitisation of the warehouse was made possible thanks to the ICE Laboratory of Verona, as part of a thesis project at the University of Verona. In addition, Sebastiano Gaiardelli (mainly) and Marco Panato helped the creator at the beginning of the project.


How to Install and Run the Project

Dependencies

Dependency Version
pandas 2.2.3
simpy 4.1.1
PyYAML 6.0.2
jsonschema 4.23.0

Python Installation

The Simulator Automatic Warehouse requires Python >= 3.9. Python 3.8 is no longer supported, as Python will end support on 2024-10.

It's possible to install the package using pip:

pip install simulator-automatic-warehouse

Otherwise, you can clone the whole project and install the requirements:

git clone https://github.com/AndreVale69/simulator-automatic-warehouse
pip install -r requirements.txt

Basic Example

The following code generate a warehouse, create a simulation environment and run a simulation.

from automatic_warehouse.warehouse import Warehouse
from automatic_warehouse.simulation.simulation_type.warehouse_simulation import WarehouseSimulation

# generate a Warehouse
warehouse = Warehouse()

# generate a simulation environment
simulation = WarehouseSimulation(warehouse)

# run the simulation
simulation.run_simulation()

# print the results
print(simulation.get_store_history_dataframe())

Note: if a configuration is not specified as an environment variable or is not updated at runtime, the default configuration is used.

Docker

Everything is easier with Docker. In the GitHub project, there are a docker folder and use docker compose to build:

cd docker
docker compose up alpine-simulator_automatic_warehouse

The available docker images are:

  • alpine-simulator_automatic_warehouse
  • debian-simulator_automatic_warehouse

To change or add some environment variables, edit docker-compose.yaml.


Benchmarks

Here are some benchmarks run with a private Python library and the following computer specifications:

  • Intel i7-8750H
  • SDRAM DDR4-2666 16GB
  • MZ-76Q2T0 860 QVO SSD 2TB 2.5"
  • SSD NVMe M.2 128 GB
  • NVIDIA GeForce GTX 1050
Actions Time to process Real-time simulation
10'000 570 milliseconds 1d. 2h. 48m.
63'000 3,5 seconds 1 week
267'900 15,3 seconds 1 month
3'250'120 3,1 minutes 1 year

Use the following links if the images are not displayed:

Relationship between simulated actions and media Standard deviation

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

simulator_automatic_warehouse-1.0.2.tar.gz (34.5 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file simulator_automatic_warehouse-1.0.2.tar.gz.

File metadata

File hashes

Hashes for simulator_automatic_warehouse-1.0.2.tar.gz
Algorithm Hash digest
SHA256 4cd10f50e3a29d2434a90c1c9fe0f568c75a82c53a4bd09468ef0a27898de1e8
MD5 2c6a970af50e7891de5da27ba18ac2b4
BLAKE2b-256 a2c0bfe3caea0a3e9aa5f9e6e9f9934b2dc68b710256d18626f29c58afd96437

See more details on using hashes here.

File details

Details for the file simulator_automatic_warehouse-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for simulator_automatic_warehouse-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 25f02d1f8eb739b66f1b63e9906cb838ae36190713b6008046822d4d23c6a057
MD5 f1651b3917bb95afe6e198fdab42f118
BLAKE2b-256 08316044f5cb1d26aa11a77428e2af8a3c72bc291143bccc265e03d9637d4135

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