46 | function get_r(k) result(r)
| 1
......
78 | call get_r(k)
| 2
Error: ‘get_r’ at (1) has a type, which is not consistent with the CALL at (2)
function get_r(k) result(r)
implicit none
real(8) , intent(in) :: k(2)
complex(8) :: r(2, 6, 6)
! r is a three dimension array
r = 0.d0
r(1, 1, 1) = -a0*r0
r(1, 4, 4) = a0*r0
r(1, 5, 5) = -a0*r0
end function get_r
function get_v(k) result(v)
implicit none
real(8), intent(in) :: k(2)
complex(8) :: v(2, 6, 6)
complex(8) :: f1(2)
complex(8) :: H(6, 6), r(2, 6, 6)
integer :: i
v = 0.d0
f1(:) = CI*(rprimd(:, 1)*exp(2.d0*Pi*CI*k(1))+rprimd(:, 2)*exp(2.d0*Pi*CI*k(2)))
v(:, 1, 2) = t1*f1; v(:, 2, 1) = dconjg(v(:, 1, 2))
v(:, 3, 4) = t1*f1; v(:, 4, 3) = dconjg(v(:, 3, 4))
v(:, 5, 6) = t1*f1; v(:, 6, 5) = dconjg(v(:, 5, 6))
call get_H(k)
call get_r(k)
do i = 1, 2, 1
v(i, :, :) = (v(i, :, :) - CI*(Matmul(r(i, :, :), H) - MatMul(H, r(i, :, :))))/h_bar
end do
end function get_v
fcode 发表于 2022-5-27 08:43
get_r 是函数,不能用 call 调用。必须 r = get_r(k)
fcode 发表于 2022-5-27 08:43
get_r 是函数,不能用 call 调用。必须 r = get_r(k)
sqs 发表于 2022-5-27 12:15
好的感谢!,另外我还有个问题就是我在主程序当中的子程序subroutine去调用module当中的函数或者程序的时 ...
fcode 发表于 2022-5-27 12:23
是的。
现代Fortran代码,应该只有 Module 和 主程序。没有“外部子程序和外部函数”,即,把所有函数都放 ...
fcode 发表于 2022-5-27 12:23
是的。
现代Fortran代码,应该只有 Module 和 主程序。没有“外部子程序和外部函数”,即,把所有函数都放 ...
fcode 发表于 2022-5-27 14:42
没有什么区别。程序单元和程序单元之间的命名空间是独立的。
程序单元A(比如主程序)中的变量 x 和程序单 ...
fcode 发表于 2022-5-27 15:17
我没太听明白你的意思,反正主程序里的 x 变量,不一定是子程序里的 x 变量。除非实参和虚参名字一样且对应 ...
fcode 发表于 2022-5-27 15:17
我没太听明白你的意思,反正主程序里的 x 变量,不一定是子程序里的 x 变量。除非实参和虚参名字一样且对应 ...
sqs 发表于 2022-5-27 15:30
比如说,
module abc内有一subroutine efg(a , b , c ),其中intent(in) 是a, b.intent(out)是 c
在主程 ...
fcode 发表于 2022-5-27 16:09
subroutine efg(a,b,c) 这里的 a b c 是虚参。
call efg(a,b,c) 这里的 a b c 是实参。
欢迎光临 Fortran Coder (http://bbs.fcode.cn/) | Powered by Discuz! X3.2 |