Jump to ratings and reviews
Rate this book

Concurrent NumPy in Python: Faster NumPy With BLAS, Python Threads, and Multiprocessing

Rate this book
Concurrency in NumPy is not an afterthought

NumPy is how we represent arrays of numbers in Python.

An entire ecosystem of third-party libraries has been developed around NumPy arrays, from machine learning and deep learning to image and computer vision and more.

Given the wide use of NumPy, it is essential we know how to get the most out of our system when using it.

We cannot afford to have CPU cores sit idle when performing mathematical operations on arrays.

Therefore we must know how to correctly harness concurrency in NumPy, such as:

* NumPy has multithreaded algorithms and functions built-in (using BLAS).
* NumPy will release the infamous GIL so Python threads can run in parallel.
* NumPy arrays can be shared efficiently between Python processes using shared memory.

The problem is, no one is talking about how.

Introducing: Concurrent NumPy in Python. A new book designed to teach you how to bring concurrency to your NumPy programs in Python, super fast!

You will get fast-paced tutorials showing you how to bring concurrency to the most common NumPy tasks.

Including:

* Parallel array multiplication, common math functions, matrix solvers, and decompositions.
* Parallel array filling and parallel creation of arrays of random numbers.
* Parallel element-wise array arithmetic and common array math functions
* Parallel programs for working with many NumPy arrays with thread and process pools.
* Efficiently share arrays directly, and copies of arrays between Python processes.

Don't worry if you are new to NumPy programming or concurrency, you will also get primers on the background required to get the most out of this book, including:

* The importance of concurrency when using NumPy and the cost of approaching it naively.
* How to perform common NumPy operations and math functions.
* How to install, query, and configure BLAS libraries for built-in multithreaded NumPy functions.
* How to use Python concurrency APIs including threading, multiprocessing, and pools of workers.

Each tutorial is carefully designed to teach one critical aspect of how to bring concurrency to your NumPy projects.

Learn Python concurrency correctly, step-by-step.

474 pages, Kindle Edition

Published September 20, 2023

About the author

Jason Brownlee

47 books76 followers
Jason Brownlee, Ph.D. trained and worked as a research scientist and software engineer for many years (e.g. enterprise, R&D, and scientific computing), and is known online for his work on Computational Intelligence (e.g. Clever Algorithms), Machine Learning and Deep Learning (e.g. Machine Learning Mastery, sold in 2021) and Python Concurrency (e.g. Super Fast Python).

Jason writes fiction under the pseudonym J.D. Brownlee: https://www.goodreads.com/jdbrownlee

Ratings & Reviews

What do you think?
Rate this book

Friends & Following

Create a free account to discover what your friends think of this book!

Community Reviews

5 stars
1 (100%)
4 stars
0 (0%)
3 stars
0 (0%)
2 stars
0 (0%)
1 star
0 (0%)
No one has reviewed this book yet.

Can't find what you're looking for?

Get help and learn more about the design.