# Dimensionality and Broadcasting

When we operate on arrays of different dimensionality, they can combine in different ways, either elementwise or through broadcasting.

Let’s start from scratch and build up to more complex examples. In the below example, we have a TensorFlow constant representing a single number.

Not much of a surprise there! We can also do computations, such as adding another number to it:

Let’s extend this concept to a list of numbers. To start, let’s create a list of three numbers, and then another list of numbers to it:

This is known as an elementwise operation, where the elements from each list are considered in turn, added together and then the results combined.

What happens if we just add a single number to this list?

Is this what you expected? This is known as an broadcasted operation. Our primary object of reference was `a`

, which is a list of numbers, also called an array or a one-dimensional vector. Adding a single number (called a scalar) results in an broadcasted operation, where the scalar is added to *each* element of the list.

Now let’s look at an extension, which is a two-dimensional array, also known as a matrix. This extra dimension can be thought of as a “list of lists”. In other words, a list is a combination of scalars, and a matrix is a list of lists.

That said, how do operations on matrices work?

That’s elementwise. If we add a scalar, the results are fairly predictable:

Here is where things start getting tricky. What happens if we add a one-dimensional array to a two-dimensional matrix?

In this case, the array was broadcasted to the shape of the matrix, resulting in the array being added to each row of the matrix. Using this terminology, a matrix is a list of rows.

What if we didn’t want this, and instead wanted to add `b`

across the columns of the matrix instead?

This didn’t work, as TensorFlow attempted to broadcast across the rows. It couldn’t do this, because the number of values in b (2) was not the same as the number of scalars in each row (3).

We can do this operation by creating a new matrix from our list instead.

What happened here? To understand this, let’s look at matrix shapes.

You can see from these two examples that `a`

has two dimensions, the first of size 2 and the second of size 2. In other words, it has two rows, each with three scalars in it.

Our `b`

constant also has two dimensions, two rows with one scalar in each. This is not the same as a list, nor is it the same as a matrix if one row of two scalars.

Due to the fact that the shapes match on the first dimension but not the second, the broadcasting happened across columns instead of rows. For more on broadcasting rules, see here.

## Exercises

- Create a 3-dimensional matrix. What happens if you add a scalar, array or matrix to it?
- Use
`tf.shape`

(it’s an operation) to get a constant’s shape during operation of the graph. - Think about use cases for higher-dimensional matrices. In other words, where might you need a 4D matrix, or even a 5D matrix? Hint: think about collections rather than single objects.

# Stuck? Get the exercise solutions here

If you are looking for solutions on the exercises, or just want to see how I solved them, then our solutions bundle is what you are after.

Buying the bundle gives you **free updates for life** - meaning when we add a new lesson, you get an updated bundle with the solutions.

It's just $9, and it also helps us to keep running the site with free lessons.

### Grow your business with data analytics

Looking to improve your business through data analytics? Are you interested in implementing data mining, automation or artificial intelligence?

This book is the ultimate guide to getting started with using data in your business, with a non-technical view and focusing on achieving good outcomes. We don't get bogged down by technical detail or complex algorithms.For additional offers, including a premium package, see this page.

You can also support LearningTensorFlow.com by becoming a patron at Patreon. If we have saved you trawling through heavy documentation, or given you a pointer on where to go next, help us to create new lessons and keep the site running.

You'll also get access to extra content and updates not available on LearningTensorFlow.com!

### Coming soon!

Note: despite the title, this book has no relationship to LearningTensorFlow.com