Python 水文预报三水源新安江模型构建




import numpy as np
import pandas as pd
from pyswmm import Simulation, SwmmModel
 
# 创建模型对象
model = SwmmModel('examples/file_A.inp')
model.set_flow_unit(SwmmModel.FLOW_UNITS_CMS)
model.set_rain_event(1, 3600)  # 设置第一个事件为持续一小时的降雨
 
# 获取节点列表和对应的下游节点
nodes = model.get_nodes()
downstream_nodes = model.get_downstream_nodes(nodes)
 
# 构建三水源新安江水文预报模型
# 假设新安江入海口为节点10,下游节点为节点11
new_alashan_junction_id = 10
new_alashan_outlet_id = 11
 
# 获取新安江入海口的初始水头
initial_head = model.get_node_init_depth(new_alashan_junction_id)
 
# 创建一个数组来存储预报的水头
heads = np.zeros(3601)
heads[0] = initial_head  # 初始时刻的水头
 
# 模拟3600秒,每秒更新一次水头
for i in range(1, 3601):
    model.step(1)  # 模拟流过一秒
    current_depth = model.get_node_depth(new_alashan_junction_id)
    heads[i] = current_depth
 
# 创建DataFrame来存储结果
results_df = pd.DataFrame({
    'Time (s)': np.arange(1, 3601),
    'Head (m)': heads
})
 
# 导出结果到CSV文件
results_df.to_csv('new_alashan_heads.csv', index=False)
 
# 关闭模型
model.close()

这段代码首先导入必要的Python库,并创建一个SWMM模型对象。然后,它设置了一个降雨事件并获取了模型中节点的相关信息。接下来,代码使用一个循环来模拟3600秒的流过过程,并存储了新安江入海口每秒时的水头。最后,它将结果保存到CSV文件中,并关闭了模型。这个过程展示了如何使用PySWMM库来模拟水文过程,并生成预报数据。

最后修改于:2024年08月16日 10:23

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日