]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/software/components/ng_paramodulation/terms.mli
First compiling version
[helm.git] / helm / software / components / ng_paramodulation / terms.mli
index dfed661d4576ba9b0799c4a61669cc98be653ec4..90ccaf5915b86d2ea7b6152ea6f766adf54f6def 100644 (file)
@@ -18,7 +18,7 @@ type 'a foterm =
 
 type 'a substitution = (int * 'a foterm) list
 
-type comparison = Lt | Eq | Gt | Incomparable
+type comparison = Lt | Eq | Gt | Incomparable | Invertible
 
 type rule = Superposition | Demodulation
 
@@ -52,8 +52,10 @@ type 'a unit_clause =
 
 type 'a clause =
     int
-    * 'a literal list (* left hand side of the arrow *)
-    * 'a literal list (* right hand side of the arrow *)
+    * ('a literal * bool) list (* left hand side of the arrow,
+                                 with flag for selection *)
+    * ('a literal * bool) list (* right hand side of the arrow,
+                                 with flag for selection *)
     * varlist
     * 'a proof
 
@@ -64,19 +66,19 @@ val vars_of_term : ?start_acc:int list -> 'a foterm  -> int list
 module M : Map.S with type key = int 
 
 type 'a bag = int (* max ID  *)
-              * (('a unit_clause * bool * int) M.t)
+              * (('a clause * bool * int) M.t)
 
 (* also gives a fresh ID to the clause *)
     val add_to_bag : 
-          'a unit_clause -> 'a bag ->
-            'a bag * 'a unit_clause
+          'a clause -> 'a bag ->
+            'a bag * 'a clause
 
     val replace_in_bag : 
-          'a unit_clause * bool * int -> 'a bag ->
+          'a clause * bool * int -> 'a bag ->
             'a bag
 
     val get_from_bag : 
-          int -> 'a bag -> 'a unit_clause * bool * int
+          int -> 'a bag -> 'a clause * bool * int
 
     val empty_bag : 'a bag