Source file localFixpoint.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
(** Fixpoint iteration solvers local to a single transfer function (don't use a constraint system). *)
module Make (D: Lattice.S) =
struct
let lfp ?(init=D.bot ()) (f: D.t -> D.t): D.t =
let rec widening x =
let x' = f x in
let x'' = D.widen x (D.join x x') in
if D.equal x x'' then
narrowing_reuse x x'
else
widening x''
and narrowing_reuse x x' =
let x'' = D.narrow x x' in
if D.equal x x'' then
x
else
narrowing x''
and narrowing x =
let x' = f x in
narrowing_reuse x x'
in
widening init
end