first commit
This commit is contained in:
commit
6a52aa8da8
51
README.md
Normal file
51
README.md
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
# Collatz Conjecture
|
||||||
|
|
||||||
|
Collatz Conjecture (Snowflake / `3n+1`) done in the GHC Type System.
|
||||||
|
|
||||||
|
## Running
|
||||||
|
|
||||||
|
in `ghci` load the file:
|
||||||
|
|
||||||
|
```
|
||||||
|
:load collatz.hs
|
||||||
|
```
|
||||||
|
|
||||||
|
and run with the following:
|
||||||
|
|
||||||
|
```
|
||||||
|
:t solution (nil :: X)
|
||||||
|
```
|
||||||
|
|
||||||
|
where `X` is the church encoding using `S n` and `Z`, ie
|
||||||
|
|
||||||
|
`(S (S (S Z)))` is the number `3`
|
||||||
|
|
||||||
|
## Example
|
||||||
|
|
||||||
|
```
|
||||||
|
*Main> :t solution (nil :: (S (S (S Z))))
|
||||||
|
solution (nil :: (S (S (S Z))))
|
||||||
|
:: Cons
|
||||||
|
(S (S (S Z)))
|
||||||
|
(Cons
|
||||||
|
(S (S (S (S (S (S (S (S (S (S Z))))))))))
|
||||||
|
(Cons
|
||||||
|
(S (S (S (S (S Z)))))
|
||||||
|
(Cons
|
||||||
|
(S (S (S (S (S (S (S (S (S (S (S (S (S (S (S (S Z))))))))))))))))
|
||||||
|
(Cons
|
||||||
|
(S (S (S (S (S (S (S (S Z))))))))
|
||||||
|
(Cons
|
||||||
|
(S (S (S (S Z))))
|
||||||
|
(Cons
|
||||||
|
(S (S Z))
|
||||||
|
(Cons
|
||||||
|
(S Z)
|
||||||
|
Nil)))))))
|
||||||
|
```
|
||||||
|
|
||||||
|
which translates to the following list:
|
||||||
|
|
||||||
|
```
|
||||||
|
[ 3 10 5 16 8 4 2 1 ]
|
||||||
|
```
|
97
collatz.hs
Normal file
97
collatz.hs
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
{-# OPTIONS_GHC -fno-warn-missing-methods #-}
|
||||||
|
{-# LANGUAGE MultiParamTypeClasses #-}
|
||||||
|
{-# LANGUAGE FunctionalDependencies #-}
|
||||||
|
{-# LANGUAGE FlexibleInstances #-}
|
||||||
|
{-# LANGUAGE UndecidableInstances #-}
|
||||||
|
|
||||||
|
nil = undefined
|
||||||
|
|
||||||
|
data True
|
||||||
|
data False
|
||||||
|
|
||||||
|
data S n
|
||||||
|
data Z
|
||||||
|
|
||||||
|
data Nil
|
||||||
|
data Cons h t
|
||||||
|
|
||||||
|
class Not t b | t -> b
|
||||||
|
instance Not True False
|
||||||
|
instance Not False True
|
||||||
|
|
||||||
|
class And a b r | a b -> r
|
||||||
|
instance And True True True
|
||||||
|
instance And True False False
|
||||||
|
instance And False True False
|
||||||
|
instance And False False False
|
||||||
|
|
||||||
|
class Equal a b t | a b -> t
|
||||||
|
instance Equal Z Z True
|
||||||
|
instance Equal (S a) Z False
|
||||||
|
instance Equal Z (S b) False
|
||||||
|
instance (Equal a b t)
|
||||||
|
=> Equal (S a) (S b) t
|
||||||
|
|
||||||
|
class Add x y r | x y -> r
|
||||||
|
instance Add x Z x
|
||||||
|
instance (Add (S x) n r)
|
||||||
|
=> Add x (S n) r
|
||||||
|
|
||||||
|
class Mul x y a r | x y a -> r
|
||||||
|
instance Mul x Z a a
|
||||||
|
instance Mul Z y a a
|
||||||
|
instance (Add x a n, Mul x y n t)
|
||||||
|
=> Mul x (S y) a t
|
||||||
|
|
||||||
|
class Half x a r | x a -> r
|
||||||
|
instance Half Z a a
|
||||||
|
instance Half (S Z) a a
|
||||||
|
instance (Half n (S a) r)
|
||||||
|
=> Half (S (S n)) a r
|
||||||
|
|
||||||
|
class ThreeEnPlusOne x v | x -> v
|
||||||
|
instance (Mul (S (S (S Z))) x Z i)
|
||||||
|
=> ThreeEnPlusOne x (S i)
|
||||||
|
|
||||||
|
class If c t f r | c t f -> r
|
||||||
|
instance If True t f t
|
||||||
|
instance If False t f f
|
||||||
|
|
||||||
|
class EqOne x r | x -> r
|
||||||
|
instance (Equal x (S Z) b)
|
||||||
|
=> EqOne x b
|
||||||
|
|
||||||
|
class IsEven a b | a -> b
|
||||||
|
instance IsEven Z True
|
||||||
|
instance IsEven (S Z) False
|
||||||
|
instance (IsEven n r)
|
||||||
|
=> IsEven (S (S n)) r
|
||||||
|
|
||||||
|
class IsOdd a b | a -> b
|
||||||
|
instance (IsEven a i, Not i r)
|
||||||
|
=> IsOdd a r
|
||||||
|
|
||||||
|
class Branch b h n | b h -> n
|
||||||
|
instance (Half h Z r)
|
||||||
|
=> Branch True h r
|
||||||
|
instance (ThreeEnPlusOne h r)
|
||||||
|
=> Branch False h r
|
||||||
|
|
||||||
|
class RunChain b h t r | b h t -> r
|
||||||
|
instance RunChain True h xs xs
|
||||||
|
instance ( IsEven h e
|
||||||
|
, EqOne h b
|
||||||
|
, Branch e h v
|
||||||
|
, RunChain b v (Cons h t) r
|
||||||
|
)
|
||||||
|
=> RunChain False h t r
|
||||||
|
|
||||||
|
class Reverse i l r | i l -> r
|
||||||
|
instance Reverse i Nil i
|
||||||
|
instance (Reverse (Cons x i) xs r)
|
||||||
|
=> Reverse i (Cons x xs) r
|
||||||
|
|
||||||
|
class Solution n r | n -> r
|
||||||
|
where solution :: n -> r
|
||||||
|
instance (RunChain False n Nil o, Reverse Nil o a)
|
||||||
|
=> Solution n a where solution = nil
|
Loading…
Reference in a new issue