X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Ftactics%2Fparamodulation%2Findexing.mli;h=52afad8c2d05d9e9cbca70856a3818cd34432689;hb=a677e0d09755766c61ce9b30a98bec10cb8902b3;hp=ef068151ea3210aa5463b0f66b7b79f86e68aa27;hpb=beb4e1e9549d5b43e24907dc86c7ef899e487a3c;p=helm.git diff --git a/helm/software/components/tactics/paramodulation/indexing.mli b/helm/software/components/tactics/paramodulation/indexing.mli index ef068151e..52afad8c2 100644 --- a/helm/software/components/tactics/paramodulation/indexing.mli +++ b/helm/software/components/tactics/paramodulation/indexing.mli @@ -30,7 +30,8 @@ module Index : module PosEqSet : Set.S with type elt = Utils.pos * Equality.equality and type t = Equality_indexing.DT.PosEqSet.t - type t = Discrimination_tree.DiscriminationTreeIndexing(PosEqSet).t + type t = + Discrimination_tree.Make(Discrimination_tree.CicIndexable)(PosEqSet).t end val index : Index.t -> Equality.equality -> Index.t @@ -48,13 +49,24 @@ val subsumption : Index.t -> Equality.equality -> (Subst.substitution * Equality.equality * bool) option - +val unification_all : + Cic.metasenv * Cic.context * CicUniv.universe_graph -> + Index.t -> + Equality.equality -> + (Subst.substitution * Equality.equality * bool) list +val subsumption_all : + Cic.metasenv * Cic.context * CicUniv.universe_graph -> + Index.t -> + Equality.equality -> + (Subst.substitution * Equality.equality * bool) list val superposition_left : + Equality.equality_bag -> Cic.conjecture list * Cic.context * CicUniv.universe_graph -> Index.t -> Equality.goal -> int -> int * Equality.goal list val superposition_right : + Equality.equality_bag -> ?subterms_only:bool -> UriManager.uri -> int -> @@ -64,6 +76,7 @@ val superposition_right : int * Equality.equality list val demodulation_equality : + Equality.equality_bag -> ?from:string -> UriManager.uri -> int -> @@ -71,19 +84,30 @@ val demodulation_equality : Index.t -> Equality.equality -> int * Equality.equality val demodulation_goal : + Equality.equality_bag -> Cic.metasenv * Cic.context * CicUniv.universe_graph -> Index.t -> Equality.goal -> bool * Equality.goal val demodulation_theorem : - 'a -> + Equality.equality_bag -> Cic.metasenv * Cic.context * CicUniv.universe_graph -> - Index.t -> - Cic.term * Cic.term * Cic.metasenv -> - 'a * (Cic.term * Cic.term * Cic.metasenv) + Index.t -> + Cic.term * Cic.term * Cic.metasenv + -> Cic.term * Cic.term + val check_target: + Equality.equality_bag -> Cic.context -> Equality.equality -> string -> unit +val solve_demodulating: + Equality.equality_bag -> + Cic.metasenv * Cic.context * CicUniv.universe_graph -> + Index.t -> + Equality.goal -> + int -> + Equality.goal option + (** profiling *) val get_stats: unit -> string