/etterna-graph

Python script to track various Etterna statistics

Primary LanguageRust

EtternaGraph

Various graphs and plots to visualize your Etterna savegame.

Usage

Download the portable exe file and execute it.

I sometimes upload beta releases, check out the releases page for that

Navigate by panning and zooming with your mouse. Drag with the right mouse button for finer zoom control. You can click on the individual scatter points to see information about the corresponding score/session in the infobar at the bottom of the screen.

Running from source

Alternatively, you can run the program from source directly:

  1. Get a copy of this repository (git clone or "Download ZIP")
  2. Install the latest version of Python 3 (if you're on Windows, check the PATH checkbox at the end!)
  3. Install the required Python libraries via pip install -r requirements.txt
  4. Optional steps to fix legend symbols not appearing in "Skillsets trained per week" graph (bug in graphing library):
    1. Locate Python package install directory with pip show pyqtgraph
    2. Open pyqtgraph/graphicsItems/LegendItem.py
    3. Towards the bottom of the file, replace the line if opts['antialias']: with if opts.get('antialias', False):
  5. Go to the latest "action" and download the compiled savegame_analysis modules. Extract the dll file (.so file on Linux) from the downloaded zip and move it into src/ (alternatively, you can compile savegame_analysis from source)
  6. Now execute the main.py file from inside the root directory python src/main.py If anything in this complicated procedure didn't work, please write an issue, or just write me on Discord/Reddit/whatever

Compiling savegame_analysis from source

savegame_analysis is an embedded library that does the more tedious parts of the save game analysis in Rust, a fast compiled language. You have to compile it separately from the rest of the project, and this is how:

  1. Install Rust nightly
  2. Compile the crate in savegame_analysis/ with cargo build --release
  3. Move the resulting library file from savegame_analysis/target/release/ into src/
    1. Windows: move and rename from savegame_analysis/target/release/savegame_analysis.dll to src/savegame_analysis.pyd
    2. Linux: move and rename from savegame_analysis/target/release/libsavegame_analysis.so to src/savegame_analysis.so

Screenshot

Code structure

main.py contains the general application state and the UI.

app.py is a dummy class with just one variable that holds a reference to the general application state. I wanted to make the application state available to every module and this is my way of doing it.

plotter.py handles drawing all the plots. It depends on data_generators.py and plot_frame.py.

plot_frame.py is a wrapper class for the pyqtgraph Plot.

data_generators.py contains 30+ functions that take the raw Etterna data and analyze them in loads of different ways. Every plot has one corresponding function in here.

replays_analysis.py contains bridging code communicating with lib_replays_analysis

util.py contains various utility functions and constants