Fortran Coder

查看: 165|回复: 3

[求助] Fortran 串行代码改并行代码

[复制链接]

2

帖子

1

主题

0

精华

新人

F 币
15 元
贡献
7 点
发表于 2021-12-30 16:52:31 | 显示全部楼层 |阅读模式
求助,将下面一段串行代码改为并行代码要怎么操作?NP=2,DIR3(NP*2)已知
[Fortran] 纯文本查看 复制代码
do ii=1,NP*2
        DIR2=DIR3(ii)
        print*,"DIR2=",DIR2
          i= CHDIR(DIR2)
        i=system("./cesm1.exe >> cesm.log.$LID 2>&1")
enddo
怎么下手呢?我用的是linux的intelmpi 编译器。
求指导,有重谢。


回复

使用道具 举报

1699

帖子

13

主题

5

精华

论坛跑堂

臭石头雪球

F 币
2330 元
贡献
1457 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

发表于 2021-12-30 20:48:25 | 显示全部楼层
你这个代码,没有什么并行的必要。并不能起到你想要的作用。

2

帖子

1

主题

0

精华

新人

F 币
15 元
贡献
7 点
 楼主| 发表于 2021-12-31 15:31:47 | 显示全部楼层
fcode 发表于 2021-12-30 20:48
你这个代码,没有什么并行的必要。并不能起到你想要的作用。

你好,请问下,不能用np*2个线程计算吗,因为每次循环的任务是独立的

904

帖子

0

主题

0

精华

大师

F 币
415 元
贡献
455 点

规矩勋章元老勋章新人勋章水王勋章

QQ
发表于 2021-12-31 15:54:10 | 显示全部楼层
i=system("./cesm1.exe >> cesm.log.$LID 2>&1")

你这种直接启动cesm1.exe 就可以了。操作系统都是多进程的。

多进程(或多线程)和并行是两回事。
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2022-1-19 16:50

Powered by Tencent X3.4

© 2013-2022 Tencent

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