ss14_chemistry_site/reworked/calc.py

53 lines
1.3 KiB
Python
Raw Normal View History

global expanded ; expanded = {}
def expand_recipe(recipe, recipes, main = False):
2024-05-01 12:07:43 +00:00
global expanded
ok = False
part = 1 # Одна часть
2024-05-01 12:07:43 +00:00
while not ok:
ok = True
min_vol = 0 # Объём мин. рецепта (вход)
# Перебираем элементы
2024-05-01 12:07:43 +00:00
for el in recipe:
# Если составное
2024-05-01 12:07:43 +00:00
if el in recipes:
# Одна часть должна делиться без остатка!
2024-05-01 12:07:43 +00:00
if part % recipes[el].out != 0:
ok = False
part += 1
expanded = {}
break
else:
min_vol += expand_recipe(recipes[el].comps, recipes)
2024-05-01 12:07:43 +00:00
else:
if el in expanded:
expanded[el] += recipe[el]*part
else:
expanded[el] = recipe[el]*part
min_vol += recipe[el]*part
if main:
return expanded, min_vol, part
else:
return min_vol
2024-05-01 12:07:43 +00:00
def calc(element, amount, recipes):
# Получаем характеристику элемента
2024-05-01 12:07:43 +00:00
recipe, out = recipes[element].comps, recipes[element].out
# Расчитываем минимальный рецепт
expanded, vol, part = expand_recipe(recipe, recipes, True)
2024-05-01 12:07:43 +00:00
# Домнажаем на сколько нужно
need = amount//vol
for i in expanded:
expanded[i] = expanded[i]*need
out = part*out*need
2024-05-01 12:07:43 +00:00
return expanded, out
2024-05-01 12:07:43 +00:00
from parse import *
#print( load_recipes() )
print( calc('Leporazine', 100, load_recipes()) )