Book Image

Applying Math with Python

By : Sam Morley
Book Image

Applying Math with Python

By: Sam Morley

Overview of this book

Python, one of the world's most popular programming languages, has a number of powerful packages to help you tackle complex mathematical problems in a simple and efficient way. These core capabilities help programmers pave the way for building exciting applications in various domains, such as machine learning and data science, using knowledge in the computational mathematics domain. The book teaches you how to solve problems faced in a wide variety of mathematical fields, including calculus, probability, statistics and data science, graph theory, optimization, and geometry. You'll start by developing core skills and learning about packages covered in Python’s scientific stack, including NumPy, SciPy, and Matplotlib. As you advance, you'll get to grips with more advanced topics of calculus, probability, and networks (graph theory). After you gain a solid understanding of these topics, you'll discover Python's applications in data science and statistics, forecasting, geometry, and optimization. The final chapters will take you through a collection of miscellaneous problems, including working with specific data formats and accelerating code. By the end of this book, you'll have an arsenal of practical coding solutions that can be used and modified to solve a wide range of practical problems in computational mathematics and data science.
Table of Contents (12 chapters)

Working with data streams

Some data is received in a constant stream from various sources. For example, we might have a situation where multiple temperature probes are reporting values at set intervals via a Kafka server. Kafka is a streaming data message broker that passes messages to different processing agents based on topics.

Processing streaming data is the perfect application for asynchronous Python. This allows us to process larger quantities of data concurrently, which could be very important in applications. Of course, we can't directly perform long-running analysis on this data in an asynchronous context, since this will interfere with the execution of the event loop.

For working with Kafka streams using Python's asynchronous programming features, we can use the Faust package. This package allows us to define asynchronous functions that will act as processing agents or services that can process or otherwise interact with a stream of data from...