Fortran Coder

查看: 219|回复: 5

[并行] Fortran程序的openmp如何解决同一个变量被多个线程调用

[复制链接]

8

帖子

2

主题

0

精华

入门

F 币
38 元
贡献
18 点
发表于 2022-8-24 11:18:12 | 显示全部楼层 |阅读模式
Fortran程序的openmp如何解决同一个变量被多个线程调用

683

帖子

2

主题

0

精华

大宗师

F 币
3351 元
贡献
2071 点
发表于 2022-8-25 09:39:26 | 显示全部楼层
1、为什么要解决,遇到啥问题,你需要说清楚这些。
2、是否需要解决,怎么解决,需要根据具体情况判断。
3、你可以先看看openmp视频 https://www.bilibili.com/video/BV1uA411v776?p=1

8

帖子

2

主题

0

精华

入门

F 币
38 元
贡献
18 点
 楼主| 发表于 2022-8-25 16:07:43 | 显示全部楼层
在循环调用同一个子函数时,出现无法并行的问题,发现是在子函数中使用了一个程序包FM(Fortran中将一些变量转变为任意精度),这个程序包涉及变化的全局变量,会引起竞争。所以想问这个问题如何解决才能并行

683

帖子

2

主题

0

精华

大宗师

F 币
3351 元
贡献
2071 点
发表于 2022-8-26 09:48:06 | 显示全部楼层
试试用 critical 指令把FM相关的圈起来。

8

帖子

2

主题

0

精华

入门

F 币
38 元
贡献
18 点
 楼主| 发表于 2022-8-26 15:11:22 | 显示全部楼层
但是这样不就变成单线程运行,实现不了并行加速啊

683

帖子

2

主题

0

精华

大宗师

F 币
3351 元
贡献
2071 点
发表于 2022-8-27 14:02:43 | 显示全部楼层
如果FM不支持omp并行,怎么都不行,除非改代码。或者用mpi。
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2022-9-28 18:09

Powered by Tencent X3.4

© 2013-2022 Tencent

快速回复 返回顶部 返回列表