我正在使用Flopy在Python 2.7中设置MODFLOW模型。我正在尝试通过HOB软件包添加头部观察。以下示例代码直接来自https://modflowpy.github.io/flopydoc/mfhob.html的功能文档:
import flopy
model = flopy.modflow.Modflow()
dis = flopy.modflow.ModflowDis(model, nlay=1, nrow=11, ncol=11,
nper=2, perlen=[1,1])
obs = flopy.modflow.mfhob.HeadObservation(model, layer=0, row=5,
column=5,
time_series_data=[[1.,54.4],
[2., 55.2]])
使用此函数的示例代码,出现以下错误:
ValueError: Can't cast from structure to non-structure, except if the structure only has a single field.
当我尝试为模型创建头部观察时会遇到相同的错误,该观察是稳态的并且具有一些不同的输入值。不幸的是,我还没有找到一个可以比较的工作示例。有什么想法吗?
编辑:jdhughes的代码就像一个符咒;但是我也没有将Flopy更新到最新版本-我尝试先更新numpy,但是直到我将Flopy从3.2.8更新到3.2.9时,我才摆脱了ValueError。现在可以工作,谢谢!!!
答案 0 :(得分:2)
您需要创建一个或多个HeadObservation类型的实例,并将其传递给ModflowHob
。下面显示了一个具有两个观察位置的示例。
# create a new hob object
obs_data = []
# observation location 1
tsd = [[1., 1.], [87163., 2.], [348649., 3.],
[871621., 4.], [24439070., 5.], [24439072., 6.]]
names = ['o1.1', 'o1.2', 'o1.3', 'o1.4', 'o1.5', 'o1.6']
obs_data.append(flopy.modflow.HeadObservation(mf, layer=0, row=2, column=0,
time_series_data=tsd,
names=names, obsname='o1'))
# observation location 2
tsd = [[0., 126.938], [87163., 126.904], [871621., 126.382],
[871718.5943, 115.357], [871893.7713, 112.782]]
names = ['o2.1', 'o2.2', 'o2.3', 'o2.4', 'o2.5']
obs_data.append(flopy.modflow.HeadObservation(mf, layer=0, row=3, column=3,
time_series_data=tsd,
names=names, obsname='o2'))
hob = flopy.modflow.ModflowHob(mf, iuhobsv=51, obs_data=obs_data)
将提交问题以更新文档和文档字符串。