- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
PAGE1
PAGE1
并行计算与性能优化
并行计算的基本概念
并行计算是指同时使用多个计算资源来解决计算任务的一种方法。在CFD(计算流体力学)领域,特别是在使用OpenFOAM进行大规模仿真时,并行计算是提高计算效率的关键技术。并行计算可以通过多种方式实现,包括共享内存并行和分布式内存并行。OpenFOAM主要使用分布式内存并行计算,通过MPI(MessagePassingInterface)来进行进程间的通信。
分布式内存并行
分布式内存并行是指将计算任务分布在多个独立的计算节点上,每个节点拥有自己的内存空间。这种并行方式适用于大规模的计算任务,因为它可以充分利用多个计算节点的资源。在OpenFOAM中,分布式内存并行通过以下步骤实现:
网格划分:将计算域划分为多个子域,每个子域由一个计算进程负责。
任务分配:每个进程独立计算自己负责的子域。
数据通信:进程间通过MPI进行数据交换,确保子域之间的边界条件和数据一致性。
网格划分
网格划分是并行计算的第一步,也是最关键的一步。OpenFOAM提供了多种网格划分工具,其中最常用的是decomposePar。decomposePar工具根据用户指定的策略将网格划分为多个子域,每个子域由一个计算进程负责。
网格划分策略
decomposePar支持多种网格划分策略,包括:
simple:将网格均匀划分为指定数量的子域。
hierarchical:按照层次结构进行划分,适用于具有复杂几何结构的网格。
scotch:使用SCOTCH库进行自动优化划分,适用于大型和非均匀网格。
metis:使用METIS库进行自动优化划分,适用于大型和非均匀网格。
代码示例:使用decomposePar进行网格划分
#创建一个案例目录
mkdir-p$FOAM_RUN/caseName
cd$FOAM_RUN/caseName
#复制网格文件
cp-r$FOAM_TUTORIALS/interFoam/damBreak/constant/polyMesh.
#编辑decomposeParDict文件
catEOFsystem/decomposeParDict
/**-C++-**\
|=========||
|\\/Field|OpenFOAM:TheOpenSourceCFDToolbox|
|\\/Operation|Version:8|
|\\/And|Web:|
|\\/Manipulation||
\**/
FoamFile
{
version2.0;
formatascii;
classdictionary;
locationsystem;
objectdecomposeParDict;
}
//*************************************//
numberOfSubdomains8;
methodscotch;
//*************************************************************************//
EOF
#运行decomposePar
decomposePar
任务分配
任务分配是指将计算任务分配给每个计算进程。在OpenFOAM中,任务分配是自动进行的,每个进程会根据分配的子域来执行相应的计算任务。通过并行计算,可以显著减少计算时间,特别是在处理大型和复杂问题时。
代码示例:运行并行计算
#进入案例目录
cd$FOAM_RUN/caseName
#编辑controlDict文件,设置并行计算
catEOFsystem/controlDict
/**-C++-**\
|=========
您可能关注的文档
- CAD软件:CATIA 二次开发_(19).CATIAV5二次开发工具与资源.docx
- CAD软件:CATIA 二次开发_(20).CATIAV6架构与开发环境配置.docx
- CAD软件:CATIA 二次开发_(21).CATIAV6自动化脚本开发.docx
- CAD软件:CATIA 二次开发_(22).CATIAV6部件与装配设计开发.docx
- CAD软件:CATIA 二次开发_(23).CATIAV6曲面与实体建模开发.docx
- CAD软件:CATIA 二次开发_(24).CATIAV6草图与特征开发.docx
- CAD软件:CATIA 二次开发_(25).CATIAV6参数化设计与约束.docx
- CAD软件:CATIA 二次开发_(26).CATIAV6数据交换与格式转换.docx
- CAD软件:CATIA 二次开发_(27).CATIAV6插件开发与集成.docx
- CAD软件:CATIA 二次开发_(28).CATIAV6用户界面定制.docx
- 书面表达之建议信(讲义)-中考英语一轮复习(含答案).pdf
- 中考历史复习小众题型类:填空题、改错题、判断题(70题).pdf
- 2024年吉林省县乡教师选调考试《教育学》真题汇编带解析必背【基础题】.pdf
- 2025年中考语文备考之《朝花夕拾》名著导读及考题.pdf
- 小说标题的含义和作用(模拟突破)-2025年中考语文考点突破之小说阅读(解析版).pdf
- 阅读理解之应用文(练习)-中考英语一轮复习(含答案).pdf
- 小说情节作用(模拟突破)-2025年中考语文考点突破之小说阅读(原卷版).pdf
- 小说段落作用(模拟突破)-2025年中考语文考点突破之小说阅读(解析版).pdf
- 小说段落作用(试题专练)-2025年中考语文考点突破之小说阅读(解析版).pdf
- 2025年上海市16区初三语文一模试题汇编之现代文阅读二(记叙文)学生版.pdf
文档评论(0)