What is this about?
On the last decade, functional programming has gained a new found power due to its declarative characteristics which, some would say, are very effective for parallel computing and for the whole usage of Moores Law.
Table of Contents
- Personal thoughts on the current functional programming bandwagon
Despite the name, this post actually clarifies some baisc concepts on Functional Programming, explains some of the History of FP and the implementation of FPs features on imperative languages and talks about all the fuss on declarative programming and why it has become so popular in the last few years.
- A Monad in Practicality – Controlling Time
- A Monad in Practicality – First Class Failures
- How to desugar Haskell Code
- Functors, Applicatives, And Monads In Pictures
- Monads Made Difficult
- Your easy guide to Monads, Applicatives, & Functors
- Tradeoffs between Unique Types and Monads
- The implementation of Functional Programming Languages – A paper by Simon Peyton Jones
- Sound and Decidable Type Inference for Functional Dependencies – Another very famous paper on Type Inference by the main creator of Haskell and GHC
- Template Meta-Programming for Haskell – Paper about generating code at compile-time in Haskell
- Why Functional Programming Matters
- From Higher-Order Logic to Haskell: There and Back Again
- Translating Haskell to Isabelle
- nLab – A wiki-lab with articles, discussion and tools from the point of view of category theory, which is the main math behind FP.
- Haskell/Category Theory – A good overview on Category Theory applied to Haskell from Wikibooks.
- Haskell Wiki
- The Little Prover – Talks about
a theorem prover called JBob for writing proofs in LISP.
- Isabelle/HOL – A Proof Assistant for Higher-Order Logic – A Book on implementing logical formalisms in Isabelle/HOL.
- The Little MLer – A book focused on teaching types, recursive thinking and other important subjects in Standard ML.
- Introduction to Programming using SML – Introduces you to programming design in a very mathematical way.
- How to Design Programs / Second Edition
- Introduction to Functional Programming
- Haskell in Depth – the perfect second book on Haskell which dives into examples and application scenarios designed to teach how Haskell works and how to apply it correctly.
- Grokking Simplicity: Taming complex software with functional thinking – Teaches functional programming from first principles using real-world scenarios.
- Lambda the Ultimate – Community focused on discussing researches, papers
and hot topic on academia. Very high tech discussion level.
- FP Complete – Community focused on helping companies and students on learning and implementing Functional Programming in Haskell. Hosters of one of the most famous Haskell learning centers: School of Haskell
- Haskellers – The meeting point for Haskell Programmers
- ElixirLangMoscow – Russian Elixir community
Discussions (Quora, Stack Overflow, Reddit, etc)
- Dont fear the Monad – Explanation on
one of the most obscure topics of Functional Programming by Microsoft researcher Brian Beckman.
- Haskell is useless – Simon Peyton Jones being
just too humble about his creation.
- Brian Beckman: The Zen of Stateless State
- Erik Meijer: Functional Programming
- Scala Monads: Declutter Your Code With Monadic Design
- Philip Wadler and Erik Meijer: On Programming Language Theory and Practice
- Kotlin for Android & Java Developers – LiveVideo course about Kotlin: functional programming, object orientation and building an Android app in Kotlin.
- C9 Lectures: Dr. Erik Meijer – Functional Programming Fundamentals – Series of Lectures from one of the creators of Haskell
- Adventure with types in Haskell – Simon Peyton Jones – Lectures about Haskells strong Type System by Simon Peyton Jones.
- The Algebra of Algebraic Data Types – Very good explanation
on the relationship between math and Algebraic Data Types, which is the Type System of some very common FP Languages such as Haskell and ML.
- [Paqmind.com] – Guides and challenges to learn and improve in programming. All content is CS and FP oriented.
- Isabelle/HOL – Generic proof assistant based on Higher Order Logic
- Idris Koans – Project for teaching Idris. A General Purpose Functional Programming with Dependent Types
- J-Bob – The proof assistant from the book
The Little Prover
- Haskell Must Watch – A list of videos, talks and courses on Haskell.
- Intro SML – Code, corrections and info on the book:
Introduction to Programming using SML
- Functional Programming Jargon – Project for providing a glossary for FP, and make learning FP easier.
- Bow – Companion library for Typed Functional Programming in Swift.
- Parsing With Haskell Parser Combinators – A step-by-step guide to parsing using Haskell parser combinators.
- Simon Peyton Jones – One of the creators of the Haskell Language and the Glasgow Haskell Compiler. Microsoft Researcher.
- Philip Wadler – Professor of Theoretical Computer Science at the University of Edinburgh, author of the famous paper Propositions as Types. One of the main people behind Java Generics Types.
- Matthias Felleisen – Author of many books such as How to Design Programs, and The Little Schemer.
- Erik Meijer – Former software architect for Microsoft, Functional Programming researcher, gives lectures on FP, Software Design and Reactive programming.
- Brian Beckman – Former Microsoft Researcher, actual Software Engineer at Amazon. Contributed to implementing FP features to inumerous Microsoft technologies such as C#, LINQ and F#