optiwindnet.pathfinding¶
Module Contents¶
- class optiwindnet.pathfinding.PathFinder(Gʹ: networkx.Graph, planar: networkx.PlanarEmbedding, A: networkx.Graph, *, branched: bool = True, iterations_limit: int = 15000, traversals_limit: int = 3, bad_streak_limit: int = 5, turn_limit: float | None = None)[source]¶
Router for feeders that would cross other routes if laid in a straight line.
PathFinder finds the shortest segmented (or detoured) routes for tentative feeders (i.e. those that were created without a check for crossings of other routes). The path-finding is performed when the instance is initialized, but a route set is returned only with a call to method .create_detours().
Only edges in graph attribute ‘tentative’ or, lacking that, edges with the attribute ‘kind’ == ‘tentative’ are checked for crossings.
- Parameters:
G – the route set without detours
P – the planar embedding associated with A
A – the available links graph
branched – if True, any terminal can be linked to root, else only subtrees’ heads/tails
iterations_limit – maximum number of steps in the path-finding process
traversals_limit – maximum number of times a single portal may be traversed
bad_streak_limit – limit on how many steps in a row without finding an improved path the traverser is allowed to take
Example:
P, A = make_planar_embedding(L) # L represents the geometry of the location S = some_solver(A, ...) # S is a topology G_tentative = G_from_S(S, A) # G_tentative is almost a route set G = PathFinder(G_tentative, planar=P, A=A).create_detours()
Note
On
capacity=2instances the defaults may not suffice to find all shortest feeders. If validate_routeset(G) reports any crossings, retry withtraversals_limit=10anditerations_limit=50000.- get_best_path(n: int)[source]¶
_.get_best_path(«node») produces a tuple(path, dists). path contains a sequence of nodes from the original networx.Graph G, from «node» to the closest root. dists contains the lengths of the segments defined by paths.