This is a university project made by Giacomo Perlo and Alessio Mana in Turin in January 2021 for our Operating Systems Exam.
We named it "TaxiCab Game".
This is written in C (standard 89) and developed for Unix-like systems.
The main target was to build and run a program where the number of concurrent processes was the maximum possible for that execution.
In this game we are simulating a city (represented by a 2d map) with a certain number of Taxi and Sources which communicates each other.
- Sources : each Source is represented by a distinct process forked by a "Master process" (Master.c, which is the one who initialize the execution). Its position is fixed in the map and, with a certain frequence, it emits some request for a "taxi services" (with: start its own position and destination a random cell in the map).
- Taxi: each Taxi is represented by a distinct process forked by a "Master process". It "born" in a random cell of the map and waits for a "taxi service call" from any source.
The main pourpose of the program is to maximize the number of taxi and sources alive simultaneously and to complete as many "taxi service calls" as possible.
What you need to execute this game is:
- GCC compiler
sudo apt install gcc
or
sudo apt install build-essential
- Make util
sudo apt install make
There is a Makefile which automatically compiles and runs the project:
- You just have to know two simple commands to use the Taxicab Game. Once you have opened a shell in the folder which contains the application files, write:
make all
to compile the application. (If you want to modify the Height and Width of the map you need to use this.)make run
to run che application. (If you modify the Settings Parameters you just need to run the application with this command without recompile it.)CTRL-c
if you want to force the termination of the game.
The game use some parameteres:
- Execution Parameters: these are specified in the Settings file and will affect the result of the game.
If you modify them you don't have to recompile the application. (Just write "make run" in the shell). - Compilation Parameters: these are specified in the Common.h file (row: 26, 27) and affect the size of the map (height and width).
If you modify them you have to recompile the application. (first you write "make all" and then, once compiled, "make run").
This project was our first experience in C concurrent programming. It allowed us to learn the mechanisms behind this kind of programming and share some good time togheter. We take advantage of all those system calls which are essential in this kind of application. We also made experience on all the IPC such as Semaphores, Shared Memory and Message Queues. We enjoyed it a lot!
For sure something could be done in a better way (such as the algorithm which calculates the path a taxi have to follow to reach the destination/source) but we focused more over the "concurrent side" of the project.
For more examples, please refer to the Documentation.
Hope you enjoy this,
Jack & Ale
Giacomo Perlo: Linkedin, perlogiacomo@gmail.com
Alessio Mana: Linkedin, alessioma20@gmail.com
If you need help or want to know something more about all of this, we are ready and excited to help you!