summaryrefslogtreecommitdiff
path: root/080_blog/00040_Haskell-Projects/00120_Lambda-Calculus
diff options
context:
space:
mode:
authorMiguel <m.i@gmx.at>2019-03-07 23:26:17 +0100
committerMiguel <m.i@gmx.at>2019-03-07 23:26:17 +0100
commit52f86ea0075c66e18e4796ad88f45541da8b4de5 (patch)
treea7dcdb140e49ca13ed2315970e3b86e0c6fb9ef3 /080_blog/00040_Haskell-Projects/00120_Lambda-Calculus
parenta9e55a351753af1cfdeb75bdf50ecfd80de129c0 (diff)
some cleanup and such
Diffstat (limited to '080_blog/00040_Haskell-Projects/00120_Lambda-Calculus')
-rw-r--r--080_blog/00040_Haskell-Projects/00120_Lambda-Calculus/index.md38
1 files changed, 0 insertions, 38 deletions
diff --git a/080_blog/00040_Haskell-Projects/00120_Lambda-Calculus/index.md b/080_blog/00040_Haskell-Projects/00120_Lambda-Calculus/index.md
deleted file mode 100644
index 25c6b83..0000000
--- a/080_blog/00040_Haskell-Projects/00120_Lambda-Calculus/index.md
+++ /dev/null
@@ -1,38 +0,0 @@
-Lambda Calculus
-===============
-
- May 2, 2018
-
-Playing with Type Quantifiers and Haskell's Rank 2 Type Polymorphsim,
-implementing Boolean logic from scratch. We use the conventional
-definitions for `True` an `False` also known as Church booleans, after Alonzo Church, who
-intruced them along Lambda Calculus in the 1930s [1].
-
-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.haskell .numberLines}
-{-# LANGUAGE Rank2Types #-}
-
-fTrue :: forall a. a->a->a
-fTrue x y = x
-
-fFalse :: forall a. a->a->a
-fFalse x y = y
-
-fAnd :: (forall a. a->a->a)->(forall a. a->a->a)->(forall a. a->a->a)
-fAnd p q = p q p
-
-fOr :: (forall a. a->a->a)->(forall a. a->a->a)->(forall a. a->a->a)
-fOr p q = p p q
-
-fNot :: (forall a. a->a->a)->(forall a. a->a->a)
-fNot p = p fFalse fTrue
-
-ifThenElse :: (forall a. a->a->a)->(forall a. a->a->a)
- ->(forall a. a->a->a)->(forall a. a->a->a)
-ifThenElse p a b = p a b
-
--- Example --
-
-main = print $ (ifThenElse fFalse fFalse $ fAnd fTrue $ fNot fFalse) "T" "F"
-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
- [1] https://en.wikipedia.org/wiki/Lambda_calculus