X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fng_paramodulation%2Forderings.mli;h=a6d1a87432f71acc0c47cdfa44492b78e092ec64;hb=2bcf927f58bac034b8758173cdbd16cb7475de36;hp=ab5c1897bbbfc5785204bbf54d8a7ec35d98f742;hpb=d807d5e4fa129504669f775f4f832a1a7eb920a0;p=helm.git diff --git a/helm/software/components/ng_paramodulation/orderings.mli b/helm/software/components/ng_paramodulation/orderings.mli index ab5c1897b..a6d1a8743 100644 --- a/helm/software/components/ng_paramodulation/orderings.mli +++ b/helm/software/components/ng_paramodulation/orderings.mli @@ -11,8 +11,9 @@ (* $Id: nCic.ml 9058 2008-10-13 17:42:30Z tassi $ *) -module Orderings (B : Terms.Blob) : +module type Blob = sig + include Terms.Blob (* This order relation should be: * - stable for instantiation @@ -20,12 +21,22 @@ module Orderings (B : Terms.Blob) : * *) val compare_terms : - B.t Terms.foterm -> B.t Terms.foterm -> Terms.comparison + t Terms.foterm -> t Terms.foterm -> Terms.comparison - val compute_unit_clause_weight : - B.t Terms.unit_clause -> int + (* these could be outside the module, but to ease experimentation + * we allow them to be tied with the ordering *) + val compute_unit_clause_weight : 't Terms.unit_clause -> int + val compute_goal_weight : 't Terms.unit_clause -> int - val compute_goal_weight : - B.t Terms.unit_clause -> int + val name : string end + +module NRKBO (B : Terms.Blob) : Blob +with type t = B.t and type input = B.input + +module KBO (B : Terms.Blob) : Blob +with type t = B.t and type input = B.input + +module LPO (B : Terms.Blob) : Blob +with type t = B.t and type input = B.input