Case Study

Get an overview of Python's use of iterators, functional programming, and itertools, which plays a pivotal role in complex computations.

Overview

Python makes extensive use of iterators and iterable collections. This underlying aspect appears in many places. Each for statement makes implicit use of this. When we use functional programming techniques, such as generator expressions, and the map(), filter(), and reduce() functions, we’re exploiting iterators.

Python has an itertools module full of additional iterator-based design patterns. This is worthy of study because it provides many examples of common operations that are readily available using built-in constructs.

We can apply these concepts in a number of places in our case study:

  • Partitioning all the original samples into testing and training subsets.
  • Testing a particular kk and distance hyperparameter set by classifying all the test cases.
  • The kk-nearest neighbors (kk-NN) algorithm itself and how it locates the kk nearest neighbors from all the training samples.

The common aspect of these three processing examples is the for all aspect of each one. We’ll take a little side-trip into the math behind comprehensions and generator functions. The math isn’t terribly complex, but the following section can be thought of as deep background. After this digression, we’ll dive into partitioning data into training and testing subsets using the iterator concepts.

The set builder background

Formally, we can summarize operations like partitioning, testing, and even locating nearest neighbors with a logic expression. Some developers like the formality of it because it can help describe the processing without forcing a specific Python implementation.

Partitioning rules for partitioning

Here’s the essential rule for partitioning, for example. This involves a for all condition that describes the elements of a set of samples, SS:

Get hands-on with 1300+ tech skills courses.