- let extensions set (r, h) = List.filter (fun one_dpm -> let (truth_value, _, _) = one_dpm (r, h) in truth_value) set;;
-
- let negate_op (phi : clause_op) : clause_op =
- fun one_dpm -> unit_set (
- fun (r, h) ->
- let truth_value' = extensions (phi one_dpm) (r, h) = []
+ let truths set (r, h) =
+ let test one_dpm =
+ let (truth_value, _, _) = one_dpm (r, h)
+ in truth_value
+ in List.filter test set;;
+
+ let negate_op (phi : clause) : clause =
+ fun one_dpm ->
+ let new_dpm = fun (r, h) ->
+ (* if one_dpm isn't already false at (r, h),
+ we want to check its behavior when updated with phi
+ bind_set (unit_set one_dpm) phi === phi one_dpm; do you remember why? *)
+ let (truth_value, _, _) = one_dpm (r, h)
+ in let truth_value' = truth_value && (truths (phi one_dpm) (r, h) = [])
+ (* new_dpm must return a (bool, r, h) *)