2014-07-07 19:40:00 +00:00
|
|
|
import logic
|
|
|
|
|
|
|
|
namespace N1
|
2014-10-02 23:20:52 +00:00
|
|
|
constant num : Type.{1}
|
|
|
|
constant foo : num → num → num
|
2014-08-07 23:59:08 +00:00
|
|
|
end N1
|
2014-07-07 19:40:00 +00:00
|
|
|
|
|
|
|
namespace N2
|
2014-10-02 23:20:52 +00:00
|
|
|
constant val : Type.{1}
|
|
|
|
constant foo : val → val → val
|
2014-08-07 23:59:08 +00:00
|
|
|
end N2
|
2014-07-07 19:40:00 +00:00
|
|
|
|
2014-09-03 23:00:38 +00:00
|
|
|
open N1
|
|
|
|
open N2
|
2014-10-02 23:20:52 +00:00
|
|
|
constants a b : num
|
|
|
|
constants x y : val
|
2014-07-07 19:40:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
check foo a b
|
|
|
|
check foo x y
|
|
|
|
|
2014-10-02 23:20:52 +00:00
|
|
|
constant f : num → val
|
2014-07-07 19:40:00 +00:00
|
|
|
coercion f
|
|
|
|
|
|
|
|
check foo a x
|
|
|
|
check foo x y
|
|
|
|
check foo x a
|
|
|
|
|
|
|
|
check foo a b
|
|
|
|
theorem T1 : foo a b = N1.foo a b
|
2014-09-04 23:36:06 +00:00
|
|
|
:= eq.refl _
|
2014-07-07 19:40:00 +00:00
|
|
|
|
2014-08-19 01:24:08 +00:00
|
|
|
definition aux1 := foo a b -- System elaborated it to N1.foo a b
|
|
|
|
#erase_cache T2
|
|
|
|
theorem T2 : aux1 = N1.foo a b
|
2014-09-04 23:36:06 +00:00
|
|
|
:= eq.refl _
|
2014-07-07 19:40:00 +00:00
|
|
|
|
2014-09-03 23:00:38 +00:00
|
|
|
open N1
|
2014-08-19 01:24:08 +00:00
|
|
|
definition aux2 := foo a b -- Now N1 is in the end of the queue, this is elaborated to N2.foo (f a) (f b)
|
2014-07-07 19:40:00 +00:00
|
|
|
check aux2
|
|
|
|
|
2014-08-19 01:24:08 +00:00
|
|
|
theorem T3 : aux2 = N2.foo (f a) (f b)
|
2014-09-04 23:36:06 +00:00
|
|
|
:= eq.refl aux2
|
2014-07-07 19:40:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
check foo a b
|
2014-08-26 04:39:46 +00:00
|
|
|
theorem T4 : foo a b = N2.foo a b
|
2014-09-04 23:36:06 +00:00
|
|
|
:= eq.refl _
|