Welcome to Predict-a-Kart โ a Mario Kart-inspired simulation where characters face off on legendary maps! This project uses Python to simulate races, leveraging stats from Super Mario Kart data to bring the thrill of the race to your terminal! ๐ฎ
Predict-a-Kart simulates epic battles between iconic Mario Kart characters across different maps! This simulation uses character stats, map-specific physics, and power-ups to determine who will cross the finish line first. You can run thousands of simulations, dive into physics-based results, and explore exciting CSV outputs!
- ๐ Race Simulations: Pit characters like Toad ๐ธ and Bowser ๐ข against each other on maps like Choco Island ๐ซ and Rainbow Road ๐!
- โ๏ธ Character & Map Data: Each character has unique stats โ from speed to handling, while each map has challenges like slipperiness and curves.
- ๐ฅ Power-Ups: Randomly applied power-ups add a thrilling twist to each race.
- ๐ Results Output: Get detailed results with character scores, map influences, and final winners saved to CSV files.
- Clone this repo: Get all the code files for the project.
- Install Requirements: Make sure you have Python 3.10 or later installed. You may also need packages like
csv
if they arenโt already available in your setup. - Run the Simulation: Use
app.py
to start the fun โ set up matchups, select maps, and let the races begin!
python app.py
app.py
: The main file to run the simulation! It sets up characters, selects maps, and runs simulations.data_loader.py
: Loads character, map, and power-up data from CSV files. ๐Simulation.py
: The core of the project โ runs each race simulation using character stats and map physics.Map.py
,Character.py
,PowerUp.py
: Classes defining the properties and methods for maps, characters, and power-ups.
Set up the number of races, choose characters, and specify maps to see who takes the gold ๐ฅ! The code runs simulations based on physics and randomness, generating scores for each matchup.
Results are saved in:
simulation_results.csv
for overall race outcomes ๐physics_simulation_results.csv
for physics-based scores and effects โ๏ธ
In simulation_results.csv
, youโll see:
- Character Matchups: E.g., Mario vs. Luigi
- Map Details: Like Choco Island ๐ซ or Koopa Beach ๐ข
- Race Outcomes: The final winner or tie
Weโre just getting started! Consider adding:
- More characters ๐
- Additional maps ๐
- Advanced power-up effects ๐
- Visualized race results ๐ผ๏ธ
Feel free to fork this repo and submit pull requests for improvements! Letโs make Mario Kart simulations even more exciting! ๐ฅณ
You can also run our preliminary UI when you download our project and run the command streamlit run app_ui.py
This project is inspired by Mario Kart and developed with โค๏ธ for simulation and data enthusiasts.
Happy racing! ๐๏ธ๐จ