on force l'annotation sur le OU
This commit is contained in:
parent
cd7749fe34
commit
b1ccb0ad71
25
affichage.ml
25
affichage.ml
@ -19,7 +19,6 @@ let rec string_of_ty = function
|
|||||||
let s1 = string_of_ty t1 in
|
let s1 = string_of_ty t1 in
|
||||||
let s2 = string_of_ty t2 in
|
let s2 = string_of_ty t2 in
|
||||||
"(" ^ s1 ^ " \\/ " ^ s2 ^ ")"
|
"(" ^ s1 ^ " \\/ " ^ s2 ^ ")"
|
||||||
| Unknown -> "Unknown"
|
|
||||||
|
|
||||||
let rec string_of_expr = function
|
let rec string_of_expr = function
|
||||||
Fun ((s, t), e) ->
|
Fun ((s, t), e) ->
|
||||||
@ -35,10 +34,14 @@ let rec string_of_expr = function
|
|||||||
"exf (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
"exf (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
| Pair (e1, e2) ->
|
| Pair (e1, e2) ->
|
||||||
"("^(string_of_expr e1)^", "^(string_of_expr e2)^")"
|
"("^(string_of_expr e1)^", "^(string_of_expr e2)^")"
|
||||||
| Left e ->
|
| Left (e, t) ->
|
||||||
"l("^(string_of_expr e)^")"
|
let s_e = string_of_expr e in
|
||||||
| Right e ->
|
let s_ty = string_of_ty t in
|
||||||
"r("^(string_of_expr e)^")"
|
"l (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
|
| Right (e, t) ->
|
||||||
|
let s_e = string_of_expr e in
|
||||||
|
let s_ty = string_of_ty t in
|
||||||
|
"r (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
|
|
||||||
let rec string_of_hlam = function
|
let rec string_of_hlam = function
|
||||||
HFun ((s, t), e) ->
|
HFun ((s, t), e) ->
|
||||||
@ -54,10 +57,14 @@ let rec string_of_hlam = function
|
|||||||
"exf (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
"exf (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
| HPair (e1, e2) ->
|
| HPair (e1, e2) ->
|
||||||
"("^(string_of_hlam e1)^", "^(string_of_hlam e2)^")"
|
"("^(string_of_hlam e1)^", "^(string_of_hlam e2)^")"
|
||||||
| HLeft e ->
|
| HLeft (e, t) ->
|
||||||
"l("^(string_of_hlam e)^")"
|
let s_e = string_of_hlam e in
|
||||||
| HRight e ->
|
let s_ty = string_of_ty t in
|
||||||
"r("^(string_of_hlam e)^")"
|
"l (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
|
| HRight (e, t) ->
|
||||||
|
let s_e = string_of_hlam e in
|
||||||
|
let s_ty = string_of_ty t in
|
||||||
|
"r (" ^ s_e ^ " : " ^ s_ty ^ ")"
|
||||||
| Ref e ->
|
| Ref e ->
|
||||||
"{"^(string_of_hlam !e)^"}"
|
"{"^(string_of_hlam !e)^"}"
|
||||||
| Hole -> "?"
|
| Hole -> "?"
|
||||||
|
32
hlam.ml
32
hlam.ml
@ -8,8 +8,8 @@ type hlam = (* hollow lam *)
|
|||||||
| HVar of id
|
| HVar of id
|
||||||
| HExf of hlam * Types.ty
|
| HExf of hlam * Types.ty
|
||||||
| HPair of hlam * hlam
|
| HPair of hlam * hlam
|
||||||
| HLeft of hlam
|
| HLeft of hlam * Types.ty
|
||||||
| HRight of hlam
|
| HRight of hlam * Types.ty
|
||||||
| Ref of hlam ref
|
| Ref of hlam ref
|
||||||
| Hole
|
| Hole
|
||||||
|
|
||||||
@ -22,8 +22,8 @@ let clean_hlam assoc (h : hlam) : hlam =
|
|||||||
| HVar s -> HVar s
|
| HVar s -> HVar s
|
||||||
| HExf (h, t) -> HExf (clean h, t)
|
| HExf (h, t) -> HExf (clean h, t)
|
||||||
| HPair (h1, h2) -> HPair (clean h1, clean h2)
|
| HPair (h1, h2) -> HPair (clean h1, clean h2)
|
||||||
| HLeft h -> HLeft (clean h)
|
| HLeft (h, t) -> HLeft (clean h, t)
|
||||||
| HRight h -> HRight (clean h)
|
| HRight (h, t) -> HRight (clean h, t)
|
||||||
| Ref (hr) ->
|
| Ref (hr) ->
|
||||||
match List.assq_opt hr !assoc with
|
match List.assq_opt hr !assoc with
|
||||||
None -> let new_h = ref (clean !hr)
|
None -> let new_h = ref (clean !hr)
|
||||||
@ -49,12 +49,12 @@ let rec hlam_of_lam : lam -> hlam = function
|
|||||||
| Exf (e, t) ->
|
| Exf (e, t) ->
|
||||||
let e = hlam_of_lam e in
|
let e = hlam_of_lam e in
|
||||||
HExf (e, t)
|
HExf (e, t)
|
||||||
| Pair (l1, l2) ->
|
| Pair (e1, e2) ->
|
||||||
HPair (hlam_of_lam l1, hlam_of_lam l2)
|
HPair (hlam_of_lam e1, hlam_of_lam e2)
|
||||||
| Left l ->
|
| Left (e, t) ->
|
||||||
HLeft (hlam_of_lam l)
|
HLeft (hlam_of_lam e, t)
|
||||||
| Right l ->
|
| Right (e, t) ->
|
||||||
HRight (hlam_of_lam l)
|
HRight (hlam_of_lam e, t)
|
||||||
|
|
||||||
let rec lam_of_hlam : hlam -> lam = function
|
let rec lam_of_hlam : hlam -> lam = function
|
||||||
HFun ((x, t), e) ->
|
HFun ((x, t), e) ->
|
||||||
@ -68,11 +68,11 @@ let rec lam_of_hlam : hlam -> lam = function
|
|||||||
| HExf (e, t) ->
|
| HExf (e, t) ->
|
||||||
let e = lam_of_hlam e in
|
let e = lam_of_hlam e in
|
||||||
Exf (e, t)
|
Exf (e, t)
|
||||||
| HPair (h1, h2) ->
|
| HPair (e1, e2) ->
|
||||||
Pair (lam_of_hlam h1, lam_of_hlam h2)
|
Pair (lam_of_hlam e1, lam_of_hlam e2)
|
||||||
| HLeft h ->
|
| HLeft (e, t) ->
|
||||||
Left (lam_of_hlam h)
|
Left (lam_of_hlam e, t)
|
||||||
| HRight h ->
|
| HRight (e, t) ->
|
||||||
Right (lam_of_hlam h)
|
Right (lam_of_hlam e, t)
|
||||||
| Ref e_ref -> lam_of_hlam !e_ref
|
| Ref e_ref -> lam_of_hlam !e_ref
|
||||||
| Hole -> raise (TacticFailed "can not translate unclosed terms")
|
| Hole -> raise (TacticFailed "can not translate unclosed terms")
|
||||||
|
20
lam.ml
20
lam.ml
@ -8,8 +8,8 @@ type lam =
|
|||||||
| Var of id
|
| Var of id
|
||||||
| Exf of lam * Types.ty
|
| Exf of lam * Types.ty
|
||||||
| Pair of lam * lam
|
| Pair of lam * lam
|
||||||
| Left of lam
|
| Left of lam * Types.ty
|
||||||
| Right of lam
|
| Right of lam * Types.ty
|
||||||
|
|
||||||
(** alpha renaming in a deterministic way
|
(** alpha renaming in a deterministic way
|
||||||
if readable is set to true, original variable's names are used to rename *)
|
if readable is set to true, original variable's names are used to rename *)
|
||||||
@ -33,8 +33,8 @@ let alpha_convert ?(readable=false) (e : lam) : lam =
|
|||||||
| Var v -> Var (get_ren_var v g)
|
| Var v -> Var (get_ren_var v g)
|
||||||
| Exf (e, t) -> Exf (alpha_aux e g, t)
|
| Exf (e, t) -> Exf (alpha_aux e g, t)
|
||||||
| Pair (e1, e2) -> Pair (alpha_aux e1 g, alpha_aux e2 g)
|
| Pair (e1, e2) -> Pair (alpha_aux e1 g, alpha_aux e2 g)
|
||||||
| Left e -> Left (alpha_aux e g)
|
| Left (e, t) -> Left (alpha_aux e g, t)
|
||||||
| Right e -> Right (alpha_aux e g)
|
| Right (e, t) -> Right (alpha_aux e g, t)
|
||||||
in alpha_aux e []
|
in alpha_aux e []
|
||||||
|
|
||||||
|
|
||||||
@ -63,8 +63,8 @@ let rec subst (m : lam) (n : lam) (x : id) : lam =
|
|||||||
let e1 = subst e1 n x in
|
let e1 = subst e1 n x in
|
||||||
let e2 = subst e2 n x in
|
let e2 = subst e2 n x in
|
||||||
Pair (e1, e2)
|
Pair (e1, e2)
|
||||||
| Left e -> Left (subst e n x)
|
| Left (e, t) -> Left (subst e n x, t)
|
||||||
| Right e -> Right (subst e n x)
|
| Right (e, t) -> Right (subst e n x, t)
|
||||||
|
|
||||||
(* INVARIANT : e has already been alpha-converted *)
|
(* INVARIANT : e has already been alpha-converted *)
|
||||||
let rec betastep (e : lam) : lam option =
|
let rec betastep (e : lam) : lam option =
|
||||||
@ -100,15 +100,15 @@ let rec betastep (e : lam) : lam option =
|
|||||||
end
|
end
|
||||||
| Some e1 -> Some (Pair (e1, e2))
|
| Some e1 -> Some (Pair (e1, e2))
|
||||||
end
|
end
|
||||||
| Left e ->
|
| Left (e, t) ->
|
||||||
begin match betastep e with
|
begin match betastep e with
|
||||||
None -> None
|
None -> None
|
||||||
| Some e -> Some (Left e)
|
| Some e -> Some (Left (e, t))
|
||||||
end
|
end
|
||||||
| Right e ->
|
| Right (e, t) ->
|
||||||
begin match betastep e with
|
begin match betastep e with
|
||||||
None -> None
|
None -> None
|
||||||
| Some e -> Some (Right e)
|
| Some e -> Some (Right (e, t))
|
||||||
end
|
end
|
||||||
| Var _ -> None
|
| Var _ -> None
|
||||||
| Exf (e, t) ->
|
| Exf (e, t) ->
|
||||||
|
@ -73,10 +73,10 @@ expression:
|
|||||||
{ Exf (e, t) }
|
{ Exf (e, t) }
|
||||||
| LPAREN e1=expression COMMA e2=expression RPAREN
|
| LPAREN e1=expression COMMA e2=expression RPAREN
|
||||||
{ Pair(e1, e2) }
|
{ Pair(e1, e2) }
|
||||||
| L LPAREN e=expression RPAREN
|
| L LPAREN e=expression COLON t=ty RPAREN
|
||||||
{ Left(e) }
|
{ Left(e, t) }
|
||||||
| R LPAREN e=expression RPAREN
|
| R LPAREN e=expression COLON t=ty RPAREN
|
||||||
{ Right(e) }
|
{ Right(e, t) }
|
||||||
| e=app_expr { e }
|
| e=app_expr { e }
|
||||||
|
|
||||||
app_expr:
|
app_expr:
|
||||||
|
12
proof.ml
12
proof.ml
@ -199,10 +199,10 @@ let tact_right ((g, gs) : proof) : proof =
|
|||||||
None -> raise (TacticFailed "no current goal")
|
None -> raise (TacticFailed "no current goal")
|
||||||
| Some (h, goal_ty, cs) ->
|
| Some (h, goal_ty, cs) ->
|
||||||
match goal_ty with
|
match goal_ty with
|
||||||
| Or(_, t) ->
|
| Or(_, t_r) as t ->
|
||||||
let new_h = Ref (ref Hole) in
|
let new_h = Ref (ref Hole) in
|
||||||
fill h (HRight new_h);
|
fill h (HRight (new_h, t));
|
||||||
Some (new_h, t, cs), gs
|
Some (new_h, t_r, cs), gs
|
||||||
| _ -> raise (TacticFailed "Not a disjunction")
|
| _ -> raise (TacticFailed "Not a disjunction")
|
||||||
|
|
||||||
let tact_left ((g, gs) : proof) : proof =
|
let tact_left ((g, gs) : proof) : proof =
|
||||||
@ -210,10 +210,10 @@ let tact_left ((g, gs) : proof) : proof =
|
|||||||
None -> raise (TacticFailed "no current goal")
|
None -> raise (TacticFailed "no current goal")
|
||||||
| Some (h, goal_ty, cs) ->
|
| Some (h, goal_ty, cs) ->
|
||||||
match goal_ty with
|
match goal_ty with
|
||||||
| Or(t, _) ->
|
| Or(t_l, _) as t->
|
||||||
let new_h = Ref (ref Hole) in
|
let new_h = Ref (ref Hole) in
|
||||||
fill h (HLeft new_h);
|
fill h (HLeft (new_h, t));
|
||||||
Some (new_h, t, cs), gs
|
Some (new_h, t_l, cs), gs
|
||||||
| _ -> raise (TacticFailed "Not a disjunction")
|
| _ -> raise (TacticFailed "Not a disjunction")
|
||||||
|
|
||||||
let apply_tactic (p : proof) (t : tactic) : proof =
|
let apply_tactic (p : proof) (t : tactic) : proof =
|
||||||
|
1
types.ml
1
types.ml
@ -6,6 +6,5 @@ type ty =
|
|||||||
| And of ty * ty
|
| And of ty * ty
|
||||||
| Or of ty * ty
|
| Or of ty * ty
|
||||||
| Bot
|
| Bot
|
||||||
| Unknown (* for Or *)
|
|
||||||
|
|
||||||
type gam = (ty_id * ty) list
|
type gam = (ty_id * ty) list
|
||||||
|
37
typing.ml
37
typing.ml
@ -1,6 +1,8 @@
|
|||||||
open Types
|
open Types
|
||||||
open Lam
|
open Lam
|
||||||
|
|
||||||
|
exception Could_not_infer
|
||||||
|
|
||||||
let rec typecheck (g : gam) (e : lam) (expected_t : ty) : bool =
|
let rec typecheck (g : gam) (e : lam) (expected_t : ty) : bool =
|
||||||
match e with
|
match e with
|
||||||
Var x -> (List.assoc x g) = expected_t
|
Var x -> (List.assoc x g) = expected_t
|
||||||
@ -25,16 +27,17 @@ let rec typecheck (g : gam) (e : lam) (expected_t : ty) : bool =
|
|||||||
(typecheck g e1 t1) && (typecheck g e2 t2)
|
(typecheck g e1 t1) && (typecheck g e2 t2)
|
||||||
| _ -> false
|
| _ -> false
|
||||||
end
|
end
|
||||||
| Left e ->
|
| Left (e, t) when t = expected_t ->
|
||||||
begin match expected_t with
|
begin match expected_t with
|
||||||
Or (t, _) -> typecheck g e t
|
Or (t_l, _) -> typecheck g e t_l
|
||||||
| _ -> false
|
| _ -> false
|
||||||
end
|
end
|
||||||
| Right e ->
|
| Right (e, t) when t = expected_t ->
|
||||||
begin match expected_t with
|
begin match expected_t with
|
||||||
Or (_, t) -> typecheck g e t
|
Or (_, t_r) -> typecheck g e t_r
|
||||||
| _ -> false
|
| _ -> false
|
||||||
end
|
end
|
||||||
|
| Left _ | Right _ -> false
|
||||||
|
|
||||||
|
|
||||||
and typeinfer (g : gam) (e : lam) : ty =
|
and typeinfer (g : gam) (e : lam) : ty =
|
||||||
@ -49,19 +52,31 @@ and typeinfer (g : gam) (e : lam) : ty =
|
|||||||
Arr (t1, t2) ->
|
Arr (t1, t2) ->
|
||||||
if typecheck g e2 t1
|
if typecheck g e2 t1
|
||||||
then t2
|
then t2
|
||||||
else failwith "couldn't infer"
|
else raise Could_not_infer
|
||||||
| _ -> failwith "couldn't infer"
|
| _ -> raise Could_not_infer
|
||||||
end
|
end
|
||||||
| Exf (e, t) ->
|
| Exf (e, t) ->
|
||||||
if typecheck g e t
|
if typecheck g e t
|
||||||
then Bot
|
then Bot
|
||||||
else failwith "couldn't infer"
|
else raise Could_not_infer
|
||||||
| Pair (e1, e2) ->
|
| Pair (e1, e2) ->
|
||||||
And (
|
And (
|
||||||
typeinfer g e1,
|
typeinfer g e1,
|
||||||
typeinfer g e2
|
typeinfer g e2
|
||||||
)
|
)
|
||||||
| Left e ->
|
| Left (e, t) ->
|
||||||
Or (typeinfer g e, Unknown)
|
begin match t with
|
||||||
| Right e ->
|
Or (t_l, _) ->
|
||||||
Or (Unknown, typeinfer g e)
|
if typecheck g e t_l
|
||||||
|
then t
|
||||||
|
else raise Could_not_infer
|
||||||
|
| _ -> raise Could_not_infer
|
||||||
|
end
|
||||||
|
| Right (e, t) ->
|
||||||
|
begin match t with
|
||||||
|
Or (_, t_r) ->
|
||||||
|
if typecheck g e t_r
|
||||||
|
then t
|
||||||
|
else raise Could_not_infer
|
||||||
|
| _ -> raise Could_not_infer
|
||||||
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user