Skip to main content

Command line crafting tree visualizer for Satisfactory Game by CoffeeStain Studios

Project description

Satisfy-Calc

Introduction:

satisfy-calc is a command line utility for calculating and visualizing crafting trees in Satisfactory Game by Coffee Stain Studios written in Python. This utility is intended to aid users in the planning of complex production lines utilizing all available recipes, or for users that simply want to check their own designs for efficiency and correctness.

satisfy-calc is available on PyPI and can be installed using python -m pip install satisfy-calc.

Quick Use Guide:

  1. On first use, invoke python -m satisfy_calc update to get all up to date recipes. Repeat this step after game updates. Note: This step might take around a minute, and requires an active internet connection.
  2. After recipes have been fetched, invoke python -m satisfy_calc calc <Item Name> <Item Rate> and make selections as instructed. Note: Use single or double quotes around item names that have multiple words in them e.g. 'Iron Plate' 20 instead of just Iron Plate 20.

Detailed Use Guide:

satisfy-calc currently has 2 operating modes:

1. Updating locally stored recipes:

Invoked through python -m satisfy_calc update or python -m satisfy_calc -u, this mode will acquire all recipes currently available the game if they do not exist locally, or update the locally stored recipes if they exist.

Recipes are fetched from the Satisfactory Wiki, and therefore are subject to change during/after updates that affect recipe contents and/or add new recipes. The fetched recipes are stored locally under the package install directory as recipes.sc.

The use of this mode is recommended during first use of the utility in order to generate the initial file locally, and after any update that adds new recipes.

satisfy-calc is not intended to allow for simple recipe browsing, as the recipe tables found on the Wiki provide a more intuitive visual representation for recipes. While the satisfy-calc recipes.sc is a plaintext file, it is not meant for human viewing.

2. Building a crafting tree for a given input item at a desired rate:

Invoked through python -m satisfy_calc calc <Item Name> <Item Rate> or python -m satisfy_calc -c <Item Name> <Item Rate>, this mode will calculate the individual requirements to craft the given item at the given rate. Rate units for items is assumed to be items/min for solids and m3/min for fluids and gases.

Upon invocation the utility will start building a tree structure, starting from the specified item and given rate. The tree will grow new branches for each ingredient required to craft the specified item. At each such step, the user will be asked to provide their recipe of choice from a suitable list of recipes that can be utilized in the production of the necessary item. In this list, the first choice will always be the base recipe for a part, and following recipes are alternate, unlockable recipes. This process will repeat for each crafing step until each branch concludes in some form of raw input that can be extracted from the world, such as Ore or Crude Oil.

The display of each crafting step can be broken down into several parts:

  • Item name produced at given rate.
  • All byproducts of the crafting step at rates which they will be produced at, if applicable.
  • Name and number of buildings to carry out the crafting step. Note: If the item is any type of raw input, the necessary rate of extraction from the world will be listed instead.

Usage Example:

Upon the invocation of the following line: python -m satisfy_calc calc 'Iron Plate' 30

The following the user will be prompted to make a recipe selection:

Begin crafting tree calculation... 
Please select what recipe to use at each step: 

1 - [Iron Plate] made from [Iron Ingot]
2 - [Coated Iron Plate] made from [Iron Ingot, Plastic]
3 - [Steel Coated Plate] made from [Steel Ingot, Plastic]
Enter recipe # to use: _

This specific crafting tree does not conclude after a single step, therefore the user will be prompted to make a selection again:

Begin crafting tree calculation... 
Please select what recipe to use at each step: 

1 - [Iron Plate] made from [Iron Ingot]
2 - [Coated Iron Plate] made from [Iron Ingot, Plastic]
3 - [Steel Coated Plate] made from [Steel Ingot, Plastic]
Enter recipe # to use: 1

1 - [Iron Ingot] made from [Iron Ore]
2 - [Pure Iron Ingot] made from [Iron Ore, Water]
3 - [Iron Alloy Ingot] made from [Iron Ore, Copper Ore]
Enter recipe # to use: _

In both cases the base recipe from the list was selected, and the crafting tree is constructed automatically after all selections have been made:

Begin crafting tree calculation... 
Please select what recipe to use at each step: 

1 - [Iron Plate] made from [Iron Ingot]
2 - [Coated Iron Plate] made from [Iron Ingot, Plastic]
3 - [Steel Coated Plate] made from [Steel Ingot, Plastic]
Enter recipe # to use: 1

1 - [Iron Ingot] made from [Iron Ore]
2 - [Pure Iron Ingot] made from [Iron Ore, Water]
3 - [Iron Alloy Ingot] made from [Iron Ore, Copper Ore]
Enter recipe # to use: 1

 30/min Iron Plate.
 Made in 1.50x Constructor.

        L_ 45.0/min Iron Ingot.
           Made in 1.50x Smelter.

                L_ 45.0/min Iron Ore.
                   Mine/Extract resource from the world.

This specific crafting tree can be read as follows:

  1. Extract 45 Iron Ore/min from the world.
  2. Use 1.5 Smelters to smelt the 45 Iron Ore/min into 45 Iron Ingot/min.
  3. Use 1.5 Constructors to craft 45 Iron Ingot/min into 30 Iron Plate/min.

Note: The 1.5x [Building] notation is used to denote the use of 1.5 times the full production capacity of a single building instance. For example:

  • One [Building] overclocked to 150%
  • One [Building] at 100%, one [Building] downclocked to 50%
  • Two [Building] downclocked to 75%
  • Any other mathematically equivalent solution

can be used to satisfy the rate requirement. Due to the sandbox nature of Satisfactory, the user is free to implement any solution appropriate for their situation.

Future Plans:

  1. Reuse of recipes already selected by the user during the crafting tree.
    • This will likely be the default behavior of the utility.
    • A command line flag will be made available for users wishing to construct more complex factories, and will be asked to make a selection for every encountered recipe.
  2. Saving of generated crafting trees locally, and being able to fetch and see saved trees freely.
  3. Addition of item transport guidelines such as the Mk. of conveyors or pipes required for each connection.
  4. Scaling of crafting trees according to user-selected input constraints.
    • For example, if a generated crafting tree requires a larger amount of resources than what the user is able to provide, the crafting tree will be able to be entirely adjusted based on the specified resource.
  5. Optimization of crafting trees towards minimizing either power use or any chosen input the user considers limiting.
    • This includes the use of alternate recipes that will either remove the chosen input or maximally reduce the amount the chosen input used.
  6. Walkthrough mode to select what recipes should be offered during crafting tree construction, to allow the users to select their favorite recipes once and not have to worry about making numerous selections during the construction of each crafting tree.
  7. And in typical software development fashion, more tests and overall polish.

Update History:

  • Version 1.1.2 released:
    • Made available on PyPI.
  • Version 1.0.0 released.

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

satisfy-calc-1.1.3.tar.gz (17.2 kB view hashes)

Uploaded Source

Built Distribution

satisfy_calc-1.1.3-py3-none-any.whl (17.4 kB view hashes)

Uploaded Python 3

Supported by

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