This application simulates a team of fire mages casting against a single boss level target within the framework of Classic Era mechanics.
Here are the steps to install and run the application on Windows.
- Under the green "Code" link above, select "download ZIP"
- Extract the ZIP file into a directory such as "C:\sims"
- Download and install the Anaconda package: tested windows version
- From the Start menu, open an Anaconda Prompt (see below)
- Go to the directory you extracted the code to in Step 2 using the "cd" command.  For the above example, cd \sims\fire-mage-simulation
- Create a conda environment with the python dependencies we use conda env create -f environment.yml
- To activate the environment run conda activate firemage
- Run the application with python -m src.gui.main
Start by selecting the Scenario editor tab on the top left.

Within the Mages section you can change the stats and other attributes of each mage. From left to right: The stats should be entered as from gear/enchant only for spell power, hit, and crit. Int should be entered as base value + gear, with no buffs. The trinket section informs the sim which active trinkets are available. Next are indicators for the UDC set bonus and whether the mage can receive PI. For now, only one PI per mage can be available. "Target" indicates whether that mage's personal DPS and their share of the ignite are included in the output. The expected output for only one mage on the team can be analyzed by checking only a single target box. Finally there are three aura indicators for Mage Atiesh, Warlock Atiesh, and Boomkin Crit. Only auras from other in-party members are counted here, self auras are not. Buttons on the far right (for the bottom mage) increase or decrease the number of mages.
As an alterative to directly editing stats, they can be automatically populated by loading a character export from the excellent website sixtyupgrades.  To do so, make a character on the website, and export it to file.  Save the exported character to the directory .\data\characters\ within the simulation installation.  Then from the scenario editor, if you click "Mage 1", the exported charater should be available to load within the simulator.  Importing a sixtyupagrades character automatically sets stats, trinkets, and set bonuses.  These attributes can no longer be adjusted.  Target, PI, and the auras are still adjustable as they are independent of gear.  To release a mage to be adjusted manually again, click the name again.
The Rotation section has an initial fixed set of rotation commands that each mage attempts to cast when the fight starts. Abilities that are not available to a mage are skipped and do not expend any time. For example if "mqg" is on the list but a mage doesn't have Mind Quickening Gem, when they get to that cast in the sequence it is ignored. The Special section assigns one or more mage to a continuing rotation in which usually scorch is cast given a set of conditions. Other mages spam the default spell once the initial rotation is complete. Details about the special rotations are given in the tooltip. After the initial rotation, and unless contradicted by a special ruleset, abilities that are on cooldown (combustion, trinkets, etc...) will be recast when they become available.
In the bottom right scenario selection panel, type in "weight_mage" for Scenario 1, and then press "Load". Switch to the Simulation tab and run the sim with default paramters. The output should look like this:
Lety's play around with a few of the scenario and simulation settings.
- Switch back to the Scenario tab. Notice that for the weight_mage scenario, there are two tabs under rotation: "No PI" and "PI". Mages that have PI will follow the PI rotation, and those that don't will follow the "No PI" rotation. The purpose of having two rotations is to increase the chances of a PI buffed mage initiating the ignite by frost buffering the non-PI mages.
- Change the "Special 1" rotation to "cobimf" for mage 3. Rerun the Stat weights. You should see a slight increase in DPS.
- In the Simualtion Settings panel, deselect "Vary All Mages" and then click on all the numbers except 1. This looks at the effect of changing only the stats for Mage 1 to calculate the stat weights. So the DPS output should not be affected, but Crit and Hit will be. You should see the crit valuation go up a few SP points. Crit is more important for the well geared Mage 1 than it is for the team aggregate.
- Return to the Scenario tab and deselect target for all mages but Mage 1. Rerun the simulation and you should see much higher DPS values.
The scenario selection panel is on the bottom right of the application. Here you can load, save, add, and remove multiple scenarios. The selection button on the left indicates which scenario is shown and edited in the scenario editor as well as the scenario that is run for stat weight/distribution type simulations.
A Scenario Comparison Run plots all scenarios in the selection panel as a function of encounter time. In the comparison plot below, BiS three mage teams with different trinkets and rotations are compared in encounters from 30s to 90s. Each trinket+rotation combination is the top DPS for an interval. The scenarios shown are based on the "undead-lf-bis-no-udc" character with only trinkets changed. Both the character and the scenarios shown are included in this package.
Here are some results from other simulations:
Thanks to elio for tracking down the error in ignite timing and providing parallel code sample! Thanks to alzy for the sim result comparison, which helped pin down a bug in the scorch refresh logic!



