gpt4 book ai didi

fortran - 函数返回类型不匹配

转载 作者:行者123 更新时间:2023-12-04 02:11:29 24 4
gpt4 key购买 nike

我正在尝试用 Fortran 重新编写一个旧的 C++ 程序以使用 LAPACK(我知道 C++ 确实有 LAPACK++,但我在安装它时遇到了很多麻烦,所以我放弃了)。

我最初没有任何编译问题,但那是我将所有变量声明为 REAL 的时候。当我开始编写需要 LAPACK 的程序部分时,我发现传递给 DSYEV 的所有参数都需要是 DOUBLE PRECISION。所以我尝试将所有内容更改为 double (包括将所有硬编码数字更改为其 double 对应项,即 0.0 -> 0.0D0)现在,当我尝试编译时,我得到以下所有函数和子例程的错误'写:

    Error: Return type mismatch of function <function> at (1) (REAL(4)/REAL(8))

我不确定这是从哪里来的,因为程序中的所有内容都已更改为 double 。

例如,我声明了以下内容:

double precision :: alpha(3),d(3),zeta1,zeta2
double precision :: A1(3),A2(3),D1(3),D2(3)
double precision :: PI
PI = 3.14159265359D0
alpha = (/0.109818D0, 0.405771D0, 2.22766D0/)
d = (/0.444635D0, 0.535328D0, 0.154329D0 /)

do 10 i=1,3

A1(i) = alpha(i)*zeta1**2.0D0
A2(i) = alpha(i)*zeta2**2.0D0
D1(i) = d(i)*(2.0D0*A1(i)/PI)**(3.0D0/4.0D0)
D2(i) = d(i)*(2.0D0*A2(i)/PI)**(3.0D0/4.0D0)

10 continue

还有函数:

subroutine createS(S,A1,A2,D1,D2,r)
double precision A1(3),A2(3),D1(3),D2(3)
double precision r
double precision S(2,2)
integer :: i,j
S(1,1) = 1.0D0
S(2,2) = 1.0D0
do 80 i=1,3
do 90 j=1,3

S(1,2) = S(1,2) + getS(A1(i),A2(j),r)*D1(i)*D2(j)

90 continue
80 continue
S(2,1) = S(1,2)
return
end

double precision function getS(a,b,r)
double precision :: PI
double precision a,b,r
double precision :: S
PI = 3.14159265359D0
S = (PI/(a+b))**1.5D0
S = S*dexp(-(a*b*r*r)/(a+b))
getS = S
return
end

然后我得到了错误

  HFSTO3G.f:85.28:

S(1,2) = S(1,2) + getS(A1(i),A2(j),r)*D1(i)*D2(j)
1
Error: Return type mismatch of function 'gets' at (1) (REAL(4)/REAL(8))

我正在使用 gfortran 进行编译。这可能是问题所在吗?我不是编程新手,而是 Fortran 新手。不在 Fortran 中对此进行编程不是一种选择。

最佳答案

您是否将子例程和函数放入模块中并使用该模块?否则,可能发生的情况是您在子例程 createS 中隐式键入 getS 作为单精度实数,但它实际上返回 double 。另一个建议:始终使用 implicit none 来查找未声明的变量。如果您忘记在源代码中包含 implicit none,gfortran 会提供编译器选项 -fimplicit-none。隐式类型是有害的,并且可能会在 Fortran 中继续使用以支持遗留代码。

附言double precision 也已过时,但比隐式键入风险小得多。如果您有最新版本的 gfortran,您可以使用以下命令:

use ISO_FORTRAN_ENV
real (real64) ::

请参阅 gfortran 手册。

编辑:implicit none 将 getS 的类型从 real(4)(通过隐式类型)更改为 unknown(未声明类型,禁用隐式类型)。如果将过程放入模块中,它们将“知道”彼此的类型:函数返回和参数类型。这将修复此错误。它还可以帮助编译器发现其他错误,但使其能够检查调用和过程参数之间参数的一致性。参见 Correct use of modules, subroutines and functions in fortranComputing the cross product of two vectors in Fortran 90例如。

关于fortran - 函数返回类型不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16741252/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com