Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
|
@@ -735,6 +735,13 @@ class NutrientCalculator:
|
|
| 735 |
"NH4+": self.target_profile['N (NH4+)']
|
| 736 |
}
|
| 737 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 738 |
def _label(self, element):
|
| 739 |
"""Форматирование названий элементов для вывода"""
|
| 740 |
labels = {
|
|
@@ -743,39 +750,44 @@ class NutrientCalculator:
|
|
| 743 |
}
|
| 744 |
return labels.get(element, element)
|
| 745 |
|
| 746 |
-
def
|
| 747 |
-
"""
|
| 748 |
-
|
| 749 |
-
|
| 750 |
-
|
| 751 |
-
|
| 752 |
-
|
| 753 |
-
|
| 754 |
-
|
| 755 |
-
|
| 756 |
-
|
| 757 |
-
|
| 758 |
-
|
| 759 |
-
|
| 760 |
-
|
| 761 |
-
|
| 762 |
-
self.
|
| 763 |
-
|
| 764 |
-
|
| 765 |
-
|
| 766 |
-
|
| 767 |
-
|
| 768 |
-
|
| 769 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 770 |
|
| 771 |
-
|
| 772 |
-
k_remaining = self.target_profile['K'] - self.actual_profile['K']
|
| 773 |
-
if k_from_kno3 > k_remaining:
|
| 774 |
-
# Если превысит - уменьшаем количество KNO3
|
| 775 |
-
no3_needed = (k_remaining / self.fertilizers["Калий азотнокислый"]["K"]) * \
|
| 776 |
-
self.fertilizers["Калий азотнокислый"]["N (NO3-)"]
|
| 777 |
|
| 778 |
-
|
|
|
|
|
|
|
| 779 |
|
| 780 |
def calculate(self):
|
| 781 |
"""Основной метод расчета с новой логикой"""
|
|
|
|
| 735 |
"NH4+": self.target_profile['N (NH4+)']
|
| 736 |
}
|
| 737 |
|
| 738 |
+
# Настройки компенсации по умолчанию
|
| 739 |
+
self.compensation_weights = {
|
| 740 |
+
'KNO3': 0.5, # Вес калийной селитры (0-1)
|
| 741 |
+
'CaNO3': 0.3, # Вес кальциевой селитры (0-1)
|
| 742 |
+
'K2SO4': 0.2 # Вес сульфата калия (0-1)
|
| 743 |
+
}
|
| 744 |
+
|
| 745 |
def _label(self, element):
|
| 746 |
"""Форматирование названий элементов для вывода"""
|
| 747 |
labels = {
|
|
|
|
| 750 |
}
|
| 751 |
return labels.get(element, element)
|
| 752 |
|
| 753 |
+
def set_compensation_weights(self, kno3_weight, cano3_weight, k2so4_weight):
|
| 754 |
+
"""Установка весов для компенсации элементов"""
|
| 755 |
+
total = kno3_weight + cano3_weight + k2so4_weight
|
| 756 |
+
self.compensation_weights = {
|
| 757 |
+
'KNO3': kno3_weight / total,
|
| 758 |
+
'CaNO3': cano3_weight / total,
|
| 759 |
+
'K2SO4': k2so4_weight / total
|
| 760 |
+
}
|
| 761 |
+
|
| 762 |
+
def calculate(self):
|
| 763 |
+
"""Основной метод расчета с новой логикой"""
|
| 764 |
+
try:
|
| 765 |
+
# 1. Вносим Mg и S
|
| 766 |
+
self._apply("Сульфат магния", "Mg", self.target_profile['Mg'])
|
| 767 |
+
|
| 768 |
+
# 2. Балансируем азот с учетом компенсации
|
| 769 |
+
self._balance_nitrogen_with_compensation()
|
| 770 |
+
|
| 771 |
+
# 3. Вносим Ca (остаток)
|
| 772 |
+
ca_needed = self.target_profile['Ca'] - self.actual_profile['Ca']
|
| 773 |
+
if ca_needed > 0.1:
|
| 774 |
+
self._apply("Кальциевая селитра", "Ca", ca_needed)
|
| 775 |
+
|
| 776 |
+
# 4. Вносим P
|
| 777 |
+
p_needed = self.target_profile['P'] - self.actual_profile['P']
|
| 778 |
+
if p_needed > 0.1:
|
| 779 |
+
self._apply("Монофосфат калия", "P", p_needed)
|
| 780 |
+
|
| 781 |
+
# 5. Корректируем K через сульфат калия (если остался дефицит)
|
| 782 |
+
k_needed = self.target_profile['K'] - self.actual_profile['K']
|
| 783 |
+
if k_needed > 0.1:
|
| 784 |
+
self._apply("Калий сернокислый", "K", k_needed)
|
| 785 |
|
| 786 |
+
return self.results
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 787 |
|
| 788 |
+
except Exception as e:
|
| 789 |
+
print(f"Ошибка при расчёте: {str(e)}")
|
| 790 |
+
raise
|
| 791 |
|
| 792 |
def calculate(self):
|
| 793 |
"""Основной метод расчета с новой логикой"""
|