SlideShare a Scribd company logo
Functional Programming
from First Principles
<v> := a|b|c|...|z
<e> := <v>|(<v> <e>)|(<e> <e>)
Presented by Melvin Zhang
melvin@melvinzhang.net
http://www.cosmiqo.com
http://magarena.github.io
Functional programming from first principles
Functional programming from first principles
http://www.ioccc.org/2012/tromp/tromp.c
John Tromp, https://tromp.github.io/
http://www.quotessays.com/bio/alonzo-church.html
http://www.princeton.edu/turing/alan/photos/
The Church-Turing thesis
Demo!
Functions are values.
Functions have no side effects.
May be lazy or eager.
May be untyped or typed.
Further readings
• Church’s Thesis and Functional Programming,
David Turner (2006)
• http://www.ioccc.org/2012/tromp/hint.html
• http://github.com/melvinzhang/binary-lambda-
calculus
http://www.meetup.com/Singapore-Clojure-Meetup/

More Related Content

PPT
Opening The Web
PDF
SXSW2013-Jenson
PDF
How Alan Turing accidentally invented Software
PDF
Solving the TSP for warehouses
PDF
Optimize all the things with MiniZinc
PDF
AMKSS Career Conference 2018: Software Engineering
PDF
Beating us at our own Games
PDF
Getting started with open source game playing AIs
Opening The Web
SXSW2013-Jenson
How Alan Turing accidentally invented Software
Solving the TSP for warehouses
Optimize all the things with MiniZinc
AMKSS Career Conference 2018: Software Engineering
Beating us at our own Games
Getting started with open source game playing AIs

More from Melvin Zhang (13)

PDF
Programs that Play better than Us
PDF
Building a Turing Machine emulator to explore Turing's great ideas
PDF
Lessons from Developing an AI to Play Magic: The Gathering
PDF
Binary Lambda Calculus and Combinatory Logic
PDF
AMKSS Career Conference 2015: Programming
PDF
Building a state of the art AI to play Magic: The Gathering
PDF
Efficient Selectivity and Backup Operators in Monte-Carlo Tree Search
PDF
Quest for the optimal algorithm
PDF
Playing Games by Throwing Dice
PDF
Becoming a better problem solver: a CS perspective
PDF
Ortholog assignment
PDF
Building pipelines with Make
PDF
Opportunities in STEM
Programs that Play better than Us
Building a Turing Machine emulator to explore Turing's great ideas
Lessons from Developing an AI to Play Magic: The Gathering
Binary Lambda Calculus and Combinatory Logic
AMKSS Career Conference 2015: Programming
Building a state of the art AI to play Magic: The Gathering
Efficient Selectivity and Backup Operators in Monte-Carlo Tree Search
Quest for the optimal algorithm
Playing Games by Throwing Dice
Becoming a better problem solver: a CS perspective
Ortholog assignment
Building pipelines with Make
Opportunities in STEM
Ad

Recently uploaded (20)

PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PPTX
VVF-Customer-Presentation2025-Ver1.9.pptx
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
Digital Strategies for Manufacturing Companies
PDF
medical staffing services at VALiNTRY
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
Understanding Forklifts - TECH EHS Solution
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PPTX
Transform Your Business with a Software ERP System
PDF
AI in Product Development-omnex systems
PPTX
CHAPTER 2 - PM Management and IT Context
PPTX
Odoo POS Development Services by CandidRoot Solutions
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
Nekopoi APK 2025 free lastest update
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
How Creative Agencies Leverage Project Management Software.pdf
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
Internet Downloader Manager (IDM) Crack 6.42 Build 41
VVF-Customer-Presentation2025-Ver1.9.pptx
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
How to Choose the Right IT Partner for Your Business in Malaysia
How to Migrate SBCGlobal Email to Yahoo Easily
Digital Strategies for Manufacturing Companies
medical staffing services at VALiNTRY
Which alternative to Crystal Reports is best for small or large businesses.pdf
Understanding Forklifts - TECH EHS Solution
Navsoft: AI-Powered Business Solutions & Custom Software Development
Transform Your Business with a Software ERP System
AI in Product Development-omnex systems
CHAPTER 2 - PM Management and IT Context
Odoo POS Development Services by CandidRoot Solutions
2025 Textile ERP Trends: SAP, Odoo & Oracle
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
Nekopoi APK 2025 free lastest update
Ad

Functional programming from first principles