mirror of
https://github.com/ilyakooo0/Idris-dev.git
synced 2024-11-10 15:16:54 +03:00
4d0a065f86
To "interface/implementation". Old syntax is still valid but gives a deprecation warning.
62 lines
1.3 KiB
Idris
62 lines
1.3 KiB
Idris
module Main
|
|
|
|
data Binary : Nat -> Type where
|
|
BEnd : Binary Z
|
|
BO : Binary n -> Binary (n + n)
|
|
BI : Binary n -> Binary (S (n + n))
|
|
|
|
implementation Show (Binary n) where
|
|
show (BO x) = show x ++ "0"
|
|
show (BI x) = show x ++ "1"
|
|
show BEnd = ""
|
|
|
|
data Parity : Nat -> Type where
|
|
Even : Parity (n + n)
|
|
Odd : Parity (S (n + n))
|
|
|
|
parity : (n:Nat) -> Parity n
|
|
parity Z = Even {n=Z}
|
|
parity (S Z) = Odd {n=Z}
|
|
parity (S (S k)) with (parity k)
|
|
parity (S (S (j + j))) | Even ?= Even {n=S j}
|
|
parity (S (S (S (j + j)))) | Odd ?= Odd {n=S j}
|
|
|
|
natToBin : (n:Nat) -> Binary n
|
|
natToBin Z = BEnd
|
|
natToBin (S k) with (parity k)
|
|
natToBin (S (j + j)) | Even = BI (natToBin j)
|
|
natToBin (S (S (j + j))) | Odd ?= BO (natToBin (S j))
|
|
|
|
intToNat : Int -> Nat
|
|
intToNat 0 = Z
|
|
intToNat x = if (x>0) then (S (intToNat (x-1))) else Z
|
|
|
|
main : IO ()
|
|
main = do putStr "Enter a number: "
|
|
x <- getLine
|
|
printLn (natToBin (fromInteger (cast x)))
|
|
|
|
---------- Proofs ----------
|
|
|
|
Main.natToBin_lemma_1 = proof
|
|
intros
|
|
rewrite plusSuccRightSucc j j
|
|
rewrite sym (plusSuccRightSucc j j)
|
|
trivial
|
|
|
|
|
|
parity_lemma_1 = proof
|
|
intros
|
|
rewrite sym (plusSuccRightSucc j j)
|
|
trivial
|
|
|
|
|
|
parity_lemma_2 = proof {
|
|
intro;
|
|
intro;
|
|
rewrite sym (plusSuccRightSucc j j);
|
|
trivial;
|
|
}
|
|
|
|
|