When the default empty-range value is an identity value for the binary operation, i.e.
Def is_ident(A; f; u) == x:A. f(u,x) = x & f(x,u) = x
which incidentally is }
}
}
Thm* f:(A
A
A), u:A.
Thm* is_ident(A; f; u)
Thm*![]()
Thm* is_assoc_sep(A; f)
Thm*![]()
Thm* (a,c,b:
, e:({a..b
}
A).
Thm* (ac
Thm* (![]()
Thm* (cb
Thm* (![]()
Thm* ((Iter(f;u) i:{a..b}. e(i))
Thm* (=
Thm* (f((Iter(f;u) i:{a..c}. e(i)),Iter(f;u) i:{c..b
}. e(i)))
If the binary operation, in addition to having an identity and being associative, is commutative,
Def is_commutative_sep(A; f) == is_commutative(A; x,z.(f(x,z)))
then iterations over two sets of values, }
A
A
A
A
Thm* f:(A
A
A), u:A.
Thm* is_commutative_sep(A; f)
Thm*![]()
Thm* is_ident(A; f; u)
Thm*![]()
Thm* is_assoc_sep(A; f)
Thm*![]()
Thm* (a,b:
, e,g:({a..b
}
A).
Thm* (f((Iter(f;u) i:{a..b}. e(i)),Iter(f;u) i:{a..b
}. g(i))
Thm* (=
Thm* ((Iter(f;u) i:{a..b}. f(e(i),g(i)))
Thm* (A)
About:
![]() | ![]() | ![]() | ![]() | ![]() | ![]() | ![]() | ![]() | ![]() | ![]() |