《编译原理》画 DAG 图与求优化后的 4 元式代码- 例题解析

DAG 图(Directed Acylic Graph)无环路有向图

(一)基本块

基本块是指程序中一顺序执行的语句序列,其中只有一个入口语句(第一个语句)和一个出口语句(最后一个语句)

对于一个基本块来说,执行时只能从其入口语句进入,从其出口语句退出

语句
出口语句 任何控制转移四元式
入口语句 所转向的目标语句

(二)划分基本块的步骤

1、求四元式序列中各个基本块的入口语句。

  • ① 程序的第一个语句
  • ② 能由条件或无条件转移语句转移到的语句
  • ③ 紧跟在条件转移语句后面的语句

2、对每一入口语句,构造所属的基本块,该基本块由:

  • 1)该入口语句到下一入口语句(不包括下一入口语句)之间的语句序列组成
  • 2)该入口语句到一转移语句(包括该转移语句)之间的语句序列组成
  • 3)该入口语句到一停语句(包括该停语句)之间的语句序列组成

3、凡是未包含在某一基本块中的语句,都是程序中控制流程不可达的语句,可删除它们。

例题:

对于下面给出的求最大公因子的程序,可以根据基本块的构造规则与其划分基本块

基本块构造步骤:

(1):由规则 (1) 中的 ① 可知语句 (1) 是一个入口语句
(2):由规则 (1) 中的 ② 可知,语句 (3) 和 (8) 均是人口语句
(3):由规则 (1) 中的 ③ 可知,语句 (5) 是二个人口语句,可以用 “+” 在人口语句的左侧作标记。
(4):由规则 (2) 可以划分该程序为四个基本块,它们分别是:

  • 语句 (1)、(2) 组成的基本块 B1
  • 语句 (3)、(4) 组成的基本块 B2
  • 语句 (5)、(6) 和 (7) 组成的基本块 B3
  • 语句 (8) .(9) 组成的基本块 B4

程序中在代码段左侧对各个基本块进行了标记。

(三)程序控制流程流图

定义: 以基本块为结点,控制程序流向作为有向边,画出的有向图称为流图。

特点:

  • 具有唯一首结点的有向图
  • 从首结点开始到流图中任何结点都有通路

如果一个结点的基本块的入口语句是程序的第一条语句,则称此结点为首结点

程序控制流程流图的表示

一个控制流程图可表示成一个三元组:
G=(N,E,n0 )

N:所有结点(基本块)集;
E:所有有向边集;
n0 :首结点。

有向边:

当下述条件有一个成立时,从结点i有一有向边引向结点 j:

  • ① 基本块 j 在程序的位置紧跟在i后,且 i 的出口语句不是无条件转移或停语句
  • ② i 的出口是 goto(S) 或 if goto(S),而 (S) 是 j 的入口语句

构造程序控制流图

对程序基本块:

构造以下程序控制流图:

(四)基本块的 DAG 表示

DAG Directed Acyclic Graph 无环路有向图

定义:

(1) 在一个有向图中,若结点 ni 有弧指向结点 nj,则 ni 是 nj 的父结点,nj 是 ni 的子结点;

(2) 若 n1,n2,…,nk 间存在有向弧 n1→n2→…→nk,则称 n1 到 nk 之间存在一条通路,若有 nk=n1,则称该通路为环路;

(3) 若有向图中任意通路都不是环路,则称该图为无环路有向图(DAG)

用来描述基本块的 DAG:

(1) 图的叶结点以一标识符或常数做标记,表示该结点代表该变量或常数的值。

(2) 图的内部结点以一运算符作为标记;

(3) 图中各个结点上可能附加一个或多个标识符,表示这些标识符具有该结点所代表的值,简称附标。

四元式对应的 DAG 结点形式

按其四元式对应结点的后继个数分成四种类型:0型、1型、2型、3型

(五)DAG 图构造例题

对于基本块 P

(1)S0 := 2
(2)S4 := 2
(3)S1 := 1.5
(4)S2 := T-C
(5)S3 := T+C
(6)S5 := S3
(7)R := 2/S3
(8)S6 := R
(9)H := R*S2

(1)试用 DAG 进行优化并重写基本块
(2)假定只有 R,H 在基本块出口是活跃的,试写出优化后的 4 元式序列
(只需要还原活跃变量)

解析:

(1)画出 DAG 图如下:

画图的步骤就是:根据基本块,一部一部组装

(2)假定只有 R,H 在基本块出口是活跃的,试写出优化后的 4 元式序列
(只需要还原活跃变量)

优化后的 4 元式代码可以写为:
(1)S2 := T-C
(2)S3 := T+C
(3)R := 2/S3
(4)H := R*S2

解释:

与原来的基本块相比较可以看出:

  • 原基本块中的 (2) 和 (7) 中的已知量都已经合并。因为 (2) 中 S4 := 2,(7) 中用 2,所以合并。
  • (5) 和 (8) 中的公共子表达式 T+C 只在 (5) 中计算一次,在 (8) 中 直接引用其结果,所以删除了多余运算。
  • (6) 中的无用赋值已被删除。S5 := S3,S5 后面没有再用,所以就和 S3 一起表示。

除了可以应用 DAG 进行上述的优化外,还可以从基本块的 DAG 中得到一些其他信息:

  • DAG 叶结点上标记的标识符是在该基本块之前的基本块内被定值,并在该基本块内被引用的标识符。
  • DAG 各结点上的附加标识符是在基本块内被定值,并可以在基本块后被引用的标识符。

如果确认某结点的一个附加标记在基本块后不会被引用,则该标识符的定值语句可以作为死代码被删除。

假设上面例子中 S0~S6。在基本块后面都不会被引用只有 R, H 在基本块出口是活跃的则优化后的四元式序列可以写为:
(1)S2 := T-C
(2)S3 := T+C
(3)R := 2/S3
(4)H := R*S2

《编译原理》画 DAG 图与求优化后的 4 元式代码- 例题解析的更多相关文章

  1. 《编译原理》LR 分析法与构造 LR(1) 分析表的步骤 - 例题解析

    <编译原理>LR 分析法与构造 LR(1) 分析表的步骤 - 例题解析 笔记 直接做题是有一些特定步骤,有技巧.但也必须先了解一些基本概念,本篇会通过例题形式解释概念,会容易理解和记忆,以 ...

  2. Go 编译原理实现计算器(测试驱动讲解)

    本文不需要你掌握任何编译原理的知识. 只需要看懂简单的golang语言即可, 完整的代码示例在GIT, 代码是从writing an interpreter in go这本书抽取了简单的部分出来, 如 ...

  3. GCC编译器原理(三)------编译原理三:编译过程(2-1)---编译之词法分析

    二.编译 引用文档:https://blog.csdn.net/chdhust/article/details/9040647 编译过程就是把预处理完的文件进行一系列词法分析.语法分析.语义分析及优化 ...

  4. POJ 1442 Air Raid(DAG图的最小路径覆盖)

    题意: 有一个城镇,它的所有街道都是单行(即有向)的,并且每条街道都是和两个路口相连.同时已知街道不会形成回路. 可以在任意一个路口放置一个伞兵,这个伞兵会顺着街道走,依次经过若干个路口. 问最少需要 ...

  5. 深入理解 Flutter 的编译原理与优化

    阿里妹导读:对于开发者而言,Flutter工程和我们的Android/iOS工程有何差别?Flutter的渲染和事件传递机制如何工作?构建缓慢或出错又如何去定位,修改和生效呢?凡此种种,都需要对Flu ...

  6. POJ - 3249 Test for Job (在DAG图利用拓扑排序中求最长路)

    (点击此处查看原题) 题意 给出一个有n个结点,m条边的DAG图,每个点都有权值,每条路径(注意不是边)的权值为其经过的结点的权值之和,每条路径总是从入度为0的点开始,直至出度为0的点,问所有路径中权 ...

  7. 《编译原理》求 FIRSTVT 集和 LASTVT 集的步骤 - 例题解析

    <编译原理>求 FIRSTVT 集和 LASTVT 集的步骤 - 例题解析 算符优先关系表的构造中涉及到求 FIRSTVT 集和 LASTVT 集. 表示及含义: FIRSTVT(T) 非 ...

  8. 编译原理_P1004

    龙书相关知识点总结 //*************************引论***********************************// 1. 编译器(compiler):从一中语言( ...

  9. Compiler Theory(编译原理)、词法/语法/AST/中间代码优化在Webshell检测上的应用

    catalog . 引论 . 构建一个编译器的相关科学 . 程序设计语言基础 . 一个简单的语法制导翻译器 . 简单表达式的翻译器(源代码示例) . 词法分析 . 生成中间代码 . 词法分析器的实现 ...

随机推荐

  1. centos7环境变量配错导致命令不能用

    吓得我都不知道挖掘机哪家强了, centos7由于配置环境变量的时候少打了$PATH,导致很多命令不能用了,吓了一跳 解决办法: 1.直接在命令行输入: export PATH=/usr/local/ ...

  2. 038--HTML

    一.HTML的定义 1. 超文本标记语言(Hypertext Markup Language,HTML)通过标签语言来标记要显示的网页中的各个部分.一套规则,浏览器认识的规则 2. 浏览器按顺序渲染网 ...

  3. hdoj3664【DP】

    题意: 有一种值E=the number of elements where ai > i.比如1 3 2 4,只有3位置是满足的,E=1.然后他会给你一个数组和一个k,问有多少个序列的E=k. ...

  4. bzoj 4871: [Shoi2017]摧毁“树状图”【树形dp】

    做不来--参考https://www.cnblogs.com/ezyzy/p/6784872.html #include<iostream> #include<cstdio> ...

  5. LuoguP2055 [ZJOI2009]假期的宿舍【二分图最大匹配】By cellur925

    题目传送门 这道题开始感觉不出是二分图最大匹配的qwq.但是今天学了匈牙利算法,想来做几个题qwq.做这个题的时候想了很久它哪里是二分图,脑子里是“两列,每列有很多点的那种图 qwq.” 然后看了题解 ...

  6. USACO Training3.3亚瑟王的宫殿【搜索】By cellur925

    题目传送门 因为太蒟了,所以参考了dalao@zbtrs ==    对此表示感谢并侵删. 看起来我们就知道这是搜索题. 最后的情况分两种:有骑士背国王/国王自食其力走到集合点. 首先,我们不知道大家 ...

  7. scanf()和scanf_s()

    在最初的C语言中,原版的输入就是scanf("<格式化字符串>",<地址表>) ANSI C中没有scanf_s(),只有scanf(),scanf()在读 ...

  8. MySql | 常用操作总结

    创建数据库: CREATE DATABASE 数据库名; 删除数据库名: drop database <数据库名>; 选择数据库: use 数据库名; 创建数据表: CREATE TABL ...

  9. 跟我一起玩Win32开发(17):启动和结束进程

    这里我再次说明一下,我不知道为什么,现在的人那么喜欢走极端,估计是价值观都“升级”了的缘故吧. 我撰写这一系列Win32相关的文章,并不是叫大家一定要用Win32去开发项目,仅仅是给大家了解一下,Wi ...

  10. yii2 checkbox 的使用实例

    使用的是Yii自带的Grid,在使用checkbox希望可以把选中行的id值传到我想要的页面. 首先需要改变key值 $dataProvider->key = 'ID'; button: Htm ...