Pour exécuter le projet : utiliser python3 sur linux (car chemins sont séparés par des slash /) utilisez le script polyhash.py
. Voici un exemple de commande :
python ./src/polyhash.py ./challenges/b_busy_day.in
Cela va créer un repertoire ./output (si pas fait) dans le lequel seront contenus les fichiers de sortie.
Le Projet PolyHash se concentre sur le développement d'un système de gestion de livraison, utilisant des drones pour l'acheminement des commandes. Le projet est structuré à l'aide de quatre fichiers clés. Les fichiers inclus sont les suivants :
-
classes.py
: Ce fichier contient les définitions des classes essentielles qui forment le squelette du système. Les classes telles que Simulation, Drone, Warehouse, Order et ProductType sont implémentées ici, chacune jouant un rôle crucial dans la simulation du processus de livraison. -
polyparser.py
: Ce module est dédié à l'extraction des données nécessaires à la simulation à partir des fichiers d'entrée. La fonction principale ,parse_challenge(), de ce fichier est de lire et interpréter les informations relatives aux entrepôts, aux commandes, aux drones et autres paramètres essentiels. -
polysolver.py
: Le fichier principal de l'algorithme de simulation. C'est ici que la logique du déroulement de la livraison est implémentée. La fonction principal ,solve(), permet pour chaque commande : la recherche du warehouse le plus proche, du drone le plus approprié, le chargement optimal, la livraison et d'autres étapes cruciales sont définies dans cet algorithme. -
polyhash.py
: Ce fichier permet de finaliser tout le code. Il contient la fonction main et la logique de l'optimisation du challenge en fonction du fichier d'entrée. L'utilisation d'une approche de var_optimize ajustée en fonction du fichier d'entrée montre l'adaptabilité du système à différents scénarios de livraison.
L'organisation en quatre fichiers distincts vise à assurer une séparation claire des responsabilités et à faciliter la maintenance et l'extension du système. La combinaison de ces fichiers offre une solution complète pour le défi complexe de la gestion de livraison par drones.
Le projet PolyHash implémente une simulation de livraison utilisant différentes classes pour représenter les entités du problème :
-Les classes nécessaires pour la simulation sont définies dans le fichier classes.py
.
-Elles incluent les classes Simulation
, Drone
, Warehouse
, Order
, et ProductType
.
-Nous avons implementer dans chaque classes des méthodes et des fonctions.
-
Simulation (
Simulation
):- Représente la simulation dans son ensemble.
- Attributs :
rows
,columns
,drones
,turns
,max_payload
,product_types
,warehouses
,orders
,score
. - Méthodes :
sort_orders()
pour trier les commandes.
-
Drone (
Drone
):- Représente un drone dans la simulation.
- Attributs :
drone_id
,location
,payload
,current_turn
,inventory
,is_free
. - Méthodes :
update_is_free()
: méthode pour mettre à jour le statut du drone,load()
: méthode pour charger le drone,deliver()
: méthode pour décharger le drone afin de livrer la commande .
-
Warehouse (
Warehouse
):- Représente un entrepôt.
- Attributs :
warehouse_id
,location
,inventory
. - Méthodes :
update_is_empty()
: méthode pour mettre à jour le statut de l'entrepôt.
-
Order (
Order
):- Représente une commande à livrer.
- Attributs :
order_id
,location
,inventory
,order_turns
,is_completed
. - Méthodes :
update_is_completed()
: méthode pour mettre à jour le statut de la commande .
-
ProductType (
ProductType
):- Représente un type de produit.
- Attributs :
product_type_id
,weight
.
Avant de commencer l'implémentation de la solution , on s'est d'abord orienté vers l'analyse des données qui nous a été fournis
-
Représentation des données sur un plan orthonormé : -Pour chaque fichier dans le répertoire
/challenges
, les données sont représentées graphiquement sur un plan orthonormé.b_busy_day.in
c_redudancy.in
mother_of_all_warehouses.in
-
Analyse statistique des données :
- Moyenne du poids d'un type de produit
- max_payload/moyenne_poids_type_produit
- Dans une commande, en moyenne le nombre d'articles
Fichier Moyenne Poids Type Produit Max Payload / Moyenne Poids Type Produit Moyenne Articles par Commande b_busy_day.in 64.5875 3.09 7.4944 c_redudancy.in 63.6525 3.14 7.444 d_mother_of_all_warehouses.in 63.816 3.13 7.72125 -
Que nous inspire cette analyse :
- Stratégie de Livraison :
- Plutôt que de boucler sur un entrepôt, il est plus efficace de se concentrer sur chaque commande individuellement.
- Pour une commande donnée, mobiliser tous les drones disponibles afin d'accélérer le processus de livraison. 2. Priorisation des Commandes :
- Les commandes devraient être triées en priorité par le nombre d'articles qu'elles contiennent.
- En cas d'égalité du nombre d'articles entre plusieurs commandes, prioriser celles ayant un poids plus élevé.
- Si des commandes ont à la fois le même nombre d'articles et le même poids, alors les trier en fonction de la diversité des types de produits.
Ces ajustements visent à optimiser la séquence d'exécution des commandes et à maximiser l'efficacité des drones dans la livraison.
-Les données d'entrée sont extraites à l'aide du fichier polyparser.py
, qui contient la fonction parse_challenge()
.
-Cette fonction permet d'extraire les paramètres essentiels, tels que le nombre de lignes, de colonnes, de drones, etc.....
-Les types de produits et leurs poids associés sont extraits pour créer une liste d'objets 'ProductType'.
-Les informations sur les entrepôts, y compris leur emplacement et inventaire, sont extraites pour instancier des objets 'Warehouse'.
-Les détails sur les commandes, incluant emplacement et inventaire, sont extraits pour créer des objets 'Order'.
-Une liste de drones est créée, initialement positionnée au premier entrepôt.
-Cette fonction lit le fichier d'entrée et crée une instance de la classe Simulation
en utilisant les classes définies dans classes.py
.
Le déroulement de notre simulation se passe dans le fichier polysolver.py
via la fonction solve()
, et suit les étapes suivantes :
Pour chaque commande o
parmi les commandes triées :
- Rechercher l'entrepôt
w
le plus proche de la commandeo
qui contient au moins un article de la commande. - Rechercher le drone
d
le plus proche (forcément non vide) de l'entrepôtw
. - Déplacer le drone
d
vers l'entrepôtw
. - Charger le drone
d
en commençant par un type de produit, prenant le minimum entre la quantité disponible dans l'entrepôtw
et celle dans le droned
. Si le chargement est impossible, décrémenter de 1 jusqu'à 0, puis passer au type de produit suivant. - Déplacer le drone
d
vers la commandeo
. - Livrer les articles dans l'inventaire du drone
d
à la commandeo
. - Si la commande est complétée, passer à la suivante. Sinon, reprendre le processus jusqu'à ce qu'elle soit complète.
Fichier | Score |
---|---|
a_example.in | 234 |
b_busy_day.in | 98708 |
c_redudancy.in | 96670 |
d_mother_of_all_warehouses.in | 73051 |
Score total | 268663 |
Les membres de l'équipe CIDIA, qui ont fourni ces livrables sont :
- Souaibou Dine Barry; [email protected]
- Seynabou Faye; [email protected]
- Younes Hammoutene; [email protected]
- Sirine Dakhli [email protected]