2014-05-20 12:17:16 -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)
|
2014-07-22 09:43:18 -07:00
|
|
|
local U_l1 = mk_sort(max_univ(l, 1)) -- Make sure U_l1 is not Prop
|
2014-05-20 12:17:16 -07:00
|
|
|
local A = Local("A", U_l)
|
|
|
|
local list_l = Const("list", {l})
|
|
|
|
|
|
|
|
local env1 = add_inductive(env,
|
|
|
|
"list", {l}, 1, Pi(A, U_l1),
|
|
|
|
"nil", Pi(A, list_l(A)),
|
|
|
|
"cons", Pi(A, mk_arrow(A, list_l(A), list_l(A))))
|
|
|
|
|
2014-09-04 15:03:59 -07:00
|
|
|
display_type(env1, Const({"list", "rec"}, {1, 1}))
|
2014-05-20 12:17:16 -07:00
|
|
|
|
|
|
|
-- Slightly different definition where A : Type.{l} is an index
|
|
|
|
-- instead of a global parameter
|
|
|
|
local U_sl = mk_sort(succ_univ(l))
|
|
|
|
local env2 = add_inductive(env,
|
|
|
|
"list", {l}, 0, Pi(A, U_sl), -- The resultant type must live in the universe succ(l)
|
|
|
|
"nil", Pi(A, list_l(A)),
|
|
|
|
"cons", Pi(A, mk_arrow(A, list_l(A), list_l(A))))
|
2014-09-04 15:03:59 -07:00
|
|
|
display_type(env2, Const({"list", "rec"}, {1, 1}))
|