mirror of
https://github.com/Akkudoktor-EOS/EOS.git
synced 2025-04-19 08:55:15 +00:00
- discharge hour penalty from start_hour
- Inverter: Frist try of small self consumption rate (fixed) for better discharge_hour results
This commit is contained in:
parent
79ecf71353
commit
653f4f8d9f
@ -31,25 +31,39 @@ class Wechselrichter:
|
|||||||
eigenverbrauch = self.max_leistung_wh
|
eigenverbrauch = self.max_leistung_wh
|
||||||
else:
|
else:
|
||||||
# Remaining power after consumption
|
# Remaining power after consumption
|
||||||
restleistung_nach_verbrauch = erzeugung - verbrauch
|
restleistung_nach_verbrauch = (erzeugung - verbrauch) * 0.95 # EVQ
|
||||||
|
# Remaining load Self Consumption not perfect
|
||||||
|
restlast_evq = (erzeugung - verbrauch) * (1.0 - 0.95)
|
||||||
|
|
||||||
# Load battery with excess energy
|
if restlast_evq > 0:
|
||||||
geladene_energie, verluste_laden_akku = self.akku.energie_laden(
|
# Akku muss den Restverbrauch decken
|
||||||
restleistung_nach_verbrauch, hour
|
aus_akku, akku_entladeverluste = self.akku.energie_abgeben(restlast_evq, hour)
|
||||||
)
|
restlast_evq -= aus_akku # Restverbrauch nach Akkuentladung
|
||||||
rest_überschuss = restleistung_nach_verbrauch - (
|
verluste += akku_entladeverluste
|
||||||
geladene_energie + verluste_laden_akku
|
|
||||||
)
|
|
||||||
|
|
||||||
# Feed-in to the grid based on remaining capacity
|
# Wenn der Akku den Restverbrauch nicht vollständig decken kann, wird der Rest ins Netz gezogen
|
||||||
if rest_überschuss > self.max_leistung_wh - verbrauch:
|
if restlast_evq > 0:
|
||||||
netzeinspeisung = self.max_leistung_wh - verbrauch
|
netzbezug += restlast_evq
|
||||||
verluste += rest_überschuss - netzeinspeisung
|
restlast_evq = 0
|
||||||
else:
|
|
||||||
netzeinspeisung = rest_überschuss
|
|
||||||
|
|
||||||
verluste += verluste_laden_akku
|
if restleistung_nach_verbrauch > 0:
|
||||||
eigenverbrauch = verbrauch # Self-consumption is equal to the load
|
# Load battery with excess energy
|
||||||
|
geladene_energie, verluste_laden_akku = self.akku.energie_laden(
|
||||||
|
restleistung_nach_verbrauch, hour
|
||||||
|
)
|
||||||
|
rest_überschuss = restleistung_nach_verbrauch - (
|
||||||
|
geladene_energie + verluste_laden_akku
|
||||||
|
)
|
||||||
|
|
||||||
|
# Feed-in to the grid based on remaining capacity
|
||||||
|
if rest_überschuss > self.max_leistung_wh - verbrauch:
|
||||||
|
netzeinspeisung = self.max_leistung_wh - verbrauch
|
||||||
|
verluste += rest_überschuss - netzeinspeisung
|
||||||
|
else:
|
||||||
|
netzeinspeisung = rest_überschuss
|
||||||
|
|
||||||
|
verluste += verluste_laden_akku
|
||||||
|
eigenverbrauch = verbrauch + aus_akku # Self-consumption is equal to the load
|
||||||
|
|
||||||
else:
|
else:
|
||||||
benötigte_energie = verbrauch - erzeugung # Energy needed from external sources
|
benötigte_energie = verbrauch - erzeugung # Energy needed from external sources
|
||||||
|
@ -361,7 +361,7 @@ class optimization_problem:
|
|||||||
|
|
||||||
# Small Penalty for not discharging
|
# Small Penalty for not discharging
|
||||||
gesamtbilanz += sum(
|
gesamtbilanz += sum(
|
||||||
0.01 for i in range(self.prediction_hours) if discharge_hours_bin[i] == 0.0
|
0.01 for i in range(start_hour, self.prediction_hours) if discharge_hours_bin[i] == 0.0
|
||||||
)
|
)
|
||||||
|
|
||||||
# Penalty for not meeting the minimum SOC (State of Charge) requirement
|
# Penalty for not meeting the minimum SOC (State of Charge) requirement
|
||||||
|
Loading…
x
Reference in New Issue
Block a user