Существуют различные аргументы, что в некоторых случаях Fortran может быть быстрее, чем C, например, когда дело доходит до сглаживания, и я часто слышал, что он лучше авто- векторизации, чем C (см. here для хорошего обсуждения).эталон простых математических функций: почему Fortran и Julia быстрее, чем C
Однако для простых функций вычисления числа Fibonaci и Mandelbrot на некотором комплексном числе с прямолинейными решениями без каких-либо трюков и дополнительных подсказок/ключевых слов для компилятора я бы ожидал, что они действительно будут выполнять то же самое.
реализация C:
int fib(int n) {
return n < 2 ? n : fib(n-1) + fib(n-2);
}
int mandel(double complex z) {
int maxiter = 80;
double complex c = z;
for (int n=0; n<maxiter; ++n) {
if (cabs(z) > 2.0) {
return n;
}
z = z*z+c;
}
return maxiter;
}
Fortran реализация:
integer, parameter :: dp=kind(0.d0) ! double precision
integer recursive function fib(n) result(r)
integer, intent(in) :: n
if (n < 2) then
r = n
else
r = fib(n-1) + fib(n-2)
end if
end function
integer function mandel(z0) result(r)
complex(dp), intent(in) :: z0
complex(dp) :: c, z
integer :: n, maxiter
maxiter = 80
z = z0
c = z0
do n = 1, maxiter
if (abs(z) > 2) then
r = n-1
return
end if
z = z**2 + c
end do
r = maxiter
end function
Юлия реализация: (. Полный код, включая другие эталонные функции можно найти here)
fib(n) = n < 2 ? n : fib(n-1) + fib(n-2)
function mandel(z)
c = z
maxiter = 80
for n = 1:maxiter
if abs(z) > 2
return n-1
end
z = z^2 + c
end
return maxiter
end
В соответствии с Julia homepage Джулия и Фортран (с -O3
) работают лучше, чем C (с -O3
) по этим двум функциям.
Как это может быть?
Что показали ваши собственные измерения? –
Где находится 'dp'? –
@HighPerformanceMark: Я не могу воспроизвести. Но это из-за [этого] (http://stackoverflow.com/questions/20001184/static-pre-calculation-optimization-in-clang). – Albert