Ich brauche ein Skalarprodukt in Fortran. Ich kann mit der intrinsischen Funktion dot_product
von Fortran tun oder ddot
von OpenBLAS verwenden. Das Problem ist, dass die ddot
langsamer ist. Dies ist mein Code:OpenBLAS langsamer als intrinsische Funktion dot_product
Mit 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
Mit 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
Die beiden Codes verwenden zusammengestellt:
gfortran file_name.f90 -lblas -o file_name.e
Was mache ich falsch? BLAS muss nicht schneller sein?
sehr viel im Zusammenhang http://stackoverflow.com/questions/35926940/ fortran-lapack-high-CPU-sys-Nutzung-mit-dsyev-keine-Parallelisierung-normal/36035152 # 36035152 –