You're not currently signed in. Sign in »

mesh sequence

Numerical Methods for Partial Differential Equations

CS555 :: Spring 2025

About the Course

Are you interested in the numerical approximation of solutions to partial differential equations? Then this course is for you!

The course covers roughly three topics: the fundamentals of finite difference approximations, an introduction to finite volume schemes, and comprehensive look at finite element methods.

Prerequites

The expectation is that you have had a course in numerical methods (like CS450), covering conditioning, numerical linear algebra, numerical quadrature and differentiation, and the basics of numerical methods for ordinary and differential equations. If you do not have this background, please check with the instructor.

In addition, you should have some familiarity with Python. All example, homeworks, and the project will be conducted in Python. If you do not have this background, please check with the instructor.

The course will take a deep look at the mathematical underpinning of the methods used to approximate solutions to partial differential equations. If you have questions about your mathematical preparation for this course, please check with the instructor.

Expected work

The course involves several assignments and a final project that we develop over the semester, culminating in a presentation. There is also a strong participation grade based on quizzes, handouts, and other in-class tasks. The tentative grade breakdown is:

  • Homework 40
  • Final Project 40
  • Quizzes, in-class work 20

This will be finalized in the first week of class.

The course assignments and examples in class will be in Python.

Lectures

Recorded Lectures: mediaspace.illinois.edu

Lecture Date Topic
images/0-elliptic.png 01-21 About the course, classifying PDEs, survey of methods
  • Book Chapter 1
images/0-advection1d.png 01-23 Finite differencing for time dependent problems
  • Book Sections 2.2, 3.1, 3.3, 5.1-5.3
images/0-lw.png 01-28 Convergence theory, Stability
  • Book Sections 5.1-5.3
images/0-wiggles.png 01-30 Stabilty, dispersion, and dissipation
  • Book Sections 5.1-5.4
images/0-dispersion.png 02-04 Dispersion, and dissipation
  • Book Sections 5.3-5.4
  • Scalar conservation laws
images/0-burgers.png 02-06 Conservation laws, finite volume methods
  • Book Sections 6.1-6.2
images/0-fvgrid.png 02-11 Finite Volume Methods
  • Book sections 6.2-6.3
images/0-godunov.png 02-13 Godunov Schemes
  • Book sections 6.3, 6.5
images/0-linearreconstruction.png 02-18 Higher resolution and slope limiting
  • Book sections 6.5
images/0-incomplete.png 02-20 Weak derivatives
  • Book sections 4.1, 8.1
images/0-interperror.png 02-25 Projections and weak problems
  • Book sections 4.1
images/0-discontinuity.png 02-27 Weak forms, Ritz-Galerkin, existence and uniqueness
  • Book Section 4.1, 4.2
images/0-1dbasis.png 03-04 Finite element assembly
  • Book section 4.4
images/0-1dexample.png 03-06 Finite element interpolant, approximation property
  • Finite element assembly, 1d
  • Read section 4.4
images/0-proj.png 03-11 Various FE methods, from least-squares to Galerkin
  • Book section 8.4
images/0-2dmap.png 03-13 Finite element assembly in 2D
  • Book section 8.4
03-18
  • Spring Break
03-20
  • Spring Break
images/0-2dmap.png 03-25 Finite element assembly in 2D
  • Book section 8.4
images/0-incomplete.png 03-27 Introduction to Functional Anaylsis
  • Book section 8.1
images/0-lax.png 04-01 An outline of theory, Lax-Milgram, and more
  • Book section 8.2
images/0-dgosc.png 04-03 Back to DG
  • Book section 9.5
images/0-dgosc.png 04-08
  • more DG
images/0-hdiv.png 04-10 Least-squares finite elements
  • Book section 10.5
04-15
  • Least-squares FE
04-17
  • Mixed order FE
04-22
  • Advanced elements
04-24
  • ...
04-29
  • ...
05-01
  • ...
05-06
  • ...
05-08
  • No class, reading day

Homework

Guidelines and files:

  • Homework Submission: All homework must be typeset using LaTeX. Use the provided templates to get started, available at homework-netid-N.tex or overleaf project.
  • Figures: Make sure all figures are clearly labeled with axes, titles, legends, and captions. Each figure must be referenced and discussed within your text for full credit.
  • Originality: Your submitted code and figures must be your own. If you use someone else's work, you must cite it.
  • Code-Based Problems: To receive points for problems involving code, your code must reproduce the reported figures and data. No points will be awarded for the Codes that do not generate the reported results.
  • Debugging Efforts: If you encounter issues that prevent your code from working as expected, detailed descriptions of your debugging attempts can earn you partial credit.

Final Project

The goal of the final project is to develop your own mini app -- a short computational example of some phenomenon in numerical PDEs. This can be related to any of the topics covered, from finite differencing to finite volume methods to finite element methods. An overarching goal of your mini app is to educate your peers on some nuanced aspect of the topics we have covered (or have skipped).

Your deliverables for the project will be a functioning Jupyter notebook, with an embeddeed description, discussion, and guide for the audience. In addition, you will present an overview of up to five minutes (with slides).

The mini app should rely only on standard Python, along with numpy, scipy, and matplotlib. If you strongly feel that you should use additional packages, please obtain prior approval.

The rubrics for the mini app are as follows.

SP, Statement of problem

  • What is the problem that you are looking at? What is the is point of the the mini app? What interesting aspect of numerical PDEs does your mini app highlight?
  • Is the problem clear? Have you provided enough background information for the audience to follow?

ID, Implementation details

  • Is your example well documented?
  • Is your mini app reproducible with minimal effort?
  • What details are needed to understand the implementation?
  • Is your Python code style clean and Pythonic? (see for example, The Zen of Pytyhon, https://peps.python.org/pep-0020/)

R, Results

  • Do your results highlight the overarching goal of your mini app?
  • What do you observe for this problem and discretization, for example?
  • Are your results clear? Do you label important details? Do you use relevant and consistent color schemes?
  • Carefully select which visualizations to show. We do not need to see everything, only figures that highlight some aspect of the goal of your mini app.

C, Reflections

  • What did you learn? What worked, what needs improvement, what are the next steps or future directions?
  • Provide a list of future directions at the end of your app -- what could be looked at next and what are some of the limitations of your implementation?

Slides should focus on

  • (3) Do you have a clear summary and goals of your miniapp?
  • (2) Do you provide a sufficient level of detail in showing off your mini app?
  • (2) Do you highlight a few (but not all) of the results in your mini app?
  • (3) Is your presentation practiced and on time? Is your slide deck of high quality?
project step description points due
project 0 idea 2 TBD
project 1 outline 2 TBD
project 2 results 2 TBD
project 3 results 3 TBD
project 4 mini app (notebook) 20 TBD
project 5 slides 10 TBD
project 6 pick a license 1 TBD
total 40

Code details.

  • The code should be your own. If you use someone else's function or module, then it should be clearly attributed and the license should conform to your license.
  • License. Ideally it would be useful if your mini app is released as open source.
  • Your notebook should be named miniapp_topic.ipynb. No spaces or dashes.

COVID and Attendance

While face coverings are not required in classrooms (current as of 12/20/2023) we fully support your decision to wear one if you wish.

If you test positive for COVID, then you should not attend class.

If you have any cold-like symptoms or do not feel well, then you should not attend class, regardless of testing negative or positive for COVID.

In either case, your missed attendance due to illness will not impact your grade in the course and we will work with you to cover the material missed in class (via Zoom).