1
1
mirror of https://github.com/idris-lang/Idris2.git synced 2025-01-07 16:26:51 +03:00
Idris2/tests/idris2/perf004/bigdpair.idr
2021-01-21 11:33:03 +00:00

31 lines
575 B
Idris

import Data.Vect
MkBig : Nat -> Type
MkBig Z = Int
MkBig (S k) = ((n ** Vect n Int), MkBig k)
bigEx : (n : Nat) -> MkBig n
bigEx Z = 94
bigEx (S k) = ((2 ** [0,0]), bigEx k)
data VWrap : Type -> Type where
MkVWrap : (0 n : Nat) -> Vect n a -> VWrap a
export
MkBig' : Nat -> Type
MkBig' Z = Int
MkBig' (S k) = (VWrap Int, MkBig' k)
namespace Foo
public
export
bigEx' : (n : Nat) -> MkBig' n
bigEx' Z = 94
bigEx' (S k) = (MkVWrap 1 [0], bigEx' k)
eqBigs : bigEx 1000000 = bigEx 1000000
eqBigs = Refl
eqBigs' : bigEx' 800000 = bigEx' 800000
eqBigs' = Refl