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

SuperFastPython.com
2.0
1 条评价
电子书
474
符合条件

关于此电子书

Concurrency in NumPy is not an afterthought


* Discover matrix multiplication that is 2.7x faster.

* Discover array initialization that is up to 3.2x faster.

* Discover sharing copied arrays that is up to 516.91x faster.


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.

评分和评价

2.0
1 条评价

作者简介

Jason Brownlee, Ph.D. helps Python developers bring modern concurrency methods to their projects with hands-on tutorials. Learn more at https://SuperFastPython.com


Jason is a software engineer and research scientist with a background in artificial intelligence and high-performance computing. He has authored more than 20 technical books on machine learning and has built, operated, and exited online businesses.

为此电子书评分

欢迎向我们提供反馈意见。

如何阅读

智能手机和平板电脑
只要安装 AndroidiPad/iPhone 版的 Google Play 图书应用,不仅应用内容会自动与您的账号同步,还能让您随时随地在线或离线阅览图书。
笔记本电脑和台式机
您可以使用计算机的网络浏览器聆听您在 Google Play 购买的有声读物。
电子阅读器和其他设备
如果要在 Kobo 电子阅读器等电子墨水屏设备上阅读,您需要下载一个文件,并将其传输到相应设备上。若要将文件传输到受支持的电子阅读器上,请按帮助中心内的详细说明操作。