File: fcl_interval.ml

package info (click to toggle)
facile 1.1.4-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 716 kB
  • sloc: ml: 6,862; makefile: 90
file content (69 lines) | stat: -rw-r--r-- 2,308 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
(***********************************************************************)
(*                                                                     *)
(*                           FaCiLe                                    *)
(*                 A Functional Constraint Library                     *)
(*                                                                     *)
(*            Nicolas Barnier, Pascal Brisset, LOG, CENA               *)
(*                                                                     *)
(* Copyright 2004 CENA. All rights reserved. This file is distributed  *)
(* under the terms of the GNU Lesser General Public License.           *)
(***********************************************************************)
(* $Id: fcl_interval.ml,v 1.14 2004/08/12 15:22:07 barnier Exp $ *)

open Fcl_var
open Fcl_arith




let cstr v inf sup b =
  let init () =
    Fcl_cstr.post (fd2e b<=~i2e 1); Fcl_cstr.post (fd2e b>=~ i2e 0) in
  let delay x =
    delay [Fd.on_subst] b x;
    delay [Fd.on_refine] v x in
  let update _ =
    match Fd.value b with
      Val 0 ->
 	begin
	  match (Fd.value v) with
	    Unk attr -> 
	      Fd.refine v (Fcl_domain.remove_closed_inter inf sup (Attr.dom attr))
	  | Val x ->
	    if x >= inf && x <= sup
	    then Fcl_stak.fail "Interval.cstr"
      	end;
	true
    | Val 1 ->
	begin
	  match (Fd.value v) with
	    Unk attr -> Fd.refine v (Fcl_domain.intersection (Fcl_domain.interval inf sup) (Attr.dom attr))
	  | Val x ->
	      if x < inf || x > sup then
	      	Fcl_stak.fail "Interval.cstr"
	end;
	true
    | Unk _attr ->
	begin
	  match (Fd.value v) with
	    Val x -> 
	      Fd.subst b (if x < inf || x > sup then 0 else 1);
	      true
	  | Unk v_attr ->
	      if Attr.min v_attr > sup || Attr.max v_attr < inf then
	      	(Fd.subst b 0; true)
(* on n'en fait pas plus pasque c'est trop couteux : on pourrait
   calculer l'intersection et si elle est vide b=0 *)
	      else if Attr.min v_attr >= inf && Attr.max v_attr <= sup then
	      	(Fd.subst b 1; true)
	      else
		false
	end
    | Val _ -> Fcl_debug.internal_error "Interval.cstr#update" in (* update *)

  Fcl_cstr.create ~init:init ~name:"Interval.cstr" update delay

let is_member v inf sup =
  let b = Fd.create Fcl_domain.boolean in
  Fcl_cstr.post (cstr v inf sup b);
  b;;