# DO NOT MODIFY THIS FILE DIRECTLY. THIS FILE MUST BE CREATED BY
# mf6/utils/createpackages.py
# FILE created on December 20, 2024 02:43:08 UTC
from .. import mfpackage
from ..data.mfdatautil import ListTemplateGenerator
[docs]class ModflowUtllaktab(mfpackage.MFPackage):
"""
ModflowUtllaktab defines a laktab package within a utl model.
Parameters
----------
model : MFModel
Model that this package is a part of. Package is automatically
added to model when it is initialized.
loading_package : bool
Do not set this parameter. It is intended for debugging and internal
processing purposes only.
nrow : integer
* nrow (integer) integer value specifying the number of rows in the
lake table. There must be NROW rows of data in the TABLE block.
ncol : integer
* ncol (integer) integer value specifying the number of columns in the
lake table. There must be NCOL columns of data in the TABLE block.
For lakes with HORIZONTAL and/or VERTICAL CTYPE connections, NCOL
must be equal to 3. For lakes with EMBEDDEDH or EMBEDDEDV CTYPE
connections, NCOL must be equal to 4.
table : [stage, volume, sarea, barea]
* stage (double) real value that defines the stage corresponding to the
remaining data on the line.
* volume (double) real value that defines the lake volume corresponding
to the stage specified on the line.
* sarea (double) real value that defines the lake surface area
corresponding to the stage specified on the line.
* barea (double) real value that defines the lake-GWF exchange area
corresponding to the stage specified on the line. BAREA is only
specified if the CLAKTYPE for the lake is EMBEDDEDH or EMBEDDEDV.
filename : String
File name for this package.
pname : String
Package name for this package.
parent_file : MFPackage
Parent package file that references this package. Only needed for
utility packages (mfutl*). For example, mfutllaktab package must have
a mfgwflak package parent_file.
"""
table = ListTemplateGenerator(('laktab', 'table', 'table'))
package_abbr = "utllaktab"
_package_type = "laktab"
dfn_file_name = "utl-laktab.dfn"
dfn = [
["header",
"multi-package", ],
["block dimensions", "name nrow", "type integer",
"reader urword", "optional false"],
["block dimensions", "name ncol", "type integer",
"reader urword", "optional false"],
["block table", "name table",
"type recarray stage volume sarea barea", "shape (nrow)",
"reader urword"],
["block table", "name stage", "type double precision", "shape",
"tagged false", "in_record true", "reader urword"],
["block table", "name volume", "type double precision", "shape",
"tagged false", "in_record true", "reader urword"],
["block table", "name sarea", "type double precision", "shape",
"tagged false", "in_record true", "reader urword"],
["block table", "name barea", "type double precision", "shape",
"tagged false", "in_record true", "reader urword",
"optional true"]]
def __init__(self, model, loading_package=False, nrow=None, ncol=None,
table=None, filename=None, pname=None, **kwargs):
super().__init__(model, "laktab", filename, pname,
loading_package, **kwargs)
# set up variables
self.nrow = self.build_mfdata("nrow", nrow)
self.ncol = self.build_mfdata("ncol", ncol)
self.table = self.build_mfdata("table", table)
self._init_complete = True