Mathematical Functions & Optimization Calculations for OSRS
Project description
The Mathematics and Optimization of OSRS
The purpose of this project is to accurately model Old School Runescape mechanics in order to optimize or analyze game play. This game is played over long periods of time (months or years) and so players are often seeking the most optimal route to their desired accomplishments. In particular, combat is a particularly rewarding application, as very complex problems that were previously unsolved for decades can now be.
If you're interested, you can join the discord to discuss anything!
There are three components to this project:
1. Applications
These application provide useful functionalities for end users. Once installed, they can be run using the command: python -m [Module Location]
.
Application | Module Location | Description |
---|---|---|
Optimize | osrsmath.apps.optimize.main |
What is the most efficient equipment to wear when fighting a given opponent? |
2. Library
For developers, they can use the basic functionalities (like modeling combat or potion boosts) to build their own applications. The code is available on PyPi, and can be installed using pip3 install osrsmath
. Within their own code the can import functionalities using import osrsmath.[module_of_interest]
. Download the source, and check out the documentation for the modules at OSRSmath/osrsmath/docs/html/osrsmath/index.html
to see what can be done.
3. Documentation
Coherent and comprehensive documentation doesn't really exist regarding the math behind osrs. This project provides a document that attempts to fill this gap. It also documents its source code, which can be viewed by downloading the source and navigating to osrsmath/docs/html/osrsmath/index.html
. In future, it would be nice to host this online.
Installing
User
This application was written in the programming language Python
, which has two major version. python3
is the version used here, more specifically any version greater than 3.6.3
should work (the latest is best).
- To install
Python
simply visit the download page. - Once it is installed, open a terminal (MacOS/Linux) or command prompt (Windows).
- Type the command
pip3 install --upgrade pip
thenpip3 install osrsmath
to install this program. - Then type
python3 -m osrsmath.apps.[app_name].main
to run an application. For example, replace[app_name]
withoptimize
to run the optimize application.
You might also consider trying the executables directly, although there are currently installation issues, particularly on MacOS so this isn't currently recommended. To do this, navigate to GitHub releases and download the latest version (Asset) for your system. Unzip, and run!
Developer
- Open a terminal/command prompt.
- Make sure you have
python3.6+
installed (typepython --version
) - Make sure
pip3
is installed (typepip3 --version
). - Update pip
pip3 install --upgrade pip
- Update setuptools
pip3 install --upgrade setuptools
To install the apps, or to use as a library:
pip3 install osrsmath
To develop the code:
- Download the github source code, unzip it and place it anywhere.
- Open a terminal in that directory (which contains setup.py).
- Run
pip3 install -e .
Run the desired application with: python3 -m osrsmath.apps.[app_name].main
. Linux may require sudo apt-get install python3-pyqt5
These installation methods have been tested on:
Ubuntu 20.04
(using wsl1 on windows),
MacOS
(Catalina 15.15.5),
and
Windows 10
(v1909)
Developing
Packaging:
These are instructions for creating app executables:
- Type
pip3 install PyInstaller
- On MacOS,
python<=3.6.3
is required since PyInstaller on macos isn't supported after that. On Windows, the app store version of Python (3.8) doesn't work. - Navigate to the
Application
folder of the app you want to create an executable for. - Type
python3 package.py
. - Symbolic links should then be created to
dist/main/main[.exe]
, the should be named osrsmath-[app_name].
On MacOS, the application has to be signed. I don't know the Mac ecosystem very well, however these websites helped me:
- https://github.com/pyinstaller/pyinstaller/wiki/Recipe-OSX-Code-Signing
- https://stackoverflow.com/questions/16845169/error-when-trying-to-obtain-a-certificate-the-specified-item-could-not-be-found
- https://apple.stackexchange.com/questions/254380/why-am-i-getting-an-invalid-active-developer-path-when-attempting-to-use-git-a
GUI Development:
These are instructions for creating & modifying the GUI design:
- Use QT designer.
- Create or modify a
.ui
file in QT designer. - Run
python -m osrsmath.apps.GUI.shared.util make
to compile them.
Documentation
To compile the latex documents a latex compiler needs to be installed. MiKTeX is a good cross-platform option. Alternatively, on linux you could simply type sudo apt-get install texlive-full
.
The central document can be compiled with pdflatex main.tex
.
The html documentation uses pdoc3
which can be installed with pip3 install pdoc3
. Then the documentation can be compiled by naviating to the top directory (containing setup.py
) and type:
pdoc --html osrsmath -o osrsmath/docs/html -c latex_math=True --force
python osrsmath/docs/compile.py
Tests
The unittest
module is used for testing. Navigate to the tests
directory and run the command python3 -m unittest
Authors
- Nawar Ismail - Palfore
If you are interested in contributing, check out the issues section on GitHub.
License
This open-source project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
Code
Knowledge
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for osrsmath-0.0.3.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | fae2a2ab6a6683767426edb18696de823b8034e41dee9ba49ef4b00f8ce06da2 |
|
MD5 | 72de073fa92ff26acd65c1e78fa77881 |
|
BLAKE2b-256 | 3796a3e894d53f837c8b3fa31d9f545d69b11f8f2772c2cb5efec27e6cdfc427 |