Skip to content

Commit

Permalink
feat(utils): move utils from modflow-devtools
Browse files Browse the repository at this point in the history
* head & budget file writing
* disu creation helper
* uniform flow field
* comparison utils
* namefile reading utility
* lint tests and notebook utils
  • Loading branch information
wpbonelli committed Nov 15, 2022
1 parent d39337d commit 0f3736b
Show file tree
Hide file tree
Showing 4 changed files with 1,877 additions and 0 deletions.
144 changes: 144 additions & 0 deletions flopy/utils/binaryfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,150 @@
from .gridutil import get_lni


def write_head(
fbin,
data,
kstp=1,
kper=1,
pertim=1.0,
totim=1.0,
text=" HEAD",
ilay=1,
):
dt = np.dtype(
[
("kstp", np.int32),
("kper", np.int32),
("pertim", np.float64),
("totim", np.float64),
("text", "S16"),
("ncol", np.int32),
("nrow", np.int32),
("ilay", np.int32),
]
)
nrow = data.shape[0]
ncol = data.shape[1]
h = np.array((kstp, kper, pertim, totim, text, ncol, nrow, ilay), dtype=dt)
h.tofile(fbin)
data.tofile(fbin)


def write_budget(
fbin,
data,
kstp=1,
kper=1,
text=" FLOW-JA-FACE",
imeth=1,
delt=1.0,
pertim=1.0,
totim=1.0,
text1id1=" GWF-1",
text2id1=" GWF-1",
text1id2=" GWF-1",
text2id2=" NPF",
):
dt = np.dtype(
[
("kstp", np.int32),
("kper", np.int32),
("text", "S16"),
("ndim1", np.int32),
("ndim2", np.int32),
("ndim3", np.int32),
("imeth", np.int32),
("delt", np.float64),
("pertim", np.float64),
("totim", np.float64),
]
)

if imeth == 1:
ndim1 = data.shape[0]
ndim2 = 1
ndim3 = -1
h = np.array(
(
kstp,
kper,
text,
ndim1,
ndim2,
ndim3,
imeth,
delt,
pertim,
totim,
),
dtype=dt,
)
h.tofile(fbin)
data.tofile(fbin)

elif imeth == 6:
ndim1 = 1
ndim2 = 1
ndim3 = -1
h = np.array(
(
kstp,
kper,
text,
ndim1,
ndim2,
ndim3,
imeth,
delt,
pertim,
totim,
),
dtype=dt,
)
h.tofile(fbin)

# write text1id1, ...
dt = np.dtype(
[
("text1id1", "S16"),
("text1id2", "S16"),
("text2id1", "S16"),
("text2id2", "S16"),
]
)
h = np.array((text1id1, text1id2, text2id1, text2id2), dtype=dt)
h.tofile(fbin)

# write ndat (number of floating point columns)
colnames = data.dtype.names
ndat = len(colnames) - 2
dt = np.dtype([("ndat", np.int32)])
h = np.array([(ndat,)], dtype=dt)
h.tofile(fbin)

# write auxiliary column names
naux = ndat - 1
if naux > 0:
auxtxt = [f"{colname:16}" for colname in colnames[3:]]
auxtxt = tuple(auxtxt)
dt = np.dtype([(colname, "S16") for colname in colnames[3:]])
h = np.array(auxtxt, dtype=dt)
h.tofile(fbin)

# write nlist
nlist = data.shape[0]
dt = np.dtype([("nlist", np.int32)])
h = np.array([(nlist,)], dtype=dt)
h.tofile(fbin)

# write the data
data.tofile(fbin)

pass
else:
raise Exception(f"unknown method code {imeth}")


class BinaryHeader(Header):
"""
The binary_header class is a class to create headers for MODFLOW
Expand Down
Loading

0 comments on commit 0f3736b

Please sign in to comment.