introductionCommon problemsOverview and rationaleWhy Python?What is parallel computing?
Figure 1
data:image/s3,"s3://crabby-images/b8568/b85688f54ad8dbd96c6cc8327eefbaf40e1555d4" alt="boxes and arrows in sequential configuration"
Serial computation
Figure 2
data:image/s3,"s3://crabby-images/fa1c2/fa1c2d91b64ce022502b68a28d9b8e2186d41915" alt="boxes and arrows with two parallel pipe lines"
Parallel computation
Figure 3
serial execution
Figure 4
parallel execution
Figure 5
data:image/s3,"s3://crabby-images/18f39/18f39eb2a6e054b22a39fdfd7c754be2205b05c1" alt="boxes and arrows showing dependencies between tasks"
Figure 6
Shared vs. Distributed memory architecture: the
crucial difference is the bandwidth to shared memory
BenchmarkingA first example with DaskMemory profilingUsing many cores
Figure 1
data:image/s3,"s3://crabby-images/1e052/1e052a9f6b690dbacab7d4d07af144d79052d33e" alt="screenshot of system monitor"
System monitor
Figure 2
data:image/s3,"s3://crabby-images/80b54/80b547442859bac0fcf59f3a6c6b522b66b888cb" alt="showing very high peak for numpy, and constant low line for dask"
Memory performance
Figure 3
Timings against number of cores
Computing $\pi$Parallelizing a Python applicationUsing Numba to accelerate Python code
Figure 1
Computing Pi
Threads and processesThreadingMultiprocessing
Delayed evaluationDask Delayed
Figure 1
Dask workflow graph
Figure 2
{.output alt=“boxes and arrows”}
Map and reduce
Figure 1
A map operation.
Figure 2
A reduction.
Exercise with FractalsThe Mandelbrot and Julia fractals
Figure 1
data:image/s3,"s3://crabby-images/33f71/33f71834ab08def4ccf41b331444854ecfc6e38d" alt="colorful rendering of mandelbrot set"
The whole Mandelbrot set
Figure 2
data:image/s3,"s3://crabby-images/ff79b/ff79b0b564802c36a983e15f3cd329643045e99c" alt="rendering of mandelbrot zoom"
Zoom in on Mandelbrot set
Figure 3
Benchmarks
Figure 4
data:image/s3,"s3://crabby-images/5f9ba/5f9ba91fd0956f3debeee2a27fd0ab230510d200" alt="colorful rendering of a Julia set"
Example of a Julia set
AsyncioIntroduction to AsyncioA first programWorking with asyncio
outside Jupyter
Figure 1
Figure 2
Figure 3
timings