2014-05-22 14:09:36 -07:00
|
|
|
function display_type(env, t)
|
|
|
|
print(tostring(t) .. " : " .. tostring(env:normalize(env:type_check(t))))
|
|
|
|
end
|
|
|
|
|
|
|
|
local env = environment()
|
|
|
|
|
|
|
|
local l = param_univ("l")
|
|
|
|
local U_l = mk_sort(l)
|
|
|
|
local A = Local("A", U_l)
|
2014-07-22 09:43:18 -07:00
|
|
|
local R = Local("R", mk_arrow(A, A, Prop))
|
2014-05-22 14:09:36 -07:00
|
|
|
local x = Local("x", A)
|
|
|
|
local y = Local("y", A)
|
|
|
|
local Acc = Const("Acc", {l})
|
|
|
|
|
|
|
|
env = add_inductive(env,
|
2014-06-30 09:14:55 -07:00
|
|
|
"Acc", {l}, 2, Pi(A, R, x, mk_sort(l+1)),
|
|
|
|
"Acc_intro", Pi(A, R, x, mk_arrow(Pi(y, mk_arrow(R(y, x), Acc(A, R, y))), Acc(A, R, x))))
|
2014-05-22 14:09:36 -07:00
|
|
|
|
2014-06-13 08:26:05 -07:00
|
|
|
env = env:add_universe("u")
|
|
|
|
env = env:add_universe("v")
|
2014-05-22 14:09:36 -07:00
|
|
|
local u = global_univ("u")
|
|
|
|
local v = global_univ("v")
|
2014-09-04 15:03:59 -07:00
|
|
|
display_type(env, Const({"Acc", "rec"}, {v, u}))
|
2014-05-22 14:09:36 -07:00
|
|
|
|
|
|
|
-- well_founded_induction_type :
|
|
|
|
-- Pi (A : Type)
|
2014-07-22 09:43:18 -07:00
|
|
|
-- (R : A -> A -> Prop)
|
2014-05-22 14:09:36 -07:00
|
|
|
-- (R_is_wf : Pi (a : A), (Acc A R a))
|
|
|
|
-- (P : A -> Type)
|
|
|
|
-- (H : Pi (x : A) (Hr : Pi (y : A) (a : R y x), (P y)), (P x))
|
|
|
|
-- (a : A),
|
|
|
|
-- (P a)
|
|
|
|
local l1 = param_univ("l1")
|
|
|
|
local l2 = param_univ("l2")
|
|
|
|
local Acc = Const("Acc", {l1})
|
|
|
|
local Acc_intro = Const("Acc_intro", {l1})
|
2014-09-04 15:03:59 -07:00
|
|
|
local Acc_rec = Const({"Acc", "rec"}, {l2, l1})
|
2014-05-22 14:09:36 -07:00
|
|
|
local A = Local("A", mk_sort(l1))
|
2014-07-22 09:43:18 -07:00
|
|
|
local R = Local("R", mk_arrow(A, A, Prop))
|
2014-05-22 14:09:36 -07:00
|
|
|
local x = Local("x", A)
|
|
|
|
local y = Local("y", A)
|
|
|
|
local a = Local("a", A)
|
|
|
|
local P = Local("P", mk_arrow(A, mk_sort(l2)))
|
|
|
|
local Hr = Local("Hr", Pi(y, mk_arrow(R(y, x), P(y))))
|
2014-06-30 09:14:55 -07:00
|
|
|
local H = Local("H", Pi(x, Hr, P(x)))
|
2014-05-22 14:09:36 -07:00
|
|
|
local HR = Local("HR", R(y, x))
|
|
|
|
local HRa = Local("HRa", R(y, a))
|
2014-06-30 09:14:55 -07:00
|
|
|
local arg = Local("arg", Pi(y, HR, Acc(A, R, y)))
|
|
|
|
local H_arg = Local("H_arg", Pi(y, HR, P(y)))
|
2014-05-22 14:09:36 -07:00
|
|
|
local d = Local("d", Acc(A, R, x))
|
|
|
|
local Hwf = Local("R_is_wf", Pi(a, Acc(A, R, a)))
|
2014-06-30 09:14:55 -07:00
|
|
|
local wfi_th_type = Pi(A, R, Hwf, P, H, a, P(a))
|
2014-05-22 14:09:36 -07:00
|
|
|
print(wfi_th_type)
|
|
|
|
type_checker(env):check(wfi_th_type, {l1, l2})
|
2014-06-30 09:14:55 -07:00
|
|
|
local wfi_th_val = Fun(A, R, Hwf, P, H, a, Acc_rec(A, R,
|
|
|
|
Fun(x, d, P(x)), -- C
|
|
|
|
Fun(x, arg, H_arg, H(x, H_arg)), -- e_1
|
|
|
|
a,
|
|
|
|
Acc_intro(A, R, a, Fun(y, HRa, Hwf(y)))
|
2014-05-22 14:09:36 -07:00
|
|
|
))
|
|
|
|
print(env:normalize(type_checker(env):check(wfi_th_val, {l1, l2})))
|
|
|
|
env = add_decl(env, mk_definition("well_founded_induction_type", {l1, l2}, wfi_th_type, wfi_th_val))
|
|
|
|
display_type(env, Const("well_founded_induction_type", {1,1}))
|