[发明专利]一种地下水溶质运移数值模拟并行加速方法在审
申请号: | 201811142706.6 | 申请日: | 2018-09-28 |
公开(公告)号: | CN109388876A | 公开(公告)日: | 2019-02-26 |
发明(设计)人: | 刘兴伟;邵景力;程汤培;崔亚莉 | 申请(专利权)人: | 中国地质大学(北京) |
主分类号: | G06F17/50 | 分类号: | G06F17/50 |
代理公司: | 北京知呱呱知识产权代理有限公司 11577 | 代理人: | 孙进华;吴林 |
地址: | 100083*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 地下水流场 地下水溶质 网格片 并行 数值模拟 求解 方程组 数据对应 系数矩阵 耦合 法器 构建 溶质 调用 地下 统计 | ||
本发明公开了一种地下水溶质运移数值模拟并行加速方法,该地下水溶质运移数值模拟并行加速方法包括:根据获取的每一网格片上的系数矩阵A和右端项RHS构建方程组,并调用并行解法器库并行求解每一网格片的地下水流场数据;统计求解每一网格片的地下水流场数据的次数;判断次数是否满足运移步,当次数满足运移步时,耦合每一网格片的地下水流场与地下溶质运移数据,计算与地下水流场数据对应的地下水溶质运移参数。
技术领域
本发明涉及地下水动力学技术领域,具体涉及一种地下水溶质运移数值模拟并行加速方法。
背景技术
地下水污染问题日益突出,地下水溶质运移数值模拟是刻画地下水污染物运移、修复治理的重要手段。例如,在地下水污染物溯源、运移路径及范围预测中均需要地下水溶质运移数值模拟技术的支持。在地下水溶质运移数值模拟程序中,由Zheng等开发的三维多组分溶质运移数值模拟模块(MT3DMS)在国内外应用较广,已作为众多地下水数值模拟商业软件中溶质运移模块的核心。但是,早期的地下水溶质运移数值模拟模块(MT3DMS)仅能够串行运行,在处理大规模、高精度的溶质运移数值模拟时,计算内存占用过大、耗时过长,有的甚至无法运行,已不能满足当前大区域、高精度地下水溶质运移数值模拟的需求。
相较串行,并行计算技术是解决大规模计算的有效方法,但传统的并行化重构研发周期长,并行难度大。此外,传统的地下水流与溶质运移数值模拟模块(MT3DMS)的耦合过程需要存储大量地下水流场数据,中间过程文件过大,溶质运移程序反复读取水流场信息影响整体效率,不能即时的对计算结果进行输出。
发明内容
本发明实施例的目的在于提供一种地下水溶质运移数值模拟并行加速方法,用以解决现有技术中存在的问题。
为实现上述目的,本发明实施例提供一种地下水溶质运移数值模拟并行加速方法,该地下水溶质运移数值模拟并行加速方法包括:根据获取的每一网格片上数据片中的系数矩阵A和右端项RHS构建方程组,并调用并行解法器库并行求解每一网格片的地下水流场数据;统计求解每一网格片的地下水流场数据的次数;判断次数是否满足运移步,当次数满足运移步时,耦合每一网格片的地下水流场数据,计算与地下水流场数据对应的地下水溶质运移参数。
可选的,当次数不满足运移步时,地下水溶质运移数值模拟并行加速方法还包括:判断次数是否满足时间步。
可选的,当次数不满足时间步时,地下水溶质运移数值模拟并行加速方法还包括:判断次数是否满足应力期;当次数满足应力期时,根据获取的每一网格片上数据片中的系数矩阵A和右端项RHS构建方程组,并调用并行解法器库并行求解每一网格片的地下水流场数据。
可选的,根据获取的每一网格片上数据片中的系数矩阵A和右端项RHS构建方程组,并调用并行解法器库并行求解每一网格片的地下水流场数据之前,地下水溶质运移数值模拟并行加速方法还包括:分配至少一个网格片至至少一个处理器核心,其中,该网格片包括数据片。
可选的,分配至少一个网格片至至少一个处理器核心,包括:主进程分配至少一个网格片至至少一个处理器核心。
可选的,分配至少一个网格片至至少一个处理器核心之前,地下水溶质运移数值模拟并行加速方法还包括:创建网格层,网格层包括至少一个网格片。
可选的,分配至少一个网格片至至少一个处理器核心之前,地下水溶质运移数值模拟并行加速方法还包括:获取相邻网格片的数据。
可选的,获取相邻网格片的数据,包括:复制相邻网格片的数据。
本发明实施例具有如下优点:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国地质大学(北京),未经中国地质大学(北京)许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811142706.6/2.html,转载请声明来源钻瓜专利网。