mirror of
https://github.com/Akkudoktor-EOS/EOS.git
synced 2025-12-13 23:36:20 +00:00
Verluste stündlich / gesamt werden ausgegeben und mit minimiert
Start ab Stunde X jetzt möglich
This commit is contained in:
@@ -1,50 +1,79 @@
|
||||
import numpy as np
|
||||
class PVAkku:
|
||||
def __init__(self, kapazitaet_wh, hours, lade_effizienz=0.9, entlade_effizienz=0.9):
|
||||
def __init__(self, kapazitaet_wh=None, hours=None, lade_effizienz=0.9, entlade_effizienz=0.9,max_ladeleistung_w=None,start_soc_prozent=0):
|
||||
# Kapazität des Akkus in Wh
|
||||
self.kapazitaet_wh = kapazitaet_wh
|
||||
# Initialer Ladezustand des Akkus in Wh
|
||||
self.soc_wh = 0
|
||||
self.start_soc_prozent = start_soc_prozent
|
||||
self.soc_wh = (start_soc_prozent / 100) * kapazitaet_wh
|
||||
self.hours = hours
|
||||
self.discharge_array = np.full(self.hours, 1)
|
||||
self.charge_array = np.full(self.hours, 1)
|
||||
# Lade- und Entladeeffizienz
|
||||
self.lade_effizienz = lade_effizienz
|
||||
self.entlade_effizienz = entlade_effizienz
|
||||
self.max_ladeleistung_w = max_ladeleistung_w if max_ladeleistung_w else self.kapazitaet_wh
|
||||
|
||||
|
||||
def reset(self):
|
||||
self.soc_wh = 0
|
||||
self.soc_wh = (self.start_soc_prozent / 100) * self.kapazitaet_wh
|
||||
self.discharge_array = np.full(self.hours, 1)
|
||||
self.charge_array = np.full(self.hours, 1)
|
||||
|
||||
def set_discharge_per_hour(self, discharge_array):
|
||||
assert(len(discharge_array) == self.hours)
|
||||
self.discharge_array = discharge_array
|
||||
|
||||
def set_charge_per_hour(self, charge_array):
|
||||
assert(len(charge_array) == self.hours)
|
||||
self.charge_array = charge_array
|
||||
|
||||
def ladezustand_in_prozent(self):
|
||||
return (self.soc_wh / self.kapazitaet_wh) * 100
|
||||
|
||||
def energie_abgeben(self, wh, hour):
|
||||
if self.discharge_array[hour] == 0:
|
||||
return 0.0
|
||||
soc_tmp = self.soc_wh
|
||||
# Berechnung der tatsächlichen Entlademenge unter Berücksichtigung der Entladeeffizienz
|
||||
effektive_entlademenge = wh / self.entlade_effizienz
|
||||
# Aktualisierung des Ladezustands ohne negativ zu werden
|
||||
self.soc_wh = max(self.soc_wh - effektive_entlademenge, 0)
|
||||
return soc_tmp-self.soc_wh
|
||||
return 0.0, 0.0 # Keine Energieabgabe und keine Verluste
|
||||
|
||||
# if self.soc_wh >= wh:
|
||||
# self.soc_wh -= wh
|
||||
# return wh
|
||||
# else:
|
||||
# abgegebene_energie = self.soc_wh
|
||||
# self.soc_wh = 0
|
||||
# return abgegebene_energie
|
||||
# Berechnung der maximal abgebenden Energiemenge unter Berücksichtigung der Entladeeffizienz
|
||||
max_abgebbar_wh = self.soc_wh * self.entlade_effizienz
|
||||
|
||||
# Tatsächlich abgegebene Energie darf nicht mehr sein als angefragt und nicht mehr als maximal abgebbar
|
||||
tatsaechlich_abgegeben_wh = min(wh, max_abgebbar_wh)
|
||||
|
||||
# Berechnung der tatsächlichen Entnahmemenge aus dem Akku (vor Effizienzverlust)
|
||||
tatsaechliche_entnahme_wh = tatsaechlich_abgegeben_wh / self.entlade_effizienz
|
||||
|
||||
# Aktualisierung des Ladezustands unter Berücksichtigung der tatsächlichen Entnahmemenge
|
||||
self.soc_wh -= tatsaechliche_entnahme_wh
|
||||
|
||||
# Berechnung der Verluste durch die Effizienz
|
||||
verluste_wh = tatsaechliche_entnahme_wh - tatsaechlich_abgegeben_wh
|
||||
|
||||
# Rückgabe der tatsächlich abgegebenen Energiemenge und der Verluste
|
||||
return tatsaechlich_abgegeben_wh, verluste_wh
|
||||
|
||||
# return soc_tmp-self.soc_wh
|
||||
|
||||
def energie_laden(self, wh, hour):
|
||||
if hour is not None and self.charge_array[hour] == 0:
|
||||
return 0,0 # Ladevorgang in dieser Stunde nicht erlaubt
|
||||
|
||||
# Wenn kein Wert für wh angegeben wurde, verwende die maximale Ladeleistung
|
||||
wh = wh if wh is not None else self.max_ladeleistung_w
|
||||
|
||||
def energie_laden(self, wh):
|
||||
# Berechnung der tatsächlichen Lademenge unter Berücksichtigung der Ladeeffizienz
|
||||
effektive_lademenge = wh * self.lade_effizienz
|
||||
effektive_lademenge = min(wh, self.max_ladeleistung_w) * self.lade_effizienz
|
||||
|
||||
# Aktualisierung des Ladezustands ohne die Kapazität zu überschreiten
|
||||
self.soc_wh = min(self.soc_wh + effektive_lademenge, self.kapazitaet_wh)
|
||||
geladene_menge = min(self.kapazitaet_wh - self.soc_wh, effektive_lademenge)
|
||||
self.soc_wh += geladene_menge
|
||||
|
||||
verluste_wh = geladene_menge* (1.0-self.lade_effizienz)
|
||||
|
||||
return geladene_menge, verluste_wh
|
||||
# effektive_lademenge = wh * self.lade_effizienz
|
||||
# self.soc_wh = min(self.soc_wh + effektive_lademenge, self.kapazitaet_wh)
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user