运行flopy.modflow.HeadObservation时出错:ValueError:无法从结构转换为非结构,除非结构只有一个字段

时间:2018-10-02 20:21:57

标签: python-2.7 numpy flopy

我正在使用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.

screenshot of error message showing traceback

当我尝试为模型创建头部观察时会遇到相同的错误,该观察是稳态的并且具有一些不同的输入值。不幸的是,我还没有找到一个可以比较的工作示例。有什么想法吗?

编辑:jdhughes的代码就像一个符咒;但是我也没有将Flopy更新到最新版本-我尝试先更新numpy,但是直到我将Flopy从3.2.8更新到3.2.9时,我才摆脱了ValueError。现在可以工作,谢谢!!!

1 个答案:

答案 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)

将提交问题以更新文档和文档字符串。