This repo includes scripts and sims for shadow priests.
Contributions are always welcome, this project uses ruff
for linting.
All scripts are run built with python3, but should be able to be run with python2 (results may vary).
- Run
pip install -r requirements.txt
in order for the scripts to work. - Edit and confirm config in
config.yml
, this controls how profiles are built, sims are ran, and aggregated. See the wiki for more information.
To run every folder of sims for composite and dungeons, you can simply run python suite.py
. This will go through each and every sim folder and sim for each type based on config.yml
for each sim. By default this currently excludes apl
, talents
, and talents-top
(can be altered by passing a list to --exclude
). This script keeps track of state via internal/suite.csv
to know which sims it has run already for that suite run. This means if you start the suite and then stop/restart it later it will pick up where it left off. To start a new, clean run you just pash the --fresh
argument. When using this command there is no reason to run the other two scripts below unless you are looking to do one off sims.
- Run
python profiles.py dir/ [--ptr, --dungeons, --talents [x, y]]
for the directory you want to sim. Current talent options are indicated by the config keys under:builds
. If you don't specifytalents
and that sim uses it based on config, all combinations will be automatically generated.
- To run the sim in Raidbots create
api_secrets.py
inside the root directory. Setapi_key = 'XXX'
. - By default if a file already exists in
output/
or if the weight ininternal/weights.py
is 0, sim.py will skip it. - To run the sims use
python sim.py dir/ [--iterations 10000, --dungeons, --talents [x, y]]
wheredir/
is the sim directory you want to sim. If you don't specifytalents
and that sim uses it based on config, all combinations will be automatically generated. - Based on config keys in
analyze
markdown, csv, and json will be generated for the aggregated sims. These will output separate files for Composite, Single Target, or Dungeon sims. You can find all output files in theresults/
folder in any sim folder.
- To run with a local simc you have three options:
- use the simc you have on your Path ( nothing to setup here )
- use a simc located in a separated folder, create a
local_secrets.py
inside the root directory and setsimc_path = '{"nightly": "path/to/executable", "rework": "another/path"}'
- add the
--auto_download
parameter to download the latest simc nightly build into theauto_download/
folder. This will override any choice inconfig.yml
with the path to the newly downloaded version. (note: this is only supported on windows currently)
We use a dict here to support different
simcVersions
like raidbots, you can so define a different simc installation by every key you define. If you don't supply thelocal_secrets.py
we will use the simc on the path for every differentsimcVersion
defined inconfig.yml
.
- By default if a file already exists in
output/
or if the weight ininternal/weights.py
is 0, sim.py will skip it. - To run the sims use
python sim.py dir/ [--iterations 10000, --dungeons, --talents [am, hv] --local]
wheredir/
is the sim directory you want to sim. If you don't specifytalents
and that sim uses it based on config, all combinations will be automatically generated. - Based on config keys in
analyze
markdown, csv, and json will be generated for the aggregated sims. These will output separate files for Composite, Single Target, or Dungeon sims. You can find all output files in theresults/
folder in any sim folder.
Based on config.yml
sim results will output in up to 3 different formats: Markdown, CSV, and JSON. The files are all located in the results/
folder of each sim type. The following sections go over how the data is listed here. Each output file is made up into various sections based on how the sim is configured. There are several layers of results.
- Sim Type
- Composite
- Dungeons
- Single
- Talents
These layers are used to create the file name. So if a sim is run with default setup without talent builds it will just be Results_SIMTYPE
i.e. Results_Composite.md
. If the sim is ran with talents this is augmented with that talent build (see config for current builds) i.e.Results_Composite_x.md
.
The markdown files are broken up and contain easy layer name at the top as a header. Each file is just a simple table broken up by Actor, DPS, and the Increase of that actor against the Base
actor.
The CSV files are the simplest of the bunch, the only trick is that we parse the sim type profile as the start of the row. So a row is simply profile,actor,DPS,increase,
.
JSON files contain the most rich information about the results. The basic structure is as follows:
{
"name": "SIMTYPE - TALENT",
"data": {
"ACTOR": {
"DPS": 1234
},
},
"ids": {
"ACTOR": null,
},
"simulated_steps": [
"DPS"
],
"sorted_data_keys": [
"ACTOR",
],
"last_updated": "YYYY-MM-DD"
}
- Name: simple name of the sim containing all relevant information about the data
- Data: this contains the sorted result list of each actor. The content of this will depend on the data itself as defined in
config
. For most sims this will just be a single entry forDPS
as the step, but for things like trinkets this will be a step for each ilevel i.e.420
,425
. - IDs: This will contain rich information for each actor to be used to generate tooltip data. There are several different ways to lookup this data, namely
spell
,item
, ornone
. ThislookupType
is defined for each type of sim inconfig
. Spell type will use this file that links actor names to spell IDs to populate this. The item type searches in.simc
files of the sim for the corresponding actor name and adds the ID it finds on that line. - Simulated Steps: This just enumerates the steps used in
data
- Sorted Data Keys: This list is sorted by maximum dps in order.
- Last Updated: simply contains the timestamp that the chart was generated