๐ŸŽ๏ธ Predict-a-Kart ๐Ÿ†

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! ๐ŸŽฎ


๐Ÿ“‹ Project Overview & Figma

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!

๐Ÿ“ŠFigma: https://www.figma.com/proto/2L4W4Rlapyn1NUwc8bFSS2/Hack24?node-id=1-3&node-type=canvas&t=vcyBvKrgJhVfZuRy-1&scaling=scale-down&content-scaling=fixed&page-id=0%3A1&starting-point-node-id=1%3A3&share=1

Features

  • ๐Ÿ 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.

๐Ÿš€ Getting Started

  1. Clone this repo: Get all the code files for the project.
  2. 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.
  3. Run the Simulation: Use app.py to start the fun โ€“ set up matchups, select maps, and let the races begin!

Example Command

python app.py

๐Ÿ“‚ Project Structure

  • 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.

๐Ÿงช Running Simulations

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 โš™๏ธ

๐Ÿ“Š Sample Data

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

๐Ÿ“ˆ Future Enhancements

Weโ€™re just getting started! Consider adding:

  • More characters ๐ŸŽ‰
  • Additional maps ๐ŸŒ
  • Advanced power-up effects ๐Ÿš€
  • Visualized race results ๐Ÿ–ผ๏ธ

๐Ÿค Contributing & Running

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


๐Ÿ† Credits

This project is inspired by Mario Kart and developed with โค๏ธ for simulation and data enthusiasts.

Happy racing! ๐ŸŽ๏ธ๐Ÿ’จ