fix solar sell pri male zaporne cene
This commit is contained in:
@@ -687,10 +687,13 @@ def solve_dispatch(
|
||||
if s.sell_price < 0:
|
||||
prob += w_arb[t] == 0
|
||||
prob += bd[t] <= pulp.lpSum(ev_via_bat[e][t] for e in range(EV))
|
||||
# BA81 (GEN port microinverters): pokud máme k dispozici GEN cut-off, držíme skutečný
|
||||
# BLOCK_EXPORT jako hard constraint: export do sítě v okně se záporným prodejem je zakázaný.
|
||||
# Přebytek pak řeší curtail PV A / nabíjení / případně GEN cut-off (reg 178 bits0–1).
|
||||
if z_gen_cutoff is not None:
|
||||
# Tvrdý zákaz vývozu při záporné prodejní ceně, pokud:
|
||||
# - site má GEN/MI cutoff model (binárky z_gen_cutoff — BA81), nebo
|
||||
# - explicitně site_grid_connection.block_export_on_negative_sell (např. fixní nákup, bez pole B).
|
||||
block_neg_sell_export = bool(
|
||||
getattr(grid, "block_export_on_negative_sell", False)
|
||||
)
|
||||
if z_gen_cutoff is not None or block_neg_sell_export:
|
||||
prob += ge[t] == 0
|
||||
|
||||
soc_prev_expr = current_soc_wh if t == 0 else soc[t - 1]
|
||||
@@ -1146,6 +1149,7 @@ async def _load_site_context(site_id: int, db):
|
||||
grid = SimpleNamespace(
|
||||
max_import_power_w=int(g["max_import_power_w"]),
|
||||
max_export_power_w=int(g["max_export_power_w"]),
|
||||
block_export_on_negative_sell=bool(g.get("block_export_on_negative_sell") or False),
|
||||
deye_gen_microinverter_cutoff_enabled=bool(g.get("deye_gen_microinverter_cutoff_enabled") or False),
|
||||
)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user