2023-09-23 –, Room L
Dask is a flexible library for parallel computing in Python. Dask provides high-level interfaces to extend the PyData ecosystem to larger-than-memory or distributed environments, as well as lower-level interfaces to customise workflows. No previous experience is required, though knowledge of Python, NumPy and pandas is preferred.
This tutorial is aimed at people who are new to parallel and distributed computing, and to using PyData libraries at scale. The primary focus is on Dask’s commonly used features and building an intuition for distributed workflows. However, since Dask is a powerful tool with a lot more capabilities, we also include an overview of the breadth of APIs and deployment options provided by Dask.
Tutorial outline :
-
Overview [10 minutes]
Quick showcase of using Dask for a larger-than-memory dataset.
Give a brief overview of what Dask is, why it's needed, and where it fits into the PyData ecosystem.
How to start a Dask client and access the dashboard. -
Diagnostic tools for understanding performance [10 mins]
Need for visualization tools in distributed computing.
Quick overview of visualizing task graphs and widgets for local computations.
Deep dive into Dask Dashboard for distributed computations. -
Parallel DataFrames using Dask DataFrame [30 mins ]
Introduction to Dask DataFrames. Discuss how Dask DataFrame mirrors pandas.
Common pandas operations with Dask (reading, groupby, apply, map_partitons). -
Parallel Arrays using Dask Array [ 30 mins ]
Introduction to Dask Arrays. Discuss how Dask collections mirror their single-threaded counterparts (e.g. Dask Array mirror NumPy).
Visualizing task graphs and using widgets to understand the computation in detail.
Best Practices around choosing chunks. -
Brief introduction to Delayed, Distributed, and Deployments [ 10 minutes ]
When to choose low-level collections.
What are the Delayed and Futures APIs?
Dask’s LocalCluster and other deployment options.
Additional resources to learn more about the topics in this section.
Jacob Tomlinson is a senior software engineer at NVIDIA. His work involves maintaining open source projects including RAPIDS and Dask. He also tinkers with Opsdroid in his spare time. He lives in Exeter, UK.