From 88757681affd65fa30dc497b121739510ab48aff Mon Sep 17 00:00:00 2001 From: hra687261 Date: Wed, 9 Oct 2024 18:24:11 +0200 Subject: [PATCH 1/2] Expose the map in ModelMap, and add `find` and `fold` functions over that map --- src/lib/structures/modelMap.ml | 15 +++++++++++---- src/lib/structures/modelMap.mli | 17 +++++++++++++++++ 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/src/lib/structures/modelMap.ml b/src/lib/structures/modelMap.ml index e8fee0f14e..dd423249a2 100644 --- a/src/lib/structures/modelMap.ml +++ b/src/lib/structures/modelMap.ml @@ -19,6 +19,11 @@ module X = Shostak.Combine module Sy = Symbols +module M: Map.S with type key = Expr.t list = Map.Make + (struct + type t = Expr.t list [@@deriving ord] + end) + (* The type of this module represents a model value for a function [f] by a finite set of constraints of the form: f(e_1, ..., e_n) = e @@ -27,10 +32,6 @@ module Sy = Symbols As functions in the SMT-LIB standard are total, one of the expressions [e] above is used as the default value of the function. *) module Constraints = struct - module M = Map.Make - (struct - type t = Expr.t list [@@deriving ord] - end) type t = Expr.t M.t @@ -137,6 +138,12 @@ let add ((id, arg_tys, _) as sy) arg_vals ret_val { values; suspicious } = in { values; suspicious } +let find k {values; _ } = + P.find k values + +let fold f {values;_} acc = + P.fold f values acc + let empty ~suspicious declared_ids = let values = List.fold_left diff --git a/src/lib/structures/modelMap.mli b/src/lib/structures/modelMap.mli index aa823bca10..f3bc5406ef 100644 --- a/src/lib/structures/modelMap.mli +++ b/src/lib/structures/modelMap.mli @@ -16,6 +16,15 @@ (* *) (**************************************************************************) +module M: Map.S with type key = Expr.t list + +type graph = + | Free of Expr.t + (* Represents a graph without any constraint. The expression is + an abstract value. *) + + | C of Expr.t M.t + type t (** Type of model. *) @@ -28,6 +37,14 @@ val empty : suspicious:bool -> Id.typed list -> t model may be wrong as it involves symbols from theories for which the model generation is known to be incomplete. *) +val find : Id.typed -> t -> graph +(** [find sy mdl] returns the graph associated with the symbol [sy] in the model + [mdl], raises [Not_found] if it doesn't exist. *) + +val fold: (Id.typed -> graph -> 'a -> 'a) -> t -> 'a -> 'a +(** [fold f mdl init] folds over the bindings in the model [mdl] with the + function [f] and with [init] as a initial value for the accumulator. *) + val subst : Id.t -> Expr.t -> t -> t (** [subst id e mdl] substitutes all the occurrences of the identifier [id] in the model [mdl] by the model term [e]. From aa653f0ac2e6713be204d28d2c18716e74bab606 Mon Sep 17 00:00:00 2001 From: hra687261 Date: Wed, 9 Oct 2024 18:33:54 +0200 Subject: [PATCH 2/2] fix indentation --- src/lib/structures/modelMap.ml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/lib/structures/modelMap.ml b/src/lib/structures/modelMap.ml index dd423249a2..47df05ccbe 100644 --- a/src/lib/structures/modelMap.ml +++ b/src/lib/structures/modelMap.ml @@ -20,9 +20,9 @@ module X = Shostak.Combine module Sy = Symbols module M: Map.S with type key = Expr.t list = Map.Make - (struct - type t = Expr.t list [@@deriving ord] - end) + (struct + type t = Expr.t list [@@deriving ord] + end) (* The type of this module represents a model value for a function [f] by a finite set of constraints of the form: