20613

Устранение общих подвыражений

Лекция

Коммуникация, связь, радиоэлектроника и цифровые приборы

2 Удаление бесполезного кода Допустим имеем следующую последовательность инструкций 3 Оптимизация циклов Пример 1: Пусть имеем цикл while i n2 Возможно модернизировать в следующую последовательность инструкций t:=n2 while i t Пример 2: while i t a:=b2 при условии что b не изменяется в теле цикла данную последовательность инструкций можно заменить на: a:=b2 while i t Метод перемещения кода заключается в выносе перед циклом выражений не изменяющихся в процессе его выполнения. 4 Переменные индукции и снижение стоимости 5 Оптимизация...

Русский

2013-07-31

92 KB

1 чел.

Лекция №14.

Устранение общих подвыражений

1) Распространение копий

Использование после инструкции вида f := g переменной g  вместо f, где это возможно.

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

Пример:

после оптимизации избавились от дорогостоящей операции сложения.

2) Удаление бесполезного кода

Допустим, имеем следующую последовательность инструкций

3) Оптимизация циклов

Пример 1:

Пусть имеем цикл

while i<n-2

Возможно модернизировать в следующую последовательность инструкций

t:=n-2

while i<t

Пример 2:

while i<t

a:=b*2

при условии, что b не изменяется в теле цикла, данную последовательность инструкций можно заменить на:

a:=b*2

while i<t

Метод перемещения кода заключается в выносе перед циклом выражений, не изменяющихся в процессе его выполнения.

4) Переменные индукции и снижение стоимости

5) Оптимизация базовых блоков на основе дагов

Пример:

Пусть имеется следующая последовательность инструкций

a:=b+c

b:=a-d

c:=b+c

d:=a-d

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

a:=b+c

d:=a-d

c:=d+c

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

6) Использование алгебраических тождеств

  1.  х+0=х-0=0+х=х
  2.  х/1=х*1=1*х=х
  3.  х**2=х*ч
  4.  х*2=2*х=х+х
  5.  замена констант

Пример:

a:=b+c

b:=b-d

c:=c+d

e:=b+c

e:=b+c    b:=b-d

e:=b-d+c    a:=b+c

e:=a-d

После выполненных преобразований исходная последовательность инструкций примет вид:

a:=b+c

c:=c+d

e:=a-d

7)Рассмотрение циклов в графах потоков

Узел d графа потока доминирует над узлом n, если любой путь из начального узла графа потока в узел n проходит через d.

d    dom    n

Таким образом, вход в цикл доминирует над всеми узлами цикла.


 

А также другие работы, которые могут Вас заинтересовать

25498. Система ТОС 29.81 KB
  Группа граждан в количестве не менее пяти процентов от числа граждан заявление об учреждении Создается организационный комитет по учреждению территориального общественного самоуправления далее организационный комитет в который могут входить представители группы граждан Организационный комитет действует до момента избрания комитета территориального общественного самоуправления. На учредительном собрании рассматриваются вопросы об учреждении территориального общественного самоуправления о наименовании территориального общественного...
25500. Показательная форма комплексного чис 41.13 KB
  Im Геометрическая интерпретация комплексного числа y φ x Re Комплексное число изображается точкой с координатами в декартовой системе координат XOY или вектором с координатами x и y. Аргументом комплексного числа z называется угол φ образованный положительным направлением оси OX и лучом OZ Обозначение: Модулем комплексного числа обозначение: или r называется длина радиусвектора . Тригонометрической формой комплексного числа.
25501. Преобразование Лапласа и его свойства 99.94 KB
  Преобразованием Лапласа функции вещественной переменной называется функция комплексной переменной [1] такая что: Правая часть этого выражения называется интегралом Лапласа. Обратное преобразование Лапласа Обратным преобразованием Лапласа функции комплексного переменного называется функция вещественной переменной такая что: где некоторое вещественное число см. Двустороннее преобразование Лапласа Двустороннее преобразование Лапласа обобщение на случай задач в которых для функции участвуют значения .
25502. Уравнение колебаний 28.54 KB
  Скорость движения точки v(t) найдем, вычислив производную: Тогда максимальное значение модуля скорости равно, а минимальное...
25505. Конфликты в семье 13.25 KB
  Конфликт – столкновение противоположно направленных целей интересов позиций мнений и тд субъектов взаимодействия По Петровской Основания анализа конфликта: 1 структура конфликта Объект субъект конфликтная ситуация инцидент = конликт 2 динамика конфликта этапы 1. инцидент развитие конфликта 4. завершение конфликта 5. послеконфликтная ситуация 3 функции конфликта: конструктивная деструктивная 4 типология конфликтов По степени выраженности: открытые и скрытые По динамика: актуальные прогрессирующие привычные По последствиям:...
25506. Методы воспитания детей в семье 12.17 KB
  Они имеют свою специфику: влияние на ребенка индивидуальное основанное на конкретных поступках и приспособлениях к личности; выбор методов зависит от педагогической культурыродителей: понимания целей воспитания родительской роли представлений о ценностях стиля отношений в семье и т. Поэтому методы семейного воспитания несут на себе яркий отпечаток личности родителей и неотделимы от них. Сколько родителей – столько разновидностей методов.