Fortran Coder

楼主: xuanyz
打印 上一主题 下一主题

[通用算法] monte carlo 模拟光子传输

[复制链接]

32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
跳转到指定楼层
楼主
发表于 2019-6-4 20:19:54 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式
蒙特卡洛方法 模拟算法测试可以运行大致思路时一次一个光子随机传输,重复很多次并统计结果。

当光子数为1千万个光子时,程序运行正常大约耗时10s左右,依次增加光子数 1.1---1.2 ----1.3----1.4----1.5---1.6千万均计算正常耗时性应增加也基本在十几秒左右,但增加到1.7千万或者更大时程序就永远无法运行完毕,不知道是什么问题,fortran对大量循环次数有限制吗,我采用fortran语言编写的程序,望高手指教,随便什么建议都可以,感谢感谢了

分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
沙发
 楼主| 发表于 2019-6-4 21:20:14 | 显示全部楼层
本帖最后由 xuanyz 于 2019-6-5 11:53 编辑

附件中文程序代码

Upscat.for

1001 Bytes, 下载次数: 32

32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
板凳
 楼主| 发表于 2019-6-4 23:07:45 来自移动端 | 显示全部楼层
本帖最后由 xuanyz 于 2019-6-5 08:41 编辑

抱歉,是我的疏忽,不需要输入文件,注释或者删掉掉代码中的这几行即可
          DO 2 i=1,72
     read(10,111) SCATT(i)
111     format(F7.5)
2     CONTINUE
     DO 4 I=1,36
      SINTH(I)=SCATT(I)
      CSINTH(I)=SCATT(I+36)
4     CONTINUE

附件Upscat.for已经更新



32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
地板
 楼主| 发表于 2019-6-5 09:31:52 | 显示全部楼层
感谢vvt,
已经按照你的思路将pm,pn改成整数
修改如下  INTEGER ZSTART,ZFINSH,BOTTOM,pm,pn
测试光子数pm=16000000正常
但光子数增加到pm=17000000时 程序依然永远无法运行完毕????
难道是我的系统或编译器的限制
我用的是win7 64位   vs2010 结合Intel® Parallel Studio XE 2011编译fortran的, 还请指教 再次感谢

32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
5#
 楼主| 发表于 2019-6-5 09:53:33 | 显示全部楼层
再次感谢 vvt ,这次
pm=17000000测试通过了,
还想弱弱的问一下,为何将pm,pn 改成整数就可以呢,原因是什么呢,方便解释一下嘛 谢谢

32

帖子

9

主题

0

精华

专家

F 币
391 元
贡献
212 点
6#
 楼主| 发表于 2019-6-5 10:15:19 来自移动端 | 显示全部楼层
再次感谢vvt,多谢了
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-5-6 21:44

Powered by Tencent X3.4

© 2013-2024 Tencent

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