2023-07-01 12:01:33
Разбиение цикла на блокиLoop tiling - оптимизирующее преобразование, призванное сделать исполнение некоторых типов циклов более эффективным.
Данный способ оптимизации состоит в разбиении пространства итерирования исходного цикла на небольшие блоки меньшего размера, что позволяет хранить используемые в этих небольших блоках данные в кэше полностью для их неоднократного использования в процессе выполнения блока.
Пример: умножение матрицы на вектор
for (i = 0; i < N; i++)
for (j = 0; j < N; j++)
c[i] = c[i] + a[i, j] * b[j];
После разбиения цикла на блоки 2 × 2:
for (i = 0; i < N; i += 2)
for (j = 0; j < N; j += 2)
for (ii = i; ii < min(i+2, N); ii++)
for (jj = j; jj < min(j+2, N); jj++)
c[ii] = c[ii] + a[ii, jj] * b[ii];
1.8K views09:01