2014-08-25 02:58:48 +00:00
|
|
|
import logic
|
2014-07-07 16:31:42 +00:00
|
|
|
|
|
|
|
namespace algebra
|
|
|
|
inductive mul_struct (A : Type) : Type :=
|
2014-08-22 22:46:10 +00:00
|
|
|
mk_mul_struct : (A → A → A) → mul_struct A
|
2014-07-07 16:31:42 +00:00
|
|
|
|
|
|
|
definition mul [inline] {A : Type} {s : mul_struct A} (a b : A)
|
|
|
|
:= mul_struct_rec (λ f, f) s a b
|
|
|
|
|
|
|
|
infixl `*`:75 := mul
|
2014-08-07 23:59:08 +00:00
|
|
|
end algebra
|
2014-07-07 16:31:42 +00:00
|
|
|
|
|
|
|
namespace nat
|
|
|
|
inductive nat : Type :=
|
2014-08-22 22:46:10 +00:00
|
|
|
zero : nat,
|
|
|
|
succ : nat → nat
|
2014-07-07 16:31:42 +00:00
|
|
|
|
|
|
|
variable mul : nat → nat → nat
|
|
|
|
variable add : nat → nat → nat
|
|
|
|
|
|
|
|
definition mul_struct [instance] : algebra.mul_struct nat
|
|
|
|
:= algebra.mk_mul_struct mul
|
2014-08-07 23:59:08 +00:00
|
|
|
end nat
|
2014-07-07 16:31:42 +00:00
|
|
|
|
|
|
|
section
|
2014-09-03 23:00:38 +00:00
|
|
|
open algebra nat
|
2014-07-07 16:31:42 +00:00
|
|
|
variables a b c : nat
|
|
|
|
check a * b * c
|
2014-07-13 21:39:16 +00:00
|
|
|
definition tst1 : nat := a * b * c
|
2014-07-07 16:31:42 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
section
|
2014-09-03 23:00:38 +00:00
|
|
|
open [notation] algebra
|
|
|
|
open nat
|
|
|
|
-- check mul_struct nat << This is an error, we are open only the notation from algebra
|
2014-07-07 16:31:42 +00:00
|
|
|
variables a b c : nat
|
|
|
|
check a * b * c
|
2014-07-13 21:39:16 +00:00
|
|
|
definition tst2 : nat := a * b * c
|
2014-07-07 16:31:42 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
section
|
2014-09-03 23:00:38 +00:00
|
|
|
open nat
|
|
|
|
-- check mul_struct nat << This is an error, we are open only the notation from algebra
|
2014-07-07 16:31:42 +00:00
|
|
|
variables a b c : nat
|
|
|
|
check #algebra a*b*c
|
2014-07-13 21:39:16 +00:00
|
|
|
definition tst3 : nat := #algebra a*b*c
|
2014-07-07 16:31:42 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
section
|
2014-09-03 23:00:38 +00:00
|
|
|
open nat
|
2014-07-13 21:39:16 +00:00
|
|
|
set_option pp.implicit true
|
2014-07-07 16:31:42 +00:00
|
|
|
definition add_struct [instance] : algebra.mul_struct nat
|
|
|
|
:= algebra.mk_mul_struct add
|
|
|
|
|
|
|
|
variables a b c : nat
|
2014-09-03 23:00:38 +00:00
|
|
|
check #algebra a*b*c -- << is open add instead of mul
|
2014-07-13 21:39:16 +00:00
|
|
|
definition tst4 : nat := #algebra a*b*c
|
2014-07-07 16:31:42 +00:00
|
|
|
end
|