| 查看: 1121 | 回复: 6 | |||
| 本帖产生 1 个 程序强帖 ,点击这里进行查看 | |||
[交流]
【求助】此程序没有错误,怎么运行不出来?
|
|||
|
|
» 猜你喜欢
心脉受损
已经有4人回复
博士读完未来一定会好吗
已经有13人回复
Springer期刊投稿求助
已经有4人回复
读博
已经有3人回复
小论文投稿
已经有3人回复
Bioresource Technology期刊,第一次返修的时候被退回好几次了
已经有9人回复
到新单位后,换了新的研究方向,没有团队,持续积累2区以上论文,能申请到面上吗
已经有8人回复
申请2026年博士
已经有6人回复
请问哪里可以有青B申请的本子可以借鉴一下。
已经有5人回复
» 本主题相关价值贴推荐,对您同样有帮助:
Perl 生物信息学编程求助,运行出现问题,烦请帮忙查找一下错误,谢谢!
已经有3人回复
【求助】程序运行已经无错误,但是输入文件有问题,求教。
已经有23人回复
【求助】此FORTRAN90程序没有错误,但是运行不出来。
已经有4人回复
【求助】有很多错误的程序,找不出来了
已经有18人回复
【求助】程序运行后出现的错误 access violation
已经有15人回复
» 抢金币啦!回帖就可以得到:
双一流大学湘潭大学“化工过程模拟与强化”国家地方联合工程研究中心招收各类博士生
+1/84
加拿大/英属哥伦比亚大学曹彦凯课题组招收全奖博士/博后 [机器学习/优化/控制方向]
+1/83
加拿大/英属哥伦比亚大学曹彦凯课题组招收全奖博士/博后 [机器学习/优化/控制方向]
+1/82
加拿大/英属哥伦比亚大学曹彦凯课题组招收全奖博士/博后 [机器学习/优化/控制方向]
+1/81
硫化物全固态电池的产业化破局:手套箱如何实现全线稳定制造
+1/80
中国地质大学(武汉)—国家级青年人才杨明教授组-招收博士-新能源材料化学及催化材料
+1/75
南京大学自旋全国重团队陆显扬课题组招聘博士后
+2/42
中国科学院理化所微纳材料与技术前沿交叉研究中心诚聘英才加盟
+1/40
南昌大学药学博士招生
+1/37
校长团队招博士生和博士后
+1/33
北京科技大学鲁启鹏招收2026年博士生1名
+1/30
中南大学冶金与环境学院陈伟老师招收环境科学与工程2026年博士生1人
+1/29
智慧能源中心招聘启事|博士后 科研助理
+1/27
澳门大学 应用物理及材料工程研究院 孙国星课题组招收博士(2026/2027学年)
+1/26
长春理工大学和西安工业大学主动光电探测成像技术重点实验室招收博士生
+1/12
中科院过程工程研究所 诚招博士后及科研助理
+1/9
北理工柔性电子国家杰青团队招【博士后】【博士】【科研助理】
+1/4
招收26年秋季入学博士生(北科大高精尖学院 力学超材料/机器学习/增材制造相关方向)
+1/4
深圳先进院三院院士成会明团队诚聘液流电池/高分子合成等方向博后、科研助理、工程师
+1/3
招收2026年秋季入学博士生1名(北京科技大学 力学超材料/机器学习/增材制造相关方向)
+1/1
2楼2010-11-24 21:58:16
zyj8119(金币+3):那应该怎么改? 2010-11-24 22:50:28
|
这一段代码是错误的 do 6 i=1,7 7 Z(i,(j+1))=1+beta(i)-q(i)*beta(i)*(Z(i,j)-beta(i))/(Z(i,j)+ * epsilon*beta(i))*(Z(i,j)+sigma*beta(i)) do 8 j=1,100000 factor(i)=(factor(i)-Z(i,j)/Z(i,(j+1))) 8 continue if(ABS(Z(i,(j+1))-Z(i,j)).lt.1E-6)goto 7 正是它导致了“死机”或运行不出来! 原因很简单,你定义数组Z的维数为(7,100000),当对J的循环完成后J=100001;此时执行 if(ABS(Z(i,(j+1))-Z(i,j)).lt.1E-6)goto 7 第2行(即标号为7的行)对Z(i,(j+1))的赋值就超出了Z的定义范围,由此导致死循环或不可预测的结果。此外,if(ABS(Z(i,(j+1))-Z(i,j)).lt.1E-6)goto 7中的(Z(i,(j+1))也是未定义的! [ Last edited by ykwang on 2010-11-24 at 22:39 ] |
3楼2010-11-24 22:33:36
4楼2010-11-24 23:23:15
|
仅从下列一段代码看不出你要做什么。例如因为J的初值为0,所以下列代码中用红字划出的Z(i,j)中必然包含了Z(i,0),而按你在Dimension中的说明Z(i,0)是无定义的!因此,建议你先把数学模型搞清楚再修改代码才能见效。 do 6 i=1,7 7 Z(i,(j+1))=1+beta(i)-q(i)*beta(i)*(Z(i,j)-beta(i))/(Z(i,j)+ * epsilon*beta(i))*(Z(i,j)+sigma*beta(i)) do 8 j=1,100000 factor(i)=(factor(i)-Z(i,j)/Z(i,(j+1))) 8 continue if(ABS(Z(i,(j+1))-Z(i,j)).lt.1E-6)goto 7 6 continue [ Last edited by ykwang on 2010-11-24 at 23:41 ] |
5楼2010-11-24 23:40:35
6楼2010-11-24 23:49:15
★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
nono2009(金币+2):鼓励应助 2010-11-25 07:41:11
zyj8119(金币+2):谢谢兄台认真回复。。。 2010-11-25 08:27:59
zyj8119(金币+10, 程序强帖+1):谢谢跟进。 2010-12-14 04:22:10
nono2009(金币+2):鼓励应助 2010-11-25 07:41:11
zyj8119(金币+2):谢谢兄台认真回复。。。 2010-11-25 08:27:59
zyj8119(金币+10, 程序强帖+1):谢谢跟进。 2010-12-14 04:22:10
|
因为事先不知道要经过多少次迭代才能收敛,所以不能采用数组方式。其实只需要两个变量即可实现这一迭代过程:一个为Old,另一个New,并将New的计算过程用一个子程序CalcFun(各种变量)来实现。有关的伪代码如下: Old = 0D0 给Old赋初值 10 CALL CalcFun(各种变量,New) 计算结果由New返回 IF(ABS(New-Old).LT.1E-6)GOTO 20 收敛后退出 Old = New 更新Old GOTO 10 构成迭代过程 20 WRITE(*,*)‘Converged!' |
7楼2010-11-25 01:08:10













回复此楼