Jump to content

тест Банерджи

В теории компиляторов тест Банерджи является тестом зависимости . Тест Банерджи предполагает, что все индексы цикла независимы, однако на самом деле это часто не так. Тест Банерджи является консервативным тестом. То есть не сломает зависимость, которой нет.

Это значит, что единственное, что может гарантировать тест – это отсутствие зависимости.

Антизависимость сломана Истинная зависимость разрушена
Истинный Нет
антизависимости
Нет
истинные зависимости
ЛОЖЬ Может быть, а может и не быть
антизависимости
Может быть, а может и не быть
истинные зависимости

Общая форма

[ редактировать ]

Для цикла формы:

for(i=0; i<n; i++) {
    c[f(i)] = a[i] + b[i]; /* statement s1 */
    d[i] = c[g(i)] + e[i];    /* statement s2 */
}

Истинная зависимость существует между утверждением s1 и утверждением s2 тогда и только тогда, когда:

Антизависимость существует между утверждениями s1 и утверждениями s2 тогда и только тогда, когда:

Для цикла формы:

for(i=0; i<n; i++) {
    c[i] = a[g(i)] + b[i]; /* statement s1 */
    a[f(i)] = d[i] + e[i];    /* statement s2 */
}

Истинная зависимость существует между утверждением s1 и утверждением s2 тогда и только тогда, когда:

Ниже приведен пример теста Банерджи.

Цикл, который необходимо проверить на зависимость:

for(i=0; i<10; i++)  {
    c[i+9] = a[i] + b[i]; /*statement s1*/
    d[i] = c[i] + e[i];    /*statement s2*/
}

Позволять

Поэтому,

и

Тестирование на антизависимость

[ редактировать ]

Затем

что дает

Теперь границы являются

Очевидно, что -9 выходит за эти пределы, поэтому антизависимость нарушена.

Тестирование на истинную зависимость

[ редактировать ]

Что дает:

Теперь границы являются

Очевидно, что -9 находится внутри границ, поэтому истинная зависимость не нарушается.

Заключение

[ редактировать ]

Поскольку антизависимость нарушена, мы можем утверждать, что между утверждениями не существует антизависимости.

Поскольку истинная зависимость не была нарушена, мы не знаем, существует ли истинная зависимость между утверждениями.

Следовательно, цикл можно распараллеливать, но операторы должны выполняться в порядке их (потенциальной) истинной зависимости.


См. также

[ редактировать ]
  • Рэнди Аллен и Кен Кеннеди. Оптимизация компиляторов для современных архитектур: подход, основанный на зависимостях
  • Ластовецкий, Алекс. Параллельные вычисления в гетерогенных сетях
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 3117a446eabaabc843864c4248cd373b__1689290640
URL1:https://arc.ask3.ru/arc/aa/31/3b/3117a446eabaabc843864c4248cd373b.html
Заголовок, (Title) документа по адресу, URL1:
Banerjee test - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)