swn.modflow.SwnModflow.route_reaches#

SwnModflow.route_reaches(start, end, *, allow_indirect=False)#

Return a list of reach identifiers that connect a pair of reaches.

Parameters:
start, endany

Start and end reach identifiers (reachID) used by FloPy.

allow_indirectbool, default False

If True, allow the route to go downstream from start to a confluence, then route upstream to end. Default False allows only a direct route along a single direction up or down.

Returns:
list
Raises:
IndexError

If start and/or end reach identifiers are not valid.

ConnecionError

If start and end reach identifiers do not connect.

Examples

>>> import flopy
>>> import geopandas
>>> import swn
>>> lines = geopandas.GeoSeries.from_wkt([
...    "LINESTRING (60 100, 60  80)",
...    "LINESTRING (40 130, 60 100)",
...    "LINESTRING (70 130, 60 100)"])
>>> lines.index += 100
>>> n = swn.SurfaceWaterNetwork.from_lines(lines)
>>> m = flopy.modflow.Modflow(version="mf2005")
>>> _ = flopy.modflow.ModflowDis(
...     m, nrow=3, ncol=2, delr=20.0, delc=20.0, xul=30.0, yul=130.0,
...     top=15.0, botm=10.0)
>>> _ = flopy.modflow.ModflowBas(m)
>>> nm = swn.modflow.SwnModflow.from_swn_flopy(n, m)
>>> nm.reaches[["iseg", "ireach", "i", "j", "segnum"]]
         iseg  ireach  i  j  segnum
reachID
1           1       1  0  0     101
2           1       2  0  1     101
3           1       3  1  1     101
4           2       1  0  1     102
5           2       2  1  1     102
6           3       1  1  1     100
7           3       2  2  1     100
>>> sel = nm.route_reaches(1, 7)
>>> sel
[1, 2, 3, 6, 7]
>>> nm.reaches.loc[sel, ["iseg", "ireach", "i", "j", "rchlen"]]
         iseg  ireach  i  j     rchlen
reachID
1           1       1  0  0  18.027756
2           1       2  0  1   6.009252
3           1       3  1  1  12.018504
6           3       1  1  1  10.000000
7           3       2  2  1  10.000000