Jump to content

Удаление общего подвыражения

В теории компиляторов исключение общего подвыражения ( CSE ) — это оптимизация компилятора , которая ищет экземпляры идентичных выражений (т. е. все они оценивают одно и то же значение) и анализирует, стоит ли заменять их одной переменной, содержащей вычисленное значение. [ 1 ]

В следующем коде:

a = b * c + g;
d = b * c * e;

возможно, стоит преобразовать код так:

tmp = b * c;
a = tmp + g;
d = tmp * e;

если стоимость хранения и извлечения tmp меньше стоимости расчета b * c дополнительное время.

Возможность выполнения CSE основана на доступном анализе выражений ( анализе потока данных ). Выражение b*c доступен в точке p программы, если:

  • каждый путь от начального узла до p оценивает b*c до достижения р ,
  • и нет никаких заданий b или c после оценки, но до p .

Анализ затрат/выгод, выполняемый оптимизатором, позволит рассчитать, будет ли стоимость магазина tmp меньше стоимости умножения; на практике другие факторы, например, какие ценности хранятся в каких регистрах, также имеют значение.

Авторы компиляторов различают два типа CSE:

  • локальное исключение общего подвыражения работает в пределах одного базового блока
  • глобальное исключение общих подвыражений работает для всей процедуры,

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

Преимущества

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

Преимущества выполнения CSE настолько велики, что это широко используемая оптимизация.

В простых случаях, как в приведенном выше примере, программисты могут вручную удалять повторяющиеся выражения во время написания кода. Основным источником CSE являются промежуточные последовательности кода, генерируемые компилятором, например, для вычислений индексации массива , когда разработчик не может вмешаться вручную. В некоторых случаях особенности языка могут создавать множество повторяющихся выражений. Например, C макросы , где раскрытие макросов может привести к появлению общих подвыражений, не видимых в исходном исходном коде.

Составители должны разумно подходить к количеству временных объектов, созданных для хранения значений. Чрезмерное количество временных значений создает нагрузку на регистры , что может привести к утечке регистров в память, что может занять больше времени, чем простое перевычисление арифметического результата, когда это необходимо.

См. также

[ редактировать ]
  1. ^ Стивен Мучник; Мучник и партнеры (15 августа 1997 г.). Расширенная реализация проекта компилятора . Морган Кауфманн. ISBN  978-1-55860-320-2 . Удаление общего подвыражения.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: d7011c21de697c8989f9cda713c63ff5__1700179620
URL1:https://arc.ask3.ru/arc/aa/d7/f5/d7011c21de697c8989f9cda713c63ff5.html
Заголовок, (Title) документа по адресу, URL1:
Common subexpression elimination - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)