4ef58f1ba5
Make zero and one reducible (see algebra/port.md) Change some theorems which need to compute into definitions
1.2 KiB
1.2 KiB
We port a lot of algebra files from the standard library to the HoTT library.
Port instructions:
- use the script port.pl in scripts/ to port the file. e.g. execute the following in the
scripts
folder:./port.pl ../library/algebra/lattice.lean ../hott/algebra/lattice.hlean
- remove imports starting with
data.
orlogic.
(sometimes you need to replace adata.
import by the correspondingtypes.
import) - Open namespaces
eq
andalgebra
if needed - (optional) add option
set_option class.force_new true
- fix all remaining errors. Typical errors include
- Replacing "and" by "prod" in comments
- and.intro is replaced by prod.intro, which should be prod.mk.
Currently, the following differences exist between the two libraries, relevant to porting:
- All of the algebraic hierarchy is in the algebra namespace in the HoTT library (on top-level in the standard library).
- The projections "zero" and "one" are reducible in HoTT. This was needed to allow type class inferences to infer
H : is_trunc 0 A |- is_trunc (succ (-1)) A
H : is_trunc 1 A |- is_trunc (succ 0) A
- Projections of most algebraic structures are definitions instead of theorems in HoTT
- Basic properties of
nat.add
have a simpler proof in HoTT (so that it computes better)