7. 迭代算法与不动点定理关联
data:image/s3,"s3://crabby-images/ba9c6/ba9c6ac456edffffc59da0ad13bbb8b16fdb9311" alt="在这里插入图片描述"
我们需要证明自己的Transfer Function是单调的
data:image/s3,"s3://crabby-images/c4419/c44194b8570e264df0477165a34239344d67ee31" alt="在这里插入图片描述"
代码什么时候会停止
data:image/s3,"s3://crabby-images/2e8be/2e8be0365bc0fbf24bfad5ee4624233c6ccb6703" alt="在这里插入图片描述"
8. May/Must Analysis, A Lattice View
May Analysis
Unsafe result->Safe result
如果我是一个查错的定义,
没有no definition的错误,这是一个不安全的结果。
所有的definition都有可能有错,这是一个安全但没有用的结果。
data:image/s3,"s3://crabby-images/d7522/d75220a4ab577e1160876f52795d1882cc83fed3" alt="在这里插入图片描述"
这里假设{a,c}是Truth。
data:image/s3,"s3://crabby-images/e51e7/e51e77fd368567e7428d87b07016cb9180457b85" alt="在这里插入图片描述"
9. MOP and Distributivity
- Meet-Over-All-Paths Solution (MOP)
- 枚举所有的路径从Entry到Si
data:image/s3,"s3://crabby-images/54f34/54f347ab064cac58bd2ee643ac4b940f0d9a97d8" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/db000/db0009338ff9c6350a9bec6a04a2e35c6957a88e" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/15201/152015945194760e88593501610e5daa7bd437d9" alt="在这里插入图片描述"
10. Constant Propagation
常量传播:
- Given a variable x at program point p, determine whether x is guaranteed to hold a constant value at p.
- The OUT of each node in CFG, includes a set of pairs (x, v) where x is a variable and v is the value held by x after that node
A data flow analysis framework (D, L, F) consists of:
- D:forwards
- L:如下
- F:如下
data:image/s3,"s3://crabby-images/77a36/77a366d1a5d84ad8c164fe0bab3ef53c9f25ca56" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/fedf6/fedf6e9964e25aa07afaa7916f2376c848aa2982" alt="在这里插入图片描述"
11. Worklist Algorithm
data:image/s3,"s3://crabby-images/f7b09/f7b09721a1e3a24ff8b9a94707276bf8704ccc50" alt="在这里插入图片描述"
Worklist算法对比迭代算法减少了无用的重复部分。
data:image/s3,"s3://crabby-images/48ad9/48ad927858465c2894c3246d538bfd6b2d73cd56" alt="在这里插入图片描述"