diff --git a/etrago/appl.py b/etrago/appl.py index cdf3f3ad..364e5be1 100644 --- a/etrago/appl.py +++ b/etrago/appl.py @@ -103,6 +103,7 @@ "generator_noise": 789456, # apply generator noise, False or seed number "extra_functionality": {}, # Choose function name or {} # Spatial Complexity: + "delete_dispensable_ac_buses": False, # bool. Find and delete unnecessary buses "network_clustering_ehv": False, # clustering of HV buses to EHV buses "network_clustering": { "active": True, # choose if clustering is activated @@ -379,6 +380,11 @@ def run_etrago(args, json_path): Limit overall energy production country-wise for each generator by carrier. Set upper/lower limit in p.u. + delete_dispensable_ac_buses: bool + Choose if unnecessary buses should be identified and deleted from the + grid. This buses have no load or generation attached. Additionally, + they are just connected to two other buses. + Default: False. network_clustering_ehv : bool Choose if you want to cluster the full HV/EHV dataset down to only the EHV buses. In that case, all HV buses are assigned to their closest EHV diff --git a/etrago/cluster/electrical.py b/etrago/cluster/electrical.py index e46d6b0f..a834e8c3 100755 --- a/etrago/cluster/electrical.py +++ b/etrago/cluster/electrical.py @@ -320,6 +320,8 @@ def cluster_on_extra_high_voltage(etrago, busmap, with_time=True): # Dealing with links links = network.links.copy() dc_links = links[links["carrier"] == "DC"] + # Discard links connected to buses under 220 kV + dc_links = dc_links[dc_links.bus0.isin(buses.index)] links = links[links["carrier"] != "DC"] new_links = ( diff --git a/etrago/cluster/spatial.py b/etrago/cluster/spatial.py index 43af10b9..db3cc161 100755 --- a/etrago/cluster/spatial.py +++ b/etrago/cluster/spatial.py @@ -395,6 +395,12 @@ def busmap_by_shortest_path(etrago, scn_name, fromlvl, tolvl, cpu_cores=4): transformer = connected_transformer(etrago.network, s_buses) mask = transformer.bus1.isin(buses_of_vlvl(etrago.network, tolvl)) + dc = etrago.network.links[etrago.network.links.carrier == "DC"] + dc.index = "DC_" + dc.index + lines_plus_dc = pd.concat([lines, dc]) + lines_plus_dc = lines_plus_dc[etrago.network.lines.columns] + lines_plus_dc["carrier"] = "AC" + # temporary end points, later replaced by bus1 pendant t_buses = transformer[mask].bus0 @@ -403,7 +409,8 @@ def busmap_by_shortest_path(etrago, scn_name, fromlvl, tolvl, cpu_cores=4): # graph creation edges = [ - (row.bus0, row.bus1, row.length, ix) for ix, row in lines.iterrows() + (row.bus0, row.bus1, row.length, ix) + for ix, row in lines_plus_dc.iterrows() ] M = graph_from_edges(edges) @@ -532,24 +539,26 @@ def fetch(): busmap = fetch() - # TODO: Or better try/except/finally - if not busmap: - print("Busmap does not exist and will be created.\n") - - cpu_cores = etrago.args["network_clustering"]["CPU_cores"] - if cpu_cores == "max": - cpu_cores = mp.cpu_count() - else: - cpu_cores = int(cpu_cores) - - busmap_by_shortest_path( - etrago, - scn_name, - fromlvl=[110], - tolvl=[220, 380, 400, 450], - cpu_cores=cpu_cores, + if busmap: + print( + "Existing busmap will be deleted and a new one will be calculated." ) - busmap = fetch() + etrago.engine.execute("""DELETE FROM grid.egon_etrago_hv_busmap""") + + cpu_cores = etrago.args["network_clustering"]["CPU_cores"] + if cpu_cores == "max": + cpu_cores = mp.cpu_count() + else: + cpu_cores = int(cpu_cores) + + busmap_by_shortest_path( + etrago, + scn_name, + fromlvl=[110], + tolvl=[220, 380, 400, 450], + cpu_cores=cpu_cores, + ) + busmap = fetch() return busmap diff --git a/etrago/tools/utilities.py b/etrago/tools/utilities.py index d44171bc..ebc858f1 100755 --- a/etrago/tools/utilities.py +++ b/etrago/tools/utilities.py @@ -127,6 +127,16 @@ def buses_grid_linked(network, voltage_level): mask = ( network.buses.index.isin(network.lines.bus0) | (network.buses.index.isin(network.lines.bus1)) + | ( + network.buses.index.isin( + network.links.loc[network.links.carrier == "DC", "bus0"] + ) + ) + | ( + network.buses.index.isin( + network.links.loc[network.links.carrier == "DC", "bus1"] + ) + ) ) & (network.buses.v_nom.isin(voltage_level)) df = network.buses[mask] @@ -1079,6 +1089,8 @@ def delete_dispensable_ac_buses(etrago): None. """ + if etrago.args["delete_dispensable_ac_buses"] is False: + return def delete_buses(delete_buses, network): drop_buses = delete_buses.index.to_list()