Course syllabus
Course-PM
DAT326 / DIT983 Domain-Specific Languages of Mathematics, Spring 2024 (7,5hp) at the CSE Department, Chalmers & UGOT.
Course purpose
The course will present 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: see below.
Schedule
Usually lectures on Tuesdays (in EC) and Thursdays (in ED) at 13.15. See TimeEdit for the details.
Exercise sessions usually on Tuesdays (15.15) and Fridays (13.15) in ES52 + ES53.
Contact details
Examiner and main lecturer: Patrik Jansson, email: patrikj@chalmers.se
Teaching Assistants:
- Freek Geerligs
- Felix Cherubini
- Rachel Samuelsson
Student representatives
- Adam Lindholm <adalindh@chalmers.se>
- Simon Uggla <simon.uggla@gmail.com>
- Egil Morén <egil.moren@gmail.com>
Mid-course evaluation meeting: Wed 2024-02-07 at 12:30 - 13:00 in CSE EDIT 6128.
Final course evaluation meeting: Fri 2024-04-12 at 15-16.
Course literature
Chapters 1-8 of the book "Domain-Specific Languages of Mathematics" (also available in Canvas, sources on GitHub) + references therein cover the course. The main references are listed on the GitHub page.
Course design
- 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
- Course material
- Please read and make sure you understand the course book.
- All (at least 19) old exams + solutions are available in the github repository
- Weekly exercise sessions (scheduled):
- Helping students solve problems in small self-organized groups
- Usually in ES52 + ES53 (see the TimeEdit schedule)
- More exercises (not scheduled)
- Make sure to work through the exercises in the book
- This is important to prepare for both the labs and the written exam
- ... and you can get bonus points.
- Assignments (labs)
- Two assignments done in groups of three
- Hand-in as text + code ...
- ... and a short oral Q&A session to make sure you have all contributed.
- Feedback will be given both during the Q&A-session and in writing
- Written exam (at the end of the course)
- 2024-03: Physical written exam
- Digital tools
- Canvas is used for the course homepage
- rapid feedback is appreciated to make sure we can improve the site
- GitHub is where all the sources of the textbook and its associated code is hosted.
- please post issues if you find problems
- and use pull-requests if you have suggestions for fixes / additions
- Slack is used as discussion forum
- Canvas is used for the course homepage
Changes made since the last occasion
Based on student feedback from the 2022-2023 instances we have made a few minor changes:
- Identified and fixed typos in the course book (will appear in the 2nd edition).
- Use of slack instead of canvas as discussion forum.
Examination form
There are two compulsory course elements:
- A = Assignments (written + oral examination in groups of three students)
- two compulsory hand-in assignments
- Grading: Pass or Fail
- The assignments are to be handed in via Canvas
- E = Exam (individual written exam at the end of the course)
- Grading: U (fail), 3, 4, 5 (top grade)
- Note: a minimum of 5p on each question is required to pass.
- Date: Friday 2024-03-15, morning
- Aids: One textbook of your choice (usually the DSLsofMath book)
To pass the course you need to pass both course elements.
Weekly Exercises
Learning objectives and 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
Course plans:
Course summary:
Date | Details | Due |
---|---|---|