Dette repositorie indeholder simuleringstoolet som er udviklet i løbet af AI-signaturprojektet Intelligent flådestyring og klimasmarte kørselsmønstre (https://ifkk.syddjurs.dk/forside/).
Dokumentationen er delt i to dele, en teknisk del rettet imod udviklere og leverandører og en anvendelsesorienteret rettet imod slutbrugere. Den tekniske del findes i det Github-repositorie som er tilknyttet projektet, https://github.com/syddjurs/IFKK / https://syddjurs.github.io/IFKK/. Den anvendelsesorienterede dokumentation findes i https://raw.githubusercontent.com/syddjurs/IFKK/master/docs/html/ifkk_dokumentation.pdf.
├───FleetCompleteExtractor [Utilities til at trække data fra FleetComplete API - separat readme]
├───SkyHostExtractor [Utilities til at trække data fra SkyHost API - separat readme]
│ └───xml_templates
└───src [Applikationskode]
└───fleetmanager [Applikationsmodul]
├───dashboard [Frontend]
│ ├───assets
│ └───Components
├───data_access [Backend data utilities]
└───model [Backend]
├───pogi [Baggrund for CO2e]
└───qampo [Backend - Optimeringsalgortimer]
Simuleringstoolet er udviklet med formål om at kunne tage en proaktiv tilgang til indkøb af køretøjsflåden for en flåde.
I dag foretages indkøb af køretøjer med begrænset input fra data. Målet er at kunne anvende den konkrete flådes data i form af kørte ture og køretøjsflåde til at simulere scenarier med forskellig sammensætning af køretøjsflåden.
Simuleringstoolet sammenligner den nuværende flåde med en fremtidig simuleret og giver informationer om kapaciteten i flåden og om forskelle i økonomiske, transportmæssige og udledningsmæssige-konsekvenser imellem de to flåder.
Specifikt, deles applikationen op 3 typer simulering:
- CO2e-orienteret simulering. En simulering, hvor køretøjer med lavere CO2e aftryk prioriteres. Giver ikke nødvendigs det absolutte lavest CO2e aftryk.
- Intelligent simulering. En optimal simulering, hvor køretøjets variable pris pr. km. afvejes med dets CO2e aftryk. Her vægtes på køretøjets attributter således turene allokeres biler på den mest optimale måde.
- Målsimulering. En optimering på flådesammensætning, hvor delflåden optimeres på både CO2e og omkostning og hvor flåden samtidig tilfredsstiller kørselsbehovet.
Simuleringstoolet er udviklet i python på backenden og brugergrænsefladen er ligeledes opsat med python-biblioteket Dash. Dokumentationen på de enkelte dele af koden er at finde i det tilhørende Github-projekt, https://github.com/syddjurs/IFKK eller på https://syddjurs.github.io/IFKK/
I dette repository findes to moduler udviklet for at trække data fra flådestyringssystemerne; FleetComplete FleetCompleteExtractor
og SkyHost SkyHostExtractor
.
De har hver deres readme og requirements filer.
Selve applikationskoden findes under src.fleetmanager
. Droids Agency har udviklet koden i dette repository i samarbejde med Qampo, der specifikt har udviklet optimeringsmodulet til "Intelligent simulering" - dette modul findes i src/fleetmanager/model/qampo
.
Applikationen er testet på Windows og Linux. Applikationen er afhængig af en række biblioteker der kan ses i src/requirements.txt
Applikationen kræver Python >= 3.9. Den installerede version af Python kan checkes ved at køre følgende kommando i kommandolinjen i Windows:
C:\Users\user>python -V
Python 3.9
Det er tiltænkt at installere applikationen som et python module for at lette import af moduler, der sker på tværs i applikation.
Installation af modulerne fra rod via setup:
python setup.py install
Applikationen forventer en database forbindelse, der trækkes fra environment variabler. Hvis de ikke findes, loades en SQLite database i memory med dummy data.
Der kan med fordel oprettes en .env
fil med værdierne, hvorfra variablerne vil blive loaded.
DB_NAME="<database navn>"
DB_PASSWORD="<database bruger password>"
DB_USER="<database brugernavn>"
DB_URL="<database url>"
DB_SERVER="mysql"
For at køre applikationen og tilgå den via http://127.0.0.1:8050/ køres følgende.
cd src
python -m fleetmanager.dashboard
Dash is running on http://127.0.0.1:8050/
* Serving Flask app 'fleetmanager.dashboard.app' (lazy loading)
* Environment: production
WARNING: This is a development server. Do not use it in a production deployment.
Use a production WSGI server instead.
* Debug mode: off
* Running on http://127.0.0.1:8050/ (Press CTRL+C to quit)
Ønsker man at køre applikationen i docker, kan følgende image bruges:
FROM python:3.9-buster
RUN apt install -y git
RUN git clone https://github.com/syddjurs/IFKK.git
WORKDIR IFKK/
RUN python setup.py install
WORKDIR src/
EXPOSE 8050
CMD ["python", "-m", "fleetmanager.dashboard"]
For at køre applikationen med docker, og kunne tilgå den via lokal browser, kør følgende kommando:
docker run -p 8050:8050 -e HOST=0.0.0.0 <image-tag>
Applikationen er afhængig af data på tilladte startsteder, biler (inkl. metadata) og ikke mindst rundture. I applikation run-time er alle tabeller påkrævet,
på-nær: trips
og leasing_types
. RoundTrips
vil altid kun indeholde GPS-koordinater der er tæt på det tilladte startsted (+- x antal meter, den tilladte distance defineret i extractor'en).
For at læse mere om hvor data stammer fra, hvilke forudsætninger der er og hvilke antagelser der laves, refereres til FleetCompleteExtractor
eller SkyhostExtractor
eller den fulde dokumentation på data og algortimer her: https://raw.githubusercontent.com/syddjurs/IFKK/master/docs/html/ifkk_dokumentation.pdf