Skip to content

Commit

Permalink
Add lecture3 slides and update figures for lecture 2
Browse files Browse the repository at this point in the history
  • Loading branch information
Crazy-Rich-Meghan committed Nov 18, 2023
2 parents 08d7239 + 139d7f4 commit 50be557
Show file tree
Hide file tree
Showing 8 changed files with 194 additions and 11,134 deletions.
5 changes: 5 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,22 @@ This repository contains the slides of the course _Object-oriented scientific pr
- `interactive slides` will be used during the lecture with the option to adjust the content interactively
- `static slides` are static versions of the lecture slides meant for printing (if really needed)

We strongly recomment using the notebooks and slides in the provided binder environment. Slides and notebooks **will not run** on a local JupyterLab installation because they require the [Jupyter kernel for C++](https://github.com/jupyter-xeus/xeus-cling) to be installed and configured properly. Note that **no support will be given** to make the slides and notebooks run on a local JupyterLab installation.

## Lectures

| lecture no. | notebooks | interactive slides | static slides |
| :---------: | :-------: | :----------------: | :-----------: |
| 1 | [![Lecture 1][badge-binder-lecture]][binder-jupyterlab-lecture1] | [![Lecture 1][badge-binder-lecture]][binder-jupyternb-lecture1] | [![Lecture 1][badge-pages-lecture]][pages-lecture1] |

<!---
| 2 | [![Lecture 2][badge-binder-lecture]][binder-jupyterlab-lecture2] | [![Lecture 2][badge-binder-lecture]][binder-jupyternb-lecture2] | [![Lecture 2][badge-pages-lecture]][pages-lecture2] |
| 3 | [![Lecture 3][badge-binder-lecture]][binder-jupyterlab-lecture3] | [![Lecture 3][badge-binder-lecture]][binder-jupyternb-lecture3] | [![Lecture 3][badge-pages-lecture]][pages-lecture3] |
| 4 | [![Lecture 4][badge-binder-lecture]][binder-jupyterlab-lecture4] | [![Lecture 4][badge-binder-lecture]][binder-jupyternb-lecture4] | [![Lecture 4][badge-pages-lecture]][pages-lecture4] |
| 5 | [![Lecture 5][badge-binder-lecture]][binder-jupyterlab-lecture5] | [![Lecture 5][badge-binder-lecture]][binder-jupyternb-lecture5] | [![Lecture 5][badge-pages-lecture]][pages-lecture5] |
| 6 | [![Lecture 6][badge-binder-lecture]][binder-jupyterlab-lecture6] | [![Lecture 6][badge-binder-lecture]][binder-jupyternb-lecture6] | [![Lecture 6][badge-pages-lecture]][pages-lecture6] |
| 7 | [![Lecture 7][badge-binder-lecture]][binder-jupyterlab-lecture7] | [![Lecture 7][badge-binder-lecture]][binder-jupyternb-lecture7] | [![Lecture 7][badge-pages-lecture]][pages-lecture7] |
--->

[badge-binder-lecture]: https://img.shields.io/badge/interactive-lecture-579ACA.svg?logo=&style=flat-square

Expand Down
1 change: 1 addition & 0 deletions notebooks/lecture-template.ipynb
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"metadata":{"kernelspec":{"display_name":"C++17","language":"C++17","name":"xcpp17"},"language_info":{"codemirror_mode":"text/x-c++src","file_extension":".cpp","mimetype":"text/x-c++src","name":"c++","version":"17"},"rise":{"autolaunch":true,"enable_chalkboard":true}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"markdown","source":"# Object-oriented scientific programming with C++\n\nMatthias Möller, Jonas Thies (Numerical Analysis, DIAM)\n\nLecture 1","metadata":{"editable":false,"raw_mimetype":"","slideshow":{"slide_type":"slide"},"tags":[]},"attachments":{}},{"cell_type":"markdown","source":"## What's this course about","metadata":{"editable":false,"slideshow":{"slide_type":"slide"},"tags":[]}},{"cell_type":"markdown","source":"### Object oriented programming\n\nLearn the **design principles** of OOP (not restricted to C++)","metadata":{"slideshow":{"slide_type":"subslide"},"tags":[]}},{"cell_type":"markdown","source":"### Matlab example\n\n```Matlab\nA = [1 2; 3 4]\nsize(A)\n```\n\nHere, the `size` **functions** is applied to the matrix `A` and determines its size from outside. That means the function `size` must be able to deduce the matrix size. In other words, the matrix size is publicly visible.","metadata":{"editable":false,"slideshow":{"slide_type":"subslide"},"tags":[]}},{"cell_type":"markdown","source":"### Python example\n\n```python\nA = numpy.matrix([[1, 2], [3, 4]])\nA.shape\n```\n\nHere, the matrix `A` provides a _member function_ to determine its size from inside.","metadata":{"editable":false,"slideshow":{"slide_type":"subslide"},"tags":[]}},{"cell_type":"markdown","source":"### Header files\n\nAt the beginning of each C++ code you include some **header files**, for instance the one for input and output streams","metadata":{"editable":false,"slideshow":{"slide_type":"slide"},"tags":[]}},{"cell_type":"code","source":"#include <iostream>","metadata":{"editable":true,"slideshow":{"slide_type":"fragment"},"tags":[],"trusted":false},"outputs":[],"execution_count":2},{"cell_type":"markdown","source":"Now, we can write our first C++ instruction","metadata":{"editable":false,"slideshow":{"slide_type":"fragment"},"tags":[]}},{"cell_type":"code","source":"std::cout << \"Hello World!\\n\";","metadata":{"editable":true,"slideshow":{"slide_type":"fragment"},"tags":[],"trusted":false},"outputs":[{"name":"stdout","output_type":"stream","text":"Hello World!\n"}],"execution_count":3}]}
2 changes: 1 addition & 1 deletion notebooks/lecture1.ipynb

Large diffs are not rendered by default.

Loading

0 comments on commit 50be557

Please sign in to comment.