package goblint

  1. Overview
  2. Docs
Static analysis framework for C

Install

Dune Dependency

Authors

Maintainers

Sources

goblint-2.5.0.tbz
sha256=452d8491527aea21f2cbb11defcc14ba0daf9fdb6bdb9fc0af73e56eac57b916
sha512=1993cd45c4c7fe124ca6e157f07d17ec50fab5611b270a434ed1b7fb2910aa85a8e6eaaa77dad770430710aafb2f6d676c774dd33942d921f23e2f9854486551

doc/goblint.domain/DisjointDomain/index.html

Module DisjointDomainSource

Abstract domains for collections of elements from disjoint unions of domains. Formally, the elements form a cofibered domain from a discrete category.

Elements are grouped into disjoint buckets by a congruence or/and a projection. All operations on elements are performed bucket-wise and must be bucket-closed.

Examples of such domains are path-sensitivity and address sets.

Sets

By projection

Sourcemodule type Representative = sig ... end

Buckets defined by projection. The module is the image (representative) of the projection function of_elt.

Sourcemodule ProjectiveSet (E : Printable.S) (B : SetDomain.S with type elt = E.t) (R : Representative with type elt = E.t) : sig ... end

Set of elements E.t grouped into buckets by R, where each bucket is described by the set B.

Sourcemodule type MayEqualSetDomain = sig ... end
Sourcemodule ProjectiveSetPairwiseMeet (E : Printable.S) (B : MayEqualSetDomain with type elt = E.t) (R : Representative with type elt = E.t) : SetDomain.S with type elt = E.t

By congruence

Sourcemodule type Congruence = sig ... end

Buckets defined by congruence.

Sourcemodule PairwiseSet (E : Printable.S) (B : SetDomain.S with type elt = E.t) (C : Congruence with type elt = E.t) : SetDomain.S with type elt = E.t

Set of elements E.t grouped into buckets by C, where each bucket is described by the set B.

Sourcemodule type RepresentativeCongruence = sig ... end

Buckets defined by a coarse projection and a fine congruence. Congruent elements must have the same representative, but not vice versa (Representative would then suffice).

Sourcemodule CombinedSet (E : Printable.S) (B : SetDomain.S with type elt = E.t) (RC : RepresentativeCongruence with type elt = E.t) : sig ... end

Set of elements E.t grouped into buckets by RC, where each bucket is described by the set B.

Maps

Generalization of above sets into maps, whose key set behaves like above sets, but each element can also be associated with a value.

By projection

Sourcemodule ProjectiveMap (E : Printable.S) (V : Printable.S) (B : MapDomain.S with type key = E.t and type value = V.t) (R : Representative with type elt = E.t) : MapDomain.S with type key = E.t and type value = B.value

Map of keys E.t grouped into buckets by R, where each bucket is described by the map B with values V.t.

By congruence

Sourcemodule PairwiseMap (E : Printable.S) (R : Printable.S) (B : MapDomain.S with type key = E.t and type value = R.t) (C : Congruence with type elt = E.t) : MapDomain.S with type key = E.t and type value = B.value

Map of keys E.t grouped into buckets by C, where each bucket is described by the map B with values R.t.

OCaml

Innovation. Community. Security.