package lambdapi
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Proof assistant for the λΠ-calculus modulo rewriting
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      lambdapi-2.2.1.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=ba73f288e435130293408bd44732f1dfc5ec8a8db91c7453c9baf9c740095829
    
    
  sha512=f88bb92fdb8aee8add60588673040fac012b2eab17c2a1d529c4b7c795cf0e1a9168122dc19889f04a31bda2bb2cf820237cbbe7e319121618aba3d134381756
    
    
  doc/src/lambdapi.common/debug.ml.html
Source file debug.ml
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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180(** Helper functions for debugging. **) open Lplib open Base open Extra (** Printing functions. *) module D = struct let ignore : 'a pp = fun _ _ -> () let log_and_return logger el = logger el; el let log_and_raise logger exc = logger exc; raise exc let depth : int pp = fun ppf l -> for _i = 1 to l do out ppf " " done; out ppf "%d. " l let bool : bool pp = fun ppf b -> out ppf "%B" b let int : int pp = fun ppf i -> out ppf "%d" i let string : string pp = fun ppf s -> out ppf "\"%s\"" s let option : 'a pp -> 'a option pp = fun elt ppf o -> match o with | None -> out ppf "None" | Some x -> out ppf "Some(%a)" elt x let pair : 'a pp -> 'b pp -> ('a * 'b) pp = fun elt1 elt2 ppf (x1,x2) -> out ppf "%a,%a" elt1 x1 elt2 x2 let list : 'a pp -> 'a list pp = fun elt ppf l -> match l with | [] -> out ppf "[]" | x::l -> out ppf "[%a" elt x; let f x = out ppf "; %a" elt x in List.iter f l; out ppf "]" let array : 'a pp -> 'a array pp = fun elt ppf a -> let n = Array.length a in if n = 0 then out ppf "[]" else begin out ppf "[%a" elt a.(0); for i = 1 to n-1 do out ppf "; %a" elt a.(i) done; out ppf "]" end let map : (('key -> 'elt -> unit) -> 'map -> unit) -> 'key pp -> string -> 'elt pp -> string -> 'map pp = fun iter key sep1 elt sep2 ppf m -> let f k t = out ppf "%a%s%a%s" key k sep1 elt t sep2 in out ppf "["; iter f m; out ppf "]" let strmap : 'a pp -> 'a StrMap.t pp = fun elt -> map StrMap.iter string ", " elt "; " let intmap : 'a pp -> 'a IntMap.t pp = fun elt -> map IntMap.iter int ", " elt "; " let iter ?sep:(sep = Format.pp_print_cut) iter elt ppf v = let is_first = ref true in let elt v = if !is_first then (is_first := false) else sep ppf (); elt ppf v in iter elt v (* To be used in a hov (and not default) box *) let surround beg fin inside = fun fmt v -> out fmt "%s@;<0 2>@[<hv>%a@]@,%s" beg inside v fin let bracket inside = surround "[" "]" inside end (** Logging function for command handling. *) (* The two successive let-bindings are necessary for type variable generalisation purposes *) let log_hndl = Logger.make 'h' "hndl" "command handling" let log_hndl = log_hndl.pp (** [time_of f x] computes [f x] and prints the time for computing it. *) let time_of : string -> (unit -> 'b) -> 'b = fun s f -> if false && Logger.log_enabled () then begin let t0 = Sys.time () in let log _ = log_hndl "%s time: %f" s (Sys.time () -. t0) in try f () |> D.log_and_return log with e -> e |> D.log_and_raise log end else f () (** To record time with [record_time]. *) let do_record_time = ref false let do_print_time = ref true type task = | Lexing | Parsing | Scoping | Rewriting | Typing | Solving | Reading | Sharing | Writing let index = function | Lexing -> 0 | Parsing -> 1 | Scoping -> 2 | Rewriting -> 3 | Typing -> 4 | Solving -> 5 | Reading -> 6 | Sharing -> 7 | Writing -> 8 let nb_tasks = 9 let task_name ppf = function | 0 -> string ppf "lexing" | 1 -> string ppf "parsing" | 2 -> string ppf "scoping" | 3 -> string ppf "rewriting" | 4 -> string ppf "typing" | 5 -> string ppf "solving" | 6 -> string ppf "reading" | 7 -> string ppf "sharing" | 8 -> string ppf "writing" | _ -> assert false (** [record_time s f] records under [s] the time spent in calling [f]. [print_time ()] outputs the recorded times. *) let record_time, print_time = let tm = Float.Array.make nb_tasks 0.0 and call_stack = ref [] in let add_time task d = let i = index task in Float.Array.(set tm i (get tm i +. d)) in let record_time : task -> (unit -> unit) -> unit = fun task f -> if !do_record_time then begin let t0 = Sys.time () in call_stack := task::!call_stack; let end_task () = let d = Sys.time () -. t0 in call_stack := List.tl !call_stack; add_time task d; match !call_stack with | [] -> () | task::_ -> add_time task (-. d) in try f (); end_task () with e -> end_task (); raise e end else f () and print_time : float -> unit -> unit = fun t0 () -> if !do_record_time && !do_print_time then begin let total = Sys.time () -. t0 in Format.printf "total %.2fs" total; let task i d = Format.printf " %a %.2fs (%.0f%%)" task_name i d (100.0 *. d /. total) in Float.Array.iteri task tm; let d = total -. (Float.Array.fold_left (+.) 0.0 tm) in Format.printf " other %.2fs (%.0f%%)@." d (100.0 *. d /. total) end in record_time, print_time (** [stream_iter f s] is the same as [Stream.iter f s] but records the time in peeking the elements of the stream. *) let stream_iter : ('a -> unit) -> 'a Stream.t -> unit = if not !do_print_time then Stream.iter else fun f strm -> let peek strm = let r = ref None in record_time Parsing (fun () -> r := Stream.peek strm); !r in let rec do_rec () = match peek strm with Some a -> Stream.junk strm; ignore(f a); do_rec () | None -> () in do_rec ()
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >