Fortran Coder

查看: 2268|回复: 8
打印 上一主题 下一主题

[通用算法] Fortran中任意精度的FMZM包,可不可应用于并行中

[复制链接]

213

帖子

2

主题

0

精华

宗师

F 币
2126 元
贡献
875 点

规矩勋章

楼主
发表于 2022-8-24 20:10:40 | 显示全部楼层
好像不行。因为该包中有涉及变化的全局变量,可能会在并行中引起racing。

213

帖子

2

主题

0

精华

宗师

F 币
2126 元
贡献
875 点

规矩勋章

沙发
发表于 2022-8-25 20:28:28 | 显示全部楼层
12138世界 发表于 2022-8-25 16:14
有没有什么修改的策略,使之能并行

如果是纯粹data parallel, 没有数据间的通讯,或许可行。如有通讯,需用线程安全的包。fmzm不是为并行设计的。下面这个包是为多线程并行设计的。

FM_files.zip

1.43 MB, 下载次数: 3

213

帖子

2

主题

0

精华

宗师

F 币
2126 元
贡献
875 点

规矩勋章

板凳
发表于 2022-8-26 22:33:41 | 显示全部楼层
12138世界 发表于 2022-8-26 16:24
使用了多线程的FM_parallel包,没有出现并行的报错,但是输出的结果不对

那就是程序的逻辑错误了,这是最难查的。

213

帖子

2

主题

0

精华

宗师

F 币
2126 元
贡献
875 点

规矩勋章

地板
发表于 2022-8-29 19:47:12 | 显示全部楼层
12138世界 发表于 2022-8-29 10:37
上面这个问题,将str设为private,可以解决,但是若这段程序是在一个子程序中,如何将str再次设置为private ...

能否把parallel do 放到子程序外?
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-5-17 01:35

Powered by Tencent X3.4

© 2013-2024 Tencent

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