Время, требуемое для работы функции на графическом процессоре
t = gputimeit(F)
t = gputimeit(F,N)
t = gputimeit(F)
измеряет типичное время (в секундах) требуемый запустить функцию, заданную указателем на функцию F
. Указатель на функцию не принимает внешних входных параметров, но может быть задан с входными параметрами к его внутреннему вызову функции.
t = gputimeit(F,N)
вызовы F
возвратить N
выходные аргументы. По умолчанию, gputimeit
вызывает функциональный F
с одним выходным аргументом или никакими выходными аргументами, если F
не возвращает выходного параметра.
Измерьте время, чтобы вычислить sum(A.' .* B, 1)
на графическом процессоре, где A
12000 400 матрица и B
400 12000.
A = rand(12000,400,'gpuArray'); B = rand(400,12000,'gpuArray'); f = @() sum(A.' .* B, 1); t = gputimeit(f)
0.0026
Сравните время, чтобы запустить svd
на графическом процессоре, с одним по сравнению с тремя выходными аргументами.
X = rand(1000,'gpuArray');
f = @() svd(X);
t3 = gputimeit(f,3)
1.0622
t1 = gputimeit(f,1)
0.2933
gputimeit
предпочтительно для timeit
для функций, которые используют графический процессор, потому что он гарантирует, что все операции на графическом процессоре закончились прежде, чем записать время и компенсируют издержки. Для операций, которые не используют графический процессор, timeit
предлагает большую точность.
Отметьте нижеследующие ограничения:
Функциональный F
не должен вызывать tic
или toc
.
Вы не можете использовать tic
и toc
измерять время выполнения gputimeit
самостоятельно.