GithubHelp home page GithubHelp logo

Domain-Specific Languages of Mathematics

GitHub repository for open source material related the book "Domain-Specific Languages of Mathematics" published in 2022 by College Publications (available from Adlibris.se, Amazon UK, Amazon.com.

The book and the repository are used in a BSc-level course at Chalmers and GU.

The main course homepage is in the Canvas LMS:

Course codes: DAT326 / DIT983

News

Contributors

  • Main author, examiner, lecturer: Patrik Jansson (patrikj AT)
  • First version (and continued support): Cezar Ionescu (cezar AT)
  • Book co-author: Jean-Philippe Bernardy
  • Teaching assistants:
    • 2024: Felix Cherubini (felixche AT), Freek Geerligs (geerligs AT), Rachel Samuelsson (lambda AT)
    • 2023: David Wärn (warnd AT), Felix Cherubini (felixche AT), Sikai Lu (sikai AT),
    • 2022: Sólrún Einarsdóttir (slrn AT), David Wärn (warnd AT), and Felix Cherubini (felixche AT)
    • 2021: Maximilian Algehed (algehed AT) and Víctor López Juan (lopezv AT)
    • 2020: Sólrún Einarsdóttir (slrn AT) and Víctor López Juan (lopezv AT)
    • 2019: Maximilian Algehed (algehed AT) and Abhiroop Sarkar (sarkara AT)
    • 2018: Daniel Schoepe (schoepe AT)
    • 2017: Frederik Hanghøj Iversen (hanghj AT student) and Daniel Schoepe (schoepe AT)
    • 2016: Irene Lobo Valbuena (lobo AT)
  • Project assistants: Daniel Heurlin, Sólrún Einarsdóttir, Adam Sandberg Ericsson (saadam AT)

where AT = @chalmers.se

Course material

This repository is mainly the home of the DSLsofMath book (originating from the course lecture notes), also available in print from Amazon.

Comments and contributions are always welcome – especially in the form of pull requests.

The main references are listed below.

Objectives

The course presents classical mathematical topics from a computing science perspective: giving specifications of the concepts introduced, paying attention to syntax and types, and ultimately constructing DSLs of some mathematical areas mentioned below.

Learning outcomes as in the course syllabus.

  • Knowledge and understanding
    • design and implement a DSL (Domain-Specific Language) for a new domain
    • organize areas of mathematics in DSL terms
    • explain main concepts of elementary real and complex analysis, algebra, and linear algebra
  • Skills and abilities
    • develop adequate notation for mathematical concepts
    • perform calculational proofs
    • use power series for solving differential equations
    • use Laplace transforms for solving differential equations
  • Judgement and approach
    • discuss and compare different software implementations of mathematical concepts

The course is elective for both computer science and mathematics students at both Chalmers and GU.

Course setup

  • Lectures
    • Introduction: Haskell, complex numbers, syntax, semantics, evaluation, approximation
    • Basic concepts of analysis: sequences, limits, convergence, ...
    • Types and mathematics: logic, quantifiers, proofs and programs, Curry–Howard, ...
      • Type classes, derivatives, differentiation, calculational proofs
    • Domain-Specific Languages and algebraic structures, algebras, homomorphisms
    • Polynomials, series, power series
    • Power series and differential equations, exp, sin, log, Taylor series, ...
    • Linear algebra: vectors, matrices, functions, bases, dynamical systems as matrices and graphs
    • Laplace transform: exp, powers series cont., solving PDEs with Laplace
  • Weekly exercise sessions
    • Half time helping students solve problems in small groups
    • Half time joint problem solving at the whiteboard

Lectures

The latest PDF snapshot of the book can be found in L/snapshots but please also consider buying the "real thing".

The "source code" for the chapters are in subdirectories of L/: L/01/, L/02/, etc. where chapter N is approximately course week N.

Exercises

Most chapters end with weekly exercises.

In L/RecEx.md you will find a list of recommended exercises for each chapter of the lecture notes.

Exams

The exams + solutions are available under the Exam/ subdirectory:

References

Some important references:

Functional programming

  • Thinking Functionally with Haskell, Richard Bird, Cambridge University Press, 2014 URL
  • Introduction to Functional Programming Using Haskell, Richard Bird, Prentice Hall, 1998. A previous (but clearly different) version of the above.
  • An Introduction to Functional Programming, Richard Bird and Phil Wadler, Prentice Hall, 1988. A previous (but clearly different) version of both of the above.

DSLs

  • Functional Programming for Domain-Specific Languages, Jeremy Gibbons. In Central European Functional Programming School 2015, LNCS 8606, 2015. URL

    This is currently the standard reference to DSLs for the functional programmer.

  • Folding Domain-Specific Languages: Deep and Shallow Embeddings, Jeremy Gibbons and Nicolas Wu, ICFP 2014. URL

    Available at the same link: a highly recommended short version and the two videos of Jeremy presenting the most important ideas of DSLs in a very accessible way.

  • Programming Languages, Mike Spivey. Lecture notes of a course given at the CS Department in Oxford. Useful material for understanding the design and implementation of embedded DSLs. URL

  • Domain-Specific Languages, Martin Fowler, 2011. URL

    The view from the object-oriented programming perspective.

The computer science perspective

  • Communicating Mathematics: Useful Ideas from Computer Science, Charles Wells, American Mathematical Monthly, May 1995. URL

    This article was one of the main triggers of this course.

    Short summary of the recommendations

Mathematics

  • The Language of First-Order Logic, 3rd Edition, Jon Barwise and John Etchemendy, 1993. Out of print, but you can get it for one penny from Amazon UK. A vast improvement over its successors (as Tony Hoare said about Algol 60).

  • Mathematics: Form and Function, Saunders Mac Lane, Springer 1986. An overview of the relationships between the many mathematical domains. Entertaining, challenging, rewarding. Fulltext from the library

  • Functional Differential Geometry, Gerald Jay Sussman and Jack Wisdom, 2013, MIT. A book about using programming as a means of understanding differential geometry. Similar in spirit to the course, but more advanced and very different in form. An earlier version appeared as an AIM report.

License: CC-BY-NC-SA 4.0

Creative Commons License
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.

dslsofmath's Projects

bscproj2022 icon bscproj2022

A proposal for a BSc thesis (group) project at Chalmers & UGOT. Domain Specific Languages for other courses.

bscproj2024 icon bscproj2024

A proposal for a BSc thesis (group) project at Chalmers & UGOT. Domain Specific Languages for other courses.

ctfp2014 icon ctfp2014

Lecture summaries for the course "Category Theory for Functional Programming", held in 2015 in Chalmers.

deptypedecth icon deptypedecth

Meeting on dependently typed decision theories, PIK 2017-03

dimensionanalysis icon dimensionanalysis

Dimension analysis and graded algebras (source code for talk at the 2022-11 Agda meeting).

dslm-peer-review icon dslm-peer-review

Instructions for the DSLsofMath course peer review of exercise solutions

flablom icon flablom

Functional Linear Algebra with Block Matrices

fpclimate icon fpclimate

PhD course on Functional Programming and Climate Impact Research

hatlab icon hatlab

Plotting with Gnuplot in Haskell

tfpie2015 icon tfpie2015

Domain Specific Languages of Mathematics: Presenting Mathematical Analysis using Functional Programming

valiantagda icon valiantagda

Certified Context-Free Parsing: A formalisation of Valiant's Algorithm in Agda

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.