Skip to main content

Worker empire optimizer for BDO using HiGHS mip solver.

Project description

bdo-empire

About

Given a contribution point limit and price list this program will find the optimum allocation of the points to maximize a Worker Node Empire's value.

It

  • generates a json file to import into Workerman
  • uses workers of level 40.
  • uses workers with optimum skills learned.
  • assumes all drops are sent to storage with zero cost (Calpheon).

and, when specified, it

  • accounts for workshop lodging cost but not profits or the workshop itself.
  • accounts for grinding node connections.
  • extends lodging and worker nodes from a base empire exported from Workerman.

It does not

  • account for CP spent outside of the Node Empire.

This program uses the HiGHS High Performance Optimization Software to solve the MIP using branch and cut. The parameters chosen guarantee the result is within 0.01% of the optimum value but in practice it is optimum for all test cases used during the development and testing of the model.

NOTE: Every change in input or options can alter the runtime! There is no real average but empirically budgets of ~350 or ~600 take the longest and all of the bench cases for v0.5.0 complete in < 30 minutes when testing every increment of 25 from 50 to 625. The vast majority of those completed nearer to 10 minutes or less. Good luck, be patient, and if needed use the 'stop' button to use the best solution found so far.

Installation

Using pipx: pipx install bdo-empire
Using pip: pip install bdo-empire

Usage

Requirements

* Use the 'reload' button on workerman's setting page prior to exporting.

Start the program

Installed using pipx: empire-optimizer.exe
Installed using pip: python -m bdo_empire.main

Fill in the required fields, click Optimize and then wait.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bdo_empire-0.5.5.tar.gz (434.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bdo_empire-0.5.5-py3-none-any.whl (478.5 kB view details)

Uploaded Python 3

File details

Details for the file bdo_empire-0.5.5.tar.gz.

File metadata

  • Download URL: bdo_empire-0.5.5.tar.gz
  • Upload date:
  • Size: 434.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for bdo_empire-0.5.5.tar.gz
Algorithm Hash digest
SHA256 8fa939134e9bf4ea01592ce82b0b0ed476ebbcd2e9e8262ddf816d84c1c5a303
MD5 50718891a2c65713b702d3e0e4bfa10e
BLAKE2b-256 4e0d54e855dedc609b026100137898a908d019d530f846e819e94413710402d0

See more details on using hashes here.

File details

Details for the file bdo_empire-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: bdo_empire-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 478.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for bdo_empire-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 e6e9d86d053774267844abf86c19d5bb434f3f70823ae87596ddee0fb21fea10
MD5 e4904ed8fb69436c5ad2cb2c771d8f2d
BLAKE2b-256 4c56cc3cc3d9ea914e1a78c31382641198576edfad3f37fbfe2b630979fa62c8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page