- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Python 多进程并行编程实践:以 multiprocessing 模块为例
專 欄
?Pytlab ,Python 中文社区专栏作者。主要从事科学计算与
高性能计算领域的应用,主要语言为 Python ,C ,C++ 。熟
悉数值算法 (最优化方法,蒙特卡洛算法等)与并行化算法
(MPI,OpenMP 等多线程以及多进程并行化)以及 python
优化方法,经常使用 C++ 给 python 写扩展。
blog :github :/PytLab
?—前言并行计算是使用并行计算机来减少单个计算问题所
需要的时间,我们可以通过利用编程语言显式的说明计算中
的不同部分如何再不同的处理器上同时执行来设计我们的
并行程序, 最终达到大幅度提升程序效率的目的。 众所周知,
Python 中的 GIL 限制了 Python 多线程并行对多核 CPU 的
利用,但是我们仍然可以通过各种其他的方式来让 Python
真正利用多核资源 , 例如通过 C/C++ 扩展来实现多线程 / 多
进程 , 以及直接利用 Python 的多进程模块 multiprocessing
来进行多进程编程。本文主要尝试仅仅通过 python 内置的
multiprocessing 模块对自己的动力学计算程序来进行优化
和效率提升,其中 :
- 实现了单机利用多核资源来实现并行并进行加速对比
- 使用 manager 模块实现了简单的多机的分布式计算本文
并不是对 Python 的 multiprocessing 模块的接口进行翻译介
绍,需要熟悉 multiprocessing 的童鞋可以参考官方文档
/2/library/multiprocessing.html 。正文
最近想用自己的微观动力学程序进行一系列的求解并将结
果绘制成二维 Map 图进行可视化, 这样就需要对二维图上的
多个点进行计算并将结果收集起来并进行绘制,由于每个点
都需要进行一次 ODE 积分以及牛顿法求解方程组,因此要
串行地绘制整张图可能会遇到极低的效率问题尤其是对参
数进行测试的时候,每画一张图都需要等很久的时间。其中
绘制的二维图中每个点都是独立计算的,于是很自然而然的
想到了进行并行化处理。串行的原始版本由于脚本比较长,
而且实现均为自己的程序,脚本的大致结构如下 , 本质是一
个二重循环,循环的变量分别为反应物气体( O2 和 CO )
的分压的值 :
整体过程就这么简单, 我需要做的就是使用 multiprocessing
的接口来对这个二重循环进行并行化。使用单核串行绘制
100 个点所需要的时间如下 , 总共花了 240.76 秒:
二维 map 图绘制的效果如下 :
进行多进程并行处理 multiprocessing 模块 multiprocessing
模块提供了类似 threading 模块的接口,并对进程的各种操
作进行了良好的封装,提供了各种进程间通信的接口例如
Pi
您可能关注的文档
最近下载
- 2025《水下清淤机器人的结构方案设计》13000字(论文).docx
- [硕士]宣钢近北庄铁矿滑坡机理及稳定性分析.pdf VIP
- 2025年“三新”协同教研共同体高一联考英语试卷及答案.docx VIP
- 中国海洋(大学)高等代数历年考研试题.pdf VIP
- 856高等代数之中国海洋(大学)(2018至2021)考研真题.pdf VIP
- 2020-2021学年安徽省合肥市长丰县杨公镇朱集中学高一数学理下学期期末试卷含解析.docx VIP
- PLC西门子S7-200温度控制系统毕业设计-使用教程.pdf VIP
- 新22S3 室外排水工程建筑工程图集.docx VIP
- 江苏省姜氏宗亲分布村落.docx
- 2025年北京理工大学计算机科学与技术专业《操作系统》科目期末试卷及答案.docx VIP
原创力文档


文档评论(0)