Skip to content

winitzki/sofp

Repository files navigation

License GitHub release SOFP build status

The Science of Functional Programming

This is the official source repository for the new book The Science of Functional Programming: A tutorial, with examples in Scala.

Book cover

The book is a tutorial exposition of the theoretical knowledge that functional programmers need. The material is developed from first principles and contains complete explanations, derivations, and proofs of almost all required results.

Discussions about the book

Discuss the book on github

Related video presentations

What I learned about functional programming while writing a book about it (extended version)

Explaining "theorems for free" and parametricity

Explaining Curry-Howard correspondence

What did functional programming ever do for us

Reasoning about types and code illustrates some of the topics and methods of this book.

What did category theory ever do for us (functional programmers)

Parametricity properties of purely functional code

Playlist: Functional programming tutorials contains audio recordings with slides. The tutorials show an early version of the material in this book. Many notations and explanations have been revised and improved when writing up the text of the book.

Source code and PDF files

The book is published under the GNU Free Documentation License. Permission is granted to copy, distribute and/or modify this book under the terms of that license. For those unfamiliar with the GNU FDL: this means the book is free (as in "freedom") -- free to use, to copy, to modify, and to distribute -- and will stay free forever, because any modified copy must have full modified sources distributed under the same license.

This git repository contains the full source code for the book (LyX / LaTeX / jpg / pdf) and shell scripts for building a PDF version of the book. So, this is a "transparent" copy in the sense of the GNU license; the source code of the book is in a format that is convenient to use and to modify.

The "Releases" section of this repository contains (under "Assets") the full uncorrected draft (sofp.pdf) and the finished and proof-read part of the draft (sofp-draft.pdf). The latest release is GitHub release and represents the most recent, relatively stable version of the text.

The PDF version of the most recent master branch of the book can be downloaded by following the link to the PDF builds, clicking on the latest PDF build, and then clicking on "PDF files and LaTeX logs". Note that you need to be logged in to github in order to download files.

This repository also contains the slides for YouTube presentations that initiated the work on this book. The talk slides are not part of the book and are partially obsolete both in content and in the notation used.

Current status of the book

Chapters 1-12 and 14, as well as appendices and discussion chapters are ready after a second proofreading of the draft.

Chapter 13 remains under construction. It is the last chapter to be written. After that, the book will be ready for general release.

Leanpub version of the draft

The draft version is available for purchase on leanpub for people who want to be notified about updates.

Printed version of the draft

A printed version of the current draft can be purchased at lulu.com.

This printed version contains only the chapters whose text has been edited and proofread. It corresponds to the PDF file sofp-draft.pdf (see the "Releases / Assets" section of github).

Readers are invited to create github issues in this repository and comment if they find something not clearly explained or wrong in the book, or if they wish to make comments or suggestions regarding the contents of the book.

Roadmap

  • Milestone 1 (achieved as of August 2019): chapters 1-6 are completed and available for purchase at lulu.com as a cheap (black/white) paperback.
  • Milestone 2 (achieved as of December 2019): chapters 1-9 are completed.
  • Milestone 3 (achieved as of November 2020): chapters 10 and 14 are completed.
  • Milestone 4 (achieved in 2021): chapters 1-12 and 14 are completed.
  • Milestone 5 (ETA: June 2023): the book is finished and available for on-demand printing at lulu.com or elsewhere.

About

A free book: "The Science of Functional Programming"

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages