Skip to content

Latest commit

 

History

History
106 lines (70 loc) · 4.4 KB

README.md

File metadata and controls

106 lines (70 loc) · 4.4 KB

UBC Solar's ASC and FSGP Simulation

Build Status

Welcome to UBC Solar's race strategy simulation environment! The objective of this simulation is to guide UBC Solar's race strategy by creating a model to predict the performance of the UBC Solar cars in the American Solar Challenge (ASC) and Formula Sun Grand Prix (FSGP).

This document contains information on how to get setup with the Simulation framework.

For more detailed information on the inner workings of the simulation please refer to the wiki.

For instructions on how to use the scripts provided, see our usage guide.

Getting started

Prerequisites

Open up your terminal/command prompt and execute the following commands to check your installations.

  • Ensure you have Git installed by running:
git --version
  • Check your Python installation by running:
python3 --version
  • Check your Poetry installation by running:
poetry --version

Installation

  • Clone the simulation repository into any directory of your choosing by running:

    git clone https://github.com/UBC-Solar/Simulation.git
  • You should now have a "Simulation" folder inside your chosen directory. To enter the "Simulation" folder run:

    cd Simulation
  • Simulation uses poetry to manage dependencies. First, we will create a virtual environment.

On Windows, the command to activate a virtual environment is .venv\Scripts\activate instead of source .venv/bin/activate.

python3 -m venv .venv
source .venv/bin/activate
  • Now, use poetry to install dependencies.
poetry install
  • You should then be able to run the command simulation_health_check, which will ensure everything is working properly.

    simulation_health_check

    You should see a dump of information ending with a "Simulation was successful!", indicating that everything worked properly.

Preparing Simulation

  • Simulation requires external data in order to construct the physical environment that our cars will traverse. As such, you'll need API keys for Google Maps's Directions API, and one of Solcast's Irradiance and Weather Forecast API or Openweather's One Call API. UBC Solar members can acquire these from the Strategy Lead.
    • Once you have acquired the necessary API keys, you can either set the global environment variables GOOGLE_MAPS_API_KEY and SOLCAST_API_KEY or OPENWEATHER_API_KEY, or you can place them in a .env file, replacing $your_key$ with your API keys.
      GOOGLE_MAPS_API_KEY=$your_key$
      SOLCAST_API_KEY=$your_key$
      
    • If you are trying to simulate FSGP, for example, modify start_year, start_month, and start_day in simulation/config/settings_FSGP.json as needed such that you are trying to simulate at a valid time for FSGP. Simulation can only simulate the near future, so if the dates are such that FSGP is in the past or distant future (beyond the length of the race) then it will fail to gather weather forecasts.
    • Now, run the following commands to invoke requests to the necessary APIs, which will cache the necessary data. See the usage guide for further details on the scripts being invoked.
      python3 simulation/cmd/compile_races.py
      python3 simulation/cmd/cache_data.py --api GIS --race FSGP
      python3 simulation/cmd/update_environment.py --race FSGP

Troubleshooting

You may run into Python path shenanigans, which is usually indicated by trying to run Simulation and getting ModuleNotFoundError: no module named simulation.utils. If this is the case, StackOverflow and Google will be your best friend but you can try the following command.

PYTHONPATH="/path/to/Simulation:$PYTHONPATH" && export PYTHONPATH

If you are having errors related to a specific package, it is likely that your system has installed an incompatible (usually too recent) version. Double check that you installed the exact versions of suspect packages.