20622

Базовые блоки

Лекция

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

Говорят что трехадресная инструкция вида определяет x и использует y и z. Выход: список базовых блоков такой что каждая трех адресная инструкция принадлежит только одному блоку. Правила: первая инструкция является лидером. любая инструкция являющаяся целевой инструкцией условного или безусловного переходов является лидером.

Русский

2013-07-31

111.5 KB

1 чел.

Лекция №9

Базовые блоки

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

Говорят, что трехадресная инструкция вида  определяет x и использует y и z.

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

Алгоритм разбиения потока на базовые блоки

Вход: последовательность трех адресных инструкций.

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

Правила:

  1.  первая инструкция является лидером.
  2.  любая инструкция, являющаяся целевой инструкцией условного или безусловного переходов является лидером.
  3.  любая инструкция, следующая за условным или безусловным переходом, является лидером.
  4.  базовый блок для каждого лидера состоит из него самого до следующего лидера, не включая его, или до конца программы.

Пример: скалярное произведение трех векторов.

begin

prod:=0;

i:=1;

repeat

prod:=prod+a[i]*b[i];

i:=i+1;

until(i>20);

end

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

Оптимизация внутри базовых блоков

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

  1.  Устранение мертвого кода

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

  1.  Переименование временных переменных

, t – временная переменная.

Если заменить имя одной временной переменной на имя другой временной переменной, при этом базовый блок не изменит своего смысла. Если такое преобразование возможно, такой базовый блок называется блоком нормального вида, тогда в дальнейшем это может позволить применить другие методы оптимизации.

  1.  Перестановка инструкций:

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

  1.  Арифметические преобразования.

Графы потоков управления

Узлами графа потоков являются базовые блоки. Графы потоков содержат информацию о потоке управления. Один из узлов графа определяется как стартовый. Направленная дуга графа потока от блока В1 к блоку В2 может быть построена, если блок В2 непосредственно следует за блоком В1 в потоке управления. Это реализуется в 2-х случаях:

  1.  имеется условный или безусловный переход от последней инструкции блока В1 к первой инструкции блока  В2 .
  2.  блок В2 следует за блоком В1, при этом В1 не должен заканчиваться инструкцией безусловного перехода.

В1 – называется предшественником В2

В2 – называется приемником В1.

Сбор информация о последующем использовании имен в базовых блоках

Алгоритм вычисления последующих использований

Пусть трехадресная инструкция с номером i присваивает значение переменной x. Если инструкция с номером j содержит x в качестве операнда и управление может перейти от i к j таким путем, на котором не меняется значение x, говорят, что j использует значение x, вычисленное в i. Сканирование на предмет последующих использований, происходит от конца базового блока к началу с запоминанием в таблице символов для каждого имени x, используется оно или нет.

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

x:=(a*(-b))+(c-(d+e))

t1:=d+e

t1:=c-t1

t2:=-b

t2:=t2*a

t1:=t1+t2

x:=t1

t1:=d+e

t1:=c-t1

t2:=-b

t2:=t2*a

x:=t1+t2


 

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

16362. Исследование электромагнитных волн в прямоугольном волноводе 458.5 KB
  Исследование электромагнитных волн в прямоугольном волноводе Методические указания к лабораторной работе Цель работы Задание для предварительного расчета Описание лабораторной установки Краткие теоретические сведения Задание к экспериментальной части...
16363. ИССЛЕДОВАНИЕ СВЧ ОБЪЕМНЫХ РЕЗОНАТОРОВ 588.5 KB
  МЕТОДИЧЕСКИЕ УКАЗАНИЯ к лабораторной работе ИССЛЕДОВАНИЕ СВЧ ОБЪЕМНЫХ РЕЗОНАТОРОВ В методических указаниях даны рекомендации по расчету объемных резонаторов и экспериментальному измерению резонансной частоты собственной и нагруженной добротности объемн
16364. Определение теплопроводности твердых теплоизоляционных материалов 133 KB
  Лабораторная работа №1. Определение теплопроводности твердых теплоизоляционных материалов Цель и задачи работы: ознакомление со стационарным методом измерения коэффициентов теплопроводности теплоизоляционных материалов и про...
16365. Исследование сложного теплообмена горизонтальной трубы с окружающим воздухом в условиях свободной конвекции 511 KB
  Лабораторная работа №4. Исследование сложного теплообмена горизонтальной трубы с окружающим воздухом в условиях свободной конвекции Цель работы: расчетное и экспериментальное определение основных характеристик сложного теплообмена количества теплоты передав...
16366. Исследование теплоотдачи при движение воздуха в пучке труб 1000 KB
  Отчёт к лабораторной работе № 5 Цель работы: Исследование теплоотдачи при движение воздуха в пучке труб. Введение: При поперечном омывании жидкость пучков труб в зависимости от числа Re различают следующие три режима: ламинарный смешанный и турбулентный. Чаще всего ...
16367. Определение степени черноты излучающего тела 1012.5 KB
  Лабораторная работа № 6 Определение степени черноты излучающего тела Цель работы: определение степени черноты излучающей поверхности тела. Задачи работы: Экспериментальное определение степени черноты различных тел. Экспериментальное исследование
16368. Определение коэффициента теплоотдачи излучением между двумя телами 103.5 KB
  Лабораторная работа №8 Цель работы: Определение коэффициента теплоотдачи излучением между двумя телами. Введение: Тепловое излучение представляет собой процесс распространения внутренней энергии излучающего тела путем электромагнитных волн распространяющих...
16369. Библиотека консольного ввода-вывода 1.07 MB
  Дисциплина Архитектура вычислительных систем и компьютерных сетей Отчет по лабораторным работам №2 На темы: Библиотека консольного вводавывода Цель работы Научится работать с функциями Win32 API для создания и управления консолью. Задание Разработать библи...
16370. Построение сетей с помощью концентраторов, коммутаторов, маршрутизаторов 857 KB
  Построение сетей с помощью концентраторов коммутаторов маршрутизаторов. Цель работы: Ознакомление с приемами моделирования сетей с помощью ПО Cisco Packet Tracer. Получение навыков по построению и моделированию сетей с использованием концентраторов коммутаторов