# 3.1. Functions on an Outcome Space¶

Random sampling can be thought of as repeated random trials, and therefore many outcome spaces consist of sequences. An outcome space representing two tosses of a coin is

If you were tossing 10 times, the outcome space would consist of the \(2^{10}\) sequences of 10 elements where each element is H or T. The outcomes are a pain to list by hand, but computers are good at saving us that kind of pain.

## 3.1.1. Product Spaces¶

The *product* of two sets \(A\) and \(B\) is the set of all pairs \((a, b)\) where \(a \in A\) and \(b \in B\). This concept is exactly what we need to describe spaces representing multiple trials.

For example, the space representing the outcome of one toss of a coin is $ \Omega_1 = { H, T }$. The *product* of \(\Omega_1\) with itself is the set of pairs \((H, H)\), \((H, T)\), \((T, H)\), and \((T, T)\), which you will recognize as the outcomes of two tosses of a coin. The product of this new space and \(\Omega_1\) is the space representing three tosses. And so on.

The Python module `itertools`

contains a function `product`

that constructs product spaces. Let’s import it.

```
from itertools import product
```

To see how `product`

works, we will start with the outcomes of one toss of a coin. We are creating an array using `make_array`

but you could use any other way of creating an array or list.

```
one_toss = make_array('H', 'T')
```

To use `product`

, we have to specify the base space and the number of repetitions, and then covert the result to a list.

```
two_tosses = list(product(one_toss, repeat=2))
two_tosses
```

```
[('H', 'H'), ('H', 'T'), ('T', 'H'), ('T', 'T')]
```

For three tosses, just change the number of repetitions:

```
three_tosses = list(product(one_toss, repeat=3))
three_tosses
```

```
[('H', 'H', 'H'),
('H', 'H', 'T'),
('H', 'T', 'H'),
('H', 'T', 'T'),
('T', 'H', 'H'),
('T', 'H', 'T'),
('T', 'T', 'H'),
('T', 'T', 'T')]
```

## 3.1.2. Probability Space¶

A *probability space* is an outcome space accompanied by the probabilities of all the outcomes. If you assume all eight outcomes of three tosses are equally likely, the probabilities are all 1/8:

```
three_toss_probs = (1/8)*np.ones(8)
```

The corresponding probability space:

```
three_toss_space = Table().with_columns(
'omega', three_tosses,
'P(omega)', three_toss_probs
)
three_toss_space
```

omega | P(omega) |
---|---|

['H' 'H' 'H'] | 0.125 |

['H' 'H' 'T'] | 0.125 |

['H' 'T' 'H'] | 0.125 |

['H' 'T' 'T'] | 0.125 |

['T' 'H' 'H'] | 0.125 |

['T' 'H' 'T'] | 0.125 |

['T' 'T' 'H'] | 0.125 |

['T' 'T' 'T'] | 0.125 |

Product spaces get large very quickly. If you roll a die 5 times, there are almost 8,000 possible outcomes:

```
6**5
```

```
7776
```

But we have `product`

so we can still list them all! Here is a probability space representing 5 rolls of a die.

```
die = np.arange(1, 7, 1)
five_rolls = list(product(die, repeat=5)) # All possible results of 5 rolls
five_rolls_probs = (1/6**5)**np.ones(6**5) # Each result has chance 1/6**5
five_rolls_space = Table().with_columns(
'omega', five_rolls,
'P(omega)', five_rolls_probs
)
five_rolls_space
```

omega | P(omega) |
---|---|

[1 1 1 1 1] | 0.000128601 |

[1 1 1 1 2] | 0.000128601 |

[1 1 1 1 3] | 0.000128601 |

[1 1 1 1 4] | 0.000128601 |

[1 1 1 1 5] | 0.000128601 |

[1 1 1 1 6] | 0.000128601 |

[1 1 1 2 1] | 0.000128601 |

[1 1 1 2 2] | 0.000128601 |

[1 1 1 2 3] | 0.000128601 |

[1 1 1 2 4] | 0.000128601 |

... (7766 rows omitted)

## 3.1.3. A Function on the Outcome Space¶

Suppose you roll a die five times and add up the number of spots you see. If that seems artificial, be patient for a moment and you’ll soon see why it’s interesting.

The sum of the rolls is a numerical function on the outcome space \(\Omega\) of five rolls. The sum is thus a *random variable*. Let’s call it \(S\). Then, formally,

The range of \(S\) is the integers 5 through 30, because each die shows at least one spot and at most six spots. We can also use the equivalent notation

From a computational perspective, the elements of \(\Omega\) are in the column `omega`

of `five_roll_space`

. Let’s apply this function and create a larger table.

```
five_rolls_sum = five_rolls_space.with_columns(
'S(omega)', five_rolls_space.apply(sum, 'omega')
).move_to_end('P(omega)')
five_rolls_sum
```

omega | S(omega) | P(omega) |
---|---|---|

[1 1 1 1 1] | 5 | 0.000128601 |

[1 1 1 1 2] | 6 | 0.000128601 |

[1 1 1 1 3] | 7 | 0.000128601 |

[1 1 1 1 4] | 8 | 0.000128601 |

[1 1 1 1 5] | 9 | 0.000128601 |

[1 1 1 1 6] | 10 | 0.000128601 |

[1 1 1 2 1] | 6 | 0.000128601 |

[1 1 1 2 2] | 7 | 0.000128601 |

[1 1 1 2 3] | 8 | 0.000128601 |

[1 1 1 2 4] | 9 | 0.000128601 |

... (7766 rows omitted)

We now have every possible outcome of five rolls of a die, along with its total number of spots. You can see that the first row of the table shows the smallest possible number of spots, corresponding to all the rolls showing 1 spot. The 7776th row shows the largest:

```
five_rolls_sum.take(7775)
```

omega | S(omega) | P(omega) |
---|---|---|

[6 6 6 6 6] | 30 | 0.000128601 |

All the other values of \(S\) are between these two extremes.

Quick Check

A standard probability space for three tosses of a coin consists of the outcome space \(\Omega = \{ HHH, HHT, HTH, THH, HTT, THT, TTH, TTT \}\) with equally likely outcomes. For each of the following descriptions, say whether or not it results in a random variable defined on \(\Omega\).

(i) Count \(1\) if the outcome in \(HHH\), \(0\) otherwise

(ii) Note the index of the final toss on which \(H\) appears

Answer

(i) Yes.

(ii) No. The description gets stuck at the outcome \(TTT\). It doesn’t say what to do in this case. Even if you decide to use \(\infty\) for this outcome, you don’t get a random variable because \(\infty\) isn’t a real number.

### 3.1.3.1. Functions of Random Variables¶

A random variable is a numerical function on \(\Omega\). Therefore by composition, a numerical function of a random variable is also a random variable.

For example, \(S^2\) is a random variable, calculated as follows:

Thus for example \(S^2(\text{[6 6 6 6 6]}) = 30^2 = 900\).

Quick Check

Let \(X\) and \(Y\) be random variables defined on the same probability space.

(a) Is \(\max(X, Y)\) a random variable?

(b) Let \(Z = 1\) if \(X=Y\) and \(Z=0\) otherwise. Is \(Z\) a random variable?

Answer

(a) Yes (b) Yes

## 3.1.4. Events Determined by \(S\)¶

From the table `five_rolls_sum`

it is hard to tell how many rows show a sum of 6, or 10, or any other value. To better understand the properties of \(S\), we have to organize the information in `five_rolls_sum`

.

For any subset \(A\) of the range of \(S\), define the event \(\{S \in A\}\) as

That is, \(\{ S \in A\}\) is the collection of all \(\omega\) for which \(S(\omega)\) is in \(A\). In terms of the table, the set consists of the values of \(\omega\) in all the rows in which the sum is in \(A\).

Events of the form \(\{ S \in A\}\) are said to be *determined by \(S\)*. If we know the value of \(S\), then we know whether or not that value is in \(A\). So we can determine whether or not the event \(\{ S \in A\}\) has occurred.

Let’s try out the definition in a special case. Take \(A = \{5, 30\}\). Then \(\{S \in A\}\) if and only if either all the rolls show 1 spot or all the rolls show 6 spots. So

It is natural to ask about the chance the sum is a particular value, say 10. That’s not easy to read off the table, but we can access the corresponding rows:

```
five_rolls_sum.where('S(omega)', are.equal_to(10))
```

omega | S(omega) | P(omega) |
---|---|---|

[1 1 1 1 6] | 10 | 0.000128601 |

[1 1 1 2 5] | 10 | 0.000128601 |

[1 1 1 3 4] | 10 | 0.000128601 |

[1 1 1 4 3] | 10 | 0.000128601 |

[1 1 1 5 2] | 10 | 0.000128601 |

[1 1 1 6 1] | 10 | 0.000128601 |

[1 1 2 1 5] | 10 | 0.000128601 |

[1 1 2 2 4] | 10 | 0.000128601 |

[1 1 2 3 3] | 10 | 0.000128601 |

[1 1 2 4 2] | 10 | 0.000128601 |

... (116 rows omitted)

There are 126 values of \(\omega\) for which \(S(\omega) = 10\). Since all the \(\omega\) are equally likely, the chance that \(S\) has the value 10 is 126/7776.

We will usually be informal with notation and write \(\{ S = 10 \}\) instead of \(\{ S \in \{10\} \}\):

Quick Check

Consider a probability space representing two rolls of a die. That is the space consists of the 36 equally likely pairs \((i,j)\) where \(1 \le i, j \le 6\). Let \(X_1\) be the result of the first roll and \(X_2\) the result of the second, and let \(D = X_1 - X_2\). Here are two events determined by \(D\). Write them as subsets of the outcome space and find their probabilities.

(a) \(D = 0\)

(b) \(D > 3\)

Answer

(a) \(\{ (1,1), (2,2), (3,3), (4,4), (5,5), (6,6) \}\), probability \(6/36\)

(b) \(\{ (5,1), (6,1), (6,2) \}\), probability \(3/36\)