Mapping Phases#
Phase mapping assigns electrical phases (A, B, C, or split-phase) to transformer secondaries and downstream branches. You can use the built-in BalancedPhaseMapper or extend BasePhaseMapper for custom logic.
Using BalancedPhaseMapper#
BalancedPhaseMapper distributes load across phases as evenly as possible. You need to provide a TransformerPhaseMapperModel for each transformer in the graph, specifying its type and capacity. The actual transformer size used by the equipment mapper may differ — this model is used only for phase assignment.
from shift import (
TransformerPhaseMapperModel,
TransformerTypes,
BalancedPhaseMapper,
add_phase_mapper_to_plot,
PlotManager,
GeoLocation,
)
from gdm import DistributionTransformer
from gdm.quantities import ApparentPower
import osmnx as ox
# `new_graph` is the DistributionGraph from the previous steps
# Build a phase mapper model for each transformer edge
mapper_models = [
TransformerPhaseMapperModel(
tr_name=edge.name,
tr_type=TransformerTypes.SPLIT_PHASE,
tr_capacity=ApparentPower(25, "kilovoltampere"),
location=new_graph.get_node(from_node).location,
)
for from_node, _, edge in new_graph.get_edges()
if edge.edge_type is DistributionTransformer
]
phase_mapper = BalancedPhaseMapper(new_graph, mapper=mapper_models, method="agglomerative")
Visualizing Phase Assignments#
center = GeoLocation(*reversed(ox.geocode("Fort Worth, TX")))
plot_manager = PlotManager(center=center)
add_phase_mapper_to_plot(phase_mapper, plot_manager)
plot_manager.show()
Custom Phase Mapper#
For non-standard phase allocation, subclass BasePhaseMapper:
from shift import BasePhaseMapper
class MyPhaseMapper(BasePhaseMapper):
def __init__(self, dist_graph):
super().__init__(dist_graph)
# Implement custom phase assignment logic
Next Step#
Proceed to Mapping Voltages to assign primary and secondary voltage levels.