arrays - FORTRAN 数组计算错误

标签 arrays linux fortran

所以我一直在检查状态方程模拟器值的一些计算问题。 经过一些检查后,我发现模块 constantes 没有将值拖到它开头声明的子例程中。我不想每次使用它们时都声明这些变量,我该怎么办?声明一个带有值的子例程,并在每次需要参数时“使用”它?

MODULE Constantes
Implicit None
!Lista de constantes para funciones a y b usadas para calcular Z
!Real,dimension(4)::y
!Real::T,P
Real,Parameter,Dimension(4)::Tc=(/ 190.56, 132.85, 304.12, 126.2 /)
Real,Parameter,Dimension(4)::Pc=(/ 45.992, 34.94, 73.74, 33.98 /)
Real,Parameter,Dimension(4)::w=(/ 0.011, 0.045, 0.225, 0.037 /)
Real,Parameter,Dimension(4)::na=(/ 0.072, 0.608, 0.974, 25765.2 /)
Real,Parameter,Dimension(4)::ma=(/15.68, 9.62, 34.04, 0.00 /)
Real,Parameter,Dimension(4)::ba=(/ 6.48, 66.2, 14.04, 0.000928699 /)
Real,Parameter,Dimension(4)::da=(/ 0.025, 0.03, 0.061, 0.00 /)
Real,Parameter,Dimension(4)::ha=(/30.56, 48.16, 34.67, 30.0 /)
Real,Parameter,Dimension(4)::ua=(/ 13.45, 14.84, 20.79, 0.0 /)
Real,Parameter,Dimension(4)::ka=(/ 1.0, 1.0, 1.0, 1.13 /)
Real,Parameter::c0=0.48,c1=1.574,c2=-0.176,eps=1,sig=0
Double Precision,Parameter::omega=0.08664035,psi=0.42748023
!Variables input para constante A
!Variables input para A y B
Contains
Subroutine CA(y,T,At,ap,aij,D,n) 
      Implicit None
    Double precision::psi 
Double precision,intent(out)::At,D
    Double Precision,Dimension(4),intent(out)::ap
    Double Precision,Dimension(4,4),intent(out)::aij
    Real,Dimension(4)::Tc,Pc,w
    Real::c0,c1,c2
    Double precision,intent(in)::T,n
    Double precision,dimension(4),intent(in)::y
    Integer::i,j
    Do i=1, 4 !Array de constantes a individuales
        ap(i)=Tc(i)*Tc(i)
        !ap(i)=(psi*(83.14*83.14*Tc(i)*Tc(i))/Pc(i))!*((1+((c0+c1*w(i)+c2*w(i)*w(i))*(1-sqrt(T/Tc(i)))))**(2))         
    End do
    Do i=1,4
        Do j=1,4
            aij(i,j)=y(i)*y(j)*sqrt(ap(i)*ap(j))!Constantes duales de a
        End do 
    End Do 
    At=sum(sum(aij,dim=1)) !A total independiente de n
    D=At*n*n !A total dependiente de n
   End Subroutine CA
   Subroutine CB(y,Bt,bi,B,bij,n)
   Implicit none
   Real,Dimension(4)::Tc,Pc
   Double precision, intent(in)::n
   Double Precision,Dimension(4),intent(out)::bi
   Double precision,dimension(4),intent(in)::y
Double precision::omega,bm
Double precision,intent(out)::Bt,B
    Double precision,Dimension(4,4),intent(out)::bij
Integer::i,j
    Do i=1,4 !Array de constantes b individuales
        bi(i)=omega*83.14*Tc(i)/Pc(i)
    End Do
    Do i=1,4 !Array constantes duales de b
        Do j=1,4
            bij(i,j)=0.5*(bi(i)+bi(j))
        End Do
    End Do
    BT=sum(bi*y) !B total independiente de n
    B=n*BT !b total dependiente de n
End Subroutine CB
END MODULE Constantes

最佳答案

您遇到的一个问题是您在子例程中重新声明(至少部分)参数数组。例如,行

Real,Dimension(4)::Tc,Pc,w

屏蔽模块变量的存在,例如

Real,Parameter,Dimension(4)::Tc=(/ 190.56, 132.85, 304.12, 126.2 /)

子例程已经可以通过主机关联访问这些参数数组,在这种情况下,在子例程中再次声明它们是错误的。

有些人会争辩说,即使不是绝对必要,您也应该通过参数列表将所有参数传递给过程。

关于arrays - FORTRAN 数组计算错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42722243/

相关文章:

java - 用Java写一个float数组到文件

javascript - 使用 forEach 的 Object.entries 映射对象数组返回未定义,除非使用 console.log

linux - Phidg​​et lib交叉编译

vim 自动硬换行 fortran 与行连续

python - 从 python 向 Fortran 传递变量会导致错误值

c - 读取数组中的输入,存储-1值,并在输入-1时退出?

javascript - React JS - 如何将不同的 Prop 传递到其他 Prop 的映射中

linux - kubernetes 在创建 pod 时出现 CrashLoopBackOff 错误

python - 如果这个 python 脚本在 linux 上,我怎样才能得到一个值?

function - Fortran - 从子例程返回匿名函数