我需要在Fortran中进行点积运算。我可以使用Fortran的内置函数
我做错了什么?BLAS不应该更快吗?
dot_product
或使用OpenBLAS中的ddot
。问题是ddot
较慢。这是我的代码:
使用BLAS:
program VectorBLAS
! time VectorBlas.e = 0.30s
implicit none
double precision, dimension(3) :: b
double precision :: result
double precision, external :: ddot
integer, parameter :: LargeInt_K = selected_int_kind (18)
integer (kind=LargeInt_K) :: I
DO I = 1, 10000000
b(:) = 3
result = ddot(3, b, 1, b, 1)
END DO
end program VectorBLAS
使用 dot_product
program VectorModule
! time VectorModule.e = 0.19s
implicit none
double precision, dimension (3) :: b
double precision :: result
integer, parameter :: LargeInt_K = selected_int_kind (18)
integer (kind=LargeInt_K) :: I
DO I = 1, 10000000
b(:) = 3
result = dot_product(b, b)
END DO
end program VectorModule
这两个代码使用以下方式进行编译:
gfortran file_name.f90 -lblas -o file_name.e
我做错了什么?BLAS不应该更快吗?