Jump to content

Анализ зависимостей

(Перенаправлено из Анализа зависимостей )

В теории компиляторов анализ зависимостей создает ограничения порядка выполнения между операторами/инструкциями. В общих чертах, оператор S2 зависит от S1 , если S1 должен быть выполнен до S2 . В общих чертах существует два класса зависимостей — зависимости управления и зависимости данных .

Анализ зависимостей определяет, безопасно ли переупорядочивать или распараллеливать операторы.

Зависимости управления

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

Зависимость управления — это ситуация, в которой инструкция программы выполняется, если предыдущая инструкция оценивается таким образом, что позволяет ее выполнение.

Оператор S2 является управляемо-зависимым от S1 (записывается ) тогда и только тогда, когда выполнение S2 условно защищено S1 . S2 зависит Управление от S1 тогда и только тогда, когда где это пост-доминантная граница высказывания . Ниже приведен пример такой зависимости управления:

S1       if x > 2 goto L1
S2       y := 3   
S3   L1: z := y + 1

Здесь S2 выполняется только в том случае, если предикат в S1 ложен.

Зависимости данных

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

Зависимость данных возникает из-за двух операторов, которые обращаются к одному и тому же ресурсу или изменяют его.

Зависимость потока(True)

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

Оператор S2 является потокозависимым от S1 (записывается ) тогда и только тогда, когда S1 изменяет ресурс, который S2 читает , и S1 предшествует S2 в выполнении. Ниже приведен пример зависимости от потока (RAW: чтение после записи):

S1       x := 10
S2       y := x + c

Антизависимость

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

Высказывание S2 антизависимо от S1 ( записывается ) тогда и только тогда, когда S2 изменяет ресурс, который S1 читает , и S1 предшествует S2 в выполнении. Ниже приведен пример антизависимости (WAR: Write After Read):

S1       x := y + c
S2       y := 10

Здесь S2 устанавливает значение y но S1 считывает предыдущее значение y.

Выходная зависимость

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

Оператор S2 выводится в зависимости от S1 (записывается ) тогда и только тогда, когда S1 и S2 модифицируют один и тот же ресурс и S1 предшествует S2 в выполнении. Ниже приведен пример зависимости вывода (WAW: Write After Write):

S1       x := 10
S2       x := 20

Здесь S2 и S1 устанавливают переменную x.

Входная зависимость

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

Оператор S2 зависит ввода от S1 (записывается ) тогда и только тогда, когда S1 и S2 читают один и тот же ресурс и S1 предшествует S2 в выполнении. Ниже приведен пример входной зависимости (RAR: Read-After-Read):

S1       y := x + 3
S2       z := x + 5

Здесь S2 и S1 оба обращаются к переменной x. Эта зависимость не запрещает переупорядочение.

Зависимости цикла

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

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

См. также

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

Дальнейшее чтение

[ редактировать ]
  • Купер, Кейт Д.; Торчон, Линда. (2005). Разработка компилятора . Морган Кауфманн. ISBN  1-55860-698-Х .
  • Кеннеди, Кен; Аллен, Рэнди. (2001). Оптимизация компиляторов для современных архитектур: подход, основанный на зависимостях . Морган Кауфманн. ISBN  1-55860-286-0 .
  • Мучник, Стивен С. (1997). Расширенное проектирование и реализация компилятора . Морган Кауфманн. ISBN  1-55860-320-4 .
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 3330f59b02591af78d1958e6aba9b62b__1705917840
URL1:https://arc.ask3.ru/arc/aa/33/2b/3330f59b02591af78d1958e6aba9b62b.html
Заголовок, (Title) документа по адресу, URL1:
Dependence analysis - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)