This a project of the lesson Operating Systems. (Unix) 2nd Bachelor at EPHEC
👉 Number : 4
👉 Authors :
- Daniel Olivier (@danny00747)
- Martin Michotte (@MMichotte)
- Morgan Valentin (@momo007dev)
- Martin Pardaens (@Martinp-95)
make
./prog
followed by --day
with it's value option sat
for example. And --step
with it's value to specify which step that needs to be runned Q1
for instance.
For race the user has the option to specify the lap --length
,
by default it's 7Km. The length command is optional.
For P sessions on friday (P1, P2, P3) :
./prog --day fri --step P2
For Q sessions on saturday (Q1, Q2, Q3) :
./prog --day sat --step Q3
For the RACE on sunday (RACE) :
./prog --day sun --step RACE --length 10
./prog -d sun -s RACE -l 10
For the manuel info (help) :
./prog --help
or./prog -h
For the version info (version) :
./prog --version
or./prog -v
IntelliJ IDEA Community Edition - A cross-platform IDE for C and C++
Use the help command for more information on how to run this program
./prog --help
Use the version command in order to get the program current version
./prog --version
- Création du GitHub
- Création d'un randomizer pour générer un temps
- Création d'un affichage temporaire pour tester des parties du code
- Réutilisation du randomizer pour la gestion des secteurs, tours et des crashs
- Création de l'affichage final
- Triage de l'affichage
- Création des forks et attribuer à chaque véhicule une structure par défaut
- Gestion de la compétition en 3 parties au niveau des séances d'essais libres
- Gestion de la compétition en 3 parties au niveau des qualifications
- Gestion de la compétition lors de la course, du grand prix
Le but du projet est de gérer un week-end complet d’un grand prix de Formule 1, depuis les séances d’essais du vendredi jusqu’à la course du dimanche, en passant par les essais du samedi et la séance de qualifications.
Il y a 20 voitures engagées dans un grand prix. Leurs numéros sont : 44, 77, 5, 7, 3, 33, 11, 31, 18, 35, 27, 55, 10, 28, 8, 20, 2, 14, 9, 16.
Un circuit de F1 est divisé en 3 secteurs (S1, S2, S3).
Le calendrier d’un week-end de F1 est établi comme suit :
- Vendredi matin, une séance d’essais libres d’1h30 (P1)
- Vendredi après-midi, une séance d’essais libres d’1h30 (P2)
- Samedi matin, une séance d’essais libres d’1h (P3)
- Samedi après-midi, la séance de qualifications, divisée en 3 parties :
- Q1, durée 18 minutes, qui élimine les 5 dernières voitures (qui occuperont les places 16 à 20 sur la grille de départ de la course)
- Q2, durée 15 minutes, qui élimine les 6 voitures suivantes (qui occuperont les places 11 à 16 sur la grille de départ de la course)
- Q3, durée 12 minutes, qui permet de classer les 10 voitures restantes pour établir les 10 premières places sur la grille de départ de la course
- Dimanche après-midi, la course en elle-même.
Votre projet devra prendre en charge les choses suivantes.
- Relever les temps dans les 3 secteurs à chaque passage pour chaque voiture
- Toujours savoir qui a le meilleur temps dans chacun des secteurs
- Classer les voitures en fonction de leur tour complet le plus rapide
- Savoir si une voiture est aux stands (P)
- Savoir si une voiture est out (abandon de la séance)
- Dans ces 2 derniers cas, on conserve toujours le meilleur temps de la voiture et celle-ci reste dans le classement
- Conserver le classement final à la fin de la séance
- Relever les temps dans les 3 secteurs à chaque passage pour chaque voiture
- Toujours savoir qui a le meilleur temps dans chacun des secteurs
- Classer les voitures en fonction de leur tour complet le plus rapide
- Savoir si une voiture est aux stands (P)
- Savoir si une voitures est out (abandon de la séance)
- Dans ces 2 derniers cas, on conserve toujours le meilleur temps de la voiture et celle-ci reste dans le classement
- A la fin de Q1, il reste 15 voitures qualifiées pour Q2 et les 5 dernières sont placées à la fin de la grille de départ (places 16 à 20)
- A la fin de Q2, il reste 10 voitures qualifiées pour Q3 et les 5 dernières sont placées dans les places 11 à 15 de la grille de départ
- Le classement de Q3 attribue les places 1 à 10 de la grille de départ
- Conserver le classement final à la fin des 3 séances (ce sera l’ordre de départ pour la course)
- Le premier classement est l’ordre sur la grille de départ
- Le classement doit toujours être maintenu tout au long de la course (gérer les dépassements)
- Relever les temps dans les 3 secteurs à chaque passage pour chaque voiture
- Toujours savoir qui a le meilleur temps dans chacun des secteurs
- Toujours savoir qui a le tour le plus rapide
- Savoir si la voiture est out (abandon) ; dans ce cas, elle sera classée en fin de classement
- Savoir si la voiture est aux stands (PIT), gérer le temps aux stands et faire ressortir la voiture à sa place dans la course (généralement 2 ou 3 PIT par voitures)
- Conserver le classement final et le tour le plus rapide
Remarque : les stands se trouvent toujours dans le secteur 3.
De plus, il vous est demandé de paramétrer votre programme.
En effet, les circuits peuvent être de longueur très variable et, dès lors le nombre de tours pour la course varie également (on essaie que le nombre total de kilomètres soit toujours plus ou moins le même pour chacune des courses du calendrier).
- Réaliser le programme en C sous Linux
- Utiliser la mémoire partagée comme moyen de communication inter-processus
- Utiliser les sémaphores pour synchroniser l’accès à la mémoire partagée
Bon courage. 👍
GNU General Public License v3.0
This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.
© Daniel Olivier, EPHEC Louvain-la-Neuve