KEMBAR78
Introduction To Probability For Data Science | PDF | Probability Distribution | Probability Density Function
100% found this document useful (1 vote)
323 views709 pages

Introduction To Probability For Data Science

This document is an introductory textbook on probability for data science by Stanley H. Chan, aimed at undergraduate and first-year graduate students in electrical engineering and computer science. It emphasizes the motivation, intuition, and implications of probabilistic tools, bridging theory and practical applications in data science. The book includes various chapters suitable for different topics within probability and data science, along with additional teaching resources available online.

Uploaded by

al-hashemi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
100% found this document useful (1 vote)
323 views709 pages

Introduction To Probability For Data Science

This document is an introductory textbook on probability for data science by Stanley H. Chan, aimed at undergraduate and first-year graduate students in electrical engineering and computer science. It emphasizes the motivation, intuition, and implications of probabilistic tools, bridging theory and practical applications in data science. The book includes various chapters suitable for different topics within probability and data science, along with additional teaching resources available online.

Uploaded by

al-hashemi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 709

Introduction to Probability

for
Data Science

Stanley H. Chan
Purdue University
Copyright 2021 Stanley H. Chan

This book is published by Michigan Publishing under an agreement with the author. It is
made available free of charge in electronic form to any student or instructor interested in
the subject matter.

Published in the United States of America by


Michigan Publishing
Manufactured in the United States of America

ISBN 978-1-60785-746-4 (hardcover)


ISBN 978-1-60785-747-1 (electronic)

ii
To Vivian, Joanna, and Cynthia Chan

And ye shall know the truth, and the truth shall make you free.
John 8:32

iii
iv
Preface

This book is an introductory textbook in undergraduate probability. It has a mission: to spell


out the motivation, intuition, and implication of the probabilistic tools we use in science
and engineering. From over half a decade of teaching the course, I have distilled what I
believe to be the core of probabilistic methods. I put the book in the context of data science
to emphasize the inseparability between data (computing) and probability (theory) in our
time.
Probability is one of the most interesting subjects in electrical engineering and com-
puter science. It bridges our favorite engineering principles to the practical reality, a world
that is full of uncertainty. However, because probability is such a mature subject, the under-
graduate textbooks alone might fill several rows of shelves in a library. When the literature
is so rich, the challenge becomes how one can pierce through to the insight while diving into
the details. For example, many of you have used a normal random variable before, but have
you ever wondered where the “bell shape” comes from? Every probability class will teach
you about flipping a coin, but how can “flipping a coin” ever be useful in machine learning
today? Data scientists use the Poisson random variables to model the internet traffic, but
where does the gorgeous Poisson equation come from? This book is designed to fill these
gaps with knowledge that is essential to all data science students.
This leads to the three goals of the book. (i) Motivation: In the ocean of mathematical
definitions, theorems, and equations, why should we spend our time on this particular topic
but not another? (ii) Intuition: When going through the derivations, is there a geometric
interpretation or physics beyond those equations? (iii) Implication: After we have learned a
topic, what new problems can we solve?
The book’s intended audience is undergraduate juniors/seniors and first-year gradu-
ate students majoring in electrical engineering and computer science. The prerequisites are
standard undergraduate linear algebra and calculus, except for the section about charac-
teristic functions, where Fourier transforms are needed. An undergraduate course in signals
and systems would suffice, even taken concurrently while studying this book.
The length of the book is suitable for a two-semester course. Instructors are encouraged
to use the set of chapters that best fits their classes. For example, a basic probability course
can use Chapters 1-5 as its backbone. Chapter 6 on sample statistics is suitable for students
who wish to gain theoretical insights into probabilistic convergence. Chapter 7 on regression
and Chapter 8 on estimation best suit students who want to pursue machine learning and
signal processing. Chapter 9 discusses confidence intervals and hypothesis testing, which are
critical to modern data analysis. Chapter 10 introduces random processes. My approach for
random processes is more tailored to information processing and communication systems,
which are usually more relevant to electrical engineering students.
Additional teaching resources can be found on the book’s website, where you can

v
find lecture videos and homework videos. Throughout the book you will see many “practice
exercises”, which are easy problems with worked-out solutions. They can be skipped without
loss to the flow of the book.
Acknowledgements: If I could thank only one person, it must be Professor Fawwaz
Ulaby of the University of Michigan. Professor Ulaby has been the source of support in
all aspects, from the book’s layout to technical content, proofreading, and marketing. The
book would not have been published without the help of Professor Ulaby. I am deeply
moved by Professor Ulaby’s vision that education should be made accessible to all students.
With textbook prices rocketing up, the EECS free textbook initiative launched by Professor
Ulaby is the most direct response to the publishers, teachers, parents, and students. Thank
you, Fawwaz, for your unbounded support — technically, mentally, and financially. Thank
you also for recommending Richard Carnes. The meticulous details Richard o↵ered have
significantly improved the fluency of the book. Thank you, Richard.
I thank my colleagues at Purdue who had shared many thoughts with me when I
taught the course (in alphabetical order): Professors Mark Bell, Mary Comer, Saul Gelfand,
Amy Reibman, and Chih-Chun Wang. My teaching assistant I-Fan Lin was instrumental in
the early development of this book. To the graduate students of my lab (Yiheng Chi, Nick
Chimitt, Kent Gauen, Abhiram Gnanasambandam, Guanzhe Hong, Chengxi Li, Zhiyuan
Mao, Xiangyu Qu, and Yash Sanghvi): Thank you! It would have been impossible to finish
the book without your participation. A few students I taught volunteered to help edit
the book: Benjamin Gottfried, Harrison Hsueh, Dawoon Jung, Antonio Kincaid, Deepak
Ravikumar, Krister Ulvog, Peace Umoru, Zhijing Yao. I would like to thank my Ph.D.
advisor Professor Truong Nguyen for encouraging me to write the book.
Finally, I would like to thank my wife Vivian and my daughters, Joanna and Cynthia,
for their love, patience, and support.

Stanley H. Chan, West Lafayette, Indiana

May, 2021

Companion website:

https://probability4datascience.com/

vi
Contents

1 Mathematical Background 1
1.1 Infinite Series . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.1.1 Geometric Series . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.1.2 Binomial Series . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.2 Approximation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
1.2.1 Taylor approximation . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
1.2.2 Exponential series . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
1.2.3 Logarithmic approximation . . . . . . . . . . . . . . . . . . . . . . . . 13
1.3 Integration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
1.3.1 Odd and even functions . . . . . . . . . . . . . . . . . . . . . . . . . . 15
1.3.2 Fundamental Theorem of Calculus . . . . . . . . . . . . . . . . . . . . 17
1.4 Linear Algebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
1.4.1 Why do we need linear algebra in data science? . . . . . . . . . . . . . 20
1.4.2 Everything you need to know about linear algebra . . . . . . . . . . . 21
1.4.3 Inner products and norms . . . . . . . . . . . . . . . . . . . . . . . . . 24
1.4.4 Matrix calculus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
1.5 Basic Combinatorics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
1.5.1 Birthday paradox . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
1.5.2 Permutation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
1.5.3 Combination . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
1.6 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
1.7 Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
1.8 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38

2 Probability 43
2.1 Set Theory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
2.1.1 Why study set theory? . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
2.1.2 Basic concepts of a set . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
2.1.3 Subsets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
2.1.4 Empty set and universal set . . . . . . . . . . . . . . . . . . . . . . . . 48
2.1.5 Union . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
2.1.6 Intersection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
2.1.7 Complement and di↵erence . . . . . . . . . . . . . . . . . . . . . . . . 52
2.1.8 Disjoint and partition . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
2.1.9 Set operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
2.1.10 Closing remarks about set theory . . . . . . . . . . . . . . . . . . . . . 57

vii
CONTENTS

2.2 Probability Space . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58


2.2.1 Sample space ⌦ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
2.2.2 Event space F . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
2.2.3 Probability law P . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
2.2.4 Measure zero sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
2.2.5 Summary of the probability space . . . . . . . . . . . . . . . . . . . . 74
2.3 Axioms of Probability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
2.3.1 Why these three probability axioms? . . . . . . . . . . . . . . . . . . . 75
2.3.2 Axioms through the lens of measure . . . . . . . . . . . . . . . . . . . 76
2.3.3 Corollaries derived from the axioms . . . . . . . . . . . . . . . . . . . 77
2.4 Conditional Probability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
2.4.1 Definition of conditional probability . . . . . . . . . . . . . . . . . . . 81
2.4.2 Independence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
2.4.3 Bayes’ theorem and the law of total probability . . . . . . . . . . . . . 89
2.4.4 The Three Prisoners problem . . . . . . . . . . . . . . . . . . . . . . . 92
2.5 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
2.6 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
2.7 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97

3 Discrete Random Variables 103


3.1 Random Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
3.1.1 A motivating example . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
3.1.2 Definition of a random variable . . . . . . . . . . . . . . . . . . . . . . 105
3.1.3 Probability measure on random variables . . . . . . . . . . . . . . . . 107
3.2 Probability Mass Function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
3.2.1 Definition of probability mass function . . . . . . . . . . . . . . . . . . 110
3.2.2 PMF and probability measure . . . . . . . . . . . . . . . . . . . . . . . 110
3.2.3 Normalization property . . . . . . . . . . . . . . . . . . . . . . . . . . 112
3.2.4 PMF versus histogram . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
3.2.5 Estimating histograms from real data . . . . . . . . . . . . . . . . . . 117
3.3 Cumulative Distribution Functions (Discrete) . . . . . . . . . . . . . . . . . . 121
3.3.1 Definition of the cumulative distribution function . . . . . . . . . . . . 121
3.3.2 Properties of the CDF . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
3.3.3 Converting between PMF and CDF . . . . . . . . . . . . . . . . . . . 124
3.4 Expectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125
3.4.1 Definition of expectation . . . . . . . . . . . . . . . . . . . . . . . . . . 125
3.4.2 Existence of expectation . . . . . . . . . . . . . . . . . . . . . . . . . . 130
3.4.3 Properties of expectation . . . . . . . . . . . . . . . . . . . . . . . . . 130
3.4.4 Moments and variance . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
3.5 Common Discrete Random Variables . . . . . . . . . . . . . . . . . . . . . . . 136
3.5.1 Bernoulli random variable . . . . . . . . . . . . . . . . . . . . . . . . . 137
3.5.2 Binomial random variable . . . . . . . . . . . . . . . . . . . . . . . . . 143
3.5.3 Geometric random variable . . . . . . . . . . . . . . . . . . . . . . . . 149
3.5.4 Poisson random variable . . . . . . . . . . . . . . . . . . . . . . . . . . 152
3.6 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164
3.7 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165
3.8 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166

viii
CONTENTS

4 Continuous Random Variables 171


4.1 Probability Density Function . . . . . . . . . . . . . . . . . . . . . . . . . . . 172
4.1.1 Some intuitions about probability density functions . . . . . . . . . . . 172
4.1.2 More in-depth discussion about PDFs . . . . . . . . . . . . . . . . . . 174
4.1.3 Connecting with the PMF . . . . . . . . . . . . . . . . . . . . . . . . . 178
4.2 Expectation, Moment, and Variance . . . . . . . . . . . . . . . . . . . . . . . 180
4.2.1 Definition and properties . . . . . . . . . . . . . . . . . . . . . . . . . 180
4.2.2 Existence of expectation . . . . . . . . . . . . . . . . . . . . . . . . . . 183
4.2.3 Moment and variance . . . . . . . . . . . . . . . . . . . . . . . . . . . 184
4.3 Cumulative Distribution Function . . . . . . . . . . . . . . . . . . . . . . . . 185
4.3.1 CDF for continuous random variables . . . . . . . . . . . . . . . . . . 186
4.3.2 Properties of CDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188
4.3.3 Retrieving PDF from CDF . . . . . . . . . . . . . . . . . . . . . . . . 193
4.3.4 CDF: Unifying discrete and continuous random variables . . . . . . . 194
4.4 Median, Mode, and Mean . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
4.4.1 Median . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
4.4.2 Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198
4.4.3 Mean . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 199
4.5 Uniform and Exponential Random Variables . . . . . . . . . . . . . . . . . . . 201
4.5.1 Uniform random variables . . . . . . . . . . . . . . . . . . . . . . . . . 202
4.5.2 Exponential random variables . . . . . . . . . . . . . . . . . . . . . . . 205
4.5.3 Origin of exponential random variables . . . . . . . . . . . . . . . . . . 207
4.5.4 Applications of exponential random variables . . . . . . . . . . . . . . 209
4.6 Gaussian Random Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211
4.6.1 Definition of a Gaussian random variable . . . . . . . . . . . . . . . . 211
4.6.2 Standard Gaussian . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213
4.6.3 Skewness and kurtosis . . . . . . . . . . . . . . . . . . . . . . . . . . . 216
4.6.4 Origin of Gaussian random variables . . . . . . . . . . . . . . . . . . 220
4.7 Functions of Random Variables . . . . . . . . . . . . . . . . . . . . . . . . . . 223
4.7.1 General principle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223
4.7.2 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225
4.8 Generating Random Numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . 229
4.8.1 General principle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229
4.8.2 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230
4.9 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
4.10 Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
4.11 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237

5 Joint Distributions 241


5.1 Joint PMF and Joint PDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
5.1.1 Probability measure in 2D . . . . . . . . . . . . . . . . . . . . . . . . . 244
5.1.2 Discrete random variables . . . . . . . . . . . . . . . . . . . . . . . . . 245
5.1.3 Continuous random variables . . . . . . . . . . . . . . . . . . . . . . . 247
5.1.4 Normalization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248
5.1.5 Marginal PMF and marginal PDF . . . . . . . . . . . . . . . . . . . . 250
5.1.6 Independent random variables . . . . . . . . . . . . . . . . . . . . . . 251
5.1.7 Joint CDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255
5.2 Joint Expectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257

ix
CONTENTS

5.2.1 Definition and interpretation . . . . . . . . . . . . . . . . . . . . . . . 257


5.2.2 Covariance and correlation coefficient . . . . . . . . . . . . . . . . . . 261
5.2.3 Independence and correlation . . . . . . . . . . . . . . . . . . . . . . . 263
5.2.4 Computing correlation from data . . . . . . . . . . . . . . . . . . . . . 265
5.3 Conditional PMF and PDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . 266
5.3.1 Conditional PMF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267
5.3.2 Conditional PDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
5.4 Conditional Expectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 275
5.4.1 Definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 275
5.4.2 The law of total expectation . . . . . . . . . . . . . . . . . . . . . . . 276
5.5 Sum of Two Random Variables . . . . . . . . . . . . . . . . . . . . . . . . . . 280
5.5.1 Intuition through convolution . . . . . . . . . . . . . . . . . . . . . . . 280
5.5.2 Main result . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 281
5.5.3 Sum of common distributions . . . . . . . . . . . . . . . . . . . . . . . 282
5.6 Random Vectors and Covariance Matrices . . . . . . . . . . . . . . . . . . . . 286
5.6.1 PDF of random vectors . . . . . . . . . . . . . . . . . . . . . . . . . . 286
5.6.2 Expectation of random vectors . . . . . . . . . . . . . . . . . . . . . . 288
5.6.3 Covariance matrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 289
5.6.4 Multidimensional Gaussian . . . . . . . . . . . . . . . . . . . . . . . . 290
5.7 Transformation of Multidimensional Gaussians . . . . . . . . . . . . . . . . . 293
5.7.1 Linear transformation of mean and covariance . . . . . . . . . . . . . . 293
5.7.2 Eigenvalues and eigenvectors . . . . . . . . . . . . . . . . . . . . . . . 295
5.7.3 Covariance matrices are always positive semi-definite . . . . . . . . . . 297
5.7.4 Gaussian whitening . . . . . . . . . . . . . . . . . . . . . . . . . . . . 299
5.8 Principal-Component Analysis . . . . . . . . . . . . . . . . . . . . . . . . . . 303
5.8.1 The main idea: Eigendecomposition . . . . . . . . . . . . . . . . . . . 303
5.8.2 The eigenface problem . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
5.8.3 What cannot be analyzed by PCA? . . . . . . . . . . . . . . . . . . . 311
5.9 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 312
5.10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
5.11 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 314

6 Sample Statistics 319


6.1 Moment-Generating and Characteristic Functions . . . . . . . . . . . . . . . . 324
6.1.1 Moment-generating function . . . . . . . . . . . . . . . . . . . . . . . . 324
6.1.2 Sum of independent variables via MGF . . . . . . . . . . . . . . . . . 327
6.1.3 Characteristic functions . . . . . . . . . . . . . . . . . . . . . . . . . . 329
6.2 Probability Inequalities . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333
6.2.1 Union bound . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333
6.2.2 The Cauchy-Schwarz inequality . . . . . . . . . . . . . . . . . . . . . . 335
6.2.3 Jensen’s inequality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 336
6.2.4 Markov’s inequality . . . . . . . . . . . . . . . . . . . . . . . . . . . . 339
6.2.5 Chebyshev’s inequality . . . . . . . . . . . . . . . . . . . . . . . . . . . 341
6.2.6 Cherno↵’s bound . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 343
6.2.7 Comparing Cherno↵ and Chebyshev . . . . . . . . . . . . . . . . . . . 344
6.2.8 Hoe↵ding’s inequality . . . . . . . . . . . . . . . . . . . . . . . . . . . 348
6.3 Law of Large Numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351
6.3.1 Sample average . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351

x
CONTENTS

6.3.2 Weak law of large numbers (WLLN) . . . . . . . . . . . . . . . . . . . 354


6.3.3 Convergence in probability . . . . . . . . . . . . . . . . . . . . . . . . 356
6.3.4 Can we prove WLLN using Cherno↵’s bound? . . . . . . . . . . . . . 358
6.3.5 Does the weak law of large numbers always hold? . . . . . . . . . . . . 359
6.3.6 Strong law of large numbers . . . . . . . . . . . . . . . . . . . . . . . . 360
6.3.7 Almost sure convergence . . . . . . . . . . . . . . . . . . . . . . . . . . 362
6.3.8 Proof of the strong law of large numbers . . . . . . . . . . . . . . . . . 364
6.4 Central Limit Theorem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 366
6.4.1 Convergence in distribution . . . . . . . . . . . . . . . . . . . . . . . . 367
6.4.2 Central Limit Theorem . . . . . . . . . . . . . . . . . . . . . . . . . . 372
6.4.3 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 377
6.4.4 Limitation of the Central Limit Theorem . . . . . . . . . . . . . . . . 378
6.5 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 380
6.6 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 381
6.7 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 383

7 Regression 389
7.1 Principles of Regression . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394
7.1.1 Intuition: How to fit a straight line? . . . . . . . . . . . . . . . . . . . 395
7.1.2 Solving the linear regression problem . . . . . . . . . . . . . . . . . . . 397
7.1.3 Extension: Beyond a straight line . . . . . . . . . . . . . . . . . . . . . 401
7.1.4 Overdetermined and underdetermined systems . . . . . . . . . . . . . 409
7.1.5 Robust linear regression . . . . . . . . . . . . . . . . . . . . . . . . . . 412
7.2 Overfitting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 418
7.2.1 Overview of overfitting . . . . . . . . . . . . . . . . . . . . . . . . . . . 419
7.2.2 Analysis of the linear case . . . . . . . . . . . . . . . . . . . . . . . . . 420
7.2.3 Interpreting the linear analysis results . . . . . . . . . . . . . . . . . . 425
7.3 Bias and Variance Trade-O↵ . . . . . . . . . . . . . . . . . . . . . . . . . . . . 429
7.3.1 Decomposing the testing error . . . . . . . . . . . . . . . . . . . . . . 430
7.3.2 Analysis of the bias . . . . . . . . . . . . . . . . . . . . . . . . . . . . 433
7.3.3 Variance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 436
7.3.4 Bias and variance on the learning curve . . . . . . . . . . . . . . . . . 438
7.4 Regularization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440
7.4.1 Ridge regularization . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440
7.4.2 LASSO regularization . . . . . . . . . . . . . . . . . . . . . . . . . . . 449
7.5 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 457
7.6 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458
7.7 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 459

8 Estimation 465
8.1 Maximum-Likelihood Estimation . . . . . . . . . . . . . . . . . . . . . . . . . 468
8.1.1 Likelihood function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 468
8.1.2 Maximum-likelihood estimate . . . . . . . . . . . . . . . . . . . . . . . 472
8.1.3 Application 1: Social network analysis . . . . . . . . . . . . . . . . . . 478
8.1.4 Application 2: Reconstructing images . . . . . . . . . . . . . . . . . . 481
8.1.5 More examples of ML estimation . . . . . . . . . . . . . . . . . . . . . 484
8.1.6 Regression versus ML estimation . . . . . . . . . . . . . . . . . . . . . 487
8.2 Properties of ML Estimates . . . . . . . . . . . . . . . . . . . . . . . . . . . . 491

xi
CONTENTS

8.2.1 Estimators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 491


8.2.2 Unbiased estimators . . . . . . . . . . . . . . . . . . . . . . . . . . . . 492
8.2.3 Consistent estimators . . . . . . . . . . . . . . . . . . . . . . . . . . . 494
8.2.4 Invariance principle . . . . . . . . . . . . . . . . . . . . . . . . . . . . 500
8.3 Maximum A Posteriori Estimation . . . . . . . . . . . . . . . . . . . . . . . . 502
8.3.1 The trio of likelihood, prior, and posterior . . . . . . . . . . . . . . . . 503
8.3.2 Understanding the priors . . . . . . . . . . . . . . . . . . . . . . . . . 504
8.3.3 MAP formulation and solution . . . . . . . . . . . . . . . . . . . . . . 506
8.3.4 Analyzing the MAP solution . . . . . . . . . . . . . . . . . . . . . . . 508
8.3.5 Analysis of the posterior distribution . . . . . . . . . . . . . . . . . . . 511
8.3.6 Conjugate prior . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 513
8.3.7 Linking MAP with regression . . . . . . . . . . . . . . . . . . . . . . . 517
8.4 Minimum Mean-Square Estimation . . . . . . . . . . . . . . . . . . . . . . . . 520
8.4.1 Positioning the minimum mean-square estimation . . . . . . . . . . . 520
8.4.2 Mean squared error . . . . . . . . . . . . . . . . . . . . . . . . . . . . 522
8.4.3 MMSE estimate = conditional expectation . . . . . . . . . . . . . . . 523
8.4.4 MMSE estimator for multidimensional Gaussian . . . . . . . . . . . . 529
8.4.5 Linking MMSE and neural networks . . . . . . . . . . . . . . . . . . . 533
8.5 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 534
8.6 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 535
8.7 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 536

9 Confidence and Hypothesis 541


9.1 Confidence Interval . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 543
9.1.1 The randomness of an estimator . . . . . . . . . . . . . . . . . . . . . 543
9.1.2 Understanding confidence intervals . . . . . . . . . . . . . . . . . . . . 545
9.1.3 Constructing a confidence interval . . . . . . . . . . . . . . . . . . . . 548
9.1.4 Properties of the confidence interval . . . . . . . . . . . . . . . . . . . 551
9.1.5 Student’s t-distribution . . . . . . . . . . . . . . . . . . . . . . . . . . 554
9.1.6 Comparing Student’s t-distribution and Gaussian . . . . . . . . . . . . 558
9.2 Bootstrapping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 559
9.2.1 A brute force approach . . . . . . . . . . . . . . . . . . . . . . . . . . 560
9.2.2 Bootstrapping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 562
9.3 Hypothesis Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 566
9.3.1 What is a hypothesis? . . . . . . . . . . . . . . . . . . . . . . . . . . . 566
9.3.2 Critical-value test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 567
9.3.3 p-value test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 571
9.3.4 Z-test and T -test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 574
9.4 Neyman-Pearson Test . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 577
9.4.1 Null and alternative distributions . . . . . . . . . . . . . . . . . . . . . 577
9.4.2 Type 1 and type 2 errors . . . . . . . . . . . . . . . . . . . . . . . . . 579
9.4.3 Neyman-Pearson decision . . . . . . . . . . . . . . . . . . . . . . . . . 582
9.5 ROC and Precision-Recall Curve . . . . . . . . . . . . . . . . . . . . . . . . . 589
9.5.1 Receiver Operating Characteristic (ROC) . . . . . . . . . . . . . . . . 589
9.5.2 Comparing ROC curves . . . . . . . . . . . . . . . . . . . . . . . . . . 592
9.5.3 The ROC curve in practice . . . . . . . . . . . . . . . . . . . . . . . . 598
9.5.4 The Precision-Recall (PR) curve . . . . . . . . . . . . . . . . . . . . . 601
9.6 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605

xii
CONTENTS

9.7 Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 606


9.8 Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 607

10 Random Processes 611


10.1 Basic Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 612
10.1.1 Everything you need to know about a random process . . . . . . . . . 612
10.1.2 Statistical and temporal perspectives . . . . . . . . . . . . . . . . . . . 614
10.2 Mean and Correlation Functions . . . . . . . . . . . . . . . . . . . . . . . . . 618
10.2.1 Mean function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 618
10.2.2 Autocorrelation function . . . . . . . . . . . . . . . . . . . . . . . . . . 622
10.2.3 Independent processes . . . . . . . . . . . . . . . . . . . . . . . . . . . 629
10.3 Wide-Sense Stationary Processes . . . . . . . . . . . . . . . . . . . . . . . . . 630
10.3.1 Definition of a WSS process . . . . . . . . . . . . . . . . . . . . . . . . 631
10.3.2 Properties of RX (⌧ ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 632
10.3.3 Physical interpretation of RX (⌧ ) . . . . . . . . . . . . . . . . . . . . . 633
10.4 Power Spectral Density . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 636
10.4.1 Basic concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 636
10.4.2 Origin of the power spectral density . . . . . . . . . . . . . . . . . . . 640
10.5 WSS Process through LTI Systems . . . . . . . . . . . . . . . . . . . . . . . . 643
10.5.1 Review of linear time-invariant systems . . . . . . . . . . . . . . . . . 643
10.5.2 Mean and autocorrelation through LTI Systems . . . . . . . . . . . . . 644
10.5.3 Power spectral density through LTI systems . . . . . . . . . . . . . . . 646
10.5.4 Cross-correlation through LTI Systems . . . . . . . . . . . . . . . . . . 649
10.6 Optimal Linear Filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 653
10.6.1 Discrete-time random processes . . . . . . . . . . . . . . . . . . . . . . 653
10.6.2 Problem formulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 654
10.6.3 Yule-Walker equation . . . . . . . . . . . . . . . . . . . . . . . . . . . 656
10.6.4 Linear prediction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 658
10.6.5 Wiener filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 662
10.7 Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 669
10.8 Appendix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 670
10.8.1 The Mean-Square Ergodic Theorem . . . . . . . . . . . . . . . . . . . 674
10.9 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 675
10.10Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 676

A Appendix 681

xiii
CONTENTS

xiv
Chapter 1

Mathematical Background

“Data science” has di↵erent meanings to di↵erent people. If you ask a biologist, data science
could mean analyzing DNA sequences. If you ask a banker, data science could mean pre-
dicting the stock market. If you ask a software engineer, data science could mean programs
and data structures; if you ask a machine learning scientist, data science could mean models
and algorithms. However, one thing that is common in all these disciplines is the concept of
uncertainty. We choose to learn from data because we believe that the latent information
is embedded in the data — unprocessed, contains noise, and could have missing entries. If
there is no randomness, all data scientists can close their business because there is simply
no problem to solve. However, the moment we see randomness, our business comes back.
Therefore, data science is the subject of making decisions in uncertainty.
The mathematics of analyzing uncertainty is probability. It is the tool to help us model,
analyze, and predict random events. Probability can be studied in as many ways as you can
think of. You can take a rigorous course in probability theory, or a “probability for dummies”
on the internet, or a typical undergraduate probability course o↵ered by your school. This
book is di↵erent from all these. Our goal is to tell you how things work in the context of data
science. For example, why do we need those three axioms of probabilities and not others?
Where does the “bell shape” Gaussian random variable come from? How many samples do
we need to construct a reliable histogram? These questions are at the core of data science,
and they deserve close attention rather than sweeping them under the rug.
To help you get used to the pace and style of this book, in this chapter, we review some
of the very familiar topics in undergraduate algebra and calculus. These topics are meant
to warm up your mathematics background so that you can follow the subsequent chapters.
Specifically, in this chapter, we cover several topics. First, in Section 1.1 we discuss infinite
series, something that will be used frequently when we evaluate the expectation and variance
of random variables in Chapter 3. In Section 1.2 we review the Taylor approximation,
which will be helpful when we discuss continuous random variables. Section 1.3 discusses
integration and reviews several tricks we can use to make integration easy. Section 1.4
deals with linear algebra, aka matrices and vectors, which are fundamental to modern data
analysis. Finally, Section 1.5 discusses permutation and combination, two basic techniques
to count events.

1
CHAPTER 1. MATHEMATICAL BACKGROUND

1.1 Infinite Series

Imagine that you have a fair coin. If you get a tail, you flip it again. You do this repeatedly
until you finally get a head. What is the probability that you need to flip the coin three
times to get one head?
This is a warm-up exercise. Since the coin is fair, the probability of obtaining a head
is 12 . The probability of getting a tail followed by a head is 12 ⇥ 12 = 14 . Similarly, the
probability of getting two tails and then a head is 12 ⇥ 12 ⇥ 12 = 18 . If you follow this logic, you
can write down the probabilities for all other cases. For your convenience, we have drawn the
first few in Figure 1.1. As you have probably noticed, the probabilities follow the pattern
{ 12 , 14 , 18 , . . .}.

Figure 1.1: Suppose you flip a coin until you see a head. This requires you to have N 1 tails followed
by a head. The probability of this sequence of events are 12 , 14 , 18 , . . . , which forms an infinite sequence.

We can also summarize these probabilities using a familiar plot called the histogram
as shown in Figure 1.2. The histogram for this problem has a special pattern, that every
value is one order higher than the preceding one, and the sequence is infinitely long.

0.5

0.4

0.3

0.2

0.1

0
1 2 3 4 5 6 7 8 9 10

Figure 1.2: The histogram of flipping a coin until we see a head. The x-axis is the number of coin flips,
and the y-axis is the probability.

Let us ask something harder: On average, if you want to be 90% sure that you will
get a head, what is the minimum number of attempts you need to try? Five attempts?
Ten attempts? Indeed, if you try ten attempts, you will very likely accomplish your goal.
However, this would seem to be overkill. If you try five attempts, then it becomes unclear
whether you will be 90% sure.

2
1.1. INFINITE SERIES

This problem can be answered by analyzing the sequence of probabilities. If we make


two attempts, then the probability of getting a head is the sum of the probabilities for one
attempt and that of two attempts:
1
P[success after 1 attempt] = = 0.5
2
1 1
P[success after 2 attempts] = + = 0.75
2 4
Therefore, if you make 3 attempts or 4 attempts, you get the following probabilities:
1 1 1
P[success after 3 attempts] = + + = 0.875
2 4 8
1 1 1 1
P[success after 4 attempts] = + + + = 0.9375.
2 4 8 16
So if we try four attempts, we will have a 93.75% probability of getting a head. Thus, four
attempts is the answer.
The MATLAB / Python codes we used to generate Figure 1.2 are shown below.
% MATLAB code to generate a geometric sequence
p = 1/2;
n = 1:10;
X = p.^n;
bar(n,X,’FaceColor’,[0.8, 0.2,0.2]);

# Python code to generate a geometric sequence


import numpy as np
import matplotlib.pyplot as plt
p = 1/2
n = np.arange(0,10)
X = np.power(p,n)
plt.bar(n,X)

This warm-up exercise has perhaps raised some of your interest in the subject. However,
we will not tell you everything now. We will come back to the probability in Chapter 3
when we discuss geometric random variables. In the present section, we want to make sure
you have the basic mathematical tools to calculate quantities, such as a sum of fractional
numbers. For example, what if we want to calculate P[success after 107 attempts]? Is there
a systematic way of performing the calculation?
Remark. You should be aware that the 93.75% only says that the probability of achieving
the goal is high. If you have a bad day, you may still need more than four attempts. Therefore,
when we stated the question, we asked for 90% “on average”. Sometimes you may need
more attempts and sometimes fewer attempts, but on average, you have a 93.75% chance
of succeeding.

1.1.1 Geometric Series


A geometric series is the sum of a finite or an infinite sequence of numbers with a constant
ratio between successive terms. As we have seen in the previous example, a geometric series

3
CHAPTER 1. MATHEMATICAL BACKGROUND

appears naturally in the context of discrete events. In Chapter 3 of this book, we will use
geometric series when calculating the expectation and moments of a random variable.

Definition 1.1. Let 0 < r < 1, a finite geometric sequence of power n is a sequence
of numbers ⇢
1, r, r2 , . . . , rn .

An infinite geometric sequence is a sequence of numbers



1, r, r2 , r3 , . . . .

Theorem 1.1. The sum of a finite geometric series of power n is


n
X 1 rn+1
rk = 1 + r + r2 + · · · + rn = . (1.1)
1 r
k=0

Proof. We multiply both sides by 1 r. The left hand side becomes


n
!
X
r (1 r) = 1 + r + r2 + · · · + rn (1 r)
k

k=0
= 1 + r + r2 + · · · + rn r + r2 + r3 + · · · + rn+1
(a)
= 1 rn+1 ,

where (a) holds because terms are canceled due to subtractions.



A corollary of Equation (1.1) is the sum of an infinite geometric sequence.

Corollary 1.1. Let 0 < r < 1. The sum of an infinite geometric series is
1
X 1
rk = 1 + r + r2 + · · · = . (1.2)
1 r
k=0

Proof. We take the limit in Equation (1.1). This yields


1
X n
X 1 rn+1 1
rk = lim rk = lim = .
n!1 n!1 1 r 1 r
k=0 k=0


Remark. Note that the condition 0 < r < 1 is important. If r > 1, then the limit
limn!1 rn+1 in Equation (1.2) will diverge. The constant r cannot equal to 1, for oth-
erwise the fraction (1 rn+1 )/(1 r)P is undefined. We are not interested in the case when
1
r = 0, because the sum is trivially 1: k=0 0k = 1 + 01 + 02 + · · · = 1.

4
1.1. INFINITE SERIES

P
1
1
Practice Exercise 1.1. Compute the infinite series 2k
.
k=2
Solution.
X1
1 1 1
k
= + + ···+
2 4 8
k=2
✓ ◆
1 1 1
= 1 + + + ···
4 2 4
1 1 1
= · = .
4 1 12 2

Remark. You should not be confused about a geometric series and a harmonic series. A
harmonic series concerns with the sum of {1, 12 , 13 , 14 , . . .}. It turns out that1

X1
1 1 1 1
= 1 + + + + · · · = 1.
n=1
n 2 3 4

On the other hand, a squared harmonic series {1, 212 , 312 , 412 , . . .} converges:

X1
1 1 1 1 ⇡2
2
= 1 + 2 + 2 + 2 + ··· = .
n=1
n 2 3 4 6

The latter result is known as the Basel problem.


We can extend the main theorem by considering more complicated series, for example
the following one.

Corollary 1.2. Let 0 < r < 1. It holds that


1
X 1
krk 1
= 1 + 2r + 3r2 + · · · = . (1.3)
(1 r)2
k=1

Proof. Take the derivative on both sides of Equation (1.2). The left hand side becomes
1 1
d X k d 2 2
X
r = 1 + r + r + · · · = 1 + 2r + 3r + · · · = krk 1
dr dr
k=0 k=1
✓ ◆
d 1 1
The right hand side becomes = .
dr 1 r (1 r)2

P1 1
Practice Exercise 1.2. Compute the infinite sum k=1 k· 3k
.

1 This result can be found in Tom Apostol, Mathematical Analysis, 2nd Edition, Theorem 8.11.

5
CHAPTER 1. MATHEMATICAL BACKGROUND

Solution. We can use the derivative result:


1
X 1 1 1 1
k· k
=1· +2· +3· + ···
3 3 9 27
k=1
✓ ◆
1 1 1 1 1 1 1 3
= · 1 + 2 · + 3 · + ··· = · 1 2
= · 4 = .
3 3 9 3 (1 3 ) 3 9 4

1.1.2 Binomial Series


A geometric series is useful when handling situations such as N 1 failures followed by
a success. However, we can easily twist the problem by asking: What is the probability
of getting one head out of 3 independent coin tosses? In this case, the probability can be
determined by enumerating all possible cases:
P[1 head in 3 coins] = P[H,T,T] + P[T,H,T] + P[T,T,H]
✓ ◆ ✓ ◆ ✓ ◆
1 1 1 1 1 1 1 1 1
= ⇥ ⇥ + ⇥ ⇥ + ⇥ ⇥
2 2 2 2 2 2 2 2 2
3
= .
8
Figure 1.3 illustrates the situation.

Figure 1.3: When flipping three coins independently, the probability of getting exactly one head can
come from three di↵erent possibilities.

What lessons have we learned in this example? Notice that you need to enumerate
all possible combinations of one head and two tails to solve this problem. The number is
3 in our example. In general, the number of combinations can be systematically studied
using combinatorics, which we will discuss later in the chapter. However, the number of
combinations motivates us to discuss another background technique known as the binomial
series. The binomial series is instrumental in algebra when handling polynomials such as
(a + b)2 or (1 + x)3 . It provides a valuable formula when computing these powers.

Theorem 1.2 (Binomial theorem). For any real numbers a and b, the binomial series
of power n is
n ✓ ◆
X n n k k
(a + b)n = a b , (1.4)
k
k=0
n n!
where k = k!(n k)! .

n
The binomial theorem is valid for any real numbers a and b. The quantity k reads
as “n choose k”. Its definition is
✓ ◆
n def n!
= ,
k k!(n k)!

6
1.1. INFINITE SERIES

where n! = n(n 1)(n 2) · · · 3 · 2 · 1. We shall discuss the physical meaning of nk in


Section 1.5. But we can quickly plug in the “n choose k” into the coin flipping example by
letting n = 3 and k = 1:
✓ ◆
3 3!
Number of combinations for 1 head and 2 tails = = = 3.
1 1!2!

So you can see why we want you to spend your precious time learning about the binomial
theorem. In MATLAB and Python, nk can be computed using the commands as follows.

% MATLAB code to compute (N choose K) and K!


n = 10;
k = 2;
nchoosek(n,k)
factorial(k)

# Python code to compute (N choose K) and K!


from scipy.special import comb, factorial
n = 10
k = 2
comb(n, k)
factorial(k)

The binomial theorem makes the most sense when we also learn about the Pascal’s
identity.

Theorem 1.3 (Pascal’s identity). Let n and k be positive integers such that k  n.
Then, ✓ ◆ ✓ ◆ ✓ ◆
n n n+1
+ = . (1.5)
k k 1 k

Proof. We start by recalling the definition of nk . This gives us


✓ ◆ ✓ ◆
n n n! n!
+ = +
k k 1 k!(n k)! (k 1)!(n (k 1))!
✓ ◆
1 1
= n! + ,
k!(n k)! (k 1)!(n k + 1)!

where we factor out n! to obtain the second equation. Next, we observe that

1 (n k + 1) n k+1
⇥ = ,
k!(n k)! (n k + 1) k!(n k + 1)!
1 k k
⇥ = .
(k 1)!(n k + 1)! k k!(n k + 1)!

7
CHAPTER 1. MATHEMATICAL BACKGROUND

Substituting into the previous equation we obtain


✓ ◆ ✓ ◆ ✓ ◆
n n n k+1 k
+ = n! +
k k 1 k!(n k + 1)! k!(n k + 1)!
✓ ◆
n+1
= n!
k!(n k + 1)!
(n + 1)!
=
k!(n + 1 k)!
✓ ◆
n+1
= .
k


The Pascal triangle is a visualization of the coefficients of (a + b)n as shown in Fig-
ure 1.4. For example, when n = 5, we know that 53 = 10. However, by Pascal’s identity, we
know that 53 = 42 + 43 . So the number 10 is actually obtained by summing the numbers
4 and 6 of the previous row.

Figure 1.4: Pascal triangle for n = 0, . . . , 5. Note that a number in one row is obtained by summing
two numbers directly above it.

Practice Exercise 1.3. Find (1 + x)3 .


Solution. Using the binomial theorem, we can show that
n ✓ ◆
X 3
(1 + x)3 = 13 k k
x
k
k=0
= 1 + 3x + 3x2 + x3 .

Practice Exercise 1.4. Let 0 < p < 1. Find


n ✓ ◆
X n
pn k
(1 p)k .
k
k=0

8
1.1. INFINITE SERIES

Solution. By using the binomial theorem, we have


n ✓ ◆
X n
pn k
(1 p)k = (p + (1 p))n = 1.
k
k=0

This result will be helpful when evaluating binomial random variables in Chapter 3.

We now prove the binomial theorem. Please feel free to skip the proof if this is your first
time reading the book.

Proof of the binomial theorem. We prove by induction. When n = 1,


(a + b)1 = a + b
1
X
= a1 k k
b .
k=0

Therefore, the base case is verified. Assume up to case n. We need to verify case n + 1.
(a + b)n+1 = (a + b)(a + b)n
Xn ✓ ◆
n n k k
= (a + b) a b
k
k=0
Xn ✓ ◆ n ✓ ◆
n n k+1 k X n n k k+1
= a b + a b .
k k
k=0 k=0

We want to apply the Pascal’s identity to combine the two terms. In order to do so, we note
that the second term in this sum can be rewritten as
Xn ✓ ◆ n ✓ ◆
n n k k+1 X n n+1 k 1 k+1
a b = a b
k k
k=0 k=0
X✓ n ◆
n+1
= an+1 ` b` , where ` = k + 1
` 1
`=1
Xn ✓ ◆
n
= an+1 ` b` + bn+1 .
` 1
`=1

The first term in the sum can be written as


Xn ✓ ◆ n ✓ ◆
n n k+1 k X n n+1 ` `
a b = a b + an+1 , where ` = k.
k `
k=0 `=1

Therefore, the two terms can be combined using Pascal’s identity to yield
Xn ✓ ◆ ✓ ◆
n+1 n n
(a + b) = + an+1 ` b` + an+1 + bn+1
` ` 1
`=1
Xn ✓ ◆ X ✓n + 1 ◆
n+1
n + 1 n+1 ` `
= a b + an+1 + bn+1 = an+1 ` `
b.
` `
`=1 `=0

9
CHAPTER 1. MATHEMATICAL BACKGROUND

Hence, the (n + 1)th case is also verified. By the principle of mathematical induction, we
have completed the proof.

The end of the proof. Please join us again.

1.2 Approximation

Consider a function f (x) = log(1 + x), for x > 0 as shown in Figure 1.5. This is a nonlinear
function, and we all know that nonlinear functions are not fun to deal with. For example,
Rb
if you want to integrate the function a x log(1 + x) dx, then the logarithm will force you
to do integration by parts. However, in many practical problems, you may not need the full
range of x > 0. Suppose that you are only interested in values x ⌧ 1. Then the logarithm
can be approximated, and thus the integral can also be approximated.

2 0.2

1.5 0.15

1 0.1

0.5 0.05

0 0
0 1 2 3 4 5 0 0.05 0.1 0.15 0.2

Figure 1.5: The function f (x) = log(1 + x) and the approximation fb(x) = x.

To see how this is even possible, we show in Figure 1.5 the nonlinear function f (x) =
log(1 + x) and an approximation fb(x) = x. The approximation is carefully chosen such that
for x ⌧ 1, the approximation fb(x) is close to the true function f (x). Therefore, we can
argue that for x ⌧ 1,
log(1 + x) ⇡ x, (1.6)
thereby simplifying the calculation. For example, if you want to integrate x log(1 + x) for
R 0.1 R 0.1
0 < x < 0.1, then the integral can be approximated by 0 x log(1 + x) dx ⇡ 0 x2 dx =
3
x 4
3 = 3.33 ⇥ 10 . (The actual integral is 3.21 ⇥ 10 4 .) In this section we will learn about
the basic approximation techniques. We will use them when we discuss limit theorems in
Chapter 6, as well as various distributions, such as from binomial to Poisson.

10
1.2. APPROXIMATION

1.2.1 Taylor approximation


Given a function f : R ! R, it is often useful to analyze its behavior by approximating f
using its local information. Taylor approximation (or Taylor series) is one of the tools for
such a task. We will use the Taylor approximation on many occasions.

Definition 1.2 (Taylor Approximation). Let f : R ! R be a continuous function with


infinite derivatives. Let a 2 R be a fixed constant. The Taylor approximation of f at
x = a is
f 00 (a)
f (x) = f (a) + f 0 (a)(x a) + (x a)2 + · · ·
2!
X1
f (n) (a)
= (x a)n , (1.7)
n=0
n!

where f (n) denotes the nth-order derivative of f .

Taylor approximation is a geometry-based approximation. It approximates the function


according to the o↵set, slope, curvature, and so on. According to Definition 1.2, the Taylor
series has an infinite number of terms. If we use a finite number of terms, we obtain the
nth-order Taylor approximation:

First-Order : f (x) = f (a) + f 0 (a)(x a) + O((x a)2 )


|{z} | {z }
o↵set slope
f 00 (a)
Second-Order : f (x) = f (a) + f 0 (a)(x a) + (x a)2 + O((x a)3 ).
|{z} | {z } | 2! {z }
o↵set slope
curvature

Here, the big-O notation O("k ) means any term that has an order at least power k. For
small ", i.e., " ⌧ 1, a high-order term O("k ) ⇡ 0 for large k.

Example 1.1. Let f (x) = sin x. Then the Taylor approximation at x = 0 is

f 00 (0) f 000 (0)


f (x) ⇡ f (0) + f 0 (0)(x 0) + (x 0)2 + (x 0)3
2! 3!
sin(0) cos(0)
= sin(0) + (cos 0)(x 0) (x 0)2 (x 0)3
2! 3!
x3 x3
=0+x 0 =x .
6 6
We can expand further to higher orders, which yields

x3 x5 x7
f (x) = x + + ···
3! 5! 7!
We show the first few approximations in Figure 1.6.
One should be reminded that Taylor approximation approximates a function f (x)
at a particular point x = a. Therefore, the approximation of f near x = 0 and the

11
CHAPTER 1. MATHEMATICAL BACKGROUND

approximation of f near x = ⇡/2 are di↵erent. For example, the Taylor approximation
at x = ⇡/2 for f (x) = sin x is

⇡ ⇡⇣ ⇡ ⌘ sin ⇡2 ⇣ ⇡ ⌘2 cos ⇡2 ⇣ ⇡ ⌘3
f (x) = sin + cos x x x
2 2 2 2! 2 3! 2
1 ⇣ ⇡ 2⌘ 1 ⇣ ⌘
⇡ 2
=1+0 x 0=1 x .
4 2 4 2

4 4
sin x sin x
3rd order 3rd order
5th order 5th order
2 2
7th order 7th order

0 0

-2 -2

-4 -4
-10 -5 0 5 10 -10 -5 0 5 10
x x
(a) Approximate at x = 0 (b) Approximate at x = ⇡/2

Figure 1.6: Taylor approximation of the function f (x) = sin x.

1.2.2 Exponential series


An immediate application of the Taylor approximation is to derive the exponential series.

Theorem 1.4. Let x be any real number. Then,


X xk 1
x2 x3
ex = 1 + x + + + ··· = . (1.8)
2 3! k!
k=0

Proof. Let f (x) = ex for any x. Then, the Taylor approximation around x = 0 is

f 00 (0)
f (x) = f (0) + f 0 (0)(x 0) + (x 0)2 + · · ·
2!
e0
= e0 + e0 (x (x 0)2 + · · ·
0) +
2!
X1
x2 xk
=1+x+ + ··· = .
2 k!
k=0


1
X k
e
Practice Exercise 1.5. Evaluate .
k!
k=0

12
1.2. APPROXIMATION

Solution.
1
X k 1
X k
e
=e =e e = 1.
k! k!
k=0 k=0

This result will be useful for Poisson random variables in Chapter 3.


p
If we substitute x = j✓ where j = 1, then we can show that

(j✓)2
ej✓
|{z} = 1 + j✓ + + ···
2!
=cos ✓+j sin ✓
✓ ◆ ✓ ◆
✓2 ✓4 ✓3
= 1 + + ··· + j ✓ + ···
2! 4! 3!
| {z } | {z }
real imaginary

Matching the real and the imaginary terms, we can show that

✓2 ✓4
cos ✓ = 1 + + ···
2! 4!
✓3 ✓5
sin ✓ = ✓ + + ···
3! 5!
This gives the infinite series representations of the two trigonometric functions.

1.2.3 Logarithmic approximation


Taylor approximation also allows us to find approximations to logarithmic functions. We
start by presenting a lemma.

Lemma 1.1. Let 0 < x < 1 be a constant. Then,

log(1 + x) = x x2 + O(x3 ). (1.9)

Proof. Let f (x) = log(1 + x). Then, the derivatives of f are


1 1
f 0 (x) = , and f 00 (x) = .
(1 + x) (1 + x)2

Taylor approximation at x = 0 gives

f 00 (0)
f (x) = f (0) + f 0 (0)(x 0) + (x 0)2 + O(x3 )
✓ ◆ ✓ 2 ◆
1 1
= log 1 + x x2 + O(x3 )
(1 + 0) (1 + 0)2
=x x2 + O(x3 ).


The di↵erence between this result and the result we showed in the beginning of this
section is the order of polynomials we used to approximate the logarithm:

13
CHAPTER 1. MATHEMATICAL BACKGROUND

First-order: log(1 + x) = x
Second-order: log(1 + x) = x x2 .
What order of approximation is good? It depends on where you want the approximation to
be good, and how far you want the approximation to go. The di↵erence between first-order
and second-order approximations is shown in Figure 1.7.
2 2

1.5 1.5

1 1

0.5 0.5

0 0
0 1 2 3 4 5 0 1 2 3 4 5
First-order approximation Second-order approximation

Figure 1.7: The function f (x) = log(1 + x), the first-order approximation fb(x) = x, and the second-
order approximation fb(x) = x x2 .

Example 1.2. When we prove the Central Limit Theorem in Chapter 6, we need to
use the following result.
✓ ◆N
s2 2
lim 1 + = es /2 .
N !1 2N
The proof
⇣ of ⌘this equation can be done using the Taylor approximation. Consider
2
N log 1 + sN . By the logarithmic lemma, we can obtain the second-order approxi-
mation: ✓ ◆
s2 s2 s4
log 1 + = .
2N 2N 4N 2
Therefore, multiplying both sides by N yields
✓ ◆
s2 s2 s4
N log 1 + = .
2N 2 4N

Putting the limit N ! 1 we can show that


⇢ ✓ ◆
s2 s2
lim N log 1 + = .
N !1 2N 2

Taking exponential on both sides yields


⇢ ✓ ◆ ⇢
s2 s2
exp lim N log 1 + = exp .
N !1 2N 2

Moving the limit outside the exponential yields the result. Figure 1.8 provides a pic-
torial illustration.

14
1.3. INTEGRATION

1.8

1.6

1.4

1.2

1
0 0.2 0.4 0.6 0.8 1
⇣ ⌘N 2
s2
Figure 1.8: We plot a sequence of function fN (x) = 1 + 2N
and its limit f (x) = es /2
.

1.3 Integration

When you learned calculus, your teacher probably told you that there are two ways to
compute an integral:

Substitution: Z Z
1
f (ax) dx = f (u) du.
a
By parts: Z Z
u dv = u v v du.

Besides these two, we want to teach you two more. The first technique is even and odd
functions when integrating a function symmetrically about the y-axis. If a function is even,
you just need to integrate half of the function. If a function is odd, you will get a zero. The
second technique is to leverage the fact that a probability density function integrates to 1.
We will discuss the first technique here and defer the second technique to Chapter 4.
Besides the two integration techniques, we will review the fundamental theorem of
calculus. We will need it when we study cumulative distribution functions in Chapter 4.

1.3.1 Odd and even functions

Definition 1.3. A function f : R ! R is even if for any x 2 R,

f (x) = f ( x), (1.10)

and f is odd if
f (x) = f ( x). (1.11)

15
CHAPTER 1. MATHEMATICAL BACKGROUND

Essentially, an even function flips over about the y-axis, whereas an odd function flips over
both the x- and y-axes.

Example 1.3. The function f (x) = x2 0.4x4 is even, because

f ( x) = ( x)2 0.4( x)4 = x2 0.4x4 = f (x).

See Figure 1.9(a) for illustration. When integrating the function, we have
Z 1 Z 1 Z 1  3 x=1
2 4 x 0.4 5 38
f (x) dx = 2 f (x) dx = 2 x 0.4 dx = 2 x = .
1 0 0 3 5 x=0 75

Example 1.4. The function f (x) = x exp( x2 /2) is odd, because


⇢ ⇢ 2
( x)2 x
f ( x) = ( x) exp = x exp = f (x).
2 2

See Figure 1.9(b) for illustration. When integrating the function, we can let u = x.
Then, the integral becomes
Z 1 Z 0 Z 1
f (x) dx = f (x) dx + f (x) dx
1 1 0
Z 1 Z 1
= f ( u) du + f (x) dx
0 0
Z 1 Z 1
= f (u) du + f (x) dx = 0.
0 0

1 1

0.5 0.5

0 0

-0.5 -0.5

-1 -1

-1.5 -1 -0.5 0 0.5 1 1.5 -1.5 -1 -0.5 0 0.5 1 1.5


x x
(a) Even function (b) Odd function
Ra
Figure 1.9: An even function is symmetric about the y-axis, and so the integration f (x) dx =
Ra Ra a
2 0 f (x) dx. An odd function is anti-symmetric about the y-axis. Thus, a f (x) dx = 0.

16
1.3. INTEGRATION

1.3.2 Fundamental Theorem of Calculus


Our following result is the Fundamental Theorem of Calculus. It is a handy tool that links
integration and di↵erentiation.

Theorem 1.5 (Fundamental Theorem of Calculus). Let f : [a, b] ! R be a continu-


ous function defined on a closed interval [a, b]. Then, for any x 2 (a, b),
Z x
d
f (x) = f (t) dt, (1.12)
dx a

Before we prove the result, let us understand the theorem if you have forgotten its meaning.

Example 1.5. Consider a function f (t) = t2 . If we integrate the function from 0 to


x, we will obtain another function
Z x Z x
def x3
F (x) = f (t) dt = t2 dt = .
0 0 3

On the other hand, we can di↵erentiate F (x) to obtain f (x):

d d x3
f (x) = F (x) = = x2 .
dx dx 3
The fundamental theorem of calculus basically puts the two together:
Z x
d
f (x) = f (t) dt.
dx 0

That’s it. Nothing more and nothing less.

How can the fundamental theorem of calculus ever be useful when studying probabil-
ity? Very soon you will learn two concepts: probability density function and cumulative
distribution function. These two functions are related to each other by the fundamental
theorem of calculus. To give you a concrete example, we write down the probability density
function of an exponential random variable. (Please do not panic about the exponential
random variable. Just think of it as a “rapidly decaying” function.)
x
f (x) = e , x 0.
It turns out that the cumulative distribution function is
Z x Z x
F (x) = f (t) dt = e t dt = 1 e x
.
0 0
d
You can also check Rthat f (x) = dx F (x). The fundamental theorem of calculus says that if
x
you tell me F (x) = 0 e dt (for whatever reason), I will be able to tell you that f (x) = e x
t

merely by visually inspecting the integrand without doing the di↵erentiation.


Figure 1.10 illustrates the pair of functions f (x) = e x and F (x) = 1 e x . One thing
you should notice is that the height of F (x) is the area under the curve of f (t) from 1 to x.
For example, in Figure 1.10 we show the area under the curve from 0 to 2. Correspondingly
in F (x), the height is F (2).

17
CHAPTER 1. MATHEMATICAL BACKGROUND

1 1

0.8 0.8

0.6 0.6

0.4 0.4

0.2 0.2

0 0
0 1 2 3 4 5 0 1 2 3 4 5
f (x) F (x)
x x
Figure 1.10: The pair of functions f (x) = e and F (x) = 1 e

The following proof of the Fundamental Theorem of Calculus can be skipped if it is your
first time reading the book.

Proof. Our proof is based on Stewart (6th Edition), Section 5.3. Define the integral as a
function F : Z x
F (x) = f (t) dt.
a
The derivative of F with respect to x is

d F (x + h) F (x)
F (x) = lim
dx h!0 h
Z x+h Z x !
1
= lim f (t) dt f (t) dt
h!0 h a a
Z
1 x+h
= lim f (t) dt
h!0 h x
Z ⇢
(a) 1 x+h
 lim max f (⌧ ) dt
h!0 h x x⌧ x+h

= lim max f (⌧ ) .
h!0 x⌧ x+h

Here, the inequality in (a) holds because

f (t)  max f (⌧ )
x⌧ x+h

for all x  t  x + h. The maximum exists because f is continuous in a closed interval.

18
1.3. INTEGRATION

Using the parallel argument, we can show that

d F (x + h) F (x)
F (x) = lim
dx h!0 h
Z x+h Z x !
1
= lim f (t) dt f (t) dt
h!0 h a a
Z
1 x+h
= lim f (t) dt
h!0 h x
Z ⇢
1 x+h
lim min f (⌧ ) dt
h!0 h x x⌧ x+h

= lim min f (⌧ ) .
h!0 x⌧ x+h

Combining the two results, we have that


⇢ ⇢
d
lim min f (⌧ )  F (x)  lim max f (⌧ ) .
h!0 x⌧ x+h dx h!0 x⌧ x+h

However, since the two limits are both converging to f (x) as h ! 0, we conclude that
d
dx F (x) = f (x).

Remark. An alternative proof is to use Mean Value Theorem in terms of Riemann-Stieltjes


integrals (see, e.g., Tom Apostol, Mathematical Analysis, 2nd edition, Theorem 7.34). To
handle more general functions such as delta functions, one can use techniques in Lebesgue’s
integration. However, this is beyond the scope of this book.

This is the end of the proof. Please join us again.

In many practical problems, the fundamental theorem of calculus needs to be used in


conjunction with the chain rule.

Corollary 1.3. Let f : [a, b] ! R be a continuous function defined on a closed interval


[a, b]. Let g : R ! [a, b] be a continuously di↵erentiable function. Then, for any x 2
(a, b),
Z g(x)
d
f (t) dt = g 0 (x) · f (g(x)). (1.13)
dx a

Proof. We can prove this with the chain rule: Let y = g(x). Then we have
Z g(x) Z y
d dy d
f (t) dt = · f (t) dt = g 0 (x) f (y),
dx a dx dy a

which completes the proof.


19
CHAPTER 1. MATHEMATICAL BACKGROUND

Practice Exercise 1.6. Evaluate the integral


Z x µ ⇢
d 1 t2
p exp dt.
dx 0 2⇡ 2 2 2

Solution. Let y = x µ. Then by using the fundamental theorem of calculus, we can


show that
Z x µ ⇢ Z y ⇢
d 1 t2 dy d 1 t2
p exp dt = · p exp dt
dx 0 2⇡ 2 2 2 dx dy 0 2⇡ 2 2 2

d(x µ) 1 y2
= ·p exp
dx 2⇡ 2 2 2

1 (x µ)2
=p exp .
2⇡ 2 2 2

This result will be useful when we do linear transformations of a Gaussian random


variable in Chapter 4.

1.4 Linear Algebra

The two most important subjects for data science are probability, which is the subject of the
book you are reading, and linear algebra, which concerns matrices and vectors. We cannot
cover linear algebra in detail because this would require another book. However, we need to
highlight some ideas that are important for doing data analysis.

1.4.1 Why do we need linear algebra in data science?


Consider a dataset of the crime rate of several cities as shown below, downloaded from
https://web.stanford.edu/~hastie/StatLearnSparsity/data.html.
The table shows that the crime rate depends on several factors such as funding for the
police department, the percentage of high school graduates, etc.

city crime rate funding hs no-hs college college4


1 478 40 74 11 31 20
2 494 32 72 11 43 18
3 643 57 71 18 16 16
4 341 31 71 11 25 19
.. .. .. .. .. .. ..
. . . . . . .
50 940 66 67 26 18 16

20
1.4. LINEAR ALGEBRA

What questions can we ask about this table? We can ask: What is the most influential
cause of the crime rate? What are the leading contributions to the crime rate? To answer
these questions, we need to describe these numbers. One way to do it is to put the numbers
in matrices and vectors. For example,
2 3 2 3 2 3
478 40 74
64947 6327 6727
6 7 6 7 6 7
y crime = 6 . 7 , xfund = 6 . 7 , xhs = 6 . 7 , . . .
4 .. 5 4 .. 5 4 .. 5
940 66 67
With this vector expression of the data, the analysis questions can roughly be translated
to finding ’s in the following equation:
y crime = fund xfund + hs xhs + ··· + college4 xcollege4 .

This equation o↵ers a lot of useful insights. First, it is a linear model of y crime . We call
it a linear model because the observable y crime is written as a linear combination of the
variables xfund , xhs , etc. The linear model assumes that the variables are scaled and added
to generate the observed phenomena. This assumption is not always realistic, but it is often
a fair assumption that greatly simplifies the problem. For example, if we can show that all
’s are zero except fund , then we can conclude that the crime rate is solely dependent on
the police funding. If two variables are correlated, e.g., high school graduate and college
graduate, we would expect the ’s to change simultaneously.
The linear model can further be simplified to a matrix-vector equation:
2 3 2 32 3
| | | | fund
6 | 7 6 | | | 76 7
6 7 6 7
6y crime 7 = 6xfund xhs · · · xcollege4 7 6
hs 7
6 7 6 746 .
.. 7
4 | 5 4 | | | 5 5
| | | | college4

Here, the lines “|” emphasize that the vectors are column vectors. If we denote the matrix
in the middle as A and the vector as , then the equation is equivalent to y = A . So we
can find by appropriately inverting the matrix A. If two columns of A are dependent, we
will not be able to resolve the corresponding ’s uniquely.
As you can see from the above data analysis problem, matrices and vectors o↵er a way
to describe the data. We will discuss the calculations in Chapter 7. However, to understand
how to interpret the results from the matrix-vector equations, we need to review some basic
ideas about matrices and vectors.

1.4.2 Everything you need to know about linear algebra


Throughout this book, you will see di↵erent sets of notations. For linear algebra, we also
have a set of notations. We denote x 2 Rd a d-dimensional vector taking real numbers as its
entries. An M -by-N matrix is denoted as X 2 RM ⇥N . The transpose of a matrix is denoted
as X T . A matrix X can be viewed according to its columns and its rows:
2 3
2 3 — x1 —
| | | 6— x2 —7
6 7
X = 4x1 x2 · · · xN 5 , and X = 6 .. 7.
| | | 4 . 5
— xM —

21
CHAPTER 1. MATHEMATICAL BACKGROUND

Here, xj denotes the jth column of X, and xi denotes the ith row of X. The (i, j)th element
of X is denoted as xij or [X]ij . The identity matrix is denoted as I. The ith column of I
is denoted as ei = [0, . . . , 1, . . . , 0]T , and is called the ith standard basis vector. An all-zero
vector is denoted as 0 = [0, . . . , 0]T .
What is the most important thing to know about linear algebra? From a data analysis
point of view, Figure 1.11 gives us the answer. The picture is straightforward, but it captures
all the essence. In almost all the data analysis problems, ultimately, there are three things we
care about: (i) The observable vector y, (ii) the variable vectors xn , and (iii) the coefficients
N
n . The set of variable vectors {xn }n=1 spans a vector space in which all vectors are living.
Some of these variable vectors are correlated, and some are not. However, for the sake of
this discussion, let us assume they are independent of each other. Then for any observable
vector y, we can always project y in the directions determined by {xn }N n=1 . The projection
of y onto xn is the coefficient n . A larger value of n means that the variable xn has more
contributions.

Figure 1.11: Representing an observable vector y by a linear combination of variable vectors x1 , x2


and x3 . The combination weights are 1 , 2 , 3 .

Why is this picture so important? Because most of the data analysis problems can be
expressed, or approximately expressed, by the picture:
N
X
y= n xn .
n=1

If you recall the crime rate example, this equation is precisely the linear model we used to
describe the crime rate. This equation can also describe many other problems.

Example 1.6. Polynomial fitting. Consider a dataset of pairs of numbers (tm , ym ) for
m = 1, . . . , M , as shown in Figure 1.12. After a visual inspection of the dataset, we
propose to use a line to fit the data. A line is specified by the equation

ym = atm + b, m = 1, . . . , M,

where a 2 R is the slope and b 2 R is the y-intercept. The goal of this problem is to
find one line (which is fully characterized by (a, b)) such that it has the best fit to all
the data pairs (tm , ym ) for m = 1, . . . , M . This problem can be described in matrices

22
1.4. LINEAR ALGEBRA

and vectors by noting that


2 3 2 3 2 3
y1 t1 1
6 .. 7 6 .. 7 6 .. 7
4 . 5 |{z}4 . 5 |{z}4 . 5,
= a + b
yM 1 tM 2 1
| {z } | {z } |{z}
y x1 x2

or more compactly,
y= 1 x1 + 2 x2 .

Here, x1 = [t1 , . . . , tM ]T contains all the variable values, and x2 = [1, . . . , 1]T contains
a constant o↵set.
5
tm ym
0.1622 2.1227
4
0.7943 3.3354
.. ..
. . 3
0.7379 3.4054
data
0.2691 2.5672 2
best fit
0.4228 2.3796 candidate
0.6020 3.2942 1
0 0.2 0.4 0.6 0.8 1

Figure 1.12: Example of fitting a set of data points. The problem can be described by y =
1 x1 + 2 x2 .

Example 1.7. Image compression. The JPEG compression for images is based on
the concept of discrete cosine transform (DCT). The DCT consists of a set of basis
vectors, or {xn }N
n=1 using our notation. In the most standard setting, each basis vector
xn consists of 8 ⇥ 8 pixels, and there are N = 64 of these xn ’s. Given an image, we can
partition the image into M small blocks of 8 ⇥ 8 pixels. Let us call one of these blocks
y. Then, DCT represents the observation y as a linear combination of the DCT basis
vectors:
N
X
y= n xn .
n=1
N
The coefficients { are called the DCT coefficients. They provide a representa-
n }n=1
tion of y, because once we know { n }N n=1 , we can completely describe y because the
basis vectors {xn }N
n=1 are known and fixed. The situation is depicted in Figure 1.13.
How can we compress images using DCT? In the 1970s, scientists found that most
images have strong leading DCT coefficients but weak tail DCT coefficients. In other
words, among the N = 64 n ’s, only the first few are important. If we truncate the
number of DCT coefficients, we can e↵ectively compress the number of bits required
to represent the image.

23
CHAPTER 1. MATHEMATICAL BACKGROUND

Figure 1.13: JPEG image compression is based on the concept of discrete cosine transform, which
can be formulated as a matrix-vector problem.

We hope by now you are convinced of the importance of matrices and vectors in the
context of data science. They are not “yet another” subject but an essential tool you must
know how to use. So, what are the technical materials you must master? Here we go.

1.4.3 Inner products and norms


We assume that you know the basic operations such as matrix-vector multiplication, taking
the transpose, etc. If you have forgotten these, please consult any undergraduate linear
algebra textbook such as Gilbert Strang’s Linear Algebra and its Applications. We will
highlight a few of the most important operations for our purposes.

Definition 1.4 (Inner product). Let x = [x1 , . . . , xN ]T , and y = [y1 , . . . , yN ]T . The


inner product xT y is
N
X
xT y = x i yi . (1.14)
i=1

Practice Exercise 1.7. Let x = [1, 0, 1]T , and y = [3, 2, 0]T . Find xT y.
Solution. The inner product is xT y = (1)(3) + (0)(2) + ( 1)(0) = 3.

Inner products are important because they tell us how two vectors are correlated.
Figure 1.14 depicts the geometric meaning of an inner product. If two vectors are correlated
(i.e., nearly parallel), then the inner product will give us a large value. Conversely, if the
two vectors are close to perpendicular, then the inner product will be small. Therefore, the
inner product provides a measure of the closeness/similarity between two vectors.

Figure 1.14: Geometric interpretation of inner product: We project one vector onto the other vector.
The projected distance is the inner product.

24
1.4. LINEAR ALGEBRA

Creating vectors and computing the inner products are straightforward in MATLAB.
We simply need to define the column vectors x and y by using the command [] with ; to
denote the next row. The inner product is done using the transpose operation x’ and vector
multiplication *.

% MATLAB code to perform an inner product


x = [1 0 -1];
y = [3 2 0];
z = x’*y;

In Python, constructing a vector is done using the command np.array. Inside this
command, one needs to enter the array. For a column vector, we write [[1],[2],[3]], with
an outer [], and three inner [] for each entry. If the vector is a row vector, the one can omit
the inner []’s by just calling np.array([1, 2, 3]). Given two column vectors x and y,
the inner product is computed via np.dot(x.T,y), where np.dot is the command for inner
product, and x.T returns the transpose of x. One can also call np.transpose(x), which is
the same as x.T.

# Python code to perform an inner product


import numpy as np
x = np.array([[1],[0],[-1]])
y = np.array([[3],[2],[0]])
z = np.dot(np.transpose(x),y)
print(z)

In data analytics, the inner product of two vectors can be useful. Consider the vectors
in Table 1.1. Just from looking at the numbers, you probably will not see anything wrong.
However, let’s compute the inner products. It turns out that xT1 x2 = 0.0031, whereas
xT1 x3 = 2.0020. There is almost no correlation between x1 and x2 , but there is a substan-
tial correlation between x1 and x3 . What happened? The vectors x1 and x2 are random
vectors constructed independently and uncorrelated to each other. The last vector x3 was
constructed by x3 = 2x1 ⇡/1000. Since x3 is completely constructed from x1 , they have
to be correlated.

x1 x2 x3
0.0006 0.0011 0.0020
0.0014 0.0024 0.0059
0.0034 0.0073 0.0099
.. .. ..
. . .
0.0001 0.0066 0.0030
0.0074 0.0046 0.0116
0.0007 0.0061 0.0017

Table 1.1: Three example vectors.

One caveat for this example is that the naive inner product xTi xj is scale-dependent.
For example, the vectors x3 = x1 and x3 = 1000x1 have the same amount of correlation,

25
CHAPTER 1. MATHEMATICAL BACKGROUND

but the simple inner product will give a larger value for the latter case. To solve this problem
we first define the norm of the vectors:

Definition 1.5 (Norm). Let x = [x1 , . . . , xN ]T be a vector. The `p -norm of x is

N
!1/p
X
kxkp = xpi , (1.15)
i=1

for any p 1.

The norm essentially tells us the length of the vector. This is most obvious if we consider
the `2 -norm:
N
!1/2
X
2
kxk2 = xi .
i=1

By taking the square on both sides, one can show that kxk22 = xT x. This is called the
squared `2 -norm, and is the sum of the squares.
On MATLAB, computing the norm is done using the command norm. Here, we can
indicate the types of norms, e.g., norm(x,1) returns the `1 -norm whereas norm(x,2) returns
the `2 -norm (which is also the default).

% MATLAB code to compute the norm


x = [1 0 -1];
x_norm = norm(x);

On Python, the norm command is listed in the np.linalg. To call the `1 -norm, we use
np.linalg.norm(x,1), and by default the `2 -norm is np.linalg.norm(x).

# Python code to compute the norm


import numpy as np
x = np.array([[1],[0],[-1]])
x_norm = np.linalg.norm(x)

Using the norm, one can define an angle called the cosine angle between two vectors.

Definition 1.6. The cosine angle between two vectors x and y is

xT y
cos ✓ = . (1.16)
kxk2 kyk2

The di↵erence between the cosine angle and the basic inner product is the normaliza-
tion in the denominator, which is the product kxk2 kyk2 . This normalization factor scales
the vector x to x/kxk2 and y to y/kyk2 . The scaling makes the length of the new vector
equal to unity, but it does not change the vector’s orientation. Therefore, the cosine angle
is not a↵ected by a very long vector or a very short vector. Only the angle matters. See
Figure 1.15.

26
1.4. LINEAR ALGEBRA

Figure 1.15: The cosine angle is the inner product divided by the norms of the vectors.

Going back to the previous example, after normalization we can show that the cosine
angle between x1 and x2 is cos ✓1,2 = 0.0031, whereas the cosine angle between x1 and
x3 is cos ✓1,3 = 0.8958. There is still a strong correlation between x1 and x3 , but now using
the cosine angle the value is between 1 and +1.

Remark 1: There are other norms one can use. The `1 -norm is useful for sparse models
where we want to have the fewest possible non-zeros. The `1 -norm of x is
N
X
kxk1 = |xi |,
i=1

which is the sum of absolute values. The `1 -norm picks the maximum of {x1 , . . . , xN }:

N
!1/p
X
kxk1 = lim xpi
p!1
i=1
= max {x1 , . . . , xN } ,

because as p ! 1, only the largest element will be amplified.


T
Remark
p 2: The standard `2 -norm is a circle: Just consider x = [x1 , x2 ] . The norm
2 2
is kxk2 = x1 + x2 . We can convert the circle to ellipses by considering a weighted norm.

Definition 1.7 (Weighted `2 -norm square). Let x = [x1 , . . . , xN ]T and let W =


diag(w1 , . . . , wN ) be a non-negative diagonal matrix. The weighted `2 -norm square of
x is

kxk2W = xT W x
2 32 3
w1 ... 0 x1 N

= x1 ...
⇤6 .
xN 4 .. .. .. 7 6 .. 7 = X w x2 . (1.17)
. . 5 4 . 5 i i
0 ... wN xN i=1

The geometry of the weighted `2 -norm is determined by the matrix W . For example,
if W = I (the identity operator), then kxk2W = kxk22 , which defines a circle. If W is any
“non-negative” matrix2 , then kxk2W defines an ellipse.
2 The technical term for these matrices is positive semi-definite matrices.

27
CHAPTER 1. MATHEMATICAL BACKGROUND

In MATLAB, the weighted inner product is just a sequence of two matrix-vector mul-
tiplications. This can be done using the command x’*W*x as shown below.

% MATLAB code to compute the weighted norm


W = [1 2 3; 4 5 6; 7 8 9];
x = [2; -1; 1];
z = x’*W*x

In Python, constructing the matrix W and the column vector x is done using np.array.
The matrix-vector multiplication is done using two np.dot commands: one for np.dot(W,x)
and the other one for np.dot(x.T, np.dot(W,x)).

# Python code to compute the weighted norm


import numpy as np
W = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
x = np.array([[2],[-1],[1]])
z = np.dot(x.T, np.dot(W,x))
print(z)

1.4.4 Matrix calculus


The last linear algebra topic we need to review is matrix calculus. As its name indicates,
matrix calculus is about the di↵erentiation of matrices and vectors. Why do we need di↵er-
entiation for matrices and vectors? Because we want to find the minimum or maximum of
a scalar function with a vector input.
Let us go back to the crime rate problem we discussed earlier. Given the data, we
want to find the model coefficients 1 , . . . , N such that the variables can best explain the
observation. In other words, we want to minimize the deviation between y and the prediction
o↵ered by our model:
N 2
X
minimize y n xn .
1 ,..., N
n=1

This equation is self-explanatory. The norm k| ~k2 measures the deviation. If y can
be perfectly explained by {xn }N n=1 , then the norm can eventually go to zero by finding a
good set of { 1 , . . . , N }. The symbol minimize means to minimize the function by finding
1 ,..., N
{ 1 , . . . , N }. Note that the norm is taking a vector as the input and generating a scalar as
the output. It can be expressed as

N 2
def
X
"( ) = y n xn ,
n=1

to emphasize this relationship. Here we define = [ 1 , . . . , N ]T as the collection of all


coefficients.
Given this setup, how would you determine such that the deviation is minimized?
Our calculus teachers told us that we could take the function’s derivative and set it to zero

28
1.4. LINEAR ALGEBRA

for scalar problems. It is the same story for vectors. What we do is to take the derivative of
the error and set it equal to zero:
d
"( ) = 0.
d
Now the question arises, how do we take the derivatives of "( ) when it takes a vector as
input? If we can answer this question, we will find the best . The answer is straightforward.
Since the function has one output and many inputs, take the derivative for each element
independently. This is called the scalar di↵erentiation of vectors.

Definition 1.8 (Scalar di↵erentiation of vectors). Let f : RN ! R be a di↵erentiable


scalar function, and let y = f (x) for some input x 2 RN . Then,
2 3
dy/dx1
dy 6 .. 7
=4 . 5.
dx
dy/dxN

As you can see from this definition, there is nothing conceptually challenging here. The only
difficulty is that things can get tedious because there will be many terms. However, the good
news is that mathematicians have already compiled a list of identities for common matrix
di↵erentiation. So instead of deriving every equation from scratch, we can enjoy the fruit of
their hard work by referring to those formulae. The best place to find these equations is the
Matrix Cookbook by Petersen and Pedersen.3 Here, we will mention two of the most useful
results.

dy
Example 1.8. Let y = xT Ax for any matrix A 2 RN ⇥N . Find dx .

Solution.
d
xT Ax = Ax + AT x.
dx
Now, if A is symmetric, i.e., A = AT , then
d
xT Ax = 2Ax.
dx

Example 1.9. Let " = kAx yk22 , where A 2 RN ⇥N is symmetric. Find d"
dx .

Solution. First, we note that

" = kAx yk22 = xT AT Ax 2y T Ax + y T y.

3 https://www.math.uwaterloo.ca/
~hwolkowi/matrixcookbook.pdf

29
CHAPTER 1. MATHEMATICAL BACKGROUND

Taking the derivative with respect to x yields


d"
= 2AT Ax 2AT y
dx
= 2AT (Ax y).

Going back to the crime rate problem, we can now show that
d"
0= ky X k2 = 2X T (X y).
d
Therefore, the solution is
b = (X T X) 1
Xy.
As you can see, if we do not have access to the matrix calculus, we will not be able to solve the
minimization problem. (There are alternative paths that do not require matrix calculus, but
they require an understanding of linear subspaces and properties of the projection operators.
So in some sense, matrix calculus is the easiest way to solve the problem.) When we discuss
the linear regression methods in Chapter 7, we will cover the interpretation of the inverses
and related topics.
In MATLAB and Python, matrix inversion is done using the command inv in MAT-
LAB and np.linalg.inv in Python. Below is an example in Python.

# Python code to compute a matrix inverse


import numpy as np
X = np.array([[1, 3], [-2, 7], [0, 1]])
XtX = np.dot(X.T, X)
XtXinv = np.linalg.inv(XtX)
print(XtXinv)

Sometimes, instead of computing the matrix inverse we are more interested in solving a
linear equation X = y (the solution of which is b = (X T X) 1 Xy). In both MATLAB and
Python, there are built-in commands to do this. In MATLAB, the command is \ (backslash).

% MATLAB code to solve X beta = y


X = [1 3; -2 7; 0 1];
y = [2; 1; 0];
beta = X\y;

In Python, the built-in command is np.linalg.lstsq.

# Python code to solve X beta = y


import numpy as np
X = np.array([[1, 3], [-2, 7], [0, 1]])
y = np.array([[2],[1],[0]])
beta = np.linalg.lstsq(X, y, rcond=None)[0]
print(beta)

30
1.5. BASIC COMBINATORICS

Closing remark: In this section, we have given a brief introduction to a few of the most
relevant concepts in linear algebra. We will introduce further concepts in linear algebra in
later chapters, such as eigenvalues, principal component analysis, linear transformations,
and regularization, as they become useful for our discussion.

1.5 Basic Combinatorics

The last topic we review in this chapter is combinatorics. Combinatorics concerns the
number of configurations that can be obtained from certain discrete experiments. It is useful
because it provides a systematic way of enumerating cases. Combinatorics often becomes
very challenging as the complexity of the event grows. However, you may rest assured that
in this book, we will not tackle the more difficult problems of combinatorics; we will confine
our discussion to two of the most basic principles: permutation and combination.

1.5.1 Birthday paradox


To motivate the discussion of combinatorics, let us start with the following problem. Suppose
there are 50 people in a room. What is the probability that at least one pair of people have
the same birthday (month and day)? (We exclude Feb. 29 in this problem.)
The first thing you might be thinking is that since there are 365 days, we need at least
366 people to ensure that one pair has the same birthday. Therefore, the chance that 2 of
50 people have the same birthday is low. This seems reasonable, but let’s do a simulated
experiment. In Figure 1.16 we plot the probability as a function of the number of people.
For a room containing 50 people, the probability is 97%. To get a 50% probability, we just
need 23 people! How is this possible?

1
0.9
0.8
Probability

0.7
0.6
0.5
0.4
0.3
0.2
0.1
0
0 10 20 30 40 50 60 70 80 90 100
Number of people

Figure 1.16: The probability for two people in a group to have the same birthday as a function of the
number of people in the group.

If you think about this problem more deeply, you will probably realize that to solve the
problem, we must carefully enumerate all the possible configurations. How can we do this?
Well, suppose you walk into the room and sequentially pick two people. The probability

31
CHAPTER 1. MATHEMATICAL BACKGROUND

that they have di↵erent birthdays is


365 364
P[The first 2 people have di↵erent birthdays] = ⇥ .
365 365
When you ask the first person to tell you their birthday, he or she can occupy any of the
365 slots. This gives us 365
365 . The second person has one slot short because the first person
has taken it, and so the probability that he or she has a di↵erent birthday from the first
person is 364
365 . Note that this calculation is independent of how many people you have in the
room because you are picking them sequentially.
If you now choose a third person, the probability that they have di↵erent birthdays is
365 364 363
P[The first 3 people have di↵erent birthdays] = ⇥ ⇥ .
365 365 365
This process can be visualized in Figure 1.17.

Figure 1.17: The probability for two people to have the same birthday as a function of the number of
people in the group. When there is only one person, this person can land on any of the 365 days. When
there are two people, the first person has already taken one day (out of 365 days), so the second person
can only choose 364 days. When there are three people, the first two people have occupied two days,
so there are only 363 days left. If we generalize this process, we see that the number of configurations
is 365 ⇥ 364 ⇥ · · · ⇥ (365 k + 1), where k is the number of people in the room.

So imagine that you keep going down the list to the 50th person. The probability that
none of these 50 people will have the same birthday is

P[The first 50 people have di↵erent birthdays]


365 364 363 316
= ⇥ ⇥ ⇥ ··· ⇥ ⇡ 0.03.
365 365 365 365
That means that the probability for 50 people to have di↵erent birthdays, the probability is
as little as 3%. If you take the complement, you can show that with 97% probability, there
is at least one pair of people having the same birthday.
The general equation for this problem is now easy to see:
365 ⇥ 364 ⇥ · · · ⇥ (365 k + 1)
P[The first k people have di↵erent birthdays] =
365 ⇥ 365 ⇥ · · · ⇥ 365
365! 1
= ⇥ .
(365 k)! 365k

32
1.5. BASIC COMBINATORICS

365!
The first term in our equation, (365 k)! , is called the permutation of picking k days from
365 options. We shall discuss this operation shortly.
Why is the probability so high with only 50 people while it seems that we need 366
people to ensure two identical birthdays? The di↵erence is the notion of probabilistic and
deterministic. The 366-people argument is deterministic. If you have 366 people, you are
certain that two people will have the same birthday. This has no conflict with the proba-
bilistic argument because the probabilistic argument says that with 50 people, we have a
97% chance of getting two identical birthdays. With a 97% success rate, you still have a
3% chance of failing. It is unlikely to happen, but it can still happen. The more people you
put into the room, the stronger guarantee you will have. However, even if you have 364
people and the probability is almost 100%, there is still no guarantee. So there is no conflict
between the two arguments since they are answering two di↵erent questions.
Now, let’s discuss the two combinatorics questions.

1.5.2 Permutation
Permutation concerns the following question:
Consider a set of n distinct balls. Suppose we want to pick k balls from the set without
replacement. How many ordered configurations can we obtain?
Note that in the above question, the word “ordered” is crucial. For example, the set
A = {a, b, c} can lead to 6 di↵erent ordered configurations

(a, b, c), (a, c, b), (b, a, c), (b, c, a), (c, a, b), (c, b, a).

As a simple illustration of how to compute the permutation, we can consider a set of


5 colored balls as shown in Figure 1.18.

Figure 1.18: Permutation. The number of choices is reduced in every stage. Therefore, the total number
is n ⇥ (n 1) ⇥ · · · ⇥ (n k + 1) if there are k stages.

If you start with the base, which contains five balls, you will have five choices. At one
level up, since one ball has already been taken, you have only four choices. You continue
the process until you reached the number of balls you want to collect. The number of
configurations you have generated is the permutation. Here is the formula:

33
CHAPTER 1. MATHEMATICAL BACKGROUND

Theorem 1.6. The number of permutations of choosing k out of n is


n!
(n k)!

where n! = n(n 1)(n 2) · · · 3 · 2 · 1.

Proof. Let’s list all possible ways:


Which ball to pick Number of choices Why?
The 1st ball n No has been picked, so we
have n choices
The 2nd ball n 1 The first ball has been
picked
The 3rd ball n 2 The first two balls have
been picked
.. .. ..
. . .
The kth ball n k+1 The first k 1 balls have
been picked
Total: n(n 1) · · · (n k + 1)

The total number of ordered configurations is n(n 1) · · · (n k + 1). This simplifies


to
n(n 1)(n 2) · · · (n k + 1)
(n k)(n k 1) · · · 3 · 2 · 1
= n(n 1)(n 2) · · · (n k + 1) ·
(n k)(n k 1) · · · 3 · 2 · 1
n!
= .
(n k)!

Practice Exercise 1.8. Consider a set of 4 balls {1, 2, 3, 4}. We want to pick two
balls at random without replacement. The ordering matters. How many permutations
can we obtain?

Solution. The possible configurations are (1,2), (2,1), (1,3), (3,1), (1,4), (4,1), (2,3),
(3,2), (2,4), (4,2), (3,4), (4,3). So totally there are 12 configurations. We can also
verify this number by noting that there are 4 balls altogether and so the number
of choices for picking the first ball is 4 and the number of choices for picking the
second ball is (4 1) = 3. Thus, the total is 4 · 3 = 12. Referring to the formula, this
result coincides with the theorem, which states that the number of permutations is
4! 4·3·2·1
(4 2)! = 2·1 = 12.

1.5.3 Combination
Another operation in combinatorics is combination. Combination concerns the following
question:

34
1.5. BASIC COMBINATORICS

Consider a set of n distinct balls. Suppose we want to pick k balls from the set without
replacement. How many unordered configurations can we obtain?
Unlike permutation, combination treats a subset of balls with whatever ordering as
one single configuration. For example, the subset (a, b, c) is considered the same as (a, c, b)
or (b, c, a), etc.
Let’s go back to the 5-ball exercise. Suppose you have picked orange, green, and light
blue. This is the same combination as if you have picked {green, orange, and light blue},
or {green, light blue, and orange}. Figure 1.19 lists all the six possible configurations for
these three balls. So what is combination? Combination needs to take these repeated cases
into account.

Figure 1.19: Combination. In this problem, we are interested in picking 3 colored balls out of 5. This
will give us 5 ⇥ 4 ⇥ 3 = 60 permutations. However, since we are not interested in the ordering, some of
the permutations are repeated. For example, there are 6 combos of (green, light blue, orange), which is
computed from 3 ⇥ 2 ⇥ 1. Dividing 60 permutations by these 6 choices of the orderings will give us 10
distinct combinations of the colors.

Theorem 1.7. The number of combinations of choosing k out of n is


n!
k!(n k)!

where n! = n(n 1)(n 2) · · · 3 · 2 · 1.

Proof. We start with the permutation result, which gives us (n n!k)! permutations. Note that
every permutation has exactly k balls. However, while these k balls can be arranged in any
order, in combination, we treat them as one single configuration. Therefore, the task is to
count the number of possible orderings for these k balls.
To this end, we note that for a set of k balls, there are in total k! possible ways of
ordering them. The number k! comes from the following table.

35
CHAPTER 1. MATHEMATICAL BACKGROUND

Which ball to pick Number of choices


The 1st ball k
The 2nd ball k 1
.. ..
. .
The kth ball 1
Total: k(k 1) · · · 3 · 2 · 1

Therefore, the total number of orderings for a set of k balls is k!. Since permutation
gives us (n n!k)! and every permutation has k! repetitions due to ordering, we divide the
number by k!. Thus the number of combinations is
n!
.
k!(n k)!

Practice Exercise 1.9. Consider a set of 4 balls {1, 2, 3, 4}. We want to pick two
balls at random without replacement. The ordering does not matter. How many com-
binations can we obtain?
Solution. The permutation result gives us 12 permutations. However, among all these
12 permutations, there are only 6 distinct pairs of numbers. We can confirm this by
noting that since we picked 2 balls, there are exactly 2 possible orderings for these 2
balls. Therefore, we have 12
2 = 6 number of combinations. Using the formula of the
theorem, we check that the number of combinations is
4! 4·3·2·1
= = 6.
2!(4 2)! (2 · 1)(2 · 1)

Example 1.10. (Ross, 8th edition, Section 1.6) Consider the equation

x1 + x2 + · · · + xK = N,

where {xk } are positive integers. How many combinations of solutions of this equation
are there?

Solution. We can determine the number of combinations by considering the figure


below. The integer N can be modeled as N balls in an urn. The number of variables K
is equivalent to the number of colors of these balls. Since all variables are positive, the
problem can be translated to partitioning the N balls into K buckets. This, in turn,
is the same as inserting K 1 dividers among N 1 holes. Therefore, the number of
combinations is ✓ ◆
N 1 (N 1)!
= .
K 1 (K 1)!(N K)!
For example, if N = 16 and K = 4, then the number of solutions is
✓ ◆
16 1 15!
= = 455.
4 1 3!12!

36
1.6. SUMMARY

Figure 1.20: One possible solution for N = 16 and K = 4. In general, the problem is equivalent
to inserting K 1 dividers among N 1 balls.

Closing remark. Permutations and combinations are two ways to enumerate all the pos-
sible cases. While the conclusions are probabilistic, as the birthday paradox shows, permu-
tation and combination are deterministic. We do not need to worry about the distribution
of the samples, and we are not taking averages of anything. Thus, modern data analysis
seldom uses the concepts of permutation and combination. Accordingly, combinatorics does
not play a large role in this book.
Does it mean that combinatorics is not useful? Not quite, because it still provides us
with powerful tools for theoretical analysis. For example, in binomial random variables, we
need the concept of combination to calculate the repeated cases. The Poisson random vari-
able can be regarded as a limiting case of the binomial random variable, and so combination
is also used. Therefore, while we do not use the concepts of permutation per se, we use them
to define random variables.

1.6 Summary

In this chapter, we have reviewed several background mathematical concepts that will be-
come useful later in the book. You will find that these concepts are important for under-
standing the rest of this book. When studying these materials, we recommend not just
remembering the “recipes” of the steps but focusing on the motivations and intuitions
behind the techniques.
We would like to highlight the significance of the birthday paradox. Many of us come
from an engineering background in which we were told to ensure reliability and guarantee
success. We want to ensure that the product we deliver to our customers can survive even
in the worst-case scenario. We tend to apply deterministic arguments such as requiring 366
people to ensure complete coverage of the 365 days. In modern data analysis, the worst-case
scenario may not always be relevant because of the complexity of the problem and the cost
of such a warranty. The probabilistic argument, or the average argument, is more reasonable
and cost-e↵ective, as you can see from our analysis of the birthday problem. The heart of
the problem is the trade-o↵ between how much confidence you need versus how much e↵ort
you need to expend. Suppose an event is unlikely to happen, but if it happens, it will be
a disaster. In that case, you might prefer to be very conservative to ensure that such a
disaster event has a low chance of happening. Industries related to risk management such
as insurance and investment banking are all operating under this principle.

37
CHAPTER 1. MATHEMATICAL BACKGROUND

1.7 Reference

Introductory materials
1-1 Erwin Kreyszig, Advanced Engineering Mathematics, Wiley, 10th Edition, 2011.
1-2 Henry Stark and John W. Woods, Probability and Random Processes with Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2002. Appendix.
1-3 Michael J. Evans and Je↵rey S. Rosenthal, Probability and Statistics: The Science of
Uncertainty, W. H. Freeman, 2nd Edition, 2009. Appendix.
1-4 James Stewart, Single Variable Calculus, Early Transcendentals, Thomson Brooks/-
Cole, 6th Edition, 2008. Chapter 5.

Combinatorics
1-5 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Section 1.6.
1-6 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Section 2.6.
1-7 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 3.

Analysis
In some sections of this chapter, we use results from calculus and infinite series. Many formal
proofs can be found in the standard undergraduate real analysis textbooks.
1-8 Tom M. Apostol, Mathematical Analysis, Pearson, 1974.
1-9 Walter Rudin, Principles of Mathematical Analysis, McGraw Hill, 1976.

1.8 Problems

Exercise 1. (Video Solution)


(a) Show that
n
X 1 rn+1
rk = .
1 r
k=0
P1
for any 0 < r < 1. Evaluate k=0 rk .
(b) Using the result of (a), evaluate

1 + 2r + 3r2 + · · · .

38
1.8. PROBLEMS

(c) Evaluate the sums


1
X ✓ ◆k+1 1
X ✓ ◆k 1
1 1
k , and k .
3 4
k=0 k=2

Exercise 2. (Video Solution)


Recall that
1
X k
=e .
k!
k=0

Evaluate
1
X k 1
X k
e e
k , and k2 .
k! k!
k=0 k=0

Exercise 3. (Video Solution)


Evaluate the integrals

(a)
Z b ✓ ◆2
1 a+b
x dx.
a b a 2

(b) Z 1
x
xe dx.
0

(c) Z 1
x |x|
e dx.
1 2

Exercise 4.
(a) Compute the result of the following matrix vector multiplication using Numpy. Submit
your result and codes.

2 3 2 3
1 2 3 1
44 5 65 ⇥ 425 .
7 8 9 3

(b) Plot a sine function on the interval [ ⇡, ⇡] with 1000 data points.
(c) Generate 10,000 uniformly distributed random numbers on interval [0, 1).
Use matplotlib.pyplot.hist to generate a histogram of all the random numbers.

39
CHAPTER 1. MATHEMATICAL BACKGROUND

Exercise 5.
Calculate ✓ ◆k+1
1
X 2
k .
3
k=0

Exercise 6.
Let   
x 1 4 1
x= , µ= , ⌃= .
y 0 1 1
1
(a) Find ⌃ , the inverse of ⌃.
(b) Find |⌃|, the determinant of ⌃.
(c) Simplify the two-dimensional function

1 1 1
f (x) = exp (x µ)T ⌃ (x µ) .
2⇡|⌃|1/2 2

(d) Use matplotlib.pyplot.contour, plot the function f (x) for the range [ 3, 3] ⇥
[ 3, 3].

Exercise 7.
Out of seven electrical engineering (EE) students and five mechanical engineering (ME)
students, a committee consisting of three EEs and two MEs is to be formed. In how many
ways can this be done if
(a) any of the EEs and any of the MEs can be included?
(b) one particular EE must be on the committee?
(c) two particular MEs cannot be on the committee?

Exercise 8.
Five blue balls, three red balls, and three white balls are placed in an urn. Three balls are
drawn at random without regard to the order in which they are drawn. Using the counting
approach to probability, find the probability that
(a) one blue ball, one red ball, and one white ball are drawn.
(b) all three balls drawn are red.
(c) exactly two of the balls drawn are blue.

Exercise 9.
A collection of 26 English letters, a-z, is mixed in a jar. Two letters are drawn at random,
one after the other.

40
1.8. PROBLEMS

(a) What is the probability of drawing a vowel (a,e,i,o,u) and a consonant in either order?
(b) Write a MATLAB / Python program to verify your answer in part (a). Randomly
draw two letters without replacement and check whether one is a vowel and the other
is a consonant. Compute the probability by repeating the experiment 10000 times.

Exercise 10.
There are 50 students in a classroom.
(a) What is the probability that there is at least one pair of students having the same
birthday? Show your steps.

(b) Write a MATLAB / Python program to simulate the event and verify your answer
in (a). Hint: You probably need to repeat the simulation many times to obtain a
probability. Submit your code and result.
You may assume that a year only has 365 days. You may also assume that all days have an
equal likelihood of being taken.

41
CHAPTER 1. MATHEMATICAL BACKGROUND

42
Chapter 2

Probability

Data and probability are inseparable. Data is the computational side of the story, whereas
probability is the theoretical side of the story. Any data science practice must be built on
the foundation of probability, and probability needs to address practical problems. However,
what exactly is “probability”? Mathematicians have been debating this for centuries. The
frequentists argue that probability is the relative frequency of an outcome. For example,
flipping a fair coin has a 1/2 probability of getting a head because if you flip the coin
infinitely many times, you will have half of the time getting a head. The Bayesians argue
that probability is a subjective belief. For example, the probability of getting an A in a
class is subjective because no one would want to take a class infinitely many times to obtain
the relative frequency. Both the frequentists and Bayesians have valid points. However, the
di↵erentiation is often non-essential because the context of your problem will force you
to align with one or the other. For example, when you have a shortage of data, then the
subjectivity of the Bayesians allows you to use prior knowledge, whereas the frequentists
tell us how to compute the confidence interval of an estimate.
No matter whether you prefer the frequentist’s view or the Bayesian’s view, there is
something more fundamental thanks to Andrey Kolmogorov (1903-1987). The development
of this fundamental definition will take some e↵ort on our part, but if we distill the essence,
we can summarize it as follows:

Probability is a measure of the size of a set.

This sentence is not a formal definition; instead, it summarizes what we believe to be the
essence of probability. We need to clarify some puzzles later in this chapter, but if you can
understand what this sentence means, you are halfway done with this book. To spell out the
details, we will describe an elementary problem that everyone knows how to solve. As we
discuss this problem, we will highlight a few key concepts that will give you some intuitive
insights into our definition of probability, after which we will explain the sequence of topics
to be covered in this chapter.

Prelude: Probability of throwing a die


Suppose that you have a fair die. It has 6 faces: { , , , , , }. What is the probability
that you get a number that is “less than 5” and is “an even number”? This is a straightfor-

43
CHAPTER 2. PROBABILITY

ward problem. You probably have already found the answer, which is 26 because “less than
5” and “an even number” means { , }. However, let’s go through the thinking process
slowly by explicitly writing down the steps.
First of all, how do we know that the denominator in 26 is 6? Well, because there are six
faces. These six faces form a set called the sample space. A sample space is the set containing
all possible outcomes, which in our case is ⌦ = { , , , , , }. The denominator 6 is the
size of the sample space.
How do we know that the numerator is 2? Again, implicitly in our minds, we have
constructed two events: E1 = “less than 5” = { , , , }, and E2 = “an even number”
= { , , }. Then we take the intersection between these two events to conclude the event
E = { , }. The numerical value “2” is the size of this event E.
So, when we say that “the probability is 26 ,” we are saying that the size of the event
E relative to the sample space ⌦ is the ratio 26 . This process involves measuring the size
of E and ⌦. In this particular example, the measure we use is a “counter” that counts the
number of elements.
This example shows us all the necessary components of probability: (i) There is a
sample space, which is the set that contains all the possible outcomes. (ii) There is an event,
which is a subset inside the sample space. (iii) Two events E1 and E2 can be combined to
construct another event E that is still a subset inside the sample space. (iv) Probability is
a number assigned by certain rules such that it describes the relative size of the event E
compared with the sample space ⌦. So, when we say that probability is a measure of the
size of a set, we create a mapping that takes in a set and outputs the size of that set.

Organization of this chapter


As you can see from this example, since probability is a measure of the size of a set, we need
to understand the operations of sets to understand probability. Accordingly, in Section 2.1
we first define sets and discuss their operations. After learning these basic concepts, we move
on to define the sample space and event space in Section 2.2. There, we discuss sample spaces
that are not necessarily countable and how probabilities are assigned to events. Of course,
assigning a probability value to an event cannot be arbitrary; otherwise, the probabilities
may be inconsistent. Consequently, in Section 2.3 we introduce the probability axioms and
formalize the notion of measure. Section 2.4 consists of a trio of topics that concern the
relationship between events using conditioning. We discuss conditional probability in Section
2.4.1, independence in Section 2.4.2, and Bayes’ theorem in Section 2.4.3.

2.1 Set Theory

2.1.1 Why study set theory?


In mathematics, we are often interested in describing a collection of numbers, for example, a
positive interval [a, b] on the real line or the ordered pairs of numbers that define a circle on
a graph with two axes. These collections of numbers can be abstractly defined as sets. In a
nutshell, a set is simply a collection of things. These things can be numbers, but they can also
be alphabets, objects, or anything. Set theory is a mathematical tool that defines operations
on sets. It provides the basic arithmetic for us to combine, separate, and decompose sets.

44
2.1. SET THEORY

Why do we start the chapter by describing set theory? Because probability is a measure
of the size of a set. Yes, probability is not just a number telling us the relative frequency of
events; it is an operator that takes a set and tells us how large the set is. Using the example
we showed in the prelude, the event “even number” of a die is a set containing numbers
{ , , }. When we apply probability to this set, we obtain the number 36 , as shown in
Figure 2.1. Thus sets are the foundation of the study of probability.

Figure 2.1: Probability is a measure of the size of a set. Whenever we talk about probability, it has to
be the probability of a set.

2.1.2 Basic concepts of a set

Definition 2.1 (Set). A set is a collection of elements. We denote

A = {⇠1 , ⇠2 , . . . , ⇠n } (2.1)

as a set, where ⇠i is the ith element in the set.

In this definition, A is called a set. It is nothing but a collection of elements ⇠1 , . . . , ⇠n . What


are these ⇠i ’s? They can be anything. Let’s see a few examples below.

Example 2.1(a). A = {apple, orange, pear} is a finite set.


Example 2.1(b). A = {1, 2, 3, 4, 5, 6} is a finite set.
Example 2.1(c). A = {2, 4, 6, 8, . . .} is a countable but infinite set.
Example 2.1(d). A = {x | 0 < x < 1} is a uncountable set.

To say that an element ⇠ is drawn from A, we write ⇠ 2 A. For example, the number 1
is an element in the set {1, 2, 3}. We write 1 2 {1, 2, 3}. There are a few common sets that
we will encounter. For example,

Example 2.2(a). R is the set of all real numbers including ±1.


Example 2.2(b). R2 is the set of ordered pairs of real numbers.
Example 2.2(c). [a, b] = {x | a  x  b} is a closed interval on R.
Example 2.2(d). (a, b) = {x | a < x < b} is an open interval on R.
Example 2.2(e). (a, b] = {x | a < x  b} is a semi-closed interval on R.

45
CHAPTER 2. PROBABILITY

Figure 2.2: From left to right: a closed interval, a semi-closed (or semi-open) interval, and an open
interval.
Sets are not limited to numbers. A set can be used to describe a collection of functions.

Example 2.3. A = {f : R ! R | f (x) = ax+b, a, b 2 R}. This is the set of all straight
lines in 2D. The notation f : R ! R means that the function f takes an argument
from R and sends it to another real number in R. The definition f (x) = ax + b says
that f is taking the specific form of ax + b. Since the constants a and b can be any
real number, the equation f (x) = ax + b enumerates all possible straight lines in 2D.
See Figure 2.3(a).

Example 2.4. A = {f : R ! [ 1, 1] | f (t) = cos(!0 t + ✓), ✓ 2 [0, 2⇡]}. This is


the set of all cosine functions of a fixed carrier frequency !0 . The phase ✓, however,
is changing. Therefore, the equation f (t) = cos(!0 t + ✓) says that the set A is the
collection of all possible cosines with di↵erent phases. See Figure 2.3(b).

1 2

0.5 1
f(t)
f(t)

0 0

-0.5 -1

-1 -2
-2 -1 0 1 2 -1 -0.5 0 0.5 1
t t

Figure 2.3: (a) The set of straight lines A = {f : R ! R | f (x) = ax + b, a, b 2 R}. (b) The set of
phase-shifted cosines A = {f : R ! [ 1, 1] | f (t) = cos(!0 t + ✓), ✓ 2 [0, 2⇡]}.

A set can also be used to describe a collection of sets. Let A and B be two sets. Then
C = {A, B} is a set of sets.

Example 2.5. Let A = {1, 2} and B = {apple, orange}. Then

C = {A, B} = {{1, 2}, {apple, orange}}

46
2.1. SET THEORY

is a collection of sets. Note that here we are not saying C is the union of two sets. We
are only saying that C is a collection of two sets. See the next example.

Example 2.6. Let A = {1, 2} and B = {3}, then C = {A, B} means that

C = {{1, 2}, {3}}.

Therefore C contains only two elements. One is the set {1, 2} and the other is the set
{3}. Note that {{1, 2}, {3}} =
6 {1, 2, 3}. The former is a set of two sets. The latter is a
set of three elements.

2.1.3 Subsets
Given a set, we often want to specify a portion of the set, which is called a subset.

Definition 2.2 (Subset). B is a subset of A if for any ⇠ 2 B, ⇠ is also in A. We


write
B✓A (2.2)
to denote that B is a subset of A.

B is called a proper subset of A if B is a subset of A and B 6= A. We denote a proper subset


as B ⇢ A. Two sets A and B are equal if and only if A ✓ B and B ✓ A.

Example 2.7.
If A = {1, 2, 3, 4, 5, 6}, then B = {1, 3, 5} is a proper subset of A.
If A = {1, 2}, then B = {1, 2} is an improper subset of A.
If A = {t | t 0}, then B = {t | t > 0} is a proper subset of A.

Practice Exercise 2.1. Let A = {1, 2, 3}. List all the subsets of A.
Solution. The subsets of A are:

A = {;, {1}, {2}, {3}, {1, 2}, {1, 3}, {2, 3}, {1, 2, 3}}.

Practice Exercise 2.2. Prove that two sets A and B are equal if and only if A ✓ B
and B ✓ A.
Solution. Suppose A ✓ B and B ✓ A. Assume by contradiction that A 6= B. Then
necessarily there must exist an x such that x 2 A but x 62 B (or vice versa). But
A ✓ B means that x 2 A will necessarily be in B. So it is impossible to have x 62 B.
Conversely, suppose that A = B. Then any x 2 A will necessarily be in B. Therefore,
we have A ✓ B. Similarly, if A = B then any x 2 B will be in A, and so B ✓ A.

47
CHAPTER 2. PROBABILITY

2.1.4 Empty set and universal set

Definition 2.3 (Empty Set). A set is empty if it contains no element. We denote


an empty set as
A = ;. (2.3)

A set containing an element 0 is not an empty set. It is a set of one element, {0}. The
number of elements of the empty set is 0. The empty set is a subset of any set, i.e., ; ✓ A
for any A. We use ✓ because A could also be an empty set.

Example 2.8(a). The set A = {x | sin x > 1} is empty because no x 2 R can make
sin x > 1.
Example 2.8(b). The set A = {x | x > 5 and x < 1} is empty because the two
conditions x > 5 and x < 1 are contradictory.

Definition 2.4 (Universal Set). The universal set is the set containing all elements
under consideration. We denote a universal set as

A = ⌦. (2.4)

The universal set ⌦ contains itself, i.e., ⌦ ✓ ⌦. The universal set is a relative concept.
Usually, we first define a universal set ⌦ before referring to subsets of ⌦. For example, we
can define ⌦ = R and refer to intervals in R. We can also define ⌦ = [0, 1] and refer to
subintervals inside [0, 1].

2.1.5 Union
We now discuss basic set operations. By operations, we mean functions of two or more sets
whose output value is a set. We use these operations to combine and separate sets. Let us
first consdier the union of two sets. See Figure 2.4 for a graphical depiction.

Definition 2.5 (Finite Union). The union of two sets A and B contains all elements
in A or in B. That is,
A [ B = {⇠ | ⇠ 2 A or ⇠ 2 B}. (2.5)

As the definition suggests, the union of two sets connects the sets using the logical operator
”or”. Therefore, the union of two sets is always larger than or equal to the individual sets.

Example 2.9(a). If A = {1, 2}, B = {1, 5}, then A [ B = {1, 2, 5}. The overlapping
element 1 is absorbed. Also, note that A [ B 6= {{1, 2}, {1, 5}}. The latter is a set of
sets.
Example 2.9(b). If A = (3, 4], B = (3.5, 1), then A [ B = (3, 1).
Example 2.9(c). If A = {f : R ! R | f (x) = ax} and B = {f : R ! R | f (x) = b},
then A [ B = a set of sloped lines with a slope a plus a set of constant lines with

48
2.1. SET THEORY

height b. Note that A [ B 6= {f : R ! R | f (x) = ax + b} because the latter is a set of


sloped lines with arbitrary y-intercept.
Example 2.9(d). If A = {1, 2} and B = ;, then A [ B = {1, 2}.
Example. If A = {1, 2} and B = ⌦, then A [ B = ⌦.

Figure 2.4: The union of two sets contains elements that are either in A or B or both.

The previous example can be generalized in the following exercise. What it says is that
if A is a subset of another set B, then the union of A and B is just B. Intuitively, this should
be straightforward because whatever you have in A is already in B, so the union will just
be B. Below is a formal proof that illustrates how to state the arguments clearly. You may
like to draw a picture to convince yourself that the proof is correct.

Practice Exercise 2.3: Prove that if A ✓ B, then A [ B = B.


Solution: We will show that A [ B ✓ B and B ✓ A [ B. Let ⇠ 2 A [ B. Then ⇠ must
be inside either A or B (or both). In any case, since we know that A ✓ B, it holds
that if ⇠ 2 A then ⇠ must also be in B. Therefore, for any ⇠ 2 A [ B we have ⇠ 2 B.
This shows A [ B ✓ B. Conversely, if ⇠ 2 B, then ⇠ must be inside A [ B because
A [ B is a larger set than B. So if ⇠ 2 B then ⇠ 2 A [ B and hence B ✓ A [ B. Since
A [ B is a subset of B or equal to B, and B is a subset of A [ B or equal to A [ B, it
follows that A [ B = B.

What should we do if we want to take the union of an infinite number of sets? First,
we need to define the concept of an infinite union.

Definition 2.6 (Infinite Union). For an infinite sequence of sets A1 , A2 , . . ., the in-
finite union is defined as
1
[
An = {⇠ | ⇠ 2 An for at least one n that is finite.} . (2.6)
n=1

An infinite union is a natural extension of a finite union. It is not difficult to see that
⇠ 2 A or ⇠ 2 B () ⇠ is in at least one of A and B.

49
CHAPTER 2. PROBABILITY

Similarly, an infinite union means that


⇠ 2 A1 or ⇠ 2 A2 or ⇠ 2 A3 . . . () ⇠ is in at least one of A1 , A2 , A3 , . . . .
The finite n requirement says that we only evaluate the sets for a finite number of n’s. This
n can be arbitrarily large, but it is finite. Why are we able to do this? Because the concept
of an infinite union is to determine A1 , which is the limit of a sequence. Like any sequence
of real numbers, the limit of a sequence of sets has to be defined by evaluating the instances
of all possible finite cases.
⇥ ⇤
Consider⇥ a sequence
⇤ of⇥ sets A
⇤ n = ⇥ 1, 1 ⇤ n1 , for n = 1, 2, . . .. For example, A1 =
[ 1, 0], A2 = 1, 12 , A3 = 1, 23 , A4 = 1, 34 , etc.

S ⇥ ⇤
Figure 2.5: The infinite union of 1 n=1 1, 1 1
n
. No matter how large n gets, the point 1 is never
included. So the infinite union is [ 1, 1)

To take the infinite union, we know that the set [ 1, 1) is always included, because the
right-hand limit 1 n1 approaches 1 as n approaches 1. So the only question concerns the
number 1. Should 1 be included? According to the definition above, we ask: Is 1 an element
of at least one of the sets A1 , A2 , . . . , An ? Clearly it is not: 1 62 A1 , 1 62 A2 , . . .. In fact,
1 62 An for any finite n. Therefore 1 is not an element of the infinite union, and we conclude
that
1
[ [1 
1
An = 1, 1 = [ 1, 1).
n=1 n=1
n

Practice
⇥ Exercise 2.4. Find the ⇤infinite union of the sequences where (a) An =
1, 1 n1 , (b) An = 1, 1 n1 .
S1 S1
Solution. (a) n=1 An = [ 1, 1). (b) n=1 An = ( 1, 1).

2.1.6 Intersection
The union of two sets is based on the logical operator or. If we use the logical operator and,
then the result is the intersection of two sets.

Definition 2.7 (Finite Intersection). The intersection of two sets A and B contains
all elements in A and in B. That is,

A \ B = {⇠ | ⇠ 2 A and ⇠ 2 B}. (2.7)

Figure 2.6 portrays intersection graphically. Intersection finds the common elements of the
two sets. It is not difficult to show that A \ B ✓ A and A \ B ✓ B.
50
2.1. SET THEORY

Figure 2.6: The intersection of two sets contains elements in both A and B.

Example 2.10(a). If A = {1, 2, 3, 4}, B = {1, 5, 6}, then A \ B = {1}.


Example 2.10(b). If A = {1, 2}, B = {5, 6}, then A \ B = ;.
Example 2.10(c). If A = (3, 4], B = [3.5, 1), then A \ B = [3.5, 4].
Example 2.10(d). If A = (3, 4], B = ;, then A \ B = ;.
Example 2.10(e). If A = (3, 4], B = ⌦, then A \ B = (3, 4].

Example 2.11. If A = {f : R ! R | f (x) = ax} and B = {f : R ! R | f (x) = b}, then


A\B = the intersection of a set of sloped lines with a slope a and a set of constant lines
with height b. The only line that can satisfy both sets is the line f (x) = 0. Therefore,
A \ B = {f | f (x) = 0}.

Example 2.12. If A = {{1}, {2}} and B = {{2, 3}, {4}}, then A \ B = ;. This is
because A is a set containing two sets, and B is a set containing two sets. The two sets
{2} and {2, 3} are not the same. Thus, A and B have no elements in common, and so
A \ B = ;.

Similarly to the infinite union, we can define the concept of infinite intersection.

Definition 2.8 (Infinite Intersection). For an infinite sequence of sets A1 , A2 , . . .,


the infinite intersection is defined as
1
\
An = {⇠ | ⇠ 2 An for every finite n.} (2.8)
n=1

To understand this definition, we note that


⇠ 2 A and ⇠ 2 B () ⇠ is in every one of A and B.
As a result, it follows that
⇠ 2 A1 and ⇠ 2 A2 and ⇠ 2 A3 . . . () ⇠ is in every one of A1 , A2 , A3 , . . . .

51
CHAPTER 2. PROBABILITY

Since the infinite intersection requires that ⇠ is in every one of A1 , A2 , . . ., An , if there is a


set Ai that does not contain ⇠, the infinite intersection is an empty
T1set.
Consider the problem of finding the infinite intersection of n=1 An , where
 ◆
1
An = 0, 1 + .
n

We note that the sequence of sets is [0, 2], [0, 1.5], [0, 1.33], . . . . As n ! 1, we note that
the limit is either [0, 1) or [0, 1]. Should the right-hand limit 1 be included in the infinite
intersection? According to the definition above, we know that 1 2 A1 , 1 2 A2 , . . . , 1 2 An
for any finite n. Therefore, 1 is included and so
1
\ 1 
\ ◆
1
An = 0, 1 + = [0, 1].
n=1 n=1
n

T ⇥
Figure 2.7: The infinite intersection of 1 n=1 0, 1 +
1
n
. No matter how large n gets, the point 1 is
never included. So the infinite intersection is [0, 1]

Practice
⇥ Exercise
⇤ 2.5. Find the infinite intersection
⇥ of the sequences
⇥ where
⇤ (a)
An = 0, 1 + n1 , (b) An = 0, 1 + n1 , (c) An = 0, 1 n1 , (d) An = 0, 1 n1 .
Solution.
T1
(a) n=1 An = [0, 1].
T1
(b) n=1 An = ( 1, 1].
T1
(c) n=1 An = [0, 0) = ;.
T1
(d) n=1 An = [0, 0] = {0}.

2.1.7 Complement and di↵erence


Besides union and intersection, there is a third basic operation on sets known as the com-
plement.

Definition 2.9 (Complement). The complement of a set A is the set containing all
elements that are in ⌦ but not in A. That is,

Ac = {⇠ | ⇠ 2 ⌦ and ⇠ 62 A}. (2.9)

Figure 2.8 graphically portrays the idea of a complement. The complement is a set that
contains everything in the universal set that is not in A. Thus the complement of a set is
always relative to a specified universal set.

52
2.1. SET THEORY

Figure 2.8: [Left] The complement of a set A contains all elements that are not in A. [Right] The
di↵erence A\B contains elements that are in A but not in B.

Example 2.13(a). Let A = {1,2,3} and ⌦ = {1,2,3,4,5,6}. Then Ac = {4,5,6}.


Example 2.13(b). Let A = {even integers} and ⌦ = {integers}. Then Ac = {odd
integers}.
Example 2.13(c). Let A = {integers} and ⌦ = R. Then Ac ={any real number that
is not an integer}.
Example 2.13(d). Let A = [0, 5) and ⌦ = R. Then Ac = ( 1, 0) [ [5, 1).
Example 2.13(e). Let A = R and ⌦ = R. Then Ac = ;.

The concept of the complement will help us understand the concept of di↵erence.

Definition 2.10 (Di↵erence). The di↵erence A\B is the set containing all elements
in A but not in B.
A\B = {⇠ | ⇠ 2 A and ⇠ 62 B}. (2.10)

Figure 2.8 portrays the concept of di↵erence graphically. Note that A\B 6= B\A. The former
removes the elements in B whereas the latter removes the elements in A.

Example 2.14(a). Let A = {1, 3, 5, 6} and B = {2, 3, 4}. Then A\B = {1, 5, 6} and
B\A = {2, 4}.
Example 2.14(b). Let A = [0, 1], B = [2, 3], then A\B = [0, 1], and B\A = [2, 3].
This example shows that if the two sets do not overlap, there is nothing to subtract.
Example 2.14(c). Let A = [0, 1], B = R, then A\B = ;, and B\A = ( 1, 0)[(1, 1).
This example shows that if one of the sets is the universal set, then the di↵erence will
either return the empty set or the complement.

53
CHAPTER 2. PROBABILITY

Figure 2.9: [Left] A and B are overlapping. [Right] A and B are disjoint.

Practice Exercise 2.6. Show that for any two sets A and B, the di↵erences A\B
and B\A never overlap, i.e., (A\B) \ (B\A) = ;.
Solution. Suppose, by contradiction, that the intersection is not empty so that there
exists an ⇠ 2 (A\B) \ (B\A). Then, by the definition of intersection, ⇠ is an element
of (A\B) and (B\A). But if ⇠ is an element of (A\B), it cannot be an element of B.
This implies that ⇠ cannot be an element of (B\A) since it is a subset of B. This is a
contradiction because we just assumed that the ⇠ can live in both (A\B) and (B\A).

Di↵erence can be defined in terms of intersection and complement:

Theorem 2.1. Let A and B be two sets. Then

A\B = A \ B c (2.11)

Proof. Let x 2 A\B. Then x 2 A and x 62 B. Since x 62 B, we have x 2 B c . Therefore,


x 2 A and x 2 B c . By the definition of intersection, we have x 2 A \ B c . This shows
that A\B ✓ A \ B c . Conversely, let x 2 A \ B c . Then, x 2 A and x 2 B c , which implies
that x 2 A and x 62 B. By the definition of A\B, we have that x 2 A\B. This shows that
A \ B c ✓ A\B.

2.1.8 Disjoint and partition


It is important to be able to quantify situations in which two sets are not overlapping. In
this situation, we say that the sets are disjoint.

Definition 2.11 (Disjoint). Two sets A and B are disjoint if

A \ B = ;. (2.12)

For a collection of sets {A1 , A2 , . . . , An }, we say that the collection is disjoint if, for
any pair i 6= j,
Ai \ Aj = ;. (2.13)

A pictorial interpretation can be found in Figure 2.9.

54
2.1. SET THEORY

Example 2.15(a). Let A = {x > 1} and B = {x < 0}. Then A and B are disjoint.
Example 2.15(b). Let A = {1, 2, 3} and B = ;. Then A and B are disjoint.
Example 2.15(c). Let A = (0, 1) and B = [1, 2). Then A and B are disjoint.

With the definition of disjoint, we can now define the powerful concept of partition.

Definition 2.12 (Partition). A collection of sets {A1 , . . . , An } is a partition of the


universal set ⌦ if it satisfies the following conditions:

( non-overlap) {A1 , . . . , An } is disjoint:

Ai \ Aj = ;. (2.14)

( decompose) Union of {A1 , . . . , An } gives the universal set:


n
[
Ai = ⌦. (2.15)
i=1

In plain language, a partition is a collection of non-overlapping subsets whose union is


the universal set. Partition is important because it is a decomposition of ⌦ into a smaller
subset, and since these subsets do not overlap, they can be analyzed separately. Partition
is a handy tool for studying probability because it allows us to decouple complex events by
treating them as isolated sub-events.

Figure 2.10: A partition of ⌦ contains disjoint subsets of which the union gives us ⌦.

Example 2.16. Let ⌦ = {1, 2, 3, 4, 5, 6}. The following sets form a partition:

A1 = {1, 2, 3}, A2 = {4, 5}, A3 = {6}

Example 2.17. Let ⌦ = {1, 2, 3, 4, 5, 6}. The collection

A1 = {1, 2, 3}, A2 = {4, 5}, A3 = {5, 6}

does not form a partition, because A2 \ A3 = {5}.

55
CHAPTER 2. PROBABILITY

If {A1 , A2 , . . . , An } forms a partition of the universal set ⌦, then for any B ✓ ⌦, we


can decompose B into n disjoint subsets: B \ A1 , B \ A2 , . . . B \ An . Two properties hold:
B \ Ai and B \ Aj are disjoint if i 6= j.
The union of B \ A1 , B \ A2 , . . . B \ An is B.

Practice Exercise 2.7. Prove the above two statements.


Solution. To prove the first statement, we can pick ⇠ 2 (B \ Ai ). This means that
⇠ 2 B and ⇠ 2 Ai . Since ⇠ 2 Ai , it cannot be in Aj because Ai and Aj are disjoint.
Therefore ⇠ cannot live in B \ Aj . This completes the proof, because we just showed
that any ⇠ 2 B \ Ai cannot simultaneously live in B \ Aj .
Sn
To prove the second statement, we pick ⇠ 2 i=1 (B \ Ai ). Since ⇠ lives in the
union, it has to live in at least one of the (B \ Ai ) for some i. Now suppose
S n ⇠ 2 B \ Ai .
This means that ⇠ is in both B and Ai , so it must live in B. Therefore, i=1 (B \ Ai ) ✓
B. Now, suppose we pick ⇠ 2 B. Then since it is an Snelement in B, it must be an element
in allSof the (B \ Ai )’s for any i. Therefore, ⇠ 2 i=1 (B \ Ai ), andSso we showed that
n n
B ✓ i=1 (B \Ai ). Combining the two directions, we conclude that i=1 (B \Ai ) = B.

Example 2.18. Let ⌦ = {1, 2, 3, 4, 5, 6} and let a partition of ⌦ be A1 = {1, 2, 3},


A2 = {4, 5}, A3 = {6}. Let B = {1, 3, 4}. Then, by the result we just proved, B can
be decomposed into three subsets:

B \ A1 = {1, 3}, B \ A2 = {4}, B \ A3 = ;.

Thus we can see that B \ A1 , B \ A2 and B \ A3 are disjoint. Furthermore, the union
of these three sets gives B.

2.1.9 Set operations


When handling multiple sets, it would be useful to have some basic set operations. There
are four basic theorems concerning set operations that you need to know for our purposes
in this book:

Theorem 2.2 (Commutative). (Order does not matter)

A \ B = B \ A, and A [ B = B [ A. (2.16)

Theorem 2.3 (Associative). (How to do multiple union and intersection)

A [ (B [ C) = (A [ B) [ C,
A \ (B \ C) = (A \ B) \ C. (2.17)

56
2.1. SET THEORY

Theorem 2.4 (Distributive). (How to mix union and intersection)

A \ (B [ C) = (A \ B) [ (A \ C),
A [ (B \ C) = (A [ B) \ (A [ C). (2.18)

Theorem 2.5 (De Morgan’s Law). (How to complement over intersection and union)

(A \ B)c = Ac [ B c ,
(A [ B)c = Ac \ B c . (2.19)

Example 2.19. Consider [1, 4] \ ([0, 2] [ [3, 5]). By the distributive property we can
simplify the set as

[1, 4] \ ([0, 2] [ [3, 5]) = ([1, 4] \ [0, 2]) [ ([1, 4] \ [3, 5])
= [1, 2] [ [3, 4].

Example 2.20. Consider ([0, 1] [ [2, 3])c . By De Morgan’s Law we can rewrite the set
as
([0, 2] [ [1, 3])c = [0, 2]c \ [1, 3]c .

2.1.10 Closing remarks about set theory


It should be apparent why set theory is useful: it shows us how to combine, split, and
remove sets. In Figure 2.11 we depict the intersection of two sets A = {even number} and
B = {less than or equal to 3}. Set theory tells us how to define the intersection so that the
probability can be applied to the resulting set.

Figure 2.11: When there are two events A and B, the probability of A \ B is determined by first taking
the intersection of the two sets and then evaluating its probability.

Universal sets and empty sets are useful too. Universal sets cover all the possible
outcomes of an experiment, so we should expect P[⌦] = 1. Empty sets contain nothing,
and so we should expect P[;] = 0. These two properties are essential to define a probability
because no probability can be greater than 1, and no probability can be less than 0.

57
CHAPTER 2. PROBABILITY

2.2 Probability Space

We now formally define probability. Our discussion will be based on the slogan probability
is a measure of the size of a set. Three elements constitute a probability space:
Sample Space ⌦: The set of all possible outcomes from an experiment.
Event Space F: The collection of all possible events. An event E is a subset in ⌦ that
defines an outcome or a combination of outcomes.
Probability Law P: A mapping from an event E to a number P[E] which, ideally,
measures the size of the event.
Therefore, whenever you talk about “probability,” you need to specify the triplet (⌦, F, P)
to define the probability space.
The necessity of the three elements is illustrated in Figure 2.12. The sample space
is the interface with the physical world. It is the collection of all possible states that can
result from an experiment. Some outcomes are more likely to happen, and some are less
likely, but this does not matter because the sample space contains every possible outcome.
The probability law is the interface with the data analysis. It is this law that defines the
likelihood of each of the outcomes. However, since the probability law measures the size of
a set, the probability law itself must be a function, a function whose argument is a set and
whose value is a number. An outcome in the sample space is not a set. Instead, a subset in
the sample space is a set. Therefore, the probability should input a subset and map it to a
number. The collection of all possible subsets is the event space.

Figure 2.12: Given an experiment, we define the collection of all outcomes as the sample space. A
subset in the sample space is called an event. The probability law is a mapping that maps an event to
a number that denotes the size of the event.
A perceptive reader like you may be wondering why we want to complicate things to
this degree when calculating probability is trivial, e.g., throwing a die gives us a probability
1
6 per face. In a simple world where problems are that easy, you can surely ignore all these
complications and proceed to the answer 16 . However, modern data analysis is not so easy.
If we are given an image of size 64 ⇥ 64 pixels, how do we tell whether this image is of a cat
or a dog? We need to construct a probability model that tells us the likelihood of having a

58
2.2. PROBABILITY SPACE

particular 64 ⇥ 64 image. What should be included in this probability model? We need to


know all the possible cases (the sample space), all the possible events (the event space),
and the probability of each of the events (the probability law). If we know all these, then our
decision will be theoretically optimal. Of course, for high-dimensional data like images, we
need approximations to such a probability model. However, we first need to understand the
theoretical foundation of the probability space to know what approximations would make
sense.

2.2.1 Sample space ⌦


We start by defining the sample space ⌦. Given an experiment, the sample space ⌦ is the
set containing all possible outcomes of the experiment.

Definition 2.13. A sample space ⌦ is the set of all possible outcomes from an ex-
periment. We denote ⇠ as an element in ⌦.

A sample space can contain discrete outcomes or continuous outcomes, as shown in


the examples below and Figure 2.13.

Example 2.21: (Discrete Outcomes)


Coin flip: ⌦ = {H, T }.
Throw a die: ⌦ = { , , , , , }.
Paper / scissor / stone: ⌦ = {paper, scissor, stone}.
Draw an even integer: ⌦ = {2, 4, 6, 8, . . .}.

Example 2.22: (Continuous Outcomes)


Waiting time for a bus in West Lafayette: ⌦ = {t | 0  t  30 minutes}.
Phase angle of a voltage: ⌦ = {✓ | 0  ✓  2⇡}.
Frequency of a pitch: ⌦ = {f | 0  f  fmax }.

Figure 2.13 also shows a functional example of the sample space. In this case, the
sample space contains functions. For example,
Set of all straight lines in 2D:

⌦ = {f | f (x) = ax + b, a, b 2 R}.

Set of all cosine functions with a phase o↵set:

⌦ = {f | f (t) = cos(2⇡!0 t + ⇥), 0  ⇥  2⇡}.

As we see from the above examples, the sample space is nothing but a universal set.
The elements inside the sample space are the outcomes of the experiment. If you change

59
CHAPTER 2. PROBABILITY

Figure 2.13: The sample space can take various forms: it can contain discrete numbers, or continuous
intervals, or even functions.

the experiment, the possible outcomes will be di↵erent so that the sample space will be
di↵erent. For example, flipping a coin has di↵erent possible outcomes from throwing a die.

What if we want to describe a composite experiment where we flip a coin and throw a
die? Here is the sample space:

Example 2.23: If the experiment contains flipping a coin and throwing a die, then
the sample space is

(H, ), (H, ), (H, ), (H, ), (H, ), (H, ),

(T, ), (T, ), (T, ), (T, ), (T, ), (T, ) .

In this sample space, each element is a pair of outcomes.

Practice Exercise 2.8. There are 8 processors on a computer. A computer job sched-
uler chooses one processor randomly. What is the sample space? If the computer job
scheduler can choose two processors at once, what is the sample space then?
Solution. The sample space of the first case is ⌦ = {1, 2, 3, 4, 5, 6, 7, 8}. The sample
space of the second case is ⌦ = {(1, 2), (1, 3), (1, 4), . . . , (7, 8)}.

Practice Exercise 2.9. A cell phone tower has a circular average coverage area of
radius of 10 km. We observe the source locations of calls received by the tower. What
is the sample space of all possible source locations?
Solution. Assume that the center of the tower is located at (x0 , y0 ). The sample space
is the set p
⌦ = {(x, y) | (x x0 )2 + (y y0 )2  10}.

Not every set can be a sample space. A sample space must be exhaustive and exclusive.
The term “exhaustive” means that the sample space has to cover all possible outcomes. If

60
2.2. PROBABILITY SPACE

there is one possible outcome that is left out, then the set is no longer a sample space. The
term “exclusive” means that the sample space contains unique elements so that there is no
repetition of elements.

Example 2.24. (Counterexamples)

The following two examples are NOT sample spaces.


Throw a die: ⌦ = {1, 2, 3} is not a sample space because it is not exhaustive.
Throw a die: ⌦ = {1, 1, 2, 3, 4, 5, 6} is not a sample space because it is not exclu-
sive.
Therefore, a valid sample space must contain all possible outcomes, and each element
must be unique.

We summarize the concept of a sample space as follows.

What is a sample space ⌦?


A sample space ⌦ is the collection of all possible outcomes.
The outcomes can be numbers, alphabets, vectors, or functions. The outcomes
can also be images, videos, EEG signals, audio speeches, etc.
⌦ must be exhaustive and exclusive.

2.2.2 Event space F


The sample space contains all the possible outcomes. However, in many practical situations,
we are not interested in each of the individual outcomes; we are interested in the com-
binations of the outcomes. For example, when throwing a die, we may ask “What is the
probability of rolling an odd number?” or “What is the probability of rolling a number that
is less than 3?” Clearly, “odd number” is not an outcome of the experiment because the
possible outcomes are { , , , , , }. We call “odd number” an event. An event must
be a subset in the sample space.

Definition 2.14. An event E is a subset in the sample space ⌦. The set of all possible
events is denoted as F.

While this definition is extremely simple, we need to keep in mind a few facts about events.
First, an outcome ⇠ is an element in ⌦ but an event E is a subset contained in ⌦, i.e.,
E ✓ ⌦. Thus, an event can contain one outcome but it can also contain many outcomes.
The following example shows a few cases of events:

Example 2.25. Throw a die. Let ⌦ = { , , , , , }. The following are two pos-
sible events, as illustrated in Figure 2.14.

E1 = {even numbers} = { , , }.

61
CHAPTER 2. PROBABILITY

E2 = {less than 3} = { , }.

Figure 2.14: Two examples of events: The first event contains numbers {2, 4, 6}, and the second
event contains numbers {1, 2}.

Practice Exercise 2.10. The “ping” command is used to measure round-trip times
for Internet packets. What is the sample space of all possible round-trip times? What
is the event that a round-trip time is between 10 ms and 20 ms?
Solution. The sample space is ⌦ = [0, 1). The event is E = [10, 20].

Practice Exercise 2.11. A cell phone tower has a circular average coverage area of
radius 10 km. We observe the source locations of calls received by the tower. What is
the event when the source location of a call is between 2 km and 5 km from the tower?
Solution. Assume p that the center of the tower is located at (x0 , y0 ). The event is
E = {(x, y) | 2  (x x0 )2 + (y y0 )2  5}.

The second point we should remember is the cardinality of ⌦ and that of F. A sample
space containing n elements has a cardinality n. However, the event space constructed from
⌦ will contain 2n events. To see why this is so, let’s consider the following example.

Example 2.26. Consider an experiment with 3 outcomes ⌦ = {|, ~, z}. We can list
out all the possible events: ;, {|}, {~}, {z}, {|, ~}, {|, z}, {~, |}, {|, ~, z}. So
in total there are 23 = 8 possible events. Figure 2.15 depicts the situation. What is
the di↵erence between | and {|}? The former is an element, whereas the latter is a
set. Thus, {|} is an event but | is not an event. Why is ; an event? Because we can
ask “What is the probability that we get an odd number and an even number?” The
probability is obviously zero, but the reason it is zero is that the event is an empty set.

62
2.2. PROBABILITY SPACE

Figure 2.15: The event space contains all the possible subsets inside the sample space.

In general, if there are n elements in the sample space, then the number of events
is 2n . To see why this is true, we can assign to each element a binary value: either 0 or 1.
For example, in Table 2.1 we consider throwing a die. For each of the six faces, we assign a
binary code. This will give us a binary string for each event. For example, the event { , }
is encoded as the binary string 100010 because only and are activated. We can count
the total number of unique strings, which is the number of strings that can be constructed
from n bits. It is easily seen that this number is 2n .

Event Binary Code


; ⇥ ⇥ ⇥ ⇥ ⇥ ⇥ 000000
{ , } ⇥ ⇥ ⇥ ⇥ 100010
{ , , } ⇥ ⇥ ⇥ 001110
.. .. .. ..
. . . .
{ , , , , } ⇥ 011111
{ , , , , , } 111111

Table 2.1: An event space contains 2n events, where n is the number of elements in the sample space.
To see this, we encode each outcome with a binary code. The resulting binary string then forms a unique
index of the event. Counting the total number of events gives us the cardinality of the event space.

The box below summarizes what you need to know about event spaces.

What is an event space F?


An event space F is the set of all possible subsets. It is a set of sets.
We need F because the probability law P is mapping a set to a number. P does
not take an outcome from ⌦ but a subset inside ⌦.

63
CHAPTER 2. PROBABILITY

Event spaces: Some advanced topics

The following discussions can be skipped if it is your first time reading the book.

What else do we need to take care of in order to ensure that an event is well defined? A
few set operations seem to be necessary. For example, if E1 = { } and E2 = { } are events,
it is necessary that E = E1 [ E2 = { , } is an event too. Another example: if E1 = { , }
and E2 = { , } are events, then it is necessary that E = E1 \ E2 = { } is also an event.
The third example: if E1 = { , , , } is an event, then E = E1c = { , } should be
an event. As you can see, there is nothing sophisticated in these examples. They are just
some basic set operations. We want to ensure that the event space is closed under these
set operations. That is, we do not want to be surprised by finding that a set constructed
from two events is not an event. However, since all set operations can be constructed from
union, intersection and complement, ensuring that the event space is closed under these
three operations e↵ectively ensures that it is closed to all set operations.
The formal way to guarantee these is the notion of a field. This term may seem to be
abstract, but it is indeed quite useful:

Definition 2.15. For an event space F to be valid, F must be a field F. It is a field


if it satisfies the following conditions
; 2 F and ⌦ 2 F.
(Closed under complement) If F 2 F, then also F c 2 F.
(Closed under union and intersection) If F1 2 F and F2 2 F, then F1 \ F2 2 F
and F1 [ F2 2 F.

For a finite set, i.e., a set that contains n elements, the collection of all possible subsets
is indeed a field. This is not difficult to see if you consider rolling a die. For example,
if E = { , , , } is inside F, then E c = { , } is also inside F. This is because F
consists of 2n subsets each being encoded by a unique binary string. So if E = 001111, then
E c = 110000, which is also in F. Similar reasoning applies to intersection and union.
At this point, you may ask:
Why bother constructing a field? The answer is that probability is a measure of the
size of a set, so we must input a set to a probability measure P to get a number. The
set being input to P must be a subset inside the sample space; otherwise, it will be
undefined. If we regard P as a mapping, we need to specify the collection of all its
inputs, which is the set of all subsets, i.e., the event space. So if we do not define the
field, there is no way to define the measure P.
What if the event space is not a field? If the event space is not a field, then we can
easily construct pathological cases where we cannot assign a probability. For example,
if the event space is not a field, then it would be possible that the complement of
E = { , , , } (which is E c = { , }) is not an event. This just does not make
sense.
The concept of a field is sufficient for finite sample spaces. However, there are two
other types of sample spaces where the concept of a field is inadequate. The first type of

64
2.2. PROBABILITY SPACE

sets consists of the countably infinite sets, and the second type consists of the sets defined
on the real line. There are other types of sets, but these two have important practical
applications. Therefore, we need to have a basic understanding of these two types.

Sigma-field
The difficulty of a countably infinite set is that there are infinitely many subsets in the field
of a countably infinite set. Having a finite union and a finite intersection is insufficient to
ensure the closedness of allSintersections and unions. In particular, having F1 [ F2 2 F does
1
not automatically give us n=1 Fn 2 F because the latter is an infinite union. Therefore,
for countably infinite sets, their requirements to be a field are more restrictive as we need
to ensure infinite intersection and union. The resulting field is called the -field.

Definition 2.16. A sigma-field ( -field) F is a field such that


F is a field, and
S1 T1
if F1 , F2 , . . . 2 F, then the union i=1 Fi and the intersection i=1 Fi are both
in F.

When do we need a -field? When the sample space is countable and has infinitely
many elements. For example, if the sample space contains all integers, then the collection
S1all possible subsets is a -field. For another, if E1 = {2}, E2 = {4}, E3S=
of
1
{6}, . . . , then
E
n=1 n = {2, 4, 6, 8, . . .} = {positive even numbers}. Clearly, we want n=1 En to live in
the sample space.

Borel sigma-field
While a sigma-field allows us to consider countable sets of events, it is still insufficient for
considering events defined on the real line, e.g., time, as these events are not countable.
So how do we define an event on the real line? It turns out that we need a di↵erent way
to define the smallest unit. For finite sets and countable sets, the smallest units are the
elements themselves because we can count them. For the real line, we cannot count the
elements because any non-empty interval is uncountably infinite.
The smallest unit we use to construct a field for the real line is a semi-closed interval
def
( 1, b] = {x | 1 < x  b}.

The Borel -field is defined as the sigma-field generated by the semi-closed inter-
vals.

Definition 2.17. The Borel -field B is a -field generated from semi-closed intervals:
def
( 1, b] = {x | 1 < x  b}.

The di↵erence between the Borel -field B and a regular -field is how we measure the
subsets. In a -field, we count the elements in the subsets, whereas, in a Borel -field, we
use the semi-closed intervals to measure the subsets.

65
CHAPTER 2. PROBABILITY

Being a field, the Borel -field is closed under complement, union, and intersection. In
particular, subsets of the following forms are also in the Borel -field B:

(a, b), [a, b], (a, b], [a, b), [a, 1), (a, 1), ( 1, b], {b}.

For example, (a, 1) can be constructed from ( 1, a]c , and (a, b] can be constructed by
taking the intersection of ( 1, b] and (a, 1).

Example 2.27: Waiting for a bus. Let ⌦ = {0  t  30}. The Borel -field contains
all semi-closed intervals (a, b], where 0  a  b  30. Here are two possible events:

F1 = {less than 10 minutes} = {0  t < 10} = {0} [ ({0 < t  10} \ {10}c ).
F2 = {more than 20 minutes} = {20 < t  30}.

Further discussion of the Borel -field can be found in Leon-Garcia (3rd Edition,)
Chapter 2.9.

This is the end of the discussion. Please join us again.

2.2.3 Probability law P


The third component of a probability space is the probability law P. Its job is to assign a
number to an event.

Definition 2.18. A probability law is a function P : F ! [0, 1] of an event E to a


real number in [0, 1].

The probability law is thus a function, and therefore we must specify the input and
the output. The input to P is an event E, which is a subset in ⌦ and an element in F. The
output of P is a number between 0 and 1, which we call the probability.
The definition above does not specify how an event is being mapped to a number.
However, since probability is a measure of the size of a set, a meaningful P should be
consistent for all events in F. This requires some rules, known as the axioms of probability,
when we define the P. Any probability law P must satisfy these axioms; otherwise, we will
see contradictions. We will discuss the axioms in the next section. For now, let us look at
two examples to make sure we understand the functional nature of P.

Example 2.28. Consider flipping a coin. The event space is F = {;, {H}, {T }, ⌦}.
We can define the probability law as
1 1
P[;] = 0, P[{H}] = , P[{T }] = , P[⌦] = 1,
2 2
as shown in Figure 2.16. This P is clearly consistent for all the events in F.
Is it possible to construct an invalid P? Certainly. Consider the following proba-

66
2.2. PROBABILITY SPACE

bility law:
1 1
P[;] = 0, P[{H}] = , P[{T }] = , P[⌦] = 1.
3 3
This law is invalid because the individual events are P[{H}] = 13 and P[{T }] = 13
but the union is P[⌦] = 1. To fix this problem, one possible solution is to define the
probability law as
1 2
P[;] = 0, P[{H}] = , P[{T }] = , P[⌦] = 1.
3 3
Then, the probabilities for all the events are well defined and consistent.

Figure 2.16: A probability law is a mapping from an event to a number. A probability law cannot be
arbitrarily assigned; it must satisfy the axioms of probability.

Example 2.29. Consider a sample


⇢ space containing three elements ⌦ = {|, ~, z}.
The event space is then F = ;, {|}, {~}, {z}, {|, ~}, {~, z}, {|, z}, {|, ~, z} .
One possible P we could define would be
1
P[;] = 0, P[{|}] = P[{~}] = P[{z}] = ,
3
2
P[{|, ~}] = P[{|, z}] = P[{~, z}] = , P[{|, ~, z}] = 1.
3

What is a probability law P?


A probability law P is a function.
It takes a subset (an element in F) and maps it to a number between 0 and 1.
P is a measure of the size of a set.
For P to be valid, it must satisfy the axioms of probability.

67
CHAPTER 2. PROBABILITY

Figure 2.17: Probability is a measure of the size of a set. The probability can be a counter that counts
the number of elements, a ruler that measures the length of an interval, or an integration that measures
the area of a region.

A probability law P is a measure


Consider the word “measure” in our slogan: probability is a measure of the size of a set.
Depending on the nature of the set, the measure can be a counter, ruler, scale, or even a
stopwatch. So far, all the examples we have seen are based on sets with a finite number of
elements. For these sets, the natural choice of the probability measure is a counter. However,
if the sets are intervals on the real line or regions in a plane, we need a di↵erent probability
law to measure their size. Let’s look at the examples shown in Figure 2.17.

Example 2.30 (Finite Set). Consider throwing a die, so that

⌦ = { , , , , , }.

Then the probability measure is a counter that reports the number of elements. If
the die is fair, i.e., all the 6 faces have equal probability of happening, then an event
E = { , } will have a probability P[E] = 26 .

Example 2.31 (Intervals). Suppose that the sample space is a unit interval ⌦ = [0, 1].
Let E be an event such that E = [a, b] where a, b are numbers in [0, 1]. Then the
probability measure is a ruler that measures the length of the intervals. If all the
numbers on the real line have equal probability of appearing, then P[E] = b a.

Example 2.32 (Regions). Suppose that the sample space is the square ⌦ = [ 1, 1] ⇥
[ 1, 1]. Let E be a circle such that E = {(x, y)|x2 + y 2 < r2 }, where r < 1. Then the
probability measure is an area measure that returns us the area of E. If we assume
that all coordinates in ⌦ are equally probable, then P[E] = ⇡r2 , for r < 1.

Because probability is a measure of the size of a set, two sets can be compared according
to their probability measures. For example, if ⌦ = {|, ~, z}, and if E1 = {|} and E2 =
{|, ~}, then one possible P is to assign P[E1 ] = P[{|}] = 13 and P[E2 ] = P[{|, ~}] = 2/3.

68
2.2. PROBABILITY SPACE

In this particular case, we see that E1 ✓ E2 and thus

P[E1 ]  P[E2 ].

Let’s now consider the term “size.” Notice that the concept of the size of a set is not
limited to the number of elements. A better way to think about size is to imagine that it is
the weight of the set. This might may seem fanciful at first, but it is quite natural. Consider
the following example.

Example 2.33. (Discrete events with di↵erent weights) Suppose we have a sample
space ⌦ = {|, ~, z}. Let us assign a di↵erent probability to each outcome:
2 1 3
P[{|}] = , P[{~}] = , P[{z}] = .
6 6 6
As illustrated in Figure 2.18, since each outcome has a di↵erent weight, when de-
termining the probability of a set of outcomes we can add these weights (instead of
counting the number of outcomes). For example, when reporting P[{|}] we find its
weight P[{|}] = 26 , whereas when reporting P[{~, z}] we find the sum of their weights
P[{~, z}] = 16 + 36 = 46 . Therefore, the notion of size does not refer to the number of
elements but to the total weight of these elements.

Figure 2.18: This example shows the “weights” of three elements in a set. The weights are numbers
between 0 and 1 such that the sum is 1. When applying a probability measure to this set, we sum the
weights for the elements in the events being considered. For example, P[~, z] = yellow + green, and
P[|] = purple.

Example 2.34. (Continuous events with di↵erent weights) Suppose that the sample
space is an interval, say ⌦ = [ 1, 1]. On this interval we define a weighting function
f (x) where f (x0 ) specifies the weight for x0 . Because ⌦ is an interval, events defined
on this ⌦ must also be intervals. For example, we can consider two events E1 = [a, b]
Rb
and E2 = [c, d]. The probabilities of these events are P[E1 ] = a f (x) dx and P[E2 ] =
Rd
c
f (x) dx, as shown in Figure 2.19.

Viewing probability as a measure is not just a game for mathematicians; rather, it


has fundamental significance for several reasons. First, it eliminates any dependency on
probability as relative frequency from the frequentist point of view. Relative frequency is a

69
CHAPTER 2. PROBABILITY

Figure 2.19: If the sample space is an interval on the real line, then the probability of an event is the
area under the curve of the weighting function.

narrowly defined concept that is largely limited to discrete events, e.g., flipping a coin. While
we can assign weights to coin-toss events to deal with those biased coins, the extension to
continuous events becomes problematic. By thinking of probability as a measure, we can
generalize the notion to apply to intervals, areas, volumes, and so on.
Second, viewing probability as a measure forces us to disentangle an event from mea-
sures. An event is a subset in the sample space. It has nothing to do with the measure
(e.g., a ruler) you use to measure the event. The measure, on the other hand, specifies the
weighting function you apply to measure the event when computing the probability. For
example, let ⌦ = [ 1, 1] be an interval, and let E = [a, b] be an event. We can define two
weighting functions f (x) and g(x). Correspondingly, we will have two di↵erent probability
measures F and G such that
Z Z b
F([a, b]) = dF = f (x) dx,
E a
Z Z b
G([a, b]) = dG = g(x) dx. (2.20)
E a

To make sense of these notations, consider only P[[a, b]] and not F([a, b]) and G([a, b]). As you
can see, the event for both measures is E = [a, b] but the measures are di↵erent. Therefore,
the values of the probability are di↵erent.

Example 2.35. (Two probability laws are di↵erent if their weighting functions are
di↵erent.) Consider two di↵erent weighting functions for throwing a die. The first one
assigns probability as the following:
1 2 3
P[{ }] = , P[{ }] = , P[{ }] = ,
12 12 12
4 1 1
P[{ }] = , P[{ }] = , P[{ }] = ,
12 12 12
whereas the second function assigns the probability like this:
2 2 2
P[{ }] = , P[{ }] = , P[{ }] = ,
12 12 12
2 2 2
P[{ }] = , P[{ }] = , P[{ }] = .
12 12 12

70
2.2. PROBABILITY SPACE

Let an event E = { , }. Let F be the measure using the first set of probabilities, and
let G be the measure of the second set of probabilities. Then,
1 2 3
F(E) = F({ , }) = + = ,
12 12 12
2 2 4
G(E) = G({ , }) = + = .
12 12 12
Therefore, although the events are the same, the two di↵erent measures will give us
two di↵erent probability values.

R
Remark. The notation E dF in Equation (2.20) is known as the Lebesgue integral. You
should be aware of this notation, but the theory of Lebesgue measure is beyond the scope
of this book.

2.2.4 Measure zero sets


Understanding the measure perspective on probability allows us to understand another
important concept of probability, namely measure zero sets. To introduce this concept, we
pose the question: What is the probability of obtaining a single point, say {0.5}, when the
sample space is ⌦ = [0, 1]?
The answer to this question is rooted in the compatibility between the measure and
the sample space. In other words, the measure has to be meaningful for the events in the
sample space. Using ⌦ = [0, 1], since ⌦ is an interval, an appropriate measure would be the
length of this interval. You may add di↵erent weighting functions to define your measure,
but ultimately, the measure must be an integral. If you use a “counter” as a measure, then
the counter and the interval are not compatible because you cannot count on the real line.
Now, suppose that we define a measure for ⌦ = [0, 1] using a weighting function f (x).
This measure is determined by an integration. Then, for E = {0.5}, the measure is
Z 0.5
P[E] = P[{0.5}] = f (x) dx = 0.
0.5

In fact, for any weighting function the integral will be zero because the length of the set
E is zero.1 An event that gives us zero probability is known as an event with measure 0.
Figure 2.20 shows an example.

Figure 2.20: The probability of obtaining a single point in a continuous interval is zero.

1 We assume that f is continuous throughout [0, 1]. If f is discontinuous at x = 0.5, some additional

considerations will apply.

71
CHAPTER 2. PROBABILITY

What are measure zero sets?


A set E (non-empty) is called a measure zero set when P[E] = 0.
For example, {0} is a measure zero set when we use a continuous measure F.
But {0} can have a positive measure when we use a discrete measure G.

Example 2.36(a). Consider a fair die with ⌦ = { , , , , , }. Then the set { }


has a probability of 16 . The sample space does not have a measure zero event because
the measure we use is a counter.
Example 2.36(b). Consider an interval with ⌦ = [1, 6]. Then the set {1} has measure
0 because it is an isolated point with respect to the sample space.
Example 2.36(c). For any intervals, P[[a, b]] = P[(a, b)] because the two end points
have measure zero: P[{a}] = P[{b}] = 0.

Formal definitions of measure zero sets

The following discussion of the formal definitions of measure zero sets is optional for the
first reading of this book.

We can formally define measure zero sets as follows:

Definition 2.19. Let ⌦ be the sample space. A set A 2 ⌦ is said to have measure
zero if for any given ✏ > 0,
There exists a countable number of subsets An such that A ✓ [1
n=1 An , and
P1
n=1 P[An ] < ✏.

You may need to read this definition carefully. Suppose we have an event A. We construct
a set of neighbors A1 , . . . , A1 such that A is included in the union [1 n=1 An . If the sum of
the all P[An ] is still less than ✏, then the set A will have a measure zero.
To understand the di↵erence between a measure for a continuous set and a countable
set, consider Figure 2.21. On the left side of Figure 2.21 we show an interval ⌦ in which there
is an isolated point x0 . The measure for this ⌦ is the length of the interval (relative to what-
ever weighting function you use). We define a small neighborhood A0 = (x0 2✏ , x0 + 2✏ )
surrounding x0 . The length of this interval is not more than ✏. We then shrink ✏. How-
ever, regardless of how small ✏ is, since x0 is an isolated point, it is always included in the
neighborhood. Therefore, the definition is satisfied, and so {x0 } has measure zero.

Example 2.37. Let ⌦ = [0, 1]. The set {0.5} ⇢ ⌦ has measure zero, i.e., P[{0.5}] = 0.
To see this, we draw a small interval around 0.5, say [0.5 ✏/3, 0.5 + ✏/3]. Inside this
interval, there is really nothing to measure besides the point 0.5. Thus we have found
an interval such that it contains 0.5, and the probability is P[[0.5 ✏/3, 0.5 + ✏/3]] =

72
2.2. PROBABILITY SPACE

2✏/3 < ✏. Therefore, by definition, the set {0.5} has measure 0.

The situation is very di↵erent for the right-hand side of Figure 2.21. Here, the measure
is not the length but a counter. So if we create a neighborhood surrounding the isolated
point x0 , we can always make a count. As a result, if you shrink ✏ to become a very small
number (in this case less than 14 ), then P[{x0 }] < ✏ will no longer be true. Therefore, the
set {x0 } has a non-zero measure when we use the counter as the measure.

Figure 2.21: [Left] For a continuous sample space, a single point event {x0 } can always be surrounded
by a neighborhood A0 whose size P[A0 ] < ✏. [Right] If you change the sample space to discrete
elements, then a single point event {x0 } can still be surrounded by a neighborhood A0 . However, the
size P[A0 ] = 1/4 is a fixed number and will not work for any ✏.

When we make probabilistic claims without considering the measure zero sets, we say
that an event happens almost surely.

Definition 2.20. An event A 2 R is said to hold almost surely (a.s.) if

P[A] = 1 (2.21)

except for all measure zero sets in R.

Therefore, if a set A contains measure zero subsets, we can simply ignore them because they
do not a↵ect the probability of events. In this book, we will omit “a.s.” if the context is
clear.

Example 2.38(a). Let ⌦ = [0, 1]. Then P[(0, 1)] = 1 almost surely because the points
0 and 1 have measure zero in ⌦.
Example 2.38(b). Let ⌦ = {x | x2  1} and let A = {x | x2 < 1}. Then P[A] = 1
almost surely because the circumference has measure zero in ⌦.

Practice Exercise 2.12. Let ⌦ = {f : R ! [ 1, 1] | f (t) = cos(!0 t + ✓)}, where !0 is


a fixed constant and ✓ is random. Construct a measure zero event and an almost sure
event.
Solution. Let
E = {f : R ! [ 1, 1] | f (t) = cos(!0 t + k⇡/2)}
for any integer k. That is, E contains all the functions with a phase of ⇡/2, 2⇡/2, 3⇡/2,
etc. Then E will have measure zero because it is a countable set of isolated functions.
The event E c will have probability P[E c ] = 1 almost surely because E has measure

73
CHAPTER 2. PROBABILITY

zero.

This is the end of the discussion. Please join us again.

2.2.5 Summary of the probability space


After the preceding long journey through theory, let us summarize.
First, it is extremely important to understand our slogan: probability is a measure of
the size of a set. This slogan is precise, but it needs clarification. When we say probability
is a measure, we are thinking of it as being the probability law P. Of course, in practice, we
always think of probability as the number returned by the measure. However, the di↵erence
is not crucial. Also, “size” not only means the number of elements in the set, but it also
means the relative weight of the set in the sample space. For example, if we use a weight
function to weigh the set elements, then size would refer to the overall weight of the set.
When we put all these pieces together, we can understand why a probability space
must consist of the three components

(⌦, F, P), (2.22)

where ⌦ is the sample space that defines all possible outcomes, F is the event space generated
from ⌦, and P is the probability law that maps an event to a number in [0, 1]. Can we drop
one or more of the three components? We cannot! If we do not specify the sample space ⌦,
then there is no way to define the events. If we do not have a complete event space F,
then some events will become undefined, and further, if the probability law is applied only
to outcomes, we will not be able to define the probability for events. Finally, if we do not
specify the probability law, then we do not have a way to assign probabilities.

2.3 Axioms of Probability

We now turn to a deeper examination of the properties. Our motivation is simple. While
the definition of probability law has achieved its goal of assigning a probability to an event,
there must be restrictions on how the assignment can be made. For example, if we set
P[{H}] = 1/3, then P[{T }] must be 2/3; otherwise, the sum of having a head and a tail
will be greater than 1. The necessary restrictions on assigning a probability to an event are
collectively known as the axioms of probability.

Definition 2.21. A probability law is a function P : F ! [0, 1] that maps an event


A to a real number in [0, 1]. The function must satisfy the axioms of probability:

I. Non-negativity: P[A] 0, for any A ✓ ⌦.


II. Normalization: P[⌦] = 1.

74
2.3. AXIOMS OF PROBABILITY

III. Additivity: For any disjoint sets {A1 , A2 , . . .}, it must be true that
"1 # 1
[ X
P Ai = P[Ai ]. (2.23)
i=1 i=1

An axiom is a proposition that serves as a premise or starting point in a logical system.


Axioms are not definitions, nor are they theorems. They are believed to be true or true
within a certain context. In our case, the axioms are true within the context of Bayesian
probability. The Kolmogorov probability relies on another set of axioms. We will not dive
into the details of these historical issues; in this book, we will confine our discussion to the
three axioms given above.

2.3.1 Why these three probability axioms?


Why do we need three axioms? Why not just two axioms? Why these three particular
axioms? The reasons are summarized in the box below.

Why these three axioms?


Axiom I (Non-negativity) ensures that probability is never negative.
Axiom II (Normalization) ensures that probability is never greater than 1.
Axiom III (Additivity) allows us to add probabilities when two events do not
overlap.

Axiom I is called the non-negativity axiom. It ensures that a probability value cannot
be negative. Non-negativity is a must for probability. It is meaningless to say that the
probability of getting an event is a negative number.
Axiom II is called the normalization axiom. It ensures that the probability of observing
all possible outcomes is 1. This gives the upper limit of the probability. The upper limit
does not have to be 1. It could be 10 or 100. As long as we are consistent about this upper
limit, we are good. However, for historical reasons and convenience, we choose 1 to be the
upper limit.
Axiom III is called the additivity axiom and is the most critical one among the three.
The additivity axiom defines how set operations can be translated into probability oper-
ations. In a nutshell, it says that if we have a set of disjoint events, the probabilities can
be added. From the measure perspective, Axiom III makes sense because if P measures the
size of an event, then two disjoint events should have their probabilities added. If two dis-
joint events do not allow their probabilities to be added, then there is no way to measure
a combined event. Similarly, if the probabilities can somehow be added even for overlap-
ping events, there will be inconsistencies because there is no systematic way to handle the
overlapping regions.
The countable additivity stated in Axiom III can be applied to both a finite number
or an infinite number of sets. The finite case states that for any two disjoint sets A and B,
we have
P[A [ B] = P[A] + P[B]. (2.24)

75
CHAPTER 2. PROBABILITY

In other words, if A and B are disjoint, then the probability of observing either A or B is
the sum of the two individual probabilities. Figure 2.22 illustrates this idea.

Example 2.39. Let’s see why Axiom III is critical. Consider throwing a fair die with
⌦ = { , , , , , }. The probability of getting { , } is
1 1 2
P[{ , }] = P[{ } [ { }] = P[{ }] + P[{ }] = + = .
6 6 6
In this equation, the second equality holds because the events { } and { } are disjoint.
If we do not have Axiom III, then we cannot add probabilities.

Figure 2.22: Axiom III says P[A [ B] = P[A] + P[B] if A \ B = ;.

2.3.2 Axioms through the lens of measure


Axioms are “rules” we must abide by when we construct a measure. Therefore, any valid
measure must be compatible with the axioms, regardless of whether we have a weighting
function or not. In the following two examples, we will see how the weighting functions are
used in the axioms.

Example 2.40. Consider a sample space with ⌦ = {|, ~, z}. The probability for
each outcome is
2 1 3
P[{|}] = , P[{~}] = , P[{z}] = .
6 6 6
Suppose we construct two disjoint events E1 = {|, ~} and E2 = {z}. Then Axiom
III says
✓ ◆
2 1 3
P[E1 [ E2 ] = P[E1 ] + P[E2 ] = + + = 1.
6 6 6

Note that in this calculation, the measure P is still a measure P. If we endow it


with a nonuniform weight function, then P applies the corresponding weights to the
corresponding outcomes. This process is compatible with the axioms. See Figure 2.23
for a pictorial illustration.

76
2.3. AXIOMS OF PROBABILITY

Example 2.41. Suppose the sample space is an interval ⌦ = [0, 1]. The two events
are E1 = [a, b] and E2 = [c, d]. Assume that the measure P uses a weighting function
f (x). Then, by Axiom III, we know that

P[E1 [ E2 ] = P[E1 ] + P[E2 ]


= P[[a, b]] + P[[c, d]] (by Axiom 3)
Z b Z d
= f (x) dx + f (x) dx, (apply the measure).
a c

As you can see, there is no conflict between the axioms and the measure. Figure 2.24
illustrates this example.

Figure 2.23: Applying weighting functions to the measures: Suppose we have three elements in the set.
To compute the probability P[{~, z} [ {|}], we can write it as the sum of P[{~, z}] and P[{|}].

Figure 2.24: The axioms are compatible with the measure, even if we use a weighting function.

2.3.3 Corollaries derived from the axioms


The union of A and B is equivalent to the logical operator “OR”. Once the logical operation
“OR” is defined, all other logical operations can be defined. The following corollaries are
examples.

Corollary 2.1. Let A 2 F be an event. Then,


(a) P[Ac ] = 1 P[A].
(b) P[A]  1.

(c) P[;] = 0.

77
CHAPTER 2. PROBABILITY

Proof. (a) Since ⌦ = A [ Ac , by finite additivity we have P[⌦] = P[A [ Ac ] = P[A] + P[Ac ].
By the normalization axiom, we have P[⌦] = 1. Therefore, P[Ac ] = 1 P[A].

(b) We prove by contradiction. Assume P[A] > 1. Consider the complement Ac where
A[Ac = ⌦. Since P[Ac ] = 1 P[A], we must have P[Ac ] < 0 because by hypothesis P[A] > 1.
But P[Ac ] < 0 violates the non-negativity axiom. So we must have P[A]  1.

(c) Since ⌦ = ⌦ [ ;, by the first corollary we have P[;] = 1 P[⌦] = 0.


Corollary 2.2 (Unions of Two Non-Disjoint Sets). For any A and B in F,

P[A [ B] = P[A] + P[B] P[A \ B]. (2.25)

This statement is di↵erent from Axiom III because A and B are not necessarily disjoint.

Figure 2.25: For any A and B, P[A [ B] = P[A] + P[B] P[A \ B].

Proof. First, observe that A [ B can be partitioned into three disjoint subsets as A [ B =
(A\B) [ (A \ B) [ (B\A). Since A\B = A \ B c and B\A = B \ Ac , by finite additivity we
have that

P[A [ B] = P[A\B] + P[A \ B] + P[B\A] = P[A \ B c ] + P[A \ B] + P[B \ Ac ]


(a)
= P[A \ B c ] + P[A \ B] + P[B \ Ac ] + P[A \ B] P[A \ B]
(b)
= P[A \ (B c [ B)] + P[(Ac [ A) \ B] P[A \ B]
= P[A \ ⌦] + P[⌦ \ B] P[A \ B] = P[A] + P[B] P[A \ B],

where in (a) we added and subtracted a term P[A \ B], and in (b) we used finite additivity
so that P[A \ B c ] + P[A \ B] = P[(A \ B c ) [ (A \ B)] = P[A \ (B c [ B)].

Example 2.42. The corollary is easy to understand if we consider the following ex-
ample. Let ⌦ = { , , , , , } be the sample space of a fair die. Let A = { , , }
and B = { , , }. Then
5
P[A [ B] = P[{ , , , , }] = .
6

78
2.3. AXIOMS OF PROBABILITY

We can also use the corollary to obtain the same result:

P[A [ B] = P[A] + P[B] P[A \ B]


= P[{ , , }] + P[{ , , }] P[{ }]
3 3 1 5
= + = .
6 6 6 6

Corollary 2.3 (Inequalities). Let A and B be two events in F. Then,


(a) P[A [ B]  P[A] + P[B]. (Union Bound)

(b) If A ✓ B, then P[A]  P[B].

Proof. (a) Since P[A[B] = P[A]+P[B] P[A\B] and by non-negativity axiom P[A\B] 0,
we must have P[A [ B]  P[A] + P[B]. (b) If A ✓ B, then there exists a set B\A such that
B = A [ (B\A). Therefore, by finite additivity we have P[B] = P[A] + P[B\A] P[A]. Since
P[B\A] 0, it follows that P[A] + P[B\A] P[A]. Thus we have P[B] P[A].

Union bound is a frequently used tool for analyzing probabilities when the intersection
A \ B is difficult to evaluate. Part (b) is useful when considering two events of di↵erent
“sizes.” For example, in the bus-waiting example, if we let A = {t  5}, and B = {t  10},
then P[A]  P[B] because we have to wait for the first 5 minutes to go into the remaining
5 minutes.

Practice Exercise 2.13. Let the events A and B have P[A] = x, P[B] = y and
P[A [ B] = z. Find the following probabilities: P[A \ B], P[Ac [ B c ], and P[A \ B c ].
Solution.

(a) Note that z = P[A [ B] = P[A] + P[B] P[A \ B]. Thus, P[A \ B] = x + y z.
(b) We can take the complement to obtain the result:

P[Ac [ B c ] = 1 P[(Ac [ B c )c ] = 1 P[A \ B] = 1 x y + z.

(c) P[A \ B c ] = P[A] P[A \ B] = x (x + y z) = z y.

Practice Exercise 2.14. Consider a sample space

⌦ = {f : R ! R | f (x) = ax, for all a 2 R, x 2 R}.

There are two events: A = {f | f (x) = ax, a 0}, and B = {f | f (x) = ax, a  0}.
So, basically, A is the set of all straight lines with positive slope, and B is the set of
straight lines with negative slope. Show that the union bound is tight.

79
CHAPTER 2. PROBABILITY

Solution. First of all, we note that

P[A [ B] = P[A] + P[B] P[A \ B].

The intersection is
P[A \ B] = P[{f | f (x) = 0}].
Since this is a point set in the real line, it has measure zero. Thus, P[A \ B] = 0 and
hence P[A [ B] = P[A] + P[B]. So the union bound is tight.

Closing remark. The development of today’s probability theory is generally credited to


Andrey Kolmogorov’s 1933 book Foundations of the Theory of Probability. We close this
section by citing one of the tables of the book. The table summarizes the correspondence
between set theory and random events.

Theory of sets Random events


A and B are disjoint, i.e., A \ B = ; Events A and B are incompatible
A1 \ A2 · · · \ AN = ; Events A1 , . . . , AN are incompatible
A1 \ A2 · · · \ AN = X Event X is defined as the simultaneous occur-
rence of events A1 , . . . , AN
A1 [ A2 · · · [ AN = X Event X is defined as the occurrence of at least
one of the events A1 , . . . , AN
Ac The opposite event Ac consisting of the non-
occurrence of event A
A=; Event A is impossible
A=⌦ Event A must occur
A1 , . . . , AN form a partition of ⌦ The experiment consists of determining which
of the events A1 , . . . , AN occurs
B⇢A From the occurrence of event B follows the
inevitable occurrence of A

Table 2.2: Kolmogorov’s summary of set theory results and random events.

2.4 Conditional Probability

In many practical data science problems, we are interested in the relationship between two
or more events. For example, an event A may cause B to happen, and B may cause C
to happen. A legitimate question in probability is then: If A has happened, what is the
probability that B also happens? Of course, if A and B are correlated events, then knowing
one event can tell us something about the other event. If the two events have no relationship,
knowing one event will not tell us anything about the other.
In this section, we study the concept of conditional probability. There are three sub-
topics in this section. We summarize the key points below.

80
2.4. CONDITIONAL PROBABILITY

The three main messages of this section are:


Section 2.4.1: Conditional probability. Conditional probability of A given B is
P[A|B] = P[A\B]
P[B] .
Section 2.4.2: Independence. Two events are independent if the occurrence of
one does not influence the occurrence of the other: P[A|B] = P[A].
Section 2.4.3: Bayes’ theorem and the law of total probability. Bayes’ theorem
allows us to switch the order of the conditioning: P[A|B] vs. P[B|A], whereas the
law of total probability allows us to decompose an event into smaller events.

2.4.1 Definition of conditional probability


We start by defining conditional probability.

Definition 2.22. Consider two events A and B. Assume P[B] 6= 0. The conditional
probability of A given B is
def P[A \ B]
P[A | B] = . (2.26)
P[B]

According to this definition, the conditional probability of A given B is the ratio of


P[A \ B] to P[B]. It is the probability that A happens when we know that B has already
happened. Since B has already happened, the event that A has also happened is represented
by A \ B. However, since we are only interested in the relative probability of A with respect
to B, we need to normalize using B. This can be seen by comparing P[A | B] and P[A \ B]:

P[A \ B] P[A \ B]
P[A | B] = and P[A \ B] = . (2.27)
P[B] P[⌦]

The di↵erence is illustrated in Figure 2.26: The intersection P[A \ B] calculates the overlap-
ping area of the two events. We make no assumptions about the cause-e↵ect relationship.

Figure 2.26: Illustration of conditional probability and its comparison with P[A \ B].

What justifies this ratio? Suppose that B has already happened. Then, anything out-
side B will immediately become irrelevant as far as the relationship between A and B is
concerned. So when we ask: “What is the probability that A happens given that B has
happened?”, we are e↵ectively asking for the probability that A \ B happens under the

81
CHAPTER 2. PROBABILITY

condition that B has happened. Note that we need to consider A \ B because we know
that B has already happened. If we take A only, then there exists a region A\B which
does not contain anything about B. However, since we know that B has happened, A\B is
impossible. In other words, among the elements of A, only those that appear in A \ B are
meaningful.

Example 2.43. Let

A = {Purdue gets Big Ten championship},


B = {Purdue wins 15 games consecutively}.

In this example,

P[A] = Prob. that Purdue gets the championship,


P[B] = Prob. that Purdue wins 15 games consecutively,
P[A \ B] = Prob. that Purdue gets the championship and wins 15 games,
P[A | B] = Prob. that Purdue gets the championship given that
Purdue won 15 games.

If Purdue has won 15 games consecutively, then it is unlikely that Purdue will get
the championship because the sample space of all possible competition results is large.
However, if we have already won 15 games consecutively, then the denominator of the
probability becomes much smaller. In this case, the conditional probability is high.

Example 2.44. Consider throwing a die. Let

A = {getting a 3} and B = {getting an odd number}.

Find P[A | B] and P[B | A].


Solution. The following probabilities are easy to calculate:
1 3
P[A] = P[{ }] = , and P[B] = P[{ , , }] = .
6 6
Also, the intersection is
1
P[A \ B] = P[{ }] = .
6
Given these values, the conditional probability of A given B can be calculated as
1
P[A \ B] 1
P[A | B] = = 6
= .
P[B] 3
6
3

In other words, if we know that we have an odd number, then the probability of
obtaining a 3 has to be computed over { , , }, which give us a probability 13 . If we

82
2.4. CONDITIONAL PROBABILITY

do not know that we have an odd number, then the probability of obtaining a 3 has
to be computed from the sample space { , , , , , }, which will give us 16 .
The other conditional probability is

P[A \ B]
P[B | A] = = 1.
P[A]

Therefore, if we know that we have rolled a 3, then the probability for this number
being an odd number is 1.

Example 2.45. Consider the situation shown in Figure 2.27. There are 12 points
with equal probabilities of happening. Find the probabilities P[A|B] and P[B|A].
Solution. In this example, we can first calculate the individual probabilities:
5 6 2
P[A] = , and P[B] = , and P[A \ B] = .
12 12 12
Then the conditional probabilities are
2
P[A \ B] 1
P[A|B] = = 12
= ,
P[B] 6
12
3
2
P[A \ B] 2
P[B|A] = = 12
= .
P[A] 5
12
5

Figure 2.27: Visualization of Example 2.45: [Left] All the sets. [Middle] P (A|B) is the ratio between
dots inside the light yellow region over those in yellow, which is 26 . [Right] P[A|B] is the ratio between
dots inside the light pink region over those in pink, which is 25 .

Example 2.46. Consider a tetrahedral (4-sided) die. Let X be the first roll and Y
be the second roll. Let B be the event that min(X, Y ) = 2 and M be the event that
max(X, Y ) = 3. Find P[M |B].
Solution. As shown in Figure 2.28, the event B is highlighted in green. (Why?)
Similarly, the event M is highlighted in blue. (Again, why?) Therefore, the probability

83
CHAPTER 2. PROBABILITY

is
2
P[M \ B] 2
P[M |B] = = 16
= .
P[B] 5
16
5

Figure 2.28: Visualization of Example 2.46. [Left] Event B. [Middle] Event M . [Right] P(M |B) is the
ratio of the number of blue squares inside the green region to the total number of green squares, which
is 25 .

Remark. Notice that if P[B]  P[⌦], then P[A | B] is always larger than or equal to P[A\B],
i.e.,
P[A|B] P[A \ B].

Conditional probabilities are legitimate probabilities


Conditional probabilities are legitimate probabilities. That is, given B, the probability
P[A|B] satisfies Axioms I, II, III.

Theorem 2.6. Let P[B] > 0. The conditional probability P[A | B] satisfies Axioms I,
II, and III.

Proof. Let’s check the axioms:


Axiom I: We want to show
P[A \ B]
P[A | B] = 0.
P[B]

Since P[B] > 0 and Axiom I requires P[A \ B] 0, we therefore have P[A | B] 0.
Axiom II:
P[⌦ \ B]
P[⌦ | B] =
P[B]
P[B]
= = 1.
P[B]

84
2.4. CONDITIONAL PROBABILITY

Axiom III: Consider two disjoint sets A and C. Then,

P[(A [ C) \ B]
P[A [ C | B] =
P[B]
P[(A \ B) [ (C \ B)]
=
P[B]
(a) P[A \ B] P[C \ B]
= +
P[B] P[B]
= P[A|B] + P[C|B],

where (a) holds because if A and C are disjoint then (A \ B) \ (C \ B) = ;.


To summarize this subsection, we highlight the essence of conditional probability.

What are conditional probabilities?


P[A\B]
Conditional probability of A given B is the ratio P[B] .
It is again a measure. It measures the relative size of A inside B.
Because it is a measure, it must satisfy the three axioms.

2.4.2 Independence
Conditional probability deals with situations where two events A and B are related. What
if the two events are unrelated? In probability, we have a technical term for this situation:
statistical independence.

Definition 2.23. Two events A and B are statistically independent if

P[A \ B] = P[A]P[B]. (2.28)

P[A\B]
Why define independence in this way? Recall that P[A | B] = P[B] . If A and B are
independent, then P[A \ B] = P[A] P[B] and so

P[A \ B] P[A] P[B]


P[A | B] = = = P[A]. (2.29)
P[B] P[B]

This suggests an interpretation of independence: If the occurrence of B provides no addi-


tional information about the occurrence of A, then A and B are independent.
Therefore, we can define independence via conditional probability:

Definition 2.24. Let A and B be two events such that P[A] > 0 and P[B] > 0. Then

85
CHAPTER 2. PROBABILITY

A and B are independent if

P[A | B] = P[A] or P[B | A] = P[B]. (2.30)

The two statements are equivalent as long as P[A] > 0 and P[B] > 0. This is because
P[A|B] = P[A \ B]/P[B]. If P[A|B] = P[A] then P[A \ B] = P[A]P[B], which implies that
P[B|A] = P[A \ B]/P[A] = P[B].
A pictorial illustration of independence is given in Figure 2.29. The key message is that
if two events A and B are independent, then P[A|B] = P[A]. The conditional probability
P[A|B] is the ratio of P[A \ B] over P[B], which is the intersection over B (the blue set).
The probability P[A] is the yellow set over the sample space ⌦.

Figure 2.29: Independence means that the conditional probability P[A|B] is the same as P[A]. This
implies that the ratio of P[A \ B] over P[B], and the ratio of P[A \ ⌦] over P[⌦] are the same.

Disjoint versus independent

Disjoint < Independent. (2.31)

The statement says that disjoint and independent are two completely di↵erent concepts.
If A and B are disjoint, then A \ B = ;. This only implies that P[A \ B] = 0.
However, it says nothing about whether P[A \ B] can be factorized into P[A] P[B]. If A
and B are independent, then we have P[A \ B] = P[A] P[B]. But this does not imply that
P[A \ B] = 0. The only condition under which Disjoint , Independence is when P[A] = 0 or
P[B] = 0. Figure 2.30 depicts the situation. When two sets are independent, the conditional
probability (which is a ratio) remains unchanged compared to unconditioned probability.
When two sets are disjoint, they simply do not overlap.

Practice Exercise 2.15. Throw a die twice. Are A and B independent, where

A = {1st die is 3} and B = {2nd die is 4}.

Solution. We can show that

P[A \ B] = P[(3, 4)] = 1


36 , P[A] = 16 , and P[B] = 16 .

So P[A \ B] = P[A]P[B]. Thus, A and B are independent.

86
2.4. CONDITIONAL PROBABILITY

Figure 2.30: Independent means that the conditional probability, which is a ratio, is the same as the
unconditioned probability. Disjoint means that the two sets do not overlap.

Figure 2.31: The two events A and B are independent because P[A] = 1
6
and P[A|B] = 16 .

A pictorial illustration of this example is shown in Figure 2.31. The two events are
independent because A is one row in the 2D space, which yields a probability of 16 . The
conditional probability P[A|B] is the coordinate (3, 4) over the event B, which is a column.
It happens that P[A|B] = 16 . Thus, the two events are independent.

Practice Exercise 2.16. Throw a die twice. Are A and B independent?

A = {1st die is 3} and B = {sum is 7}.

Solution. Note that

P[A \ B] = P[(3, 4)] = 1


36 , P[A] = 16 ,
P[B] = P[(1, 6), (2, 5), (3, 4), (4, 3), (5, 2), (6, 1)] = 16 .

So P[A \ B] = P[A] P[B]. Thus, A and B are independent.

A pictorial illustration of this example is shown in Figure 2.32. Notice that whether the
two events intersect is not how we determine independence (that only determines disjoint or

87
CHAPTER 2. PROBABILITY

not). The key is whether the conditional probability (which is the ratio) remains unchanged
compared to the unconditioned probability.

Figure 2.32: The two events A and B are independent because P[A] = 1
6
and P[A \ B] = 16 .

If we let B = {sum is 8}, then the situation is di↵erent. The intersection A \ B has a
probability 15 relative to B, and therefore P[A|B] = 15 . Hence, the two events A and B are
dependent. If you like a more intuitive argument, you can imagine that B has happened,
i.e., the sum is 8. Then the probability for the first die to be 1 is 0 because there is no way
to construct 8 when the first die is 1. As a result, we have eliminated one choice for the first
die, leaving only five options. Therefore, since B has influenced the probability of A, they
are dependent.

Practice Exercise 2.17. Throw a die twice. Let

A = {max is 2} and B = {min is 2}.

Are A and B independent?


Solution. Let us first list out A and B:

A = {(1, 2), (2, 1), (2, 2)},


B = {(2, 2), (2, 3), (2, 4), (2, 5), (2, 6), (3, 2), (4, 2), (5, 2), (6, 2)}.

Therefore, the probabilities are


3 9 1
P[A] = , P[B] = , and P[A \ B] = P[(2, 2)] = .
36 36 36
Clearly, P[A \ B] 6= P[A]P[B] and so A and B are dependent.

What is independence?
Two events are independent when the ratio P[A \ B]/P[B] remains unchanged
compared to P[A].
Independence 6= disjoint.

88
2.4. CONDITIONAL PROBABILITY

2.4.3 Bayes’ theorem and the law of total probability

Theorem 2.7 (Bayes’ theorem). For any two events A and B such that P[A] > 0
and P[B] > 0,
P[B | A] P[A]
P[A | B] = .
P[B]

Proof. By the definition of conditional probabilities, we have

P[A \ B] P[B \ A]
P[A | B] = and P[B | A] = .
P[B] P[A]

Rearranging the terms yields

P[A | B]P[B] = P[B | A]P[A],

which gives the desired result by dividing both sides by P[B].



Bayes’ theorem provides two views of the intersection P[A \ B] using two di↵erent con-
ditional probabilities. We call P[B | A] the conditional probability and P[A | B] the posterior
probability. The order of A and B is arbitrary. We can also call P[A | B] the conditional
probability and P[B | A] the posterior probability. The context of the problem will make this
clear.
Bayes’ theorem provides a way to switch P[A|B] and P[B|A]. The next theorem helps
us decompose an event into smaller events.

Theorem 2.8 (Law of Total Probability). Let {A1 , . . . , An } be a partition of ⌦, i.e.,


A1 , . . . , An are disjoint and ⌦ = A1 [ · · · [ An . Then, for any B ✓ ⌦,
n
X
P[B] = P[B | Ai ] P[Ai ]. (2.32)
i=1

Proof. We start from the right-hand side.


n n
" n
#
X (a) X (b) [
P[B | Ai ] P[Ai ] = P[B \ Ai ] = P (B \ Ai )
i=1 i=1 i=1
" n
!#
(c) [ (d)
= P B\ Ai = P[B \ ⌦] = P[B],
i=1

where (a) follows from the definition of conditional probability, (b) is due to Axiom III, (c)
holds because of the distributive property of sets, and (d) results from the partition property
of {A1 , A2 , . . . , An }.

Interpretation. The law of total probability can be understood as follows. If the sample
space ⌦ consists of disjoint subsets A1 , . . . , An , we can compute the probability P[B] by

89
CHAPTER 2. PROBABILITY

summing over its portion P[B \A1 ], . . . , P[B \An ]. However, each intersection can be written
as
P[B \ Ai ] = P[B | Ai ]P[Ai ]. (2.33)
In other words, we write P[B \ Ai ] as the conditional probability P[B | Ai ] times the prior
probability P[Ai ]. When we sum all these intersections, we obtain the overall probability.
See Figure 2.33 for a graphical portrayal.

Figure 2.33: The law of total probability decomposes the probability P[B] into multiple conditional
probabilities P[B | Ai ]. The probability of obtaining each P[B | Ai ] is P[Ai ].

Corollary 2.4. Let {A1 , A2 , . . . , An } be a partition of ⌦, i.e., A1 , . . . , An are disjoint


and ⌦ = A1 [ A2 [ · · · [ An . Then, for any B ✓ ⌦,

P[B | Aj ] P[Aj ]
P[Aj | B] = Pn . (2.34)
i=1 P[B | Ai ] P[Ai ]

Proof. The result follows directly from Bayes’ theorem:


P[B | Aj ] P[Aj ] P[B | Aj ] P[Aj ]
P[Aj | B] = = Pn .
P[B] i=1 P[B | Ai ] P[Ai ]

Example 2.47. Suppose there are three types of players in a tennis tournament: A,
B, and C. Fifty percent of the contestants in the tournament are A players, 25% are
B players, and 25% are C players. Your chance of beating the contestants depends on
the class of the player, as follows:

0.3 against an A player


0.4 against a B player
0.5 against a C player

If you play a match in this tournament, what is the probability of your winning the
match? Supposing that you have won a match, what is the probability that you played
against an A player?
Solution. We first list all the known probabilities. We know from the percentage

90
2.4. CONDITIONAL PROBABILITY

of players that

P[A] = 0.5, P[B] = 0.25, P[C] = 0.25.

Now, let W be the event that you win the match. Then the conditional probabilities
are defined as follows:

P[W |A] = 0.3, P[W |B] = 0.4, P[W |C] = 0.5.

Therefore, by the law of total probability, we can show that the probability of
winning the match is

P[W ] = P[W | A] P[A] + P[W | B] P[B] + P[W | C] P[C]


= (0.3)(0.5) + (0.4)(0.25) + (0.5)(0.25) = 0.375.

Given that you have won the match, the probability of A given W is

P[W |A]P[A] (0.3)(0.5)


P[A|W ] = = = 0.4.
P[W ] 0.375

Example 2.48. Consider the communication channel shown below. The probability
of sending a 1 is p and the probability of sending a 0 is 1 p. Given that 1 is sent, the
probability of receiving 1 is 1 ⌘. Given that 0 is sent, the probability of receiving 0
is 1 ". Find the probability that a 1 has been correctly received.

Solution. Define the events

S0 = “0 is sent”, and R0 = “0 is received”.


S1 = “1 is sent”, and R1 = “1 is received”.

Then, the probability that 1 is received is P[R1 ]. However, P[R1 ] 6= 1 ⌘ because 1 ⌘

91
CHAPTER 2. PROBABILITY

is the conditional probability that 1 is received given that 1 is sent. It is possible that
we receive 1 as a result of an error when 0 is sent. Therefore, we need to consider the
probability that both S0 and S1 occur. Using the law of total probability we have

P[R1 ] = P[R1 | S1 ] P[S1 ] + P[R1 | S0 ] P[S0 ]


= (1 ⌘)p + "(1 p).

Now, suppose that we have received 1. What is the probability that 1 was origi-
nally sent? This is asking for the posterior probability P[S1 | R1 ], which can be found
using Bayes’ theorem

P[R1 | S1 ] P[S1 ] (1 ⌘)p


P[S1 | R1 ] = = .
P[R1 ] (1 ⌘)p + "(1 p)

When do we need to use Bayes’ theorem and the law of total probability?
Bayes’ theorem switches the role of the conditioning, from P[A|B] to P[B|A].
Example:

P[win the game | play with A] and P[play with A | win the game].

The law of total probability decomposes an event into smaller events.


Example:
P[win] = P[win | A]P[A] + P[win | B]P[B].

2.4.4 The Three Prisoners problem


Now that you are familiar with the concepts of conditional probabilities, we would like to
challenge you with the following problem, known as the Three Prisoners problem. If you
understand how this problem can be resolved, you have mastered conditional probability.
Once upon a time, there were three prisoners A, B, and C. One day, the king decided
to pardon two of them and sentence the last one, as in this figure:

Figure 2.34: The Three Prisoners problem: The king says that he will pardon two prisoners and sentence
one.

One of the prisoners, prisoner A, heard the news and wanted to ask a friendly guard
about his situation. The guard was honest. He was allowed to tell prisoner A that prisoner B
would be pardoned or that prisoner C would be pardoned, but he could not tell A whether
he would be pardoned. Prisoner A thought about the problem, and he began to hesitate to
ask the guard. Based on his present state of knowledge, his probability of being pardoned

92
2.4. CONDITIONAL PROBABILITY

is 23 . However, if he asks the guard, this probability will be reduced to 12 because the guard
would tell him that one of the two other prisoners would be pardoned, and would tell him
which one it would be. Prisoner A reasons that his chance of being pardoned would then
drop because there are now only two prisoners left who may be pardoned, as illustrated in
Figure 2.35:

Figure 2.35: The Three Prisoners problem: If you do not ask the guard, your chance of being released
is 2/3. If you ask the guard, the guard will tell you which one of the other prisoners will be released.
Your chance of being released apparently drops to 1/2.

Should prisoner A ask the guard? What has gone wrong with his reasoning? This
problem is tricky in the sense that the verbal argument of prisoner A seems flawless. If
he asked the guard, indeed, the game would be reduced to two people. However, this does
not seem correct, because regardless of what the guard says, the probability for A to be
pardoned should remain unchanged. Let’s see how we can solve this puzzle.
Let XA , XB , XC be the events of sentencing prisoners A, B, C, respectively. Let GB
be the event that the guard says that the prisoner B is released. Without doing anything,
we know that
1 1 1
P[XA ] = , P[XB ] = , P[XC ] = .
3 3 3
Conditioned on these events, we can compute the following conditional probabilities that
the guard says B is pardoned:
1
P[GB | XA ] = , P[GB | XB ] = 0, P[GB | XC ] = 1.
2
Why are these conditional probabilities? P[GB | XB ] = 0 quite straightforward. If the king
decides to sentence B, the guard has no way of saying that B will be pardoned. Therefore,
P[GB | XB ] must be zero. P[GB | XC ] = 1 is also not difficult. If the king decides to
sentence C, then the guard has no way to tell you that B will be pardoned because the
guard cannot say anything about prisoner A. Finally, P[GB | XA ] = 21 can be understood
as follows: If the king decides to sentence A, the guard can either tell you B or C. In other
words, the guard flips a coin.
With these conditional probabilities ready, we can determine the probability. This is the
conditional probability P[XA | GB ]. That is, supposing that the guard says B is pardoned,
what is the probability that A will be sentenced? This is the actual scenario that A is facing.
Solving for this conditional probability is not difficult. By Bayes’ theorem we know that
P[GB | XA ]P[XA ]
P[XA | GB ] = ,
P[GB ]

93
CHAPTER 2. PROBABILITY

and P[GB ] = P[GB |XA ]P[XA ] + P[GB |XB ]P[XB ] + P[GB |XC ]P[XC ] according to the law of
total probability. Substituting the numbers into these equations, we have that

P[GB ] = P[GB |XA ]P[XA ] + P[GB |XB ]P[XB ] + P[GB |XC ]P[XC ]
1 1 1 1 1
= ⇥ +0⇥ +1⇥ = ,
2 3 3 3 2
1 1
P[GB | XA ]P[XA ] ⇥ 1
P[XA | GB ] = = 2 1 3 = .
P[GB ] 2
3

Therefore, given that the guard says B is pardoned, the probability that A will be sentenced
remains 13 . In fact, what you can show in this example is that P[XA | GB ] = 13 = P[XA ].
Therefore, the presence or absence of the guard does not alter the probability. This is because
what the guard says is independent of whether the prisoners will be pardoned. The lesson
we learn from this problem is not to rely on verbal arguments. We need to write down the
conditional probabilities and spell out the steps.

Figure 2.36: The Three Prisoners problem is resolved by noting that P[XA |GB ] = P[XA ]. Therefore,
the events XA and GB are independent.

How to resolve the Three Prisoners problem?


The key is that GA , GB , GC do not form a partition. See Figure 2.36.
GB 6= XB . When GB happens, the remaining set is not XA [ XC .
The ratio P[XA \ GB ]/P[GB ] equals P[XA ]. This is independence.

94
2.5. SUMMARY

2.5 Summary

By now, we hope that you have become familiar with our slogan probability is a measure
of the size of a set. Let us summarize:
Probability = a probability law P. You can also view it as the value returned by P.
Measure = a ruler, a scale, a stopwatch, or another measuring device. It is a tool that
tells you how large or small a set is. The measure has to be compatible with the set.
If a set is finite, then the measure can be a counter. If a set is a continuous interval,
then the measure can be the length of the interval.
Size = the relative weight of the set for the sample space. Measuring the size is done
by using a weighting function. Think of a fair coin versus a biased coin. The former
has a uniform weight, whereas the latter has a nonuniform weight.
Set = an event. An event is a subset in the sample space. A probability law P always
maps a set to a number. This is di↵erent from a typical function that maps a number
to another number.
If you understand what this slogan means, you will understand why probability can be
applied to discrete events, continuous events, events in n-D spaces, etc. You will also under-
stand the notion of measure zero and the notion of almost sure. These concepts lie at the
foundation of modern data science, in particular, theoretical machine learning.
The second half of this chapter discusses the concept of conditional probability. Con-
ditional probability is a metaconcept that can be applied to any measure you use. The
motivation of conditional probability is to restrict the probability to a subevent happening
in the sample space. If B has happened, the probability for A to also happen is P[A\B]/P[B].
If two events are not influencing each other, then we say that A and B are independent.
According to Bayes’ theorem, we can also switch the order of A given B and B given A, ac-
cording to Bayes’ theorem. Finally, the law of total probability gives us a way to decompose
events into subevents.
We end this chapter by mentioning a few terms related to conditional probabilities
that will become useful later. Let us use the tennis tournament as an example:
P[W | A] = conditional probability = Given that you played with player A, what is
the probability that you will win?
P[A] = prior probability = Without even entering the game, what is the chance that
you will face player A?
P[A | W ] = posterior probability = After you have won the game, what is the proba-
bility that you have actually played with A?
In many practical engineering problems, the question of interest is often the last one. That
is, supposing that you have observed something, what is the most likely cause of that event?
For example, supposing we have observed this particular dataset, what is the best Gaussian
model that would fit the dataset? Questions like these require some analysis of conditional
probability, prior probability, and posterior probability.

95
CHAPTER 2. PROBABILITY

2.6 References

Introduction to Probability
2-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 1.
2-2 Mark D. Ward and Ellen Gundlach, Introduction to Probability, W.H. Freeman and
Company, 2016. Chapter 1 – Chapter 6.
2-3 Roy D. Yates and David J. Goodman, Probability and Stochastic Processes, 3rd Edi-
tion, Wiley 2013, Chapter 1.
2-4 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapter 2.
2-5 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
2 and Chapter 3.
2-6 Ani Adhikari and Jim Pitman, Probability for Data Science, http://prob140.org/
textbook/content/README.html. Chapters 1 and 2.
2-7 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 2.1 – 2.7.
2-8 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 2.
2-9 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapter 1.

Measure-Theoretic Probability
2-10 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 2.8 and 2.9.
2-11 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Appendix D.
2-12 William Feller, An Introduction to Probability Theory and Its Applications, Wiley and
Sons, 3rd Edition, 1950.
2-13 Andrey Kolmogorov, Foundations of the Theory of Probability, 2nd English Edition,
Dover 2018. (Translated from Russian to English. Originally published in 1950 by
Chelsea Publishing Company New York.)
2-14 Patrick Billingsley, Probability and Measure, Wiley, 3rd Edition, 1995.

Real Analysis
2-15 Tom M. Apostol, Mathematical Analysis, Pearson, 1974.
2-16 Walter Rudin, Principles of Mathematical Analysis, McGraw Hill, 1976.

96
2.7. PROBLEMS

2.7 Problems

Exercise 1.
A space S and three of its subsets are given by S = {1, 3, 5, 7, 9, 11}, A = {1, 3, 5}, B =
{7, 9, 11}, and C = {1, 3, 9, 11}. Find A \ B \ C, Ac \ B, A C, and (A B) [ B.

Exercise 2.
Let A = ( 1, r] and B = ( 1, s] where r  s. Find an expression for C = (r, s] in terms
of A and B. Show that B = A [ C, and A \ C = ;.

Exercise 3. (Video Solution)


Simplify the following sets.
(a) [1, 4] \ ([0, 2] [ [3, 5])
(b) ([0, 1] [ [2, 3])c
T1
(c) i=1 ( 1/n, +1/n)
S1
(d) i=1 [5, 8 (2n) 1 ]

Exercise 4.
We will sometimes deal with the relationship between two sets. We say that A implies B
when A is a subset of B (why?). Show the following results.
(a) Show that if A implies B, and B implies C, then A implies C.
(b) Show that if A implies B, then B c implies Ac .

Exercise 5.
Show that if A [ B = A and A \ B = A, then A = B.

Exercise 6.
A space S is defined as S = {1, 3, 5, 7, 9, 22}, and three subsets as A = {1, 3, 5}, B =
{7, 9, 11}, C = {1, 3, 9, 11}. Assume that each element has probability 1/6. Find the following
probabilities:
(a) P[A]
(b) P[B]
(c) P[C]
(d) P[A [ B]
(e) P[A [ C]
(f) P[(A\C) [ B]

97
CHAPTER 2. PROBABILITY

Exercise 7. (Video Solution)


A collection of 26 letters, a-z, is mixed in a jar. Two letters are drawn at random, one after
the other. What is the probability of drawing a vowel (a,e,i,o,u) and a consonant in either
order? What is the sample space?

Exercise 8.
Consider an experiment consisting of rolling a die twice. The outcome of this experiment is
an ordered pair whose first element is the first value rolled and whose second element is the
second value rolled.
(a) Find the sample space.
(b) Find the set A representing the event that the value on the first roll is greater than
or equal to the value on the second roll.
(c) Find the set B corresponding to the event that the first roll is a six.
(d) Let C correspond to the event that the first valued rolled and the second value rolled
di↵er by two. Find A \ C.
Note that A, B, and C should be subsets of the sample space specified in Part (a).

Exercise 9.
A pair of dice are rolled.
(a) Find the sample space ⌦
(b) Find the probabilities of the events: (i) the sum is even, (ii) the first roll is equal to
the second, (iii) the first roll is larger than the second.

Exercise 10.
Let A, B and C be events in an event space. Find expressions for the following:
(a) Exactly one of the three events occurs.

(b) Exactly two of the events occurs.


(c) Two or more of the events occur.
(d) None of the events occur.

Exercise 11.
A system is composed of five components, each of which is either working or failed. Consider
an experiment that consists of observing the status of each component, and let the outcomes
of the experiment be given by all vectors (x1 , x2 , x3 , x4 , x5 ), where xi is 1 if component i is
working and 0 if component i is not working.
(a) How many outcomes are in the sample space of this experiment?
(b) Suppose that the system will work if components 1 and 2 are both working, or if
components 3 and 4 are both working, or if components 1, 3, and 5 are all working.
Let W be the event that the system will work. Specify all of the outcomes in W .

98
2.7. PROBLEMS

(c) Let A be the event that components 4 and 5 have both failed. How many outcomes
are in the event A?
(d) Write out all outcomes in the event A \ W .

Exercise 12. (Video Solution)


A number x is selected at random in the interval [ 1, 2]. Let the events A = {x | x < 0},
B = {x | |x 0.5| < 0.5}, C = {x | x > 0.75}. Find (a) P[A | B], (b) P[B | C], (c) P[A | C c ],
(d) P[B | C c ].

Exercise 13. (Video Solution)


Let the events A and B have P[A] = x, P[B] = y and P[A [ B] = z. Find the following
probabilities: (a) P[A \ B], (b) P[Ac \ B c ], (c) P[Ac [ B c ], (d) P[A \ B c ], (e) P[Ac [ B].

Exercise 14.
(a) By using the fact that P[A [ B]  P[A] + P[B], show that P[A [ B [ C]  P[A] + P[B] +
P[C].
Sn Pn
(b) By using the fact that P [ k=1 Ak ]  k=1 P[Ak ], show that
" n # n
\ X
P Ak 1 P[Ack ].
k=1 k=1

Exercise 15.
Use the distributive property of set operations to prove the following generalized distributive
law: !
n
\ \n
A[ Bi = (A [ Bi ) .
i=1 i=1

Hint: Use mathematical induction. That is, show that the above is true for n = 2 and that
it is also true for n = k + 1 when it is true for n = k.

Exercise 16.
The following result is known as the Bonferroni’s Inequality.
(a) Prove that for any two events A and B, we have

P(A \ B) P(A) + P(B) 1.

(b) Generalize the above to the case of n events A1 , A2 , . . . , An , by showing that

P(A1 \ A2 \ · · · \ An )P(A1 ) + P(A2 ) + · · · + P(An ) (n 1).


Sn Pn
Hint: You may use the generalized Union Bound P( i=1 Ai )  i=1 P(Ai ).

Exercise 17. (Video Solution)


Let A, B, C be events with probabilities P[A] = 0.5, P[B] = 0.2, P[C] = 0.4. Find

99
CHAPTER 2. PROBABILITY

(a) P[A [ B] if A and B are independent.


(b) P[A [ B] if A and B are disjoint.
(c) P[A [ B [ C] if A, B and C are independent.
(d) P[A [ B [ C] if A, B and C are pairwise disjoint; can this happen?

Exercise 18. (Video Solution)


A block of information is transmitted repeated over a noisy channel until an error-free block
is received. Let M 1 be the number of blocks required for a transmission. Define the
following sets.
(i) A = {M is even}
(ii) B = {M is a multiple of 3}
(iii) C = {M is less than or equal to 6}
Assume that the probability of requiring one additional block is half of the probability
without the additional block. That is:
✓ ◆k
1
P[M = k] = , k = 1, 2, . . . .
2
Determine the following probabilities.
(a) P[A], P[B], P[C], P[C c ]
(b) P[A \ B], P[A\B], P[A \ B \ C]
(c) P[A | B], P[B | A]
(d) P[A | B \ C], P[A \ B | C]

Exercise 19. (Video Solution)


A binary communication system transmits a signal X that is either a +2-voltage signal or
a 2-voltage signal. A malicious channel reduces the magnitude of the received signal by
the number of heads it counts in two tosses of a coin. Let Y be the resulting signal. Possible
values of Y are listed below.
2 Heads 1 Head No Head
X= 2 Y =0 Y = 1 Y = 2
X = +2 Y =0 Y = +1 Y = +2

Assume that the probability of having X = +2 and X = 2 is equal.


(a) Find the sample space of Y , and hence the probability of each value of Y .
(b) What are the probabilities P[X = +2 | Y = 1] and P[Y = 1 | X = 2]?

Exercise 20. (Video Solution)


A block of 100 bits is transmitted over a binary communication channel with a probability
of bit error p = 10 2 .

100
2.7. PROBLEMS

(a) If the block has 1 or fewer errors, then the receiver accepts the block. Find the prob-
ability that the block is accepted.
(b) If the block has more than 1 error, then the block is retransmitted. What is the
probability that 4 blocks are transmitted?

Exercise 21. (Video Solution)


A machine makes errors in a certain operation with probability p. There are two types of
errors. The fraction of errors that are type A is ↵ and the fraction that are type B is 1 ↵.
(a) What is the probability of k errors in n operations?

(b) What is the probability of k1 type A errors in n operations?


(c) What is the probability of k2 type B errors in n operations?
(d) What is the joint probability of k1 type A errors and k2 type B errors in n operations?
Hint: There are kn1 n k2k1 possibilities of having k1 type A errors and k2 type B errors
in n operations. (Why?)

Exercise 22. (Video Solution)


A computer manufacturer uses chips from three sources. Chips from sources A, B and C
are defective with probabilities 0.005, 0.001 and 0.01, respectively. The proportions of chips
from A, B and C are 0.5, 0.1 and 0.4 respectively. If a randomly selected chip is found to
be defective, find
(a) the probability that the chips are from A.
(b) the probability that the chips are from B.

(c) the probability that the chips are from C.

Exercise 23. (Video Solution)


In a lot of 100 items, 50 items are defective. Suppose that m items are selected for testing.
We say that the manufacturing process is malfunctioning if the probability that one or more
items are tested to be defective. Call this failure probability p. What should be the minimum
m such that p 0.99?

Exercise 24. (Video Solution)


One of two coins is selected at random and tossed three times. The first coin comes up heads
with probability p1 = 1/3 and the second coin with probability p2 = 2/3.

(a) What is the probability that the number of heads is k = 3?


(b) Repeat (a) for k = 0, 1, 2.
(c) Find the probability that coin 1 was tossed given that k heads were observed, for
k = 0, 1, 2, 3.

(d) In part (c), which coin is more probably when 2 heads have been observed?

101
CHAPTER 2. PROBABILITY

Exercise 25. (Video Solution)


Consider the following communication channel. A source transmits a string of binary symbols
through a noisy communication channel. Each symbol is 0 or 1 with probability p and
1 p, respectively, and is received incorrectly with probability "0 and "1 . Errors in di↵erent
symbols transmissions are independent.

Denote S as the source and R as the receiver.


(a) What is the probability that a symbol is correctly received? Hint: Find

P[R = 1 \ S = 1] and P[R = 0 \ S = 0].

(b) Find the probability of receiving 1011 conditioned on that 1011 was sent, i.e.,

P[R = 1011 | S = 1011].

(c) To improve reliability, each symbol is transmitted three times, and the received
string is decoded by the majority rule. In other words, a 0 (or 1) is transmitted as
000 (or 111, respectively), and it is decoded at the receiver as a 0 (or 1) if and only if
the received three-symbol string contains at least two 0s (or 1s, respectively). What
is the probability that the symbol is correctly decoded, given that we send a 0?

(d) Suppose that the scheme of part (c) is used. What is the probability that a 0 was
sent if the string 101 was received?
(e) Suppose the scheme of part (c) is used and given that a 0 was sent. For what value of
"0 is there an improvement in the probability of correct decoding? Assume that
"0 6= 0.

102
Chapter 3

Discrete Random Variables

When working on a data analysis problem, one of the biggest challenges is the disparity
between the theoretical tools we learn in school and the actual data our boss hands to us.
By actual data, we mean a collection of numbers, perhaps organized or perhaps not. When
we are given the dataset, the first thing we do would certainly not be to define the Borel
-field and then define the measure. Instead, we would normally compute the mean, the
standard deviation, and perhaps some scores about the skewness.
The situation is best explained by the landscape shown in Figure 3.1. On the one hand,
we have well-defined probability tools, but on the other hand, we have a set of practical
“battle skills” for processing data. Often we view them as two separate entities. As long as
we can pull the statistics from the dataset, why bother about the theory? Alternatively, we
have a set of theories, but we will never verify them using the actual datasets. How can we
bridge the two? What are the missing steps in the probability theory we have learned so
far? The goal of this chapter (and the next) is to fill this gap.

Figure 3.1: The landscape of probability and data. Often we view probability and data analysis as two
di↵erent entities. However, probability and data analysis are inseparable. The goal of this chapter is to
link the two.

Three concepts to bridge the gap between theory and practice


The starting point of our discussion is a probability space (⌦, F, P). It is an abstract concept,
but we hope we have convinced you in Chapter 2 of its significance. However, the probability
space is certainly not “user friendly” because no one would write a Python program to

103
CHAPTER 3. DISCRETE RANDOM VARIABLES

implement those theories. How do we make the abstract probability space more convenient
so that we can model practical scenarios?
The first step is to recognize that the sample space and the event space are all based
on statements, for example, “getting a head when flipping a coin” or “winning the game.”
These statements are not numbers, but we (engineers) love numbers. Therefore, we should
ask a very basic question: How do we convert a statement to a number? The answer is the
concept of random variables.

Key Concept 1: What are random variables?


Random variables are mappings from events to numbers.

Now, suppose that we have constructed a random variable that translates statements to
numbers. The next task is to endow the random variable with probabilities. More precisely,
we need to assign probabilities to the random variable so that we can perform computations.
This is done using the concept called probability mass function (PMF).

Key Concept 2: What are probability mass functions (PMFs)?


Probability mass functions are the ideal histograms of random variables.

The best way to think about a PMF is a histogram, something we are familiar with.
A histogram has two axes: The x-axis denotes the set of states and the y-axis denotes
the probability. For each of the states that the random variable possesses, the histogram
tells us the probability of getting a particular state. The PMF is the ideal histogram of a
random variable. It provides a complete characterization of the random variable. If you have
a random variable, you must specify its PMF. Vice versa, if you tell us the PMF, you have
specified a random variable.
We ask the third question about pulling information from the probability mass func-
tion, such as the mean and standard deviation. How do we obtain these numbers from the
PMF? We are also interested in operations on the mean and standard deviations. For ex-
ample, if a professor o↵ers ten bonus points to the entire class, how will it a↵ect the mean
and standard deviation? If a store provides 20% o↵ on all its products, what will happen to
its mean retail price and standard deviation? However, the biggest question is perhaps the
di↵erence between the mean we obtain from a PMF and the mean we obtain from a his-
togram. Understanding this di↵erence will immediately help us build a bridge from theory
to practice.

Key Concept 3: What is expectation?


Expectation = Mean = Average computed from a PMF.

Organization of this chapter


The plan for this chapter is as follows. We will start with the basic concepts of random
variables in Section 3.1. We will formally define the random variables and discuss their
relationship with the abstract probability space. Once this linkage is built, we can put

104
3.1. RANDOM VARIABLES

the abstract probability space aside and focus on the random variables. In Section 3.2
we will define the probability mass function (PMF) of a random variable, which tells us
the probability of obtaining a state of the random variable. PMF is closely related to the
histogram of a dataset. We will explain the connection. In Section 3.3 we take a small detour
to consider the cumulative distribution functions (CDF). Then, we discuss the mean and
standard deviation in Section 3.4. Section 3.5 details a few commonly used random variables,
including Bernoulli, binomial, geometric, and Poisson variables.

3.1 Random Variables

3.1.1 A motivating example


Consider an experiment with 4 outcomes ⌦ = {|, }, ~, }. We want to construct the
probability space (⌦, F, P). The sample space ⌦ is already defined. The event space F is the
set of all possible subsets in ⌦, which, in our case, is a set of 24 subsets. For the probability
law P, let us assume that the probability of obtaining each outcome is
1 2 2 1
P[{|}] = , P[{}}] = , P[{~}] = , P[{}] = .
6 6 6 6
Therefore, we have constructed a probability space (⌦, F, P) where everything is perfectly
defined. So, in principle, they can live together happily forever.
A lazy data scientist comes, and there is a (small) problem. The data scientist does not
want to write the symbols |, }, ~, . There is nothing wrong with his motivation because
all of us want efficiency. How can we help him? Well, the easiest solution is to encode each
symbol with a number, for example, | 1, } 2, ~ 3,  4, where the arrow means
that we assign a number to the symbol. But we can express this more formally by defining
a function X : ⌦ ! R with

X(|) = 1, X(}) = 2, X(~) = 3, X() = 4.

There is nothing new here: we have merely converted the symbols to numbers, with the help
of a function X. However, with X defined, the probabilities can be written as
1 2 2 1
P[X = 1] = , P[X = 2] = , P[X = 3] = , P[X = 4] = .
6 6 6 6
This is much more convenient, and so the data scientist is happy.

3.1.2 Definition of a random variable


The story above is exactly the motivation for random variables. Let us define a random
variable formally.

Definition 3.1. A random variable X is a function X : ⌦ ! R that maps an outcome


⇠ 2 ⌦ to a number X(⇠) on the real line.

105
CHAPTER 3. DISCRETE RANDOM VARIABLES

This definition may be puzzling at first glance. Why should we overcomplicate things by
defining a function and calling it a variable?
If you recall the story above, we can map the notations of the story to the notations
of the definition as follows.

Symbol Meaning
⌦ sample space = the set containing |, }, ~, 
⇠ an element in the sample space, which is one of |, }, ~, 
X a function that maps | to the number 1, } to the number 2, etc
X(⇠) a number on the real line, e.g., X(|) = 1

This explains our informal definition of random variables:

Key Concept 1: What are random variables?


Random variables are mappings from events to numbers.

The random variable X is a function. The input to the function is an outcome of the sample
space, whereas the output is a number on the real line. This type of function is somewhat
di↵erent from an ordinary function that often translates a number to another number.
Nevertheless, X is a function.

Figure 3.2: A random variable is a mapping from the outcomes in the sample space to numbers on the
real line. We can think of a random variable X as a translator that translates a statement to a number.

Why do we call this function X a variable? X is a variable because X has multiple


states. As we illustrate in Figure 3.2, the mapping X translates every outcome ⇠ to a
number. There are multiple numbers, which are the states of X. Each state has a certain
probability for X to land on. Because X is not deterministic, we call it a random variable.

Example 3.1. Suppose we flip a fair coin so that ⌦ = {head, tail}. We can define the
random variable X : ⌦ ! R as

X(head) = 1, and X(tail) = 0.

106
3.1. RANDOM VARIABLES

Therefore, when we write P[X = 1] we actually mean P[{head}]. Is there any di↵erence
between P[{Head}] and P[X = 1]? No, because they are describing two identical events.
Note that the assignment of the value is totally up to you. You can say “head” is equal
to the value 102. This is allowed and legitimate, but it isn’t very convenient.

Example 3.2. Flip a coin 2 times. The sample space ⌦ is

⌦ = {(head, head), (head, tail), (tail, head), (tail, tail)}.

Suppose that X is a random variable that maps an outcome to a number representing


the sum of “head,” i.e.,
X(·) = number of heads.
Then, for the 4 ⇠’s in the sample space there are only 3 distinct numbers. More precisely,
if we let ⇠1 = (head, head), ⇠2 = (head, tail), ⇠3 = (tail, head), ⇠4 = (tail, tail), then,
we have

X(⇠1 ) = 2, X(⇠2 ) = 1, X(⇠3 ) = 1, X(⇠4 ) = 0.

A pictorial illustration of this random variable is shown in Figure 3.3. This example
shows that the mapping defined by the random variable is not necessarily a one-to-one
mapping because multiple outcomes can be mapped to the same number.

Figure 3.3: A random variable that maps a pair of coins to a number, where the number represents the
number of heads.

3.1.3 Probability measure on random variables


By now, we hope that you understand Key Concept 1: A random variable is a mapping
from a statement to a number. However, we are now facing another difficulty. We knew
how to measure the size of an event using the probability law P because P(·) takes an event
E 2 F and sends it to a number between [0, 1]. After the translation X, we cannot send the
output X(⇠) to P(·) because P(·) “eats” a set E 2 F and not a number X(⇠) 2 R. Therefore,
when we write P[X = 1], how do we measure the size of the event X = 1?

107
CHAPTER 3. DISCRETE RANDOM VARIABLES

This question appears difficult but is actually quite easy to answer. Since the prob-
ability law P(·) is always applied to an event, we need to define an event for the random
variable X. If we write the sets clearly, we note that “X = a” is equivalent to the set

E = ⇠ 2 ⌦ X(⇠) = a .

This is the set that contains all possible ⇠’s such that X(⇠) = a. Therefore, when we say
“find the probability of X = a,” we are e↵ectively asking the size of the set E = {⇠ 2
⌦ | X(⇠) = a}.
How then do we measure the size of E? Since E is a subset in the sample space, E is
measurable by P. All we need to do is to determine what E is for a given a. This, in turn,
requires us to find the pre-image X 1 (a), which is defined as

1 def
X (a) = ⇠ 2 ⌦ X(⇠) = a .

Wait a minute, is this set just equal to E? Yes, the event E we are seeking is exactly the
pre-image X 1 (a). As such, the probability measure of E is
1
P[X = a] = P[X (a)].

Figure 3.4 illustrates a situation where two outcomes ⇠1 and ⇠2 are mapped to the same
value a on the real line. The corresponding event is the set X 1 (a) = {⇠1 , ⇠2 }.

Figure 3.4: When computing the probability of P[{⇠ 2 ⌦ | X(⇠) = a}], we e↵ectively take the inverse
mapping X 1 (a) and compute the probability of the event P[{⇠ 2 X 1 (a)}] = P[{⇠1 , ⇠2 }].

Example 3.3. Suppose we throw a die. The sample space is

⌦ = { , , , , , }.

There is a natural mapping X that maps X( ) = 1, X( ) = 2 and so on. Thus,

108
3.1. RANDOM VARIABLES

(a)
P[X  3] = P[X = 1] + P[X = 2] + P[X = 3]
(b) 1 1
= P[X (2)] + P[X 1 (3)]
(1)] + P[X
(c) 3
= P[{ }] + P[{ }] + P[{ }] = .
6
In this derivation, step (a) is based on Axiom III, where the three events are disjoint.
Step (b) is the pre-image due to the random variable X. Step (c) is the list of ac-
tual events in the event space. Note that there is no hand-waving argument in this
derivation. Every step is justified by the concepts and theorems we have learned so
far.

Example 3.4. Throw a die twice. The sample space is then

⌦ = {( , ), ( , ), . . . , ( , )}.

These elements can be translated to 36 outcomes:

⇠1 = ( , ), ⇠2 = ( , ), . . . , ⇠36 = ( , ).

Let
X = sum of two numbers.
Then, if we want to find the probability of getting X = 7, we can trace back and ask:
Among the 36 outcomes, which of those ⇠i ’s will give us X(⇠) = 7? Or, what is the set
X 1 (7)? To this end, we can write

P[X = 7] = P[{( , ), ( , ), ( , ), ( , ), ( , ), ( , )}]


= P[( , )] + P[( , )] + P[( , )]
+ P[( , )] + P[( , )] + P[( , )]
1 1 1 1 1 1 1
= + + + + + = .
36 36 36 36 36 36 6
Again, in this example, you can see that all the steps are fully justified by the concepts
we have learned so far.

Closing remark. In practice, when the problem is clearly defined, we can skip the inverse
mapping X 1 (a). However, this does not mean that the probability triplet (⌦, F, P) is gone;
it is still present. The triplet is now just the background of the problem.
The set of all possible values returned by X is denoted as X(⌦). Since X is not
necessarily a bijection, the size of X(⌦) is not necessarily the same as the size of ⌦. The
elements in X(⌦) are often denoted as a or x. We call a or x one of the states of X. Be
careful not to confuse x and X. The variable X is the random variable; it is a function.
The variable x is a state assigned by X. A random variable X has multiple states. When
we write P[X = x], we describe the probability of a random variable X taking a particular
state x. It is exactly the same as P[{⇠ 2 ⌦ | X(⇠) = x}].

109
CHAPTER 3. DISCRETE RANDOM VARIABLES

3.2 Probability Mass Function

Random variables are mappings that translate events to numbers. After the translation,
we have a set of numbers denoting the states of the random variables. Each state has a
di↵erent probability of occurring. The probabilities are summarized by a function known as
the probability mass function (PMF).

3.2.1 Definition of probability mass function

Definition 3.2. The probability mass function (PMF) of a random variable X is a


function which specifies the probability of obtaining a number X(⇠) = x. We denote a
PMF as
pX (x) = P[X = x]. (3.1)
The set of all possible states of X is denoted as X(⌦).

Do not get confused by the sample space ⌦ and the set of states X(⌦). The sample space ⌦
contains all the possible outcomes of the experiments, whereas X(⌦) is the translation by
the mapping X. The event X = a is the set X 1 (a) ✓ ⌦. Therefore, when we say P[X = x]
we really mean P[X 1 (x)].
The probability mass function is a histogram summarizing the probability of each of
the states X takes. Since it is a histogram, a PMF can be easily drawn as a bar chart.

Example 3.5. Flip a coin twice. The sample space is ⌦ = {HH, HT, TH, TT}. We
can assign a random variable X = number of heads. Therefore,

X(“HH”) = 2, X(“TH”) = 1, X(“HT”) = 1, X(“TT”) = 0.

So the random variable X takes three states: 0, 1, 2. The PMF is therefore


1
pX (0) = P[X = 0] = P[{“TT”}] = ,
4
1
pX (1) = P[X = 1] = P[{“TH”, “HT”}] = ,
2
1
pX (2) = P[X = 2] = P[{“HH”}] = .
4

3.2.2 PMF and probability measure


In Chapter 2, we learned that probability is a measure of the size of a set. We introduced a
weighting function that weights each of the elements in the set. The PMF is the weighing
function for discrete random variables. Two random variables are di↵erent when their PMFs
are di↵erent because they are constructing two di↵erent measures.

110
3.2. PROBABILITY MASS FUNCTION

To illustrate the idea, suppose there are two dice. They each have probability masses
as follows.
1 2 3 4 1 1
P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = ,
12 12 12 12 12 12
2 2 2 2 2 2
P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = , P[{ }] = ,
12 12 12 12 12 12
Let us define two random variables, X and Y , for the two dice. Then, the PMFs pX and pY
can be defined as
1 2 3 4 1 1
pX (1) = , pX (2) = , pX (3) = , pX (4) = , pX (5) = , pX (6) = ,
12 12 12 12 12 12
2 2 2 2 2 2
pY (1) = , pY (2) = , pY (3) = , pY (4) = , pY (5) = , pY (6) = .
12 12 12 12 12 12
These two probability mass functions correspond to two di↵erent probability measures, let’s
say F and G. Define the event E = {between 2 and 3}. Then, F(E) and G(E) will lead to
two di↵erent results:
1 2 3
F(E) = P[2  X  3] = pX (2) + pX (3) = + = ,
12 12 12
2 2 4
G(E) = P[2  Y  3] = pY (2) + pY (3) = + = .
12 12 12
Note that even though for some particular events two final results could be the same (e.g.,
2  X  4 and 2  Y  4), the underlying measures are completely di↵erent.
Figure 3.5 shows another example of two di↵erent measures F and G on the same
sample space ⌦ = {|, }, ~, }. Since the PMFs of the two measures are di↵erent, even
when given the same event E, the resulting probabilities will be di↵erent.

Figure 3.5: If we want to measure the size of a set E, using two di↵erent PMFs is equivalent to using
two di↵erent measures. Therefore, the probabilities will be di↵erent.

Does pX = pY imply X = Y ? If two random variables X and Y have the same PMF,
does it mean that the random variables are the same? The answer is no. Consider a random
variable with a symmetric PMF, e.g.,
1 1 1
pX ( 1) = , pX (0) = , pX (1) = . (3.2)
4 2 4
Suppose Y = X. Then, pY ( 1) = 14 , pY (0) = 12 , and pY (1) = 14 , which is the same as pX .
However, X and Y are two di↵erent random variables. If the sample space is {|, }, ~}, we
can define the mappings X(·) and Y (·) as
X(|) = 1, X(}) = 0, X(~) = +1,
Y (|) = +1, Y (}) = 0, Y (~) = 1.

111
CHAPTER 3. DISCRETE RANDOM VARIABLES

Therefore, when we say pX ( 1) = 14 , the underlying event is |. But when we say pY ( 1) = 14 ,


the underlying event is ~. The two random variables are di↵erent, although their PMFs have
exactly the same shape.

3.2.3 Normalization property


Here we must mention one important property of a probability mass function. This property
is known as the normalization property, which is a useful tool for a sanity check.

Theorem 3.1. A PMF should satisfy the condition that


X
pX (x) = 1. (3.3)
x2X(⌦)

Proof. The proof follows directly from Axiom II, which states that P[⌦] = 1. Since x covers
all numerical values X can take, and since each x is distinct, by Axiom III we have
X X
P[X = x] = P [{⇠ 2 ⌦ | X(⇠) = x}]
x2X(⌦) x2X(⌦)
2 3
[
= P4 {⇠ 2 ⌦ | X(⇠) = x}5 = P[⌦] = 1.
⇠2⌦

k
Practice Exercise 3.1. Let pX (k) = c 12 , where k = 1, 2, . . .. Find c.
P
Solution. Since k2X(⌦) pX (k) = 1, we must have

1 ✓ ◆k
X 1
= 1.
2
k=1

Evaluating the geometric series on the right-hand side, we can show that
1
X ✓ ◆k 1 ✓ ◆k
1 cX 1
c =
2 2 2
k=1 k=0
c 1
= · 1
2 1 2
=c =) c = 1.


Practice Exercise 3.2. Let pX (k) = c · sin 2k , where k = 1, 2, . . .. Find c.
Solution. The reader may might be tempted to sum pX (k) over all the possible k’s:
1
X ⇣⇡ ⌘
?
sin k =1+0 1 + 0 + · · · = 0.
2
k=1

112
3.2. PROBABILITY MASS FUNCTION

However, a more careful inspection reveals that pX (k) is actually negative when k =
3, 7, 11, . . .. This cannot happen because a probability mass function must be non-
negative. Therefore, the problem is not defined, and so there is no solution.

0.5
1

0.5

0.25 0

0.125 -0.5
0.0625 -1
1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10

(a) (b)
k
Figure 3.6: (a) The PMF of pX (k) = c 12 , for k = 1, 2, . . .. (b) The PMF of pX (k) = sin ⇡2 k ,
where k = 1, 2, . . .. Note that this is not a valid PMF because probability cannot have negative values.

3.2.4 PMF versus histogram


PMFs are closely related to histograms. A histogram is a plot that shows the frequency of
a state. As we see in Figure 3.6, the x-axis is a collection of states, whereas the y-axis is
the frequency. So a PMF is indeed a histogram.
Viewing a PMF as a histogram can help us understand a random variable. For better
or worse, treating a random variable as a histogram could help you di↵erentiate a random
variable from a variable. An ordinary variable only has one state, but a random variable
has multiple states. At any particular instance, we do not know which state will show up
before our observation. However, we do know the probability. For example, in the coin-flip
example, while we do not know whether we will get “HH,” we know that the chance of
getting “HH” is 1/4. Of course, having a probability of 1/4 does not mean that we will get
“HH” once every four trials. It only means that if we run an infinite number of experiments,
then 1/4 of the experiments will give us “HH.”
The linkage between PMF and histogram can be quite practical. For example, while
we do not know the true underlying distribution of the 26 letters of the English alphabet, we
can collect a large number of words and plot the histogram. The example below illustrates
how we can empirically define a random variable from the data.

Example. There are 26 English letters, but the frequencies of the letters in writing are
di↵erent. If we define a random variable X as a letter we randomly draw from an English
text, we can think of X as an object with 26 di↵erent states. The mapping associated with the
random variable is straightforward: X(“a”) = 1, X(“b”) = 2, etc. The probability of landing
on a particular state approximately follows a histogram shown in Figure 3.7. The histogram
provides meaningful values of the probabilities, e.g., pX (1) = 0.0847, pX (2) = 0.0149, etc.
The true probability of the states may not be exactly these values. However, when we have
enough samples, we generally expect the histogram to approach the theoretical PMF. The
MATLAB and Python codes used to generate this histogram are shown below.
% MATLAB code to generate the histogram
load(‘ch3_data_English’);
bar(f/100,‘FaceColor’,[0.9,0.6,0.0]);

113
CHAPTER 3. DISCRETE RANDOM VARIABLES

0.12

0.1

0.08

0.06

0.04

0.02

0
a b c d e f g h i j k l mn o p q r s t u v w x y z

Figure 3.7: The frequency of the 26 English letters. Data source: Wikipedia.

xticklabels({‘a’,‘b’,‘c’,‘d’,‘e’,‘f’,‘g’,‘h’,‘i’,‘j’,‘k’,‘l’,...
‘m’,‘n’,‘o’,‘p’,‘q’,‘r’,‘s’,‘t’,‘u’,‘v’,‘w’,‘x’,‘y’,‘z’});
xticks(1:26);
yticks(0:0.02:0.2);
axis([1 26 0 0.13]);

# Python code generate the histogram


import numpy as np
import matplotlib.pyplot as plt
f = np.loadtxt(‘./ch3_data_english.txt’)
n = np.arange(26)
plt.bar(n, f/100)
ntag = [‘a’,‘b’,‘c’,‘d’,‘e’,‘f’,‘g’,‘h’,‘i’,‘j’,‘k’,‘l’,‘m’,...
‘n’,‘o’,‘p’,‘q’,‘r’,‘s’,‘t’,‘u’,‘v’,‘w’,‘x’,‘y’,‘z’]
plt.xticks(n, ntag)

PMF = ideal histograms


If a random variable is more or less a histogram, why is the PMF such an important concept?
The answer to this question has two parts. The first part is that the histogram generated
from a dataset is always an empirical histogram, so-called because the dataset comes from
observation or experience rather than theory. Thus the histograms may vary slightly every
time we collect a dataset.
As we increase the number of data points in a dataset, the histogram will eventually
converge to an ideal histogram, or a distribution. For example, counting the number of
heads in 100 coin flips will fluctuate more in percentage terms than counting the heads in 10
million coin flips. The latter will almost certainly have a histogram that is closer to a 50–50
distribution. Therefore, the “histogram” generated by a random variable can be considered
the ultimate histogram or the limiting histogram of the experiment.
To help you visualize the di↵erence between a PMF and a histogram, we show in
Figure 3.8 an experiment in which a die is thrown N times. Assuming that the die is fair,
the PMF is simply pX (k) = 1/6 for k = 1, . . . , 6, which is a uniform distribution across
the 6 states. Now, we can throw the die many times. As N increases, we observe that the

114
3.2. PROBABILITY MASS FUNCTION

N = 100 N = 1000
0.2 0.2

0.15 0.15

0.1 0.1

0.05 0.05

0 0
1 2 3 4 5 6 1 2 3 4 5 6
(a) N = 100 (b) N = 1000
N = 10000 N=
0.2 0.2

0.15 0.15

0.1 0.1

0.05 0.05

0 0
1 2 3 4 5 6 1 2 3 4 5 6
(c) N = 10000 (d) PMF

Figure 3.8: Histogram and PMF, when throwing a fair die N times. As N increases, the histograms are
becoming more similar to the PMF.

histogram becomes more like the PMF. You can imagine that when N goes to infinity, the
histogram will eventually become the PMF. Therefore, when given a dataset, one way to
think of it is to treat the data as random realizations drawn from a certain PMF. The more
data points you have, the closer the histogram will become to the PMF.
The MATLAB and Python codes used to generate Figure 3.8 are shown below. The
two commands we use here are randi (in MATLAB), which generates random integer num-
bers, and hist, which computes the heights and bin centers of a histogram. In Python,
the corresponding commands are np.random.randint and plt.hist. Note that because of
the di↵erent indexing schemes in MATLAB and Python, we o↵set the maximum index in
np.random.randint to 7 instead of 6. Also, we shift the x-axes so that the bars are centered
at the integers.
% MATLAB code to generate the histogram
x = [1 2 3 4 5 6];
q = randi(6,100,1);

figure;
[num,val] = hist(q,x-0.5);
bar(num/100,‘FaceColor’,[0.8, 0.8,0.8]);
axis([0 7 0 0.24]);

# Python code generate the histogram


import numpy as np
import matplotlib.pyplot as plt
q = np.random.randint(7,size=100)

115
CHAPTER 3. DISCRETE RANDOM VARIABLES

plt.hist(q+0.5,bins=6)

This generative perspective is illustrated in Figure 3.9. We assume that the underlying
latent random variable has some PMF that can be described by a few parameters, e.g., the
mean and variance. Given the data points, if we can infer these parameters, we might retrieve
the entire PMF (up to the uncertainty level intrinsic to the dataset). We refer to this inverse
process as statistical inference.

Figure 3.9: When analyzing a dataset, one can treat the data points are samples drawn according to a
latent random variable with certain a PMF. The dataset we observe is often finite, and so the histogram
we obtain is empirical. A major task in data analysis is statistical inference, which tries to retrieve the
model information from the available measurements.

Returning to the question of why we need to understand the PMFs, the second part
of the answer is the di↵erence between synthesis and analysis. In synthesis, we start with
a known random variable and generate samples according to the PMF underlying the ran-
dom variable. For example, on a computer, we often start with a Gaussian random variable
and generate random numbers according to the histogram specified by the Gaussian ran-
dom variable. Synthesis is useful because we can predict what will happen. We can, for
example, create millions of training samples to train a deep neural network. We can also
evaluate algorithms used to estimate statistical quantities such as mean, variance, moments,
etc., because the synthesis approach provides us with ground truth. In supervised learning
scenarios, synthesis is vital to ensuring sufficient training data.
The other direction of synthesis is analysis. The goal is to start with a dataset and
deduce the statistical properties of the dataset. For example, suppose we want to know
whether the underlying model is indeed a Gaussian model. If we know that it is a Gaussian
(or if we choose to use a Gaussian), we want to know the parameters that define this
Gaussian. The analysis direction addresses this model selection and parameter estimation
problem. Moving forward, once we know the model and the parameters, we can make a
prediction or do recovery, both of which are ubiquitous in machine learning.
We summarize our discussions below, which is Key Concept 2 of this chapter.

Key Concept 2: What are probability mass functions (PMFs)?


PMFs are the ideal histograms of random variables.

116
3.2. PROBABILITY MASS FUNCTION

3.2.5 Estimating histograms from real data

The following discussions about histogram estimation can be skipped if it is your first
time reading the book.

If you have a dataset, how would you plot the histogram? Certainly, if you have access
to MATLAB or Python, you can call standard functions such as hist (in MATLAB) or
np.histogram (in Python). However, when plotting a histogram, you need to specify the
number of bins (or equivalently the width of bins). If you use larger bins, then you will have
fewer bins with many elements in each bin. Conversely, if the bin width is too small, you
may not have enough samples to fill the histogram. Figure 3.10 illustrates two histograms
in which the bins are respectively too large and too small.

1000 50
K=5 K = 200
800 40

600 30

400 20

200 10

0 0
0 2 4 6 8 10 0 2 4 6 8 10
(a) 5 bins (b) 200 bins

Figure 3.10: The width of the histogram has substantial influence on the information that can be
extracted from the histogram.

The MATLAB and Python codes used to generate Figure 3.10 are shown below. Note
that here we are using an exponential random variable (to be discussed in Chapter 4). In
MATLAB, calling an exponential random variable is done using exprnd, whereas in Python
the command is np.random.exponential. For this experiment, we can specify the number
of bins k, which can be set to k = 200 or k = 5. To suppress the Python output of the array,
we can add a semicolon ;. A final note is that lambda is a reserved variable in Python. Use
something else.
% MATLAB code used to generate the plots
lambda = 1;
k = 1000;
X = exprnd(1/lambda,[k,1]);
[num,val] = hist(X,200);
bar(val,num,‘FaceColor’,[1, 0.5,0.5]);

# Python code used to generate the plots


import numpy as np
import matplotlib.pyplot as plt
lambd = 1

117
CHAPTER 3. DISCRETE RANDOM VARIABLES

k = 1000
X = np.random.exponential(1/lambd, size=k)
plt.hist(X,bins=200);

In statistics, there are various rules to determine the bin width of a histogram. We
mention a few of them here. Let K be the number of bins and N the number of samples.
p
Square-root: K = N
Sturges’ formula: K = log2 N + 1.
p
Rice Rule: K = 2 3 N
p
max X min X 3.5 Var[X]
Scott’s normal reference rule: K = h , where h = p
3
N
is the bin
width.
For the example data shown in Figure 3.10, the histograms obtained using the above rules
are given in Figure 3.11. As you can see, di↵erent rules have di↵erent suggested bin widths.
Some are more conservative, e.g., using fewer bins, whereas some are less conservative. In
any case, the suggested bin widths do seem to provide better histograms than the original
ones in Figure 3.10. However, no bin width is the best for all purposes.
500 500
Square-root, K = 32 Sturges Rule, K = 11

400 400

300 300

200 200

100 100

0 0
0 1 2 3 4 5 0 1 2 3 4 5
500 500
Rice Rule, K = 20 Scott Rule, K = 22

400 400

300 300

200 200

100 100

0 0
0 1 2 3 4 5 0 1 2 3 4 5

Figure 3.11: Histograms of a dataset using di↵erent bin width rules.

Beyond these predefined rules, there are also algorithmic tools to determine the bin
width. One such tool is known as cross-validation. Cross-validation means defining some
kind of cross-validation score that measures the statistical risk associated with the his-
togram. A histogram having a lower score has a lower risk, and thus it is a better histogram.

118
3.2. PROBABILITY MASS FUNCTION

Note that the word “better” is relative to the optimality criteria associated with the cross-
validation score. If you do not agree with our cross-validation score, our optimal bin width is
not necessarily the one you want. In this case, you need to specify your optimality criteria.
Theoretically, deriving a meaningful cross-validation score is beyond the scope of this
book. However, it is still possible to understand the principle. Let h be the bin width of the
histogram, K the number of bins, and N the number of samples. Given a dataset, we follow
this procedure:
Step 1: Choose a bin width h.
Step 2: Construct a histogram from the data, using the bin width h. The histogram will
have the empirical PMF values pb1 , pb2 , . . . , pbK , which are the heights of the histograms
normalized so that the sum is 1.
Step 3: Compute the cross-validation score (see Wasserman, All of Statistics, Section
20.2):
2 N +1
J(h) = pb2 + pb22 + · · · + pb2K (3.4)
(N 1)h (N 1)h 1

Repeat Steps 1, 2, 3, until we find an h that minimizes J(h).


Note that when we use a di↵erent h, the PMF values pb1 , pb2 , . . . , pbK will change, and the
number of bins K will also change. Therefore, when changing h, we are changing not only
the terms in J(h) that explicitly contain h but also terms that are implicitly influenced.

10-4
10-3 5
-2.9
Cross-validation Score

4
Cross-validation Score

-3

-3.1
3

-3.2
2
-3.3
1
-3.4

-3.5 0
20 40 60 80 100 120 140 160 180 200 20 40 60 80 100 120 140 160 180 200
Number of Bins Number of Bins
(a) One dataset (b) Average of many datasets

Figure 3.12: Cross-validation score for the histogram. (a) The score of one particular dataset. (b) The
scores for many di↵erent datasets generated by the same model.

For the dataset we showed in Figure 3.10, the cross-validation score J(h) is shown in
Figure 3.12. We can see that although the curve is noisy, there is indeed a reasonably clear
minimum happening around 20  K  30, which is consistent with some of the rules.
The MATLAB and Python codes we used to generate Figure 3.12 are shown below.
The key step is to implement Equation (3.4) inside a for-loop, where the loop goes through
the range of bins we are interested in. To obtain the PMF values pb1 , . . . , pbK , we call hist
in MATLAB and np.histogram in Python. The bin width h is the number of samples n
divided by the number of bins m.

119
CHAPTER 3. DISCRETE RANDOM VARIABLES

% MATLAB code to perform the cross validation


lambda = 1;
n = 1000;
X = exprnd(1/lambda,[n,1]);
m = 6:200;
J = zeros(1,195);
for i=1:195
[num,binc] = hist(X,m(i));
h = n/m(i);
J(i) = 2/((n-1)*h)-((n+1)/((n-1)*h))*sum( (num/n).^2 );
end
plot(m,J,‘LineWidth’,4,‘Color’,[0.9,0.2,0.0]);

# Python code to perform the cross validation


import numpy as np
import matplotlib.pyplot as plt
lambd = 1
n = 1000
X = np.random.exponential(1/lambd, size=n)
m = np.arange(5,200)
J = np.zeros((195))
for i in range(0,195):
hist,bins = np.histogram(X,bins=m[i])
h = n/m[i]
J[i] = 2/((n-1)*h)-((n+1)/((n-1)*h))*np.sum((hist/n)**2)
plt.plot(m,J);

In Figure 3.12(b), we show another set of curves from the same experiment. The
di↵erence here is that we assume access to the true generative model so that we can generate
the many datasets of the same distribution. In this experiment we generated T = 1000
datasets. We compute the cross-validation score J(h) for each of the datasets, yielding T
score functions J (1) (h), . . . , J (T ) (h). We subtract the minimum because di↵erent realizations
have di↵erent o↵sets. Then we compute the average:
T ⇢
1X
J(h) = J (t) (h) min J (t) (h) . (3.5)
T t=1 h

This gives us a smooth red curve as shown in Figure 3.12(b). The minimum appears to be
at N = 25. This is the optimal N , concerning the cross-validation score, on the average of
all datasets.
All rules, including cross-validation, are based on optimizing for a certain objective.
Your objective could be di↵erent from our objective, and so our optimum is not necessarily
your optimum. Therefore, cross-validation may not be the best. It depends on your problem.

End of the discussion.

120
3.3. CUMULATIVE DISTRIBUTION FUNCTIONS (DISCRETE)

3.3 Cumulative Distribution Functions (Discrete)

While the probability mass function (PMF) provides a complete characterization of a dis-
crete random variable, the PMFs themselves are technically not “functions” because the
impulses in the histogram are essentially delta functions. More formally, a PMF pX (k)
should actually be written as
X
pX (x) = pX (k) · (x k) .
| {z } | {z }
k2X(⌦)
PMF values delta function

This is a train of delta functions, where the height is specified by the probability mass pX (k).
For example, a random variable with PMF values
1 1 1
pX (0) = , pX (1) = , pX (2) =
4 2 4
will be expressed as
1 1 1
pX (x) = (x) + (x 1) + (x 2).
4 2 4
Since delta functions need to be integrated to generate values, the typical things we want to
do, e.g., integration and di↵erentiation, are not as straightforward in the sense of Riemann-
Stieltjes.
The way to handle the unfriendliness of the delta functions is to consider mild modi-
fications of the PMF. This notation of “cumulative” distribution functions will allow us to
resolve the delta function problems. We will defer the technical details to the next chap-
ter. For the time being, we will briefly introduce the idea to prepare you for the technical
discussion later.

3.3.1 Definition of the cumulative distribution function

Definition 3.3. Let X be a discrete random variable with ⌦ = {x1 , x2 , . . .}. The
cumulative distribution function (CDF) of X is
k
X
def
FX (xk ) = P[X  xk ] = pX (x` ). (3.6)
`=1

If ⌦ = {. . . , 1, 0, 1, 2, . . .}, then the CDF of X is


k
X
def
FX (k) = P[X  k] = pX (`). (3.7)
`= 1

A CDF is essentially the cumulative sum of a PMF from 1 to x, where the variable x0 in
the sum is a dummy variable.

121
CHAPTER 3. DISCRETE RANDOM VARIABLES

Example 3.6. Consider a random variable X with PMF pX (0) = 14 , pX (1) = 1


2 and
pX (4) = 14 . The CDF of X can be computed as

1
FX (0) = P[X  0] = pX (0) = ,
4
3
FX (1) = P[X  1] = pX (0) + pX (1) = ,
4
FX (4) = P[X  4] = pX (0) + pX (1) + pX (4) = 1.

As shown in Figure 3.13, the CDF of a discrete random variable is a staircase function.

1 1

0.75 0.75

0.5 0.5

0.25 0.25

0 1 4 0 1 4
(a) PMF pX (k) (b) CDF FX (k)

Figure 3.13: Illustration of a PMF and a CDF.

The MATLAB code and the Python code used to generate Figure 3.13 are shown
below. The CDF is computed using the command cumsum in MATLAB and np.cumsum in
Python.

% MATLAB code to generate a PMF and a CDF


p = [0.25 0.5 0.25];
x = [0 1 4];
F = cumsum(p);

figure(1);
stem(x,p,‘.’,‘LineWidth’,4,‘MarkerSize’,50);
figure(2);
stairs([-4 x 10],[0 F 1],‘.-’,‘LineWidth’,4,‘MarkerSize’,50);

% Python code to generate a PMF and a CDF


import numpy as np
import matplotlib.pyplot as plt
p = np.array([0.25, 0.5, 0.25])
x = np.array([0, 1, 4])
F = np.cumsum(p)

plt.stem(x,p,use_line_collection=True); plt.show()
plt.step(x,F); plt.show()

122
3.3. CUMULATIVE DISTRIBUTION FUNCTIONS (DISCRETE)

Why is CDF a better-defined function than PMF? There are technical reasons associ-
ated with whether a function is integrable. Without going into the details of these discus-
sions, a short answer is that delta functions are defined through integrations; they are not
functions. ARdelta function is defined as a function such that (x) = 0 everywhere except at
x = 0, and ⌦ (x) dx = 1. On the other hand, a staircase function is always well-defined.
The discontinuous points of a staircase can be well defined if we specify the gap between
two consecutive steps. For example, in Figure 3.13, as soon as we specify the gap 1/4, 1/2,
and 1/4, the staircase function is completely defined.

Example. Figure 3.14 shows the empirical histogram of the English letters and the corre-
sponding empirical CDF. We want to di↵erentiate PMF versus histogram and CDF versus
empirical CDF. The empirical CDF is the CDF computed from a finite dataset.

1
0.12
0.9
0.1 0.8
0.7
0.08 0.6
0.06 0.5
0.4
0.04 0.3
0.2
0.02
0.1
0 0
a b c d e f g h i j k l mn o p q r s t u v w x y z a b c d e f g h i j k l mn o p q r s t u v w x y z

Figure 3.14: PMF and a CDF of the frequency of English letters.

3.3.2 Properties of the CDF


We observe from the example in Figure 3.13 that a CDF has several properties. First, being
a staircase function, the CDF is non-decreasing. It can stay constant for a while, but it never
drops. Second, the minimum value of a CDF is 0, whereas the maximum value is 1. It is 0
for any value that is smaller than the first state; it is 1 for any value that is larger than the
last state. Third, the gap at each jump is exactly the probability mass at that state. Let us
summarize these observations in the following theorem.

Theorem 3.2. If X is a discrete random variable, then the CDF of X has the following
properties:

(i) The CDF is a sequence of increasing unit steps.


(ii) The maximum of the CDF is when x = 1: FX (+1) = 1.
(iii) The minimum of the CDF is when x = 1: FX ( 1) = 0.
(iv) The unit steps have jumps at positions where pX (x) > 0.

Proof. Statement (i) can be seen from the summation


X
FX (x) = pX (x0 ).
x0 x

123
CHAPTER 3. DISCRETE RANDOM VARIABLES

Since the probability mass function is non-negative, the value of FX is larger when the value
of the argument is larger. That is, x  y implies FX (x)  FX (y). The second statement (ii)
is true because the summation includes all possible states. So we have
1
X
FX (+1) = pX (x0 ) = 1.
x0 = 1

Similarly, for the third statement (iii),


X
FX ( 1) = pX (x0 ).
x0  1

The summation is taken over an empty set, and so FX ( 1) = 0. Statement (iv) is true
because the cumulative sum changes only when there is a non-zero mass in the PMF. ⇤

As we can see in the proof, the basic argument of the CDF is the cumulative sum of
the PMF. By definition, a cumulative sum always adds mass. This is why the CDF is always
increasing, has 0 at 1, and has 1 at +1. This last statement deserves more attention. It
implies that the unit step always has a solid dot on the left-hand side and an empty dot
on the right-hand side, because when the CDF jumps, the final value is specified by the
“” sign in Equation (3.6). The technical term for this property is right continuous.

3.3.3 Converting between PMF and CDF

Theorem 3.3. If X is a discrete random variable, then the PMF of X can be obtained
from the CDF by
pX (xk ) = FX (xk ) FX (xk 1 ), (3.8)
where we assumed that X has a countable set of states {x1 , x2 , . . .}. If the sample space
of the random variable X contains integers from 1 to +1, then the PMF can be
defined as
pX (k) = FX (k) FX (k 1). (3.9)

Example 3.7. Continuing with the example in Figure 3.13, if we are given the CDF
1 3
FX (0) = , FX (1) = , FX (4) = 1,
4 4
how do we find the PMF? We know that the PMF will have non-negative values only
at x = 0, 1, 4. For each of these x, we can show that
1 1
pX (0) = FX (0) FX ( 1) = 0= ,
4 4
3 1 1
pX (1) = FX (1) FX (0) = = ,
4 4 2
3 1
pX (4) = FX (4) FX (1) = 1 = .
4 4

124
3.4. EXPECTATION

3.4 Expectation

When analyzing data, it is often useful to extract certain key parameters such as the mean
and the standard deviation. The mean and the standard deviation can be seen from the lens
of random variables. In this section, we will formalize the idea using expectation.

3.4.1 Definition of expectation

Definition 3.4. The expectation of a random variable X is


X
E[X] = x pX (x). (3.10)
x2X(⌦)

Expectation is the mean of the random variable X. Intuitively, we can think of pX (x) as the
percentage of times that the random variable X attains the value x. When this percentage
is multiplied by x, we obtain the contribution of each x. Summing over all possible values
of x then yields the mean. To see this more clearly, we can write the definition as
X
E[X] = | {z x } | pX (x) .
{z }
x2X(⌦) a state X takes
| {z } the percentage
sum over all states

Figure 3.15 illustrates a PMF that contains five states x1 , . . . , x5 . Corresponding to each
state are pX (x1 ), . . . , pX (x5 ). For this PMF to make sense, we must assume that pX (x1 ) +
def
· · · + pX (x5 ) = 1. To simplify notation, let us define pi = pX (xi ). Then the expectation
of X is just the sum of the products: value (xi ) times height (pi ). This gives E[X] =
P5
i=1 xi pX (xi ).

Figure 3.15: The expectation of a random variable is the sum of xi pi .

We emphasize that the definition of the expectation is exactly the same as the usual
way we calculate the average of a dataset. When we calculate the average of a dataset
D = {x(1) , x(2) , . . . , x(N ) }, we sum up these N samples and divide by the number of samples.
This is what we called the empirical average or the sample average:
N
1 X (n)
average = x . (3.11)
N n=1

125
CHAPTER 3. DISCRETE RANDOM VARIABLES

Of course, in a typical dataset, these N samples often take distinct values. But suppose
that among these N samples there are only K di↵erent values. For example, if we throw a
die a million times, every sample we record will be one of the six numbers. This situation
is illustrated in Figure 3.16, where we put the samples into the correct bin storing these
values. In this case, to calculate the average we are e↵ectively doing a binning:
K
1 X
average = value xk ⇥ number of samples with value xk . (3.12)
N
k=1

Equation (3.12) is exactly the same as Equation (3.11), as long as the samples can be grouped
into K di↵erent values. With a little calculation, we can rewrite Equation (3.12) as
K
X number of samples with value xk
average = value xk ⇥ ,
| {z } N
k=1 | {z }
|{z} a state X takes
the percentage
sum of all states

which is the same as the definition of expectation.

Figure 3.16: If we have a dataset D containing N samples, and if there are only K distinct values, we
can e↵ectively put these N samples into K bins. Thus, the “average” (which is the sum divided by the
number N ) is exactly the same as our definition of expectation.

The di↵erence between E[X] and the average is that E[X] is computed from the ideal
histogram, whereas average is computed from the empirical histogram. When the number of
samples N approaches infinity, we expect the average to approximate E[X]. However, when
N is small, the empirical average will have random fluctuations around E[X]. Every time
we experiment, the empirical average may be slightly di↵erent. Therefore, we can regard
E[X] as the true average of a certain random variable, and the empirical average as a finite-
sample average based on the particular experiment we are working with. This summarizes
Key Concept 3 of this chapter.

Key Concept 3: What is expectation?


Expectation = Mean = Average computed from a PMF.

If we are given a dataset on a computer, computing the mean can be done by calling
the command mean in MATLAB and np.mean in Python. The example below shows the
case of finding the mean of 10000 uniformly distributed random numbers.

126
3.4. EXPECTATION

% MATLAB code to compute the mean of a dataset


X = rand(10000,1);
mX = mean(X);

# Python code to compute the mean of a dataset


import numpy as np
X = np.random.rand(10000)
mX = np.mean(X)

Example 3.8. Let X be a random variable with PMF pX (0) = 1/4, pX (1) = 1/2 and
pX (2) = 1/4. We can show that the expectation is
✓ ◆ ✓ ◆ ✓ ◆
1 1 1
E[X] = (0) + (1) + (2) = 1.
4 2 4
| {z } | {z } | {z }
pX (0) pX (1) pX (2)

On MATLAB and Python, if we know the PMF then computing the expectation is
straight-forward. Here is the code to compute the above example.

% MATLAB code to compute the expectation


p = [0.25 0.5 0.25];
x = [0 1 2];
EX = sum(p.*x);

# Python code to compute the expectation


import numpy as np
p = np.array([0.25, 0.5, 0.25])
x = np.array([0, 1, 2])
EX = np.sum(p*x)

Example 3.9. Flip an unfair coin, where the probability of getting a head is 34 . Let
X be a random variable such that X = 1 means getting a head. Then we can show
that pX (1) = 34 and pX (0) = 14 . The expectation of X is therefore
✓ ◆ ✓ ◆
3 1 3
E[X] = (1)pX (1) + (0)pX (0) = (1) + (0) = .
4 4 4

Center of mass. How would you interpret the result of this example? Does it mean
that, on average, we will get 3/4 heads (but there is not anything called 3/4 heads!). Recall
the definition of a random variable: it is a translator that translates a descriptive state
to a number on the real line. Thus the expectation, which is an operation defined on the
real line, can only tell us what is happening on the real line, not in the original sample

127
CHAPTER 3. DISCRETE RANDOM VARIABLES

Figure 3.17: Center of mass. If a state x2 is more influential than another state x1 , the center of mass
E[X] will lean towards x2 .

space. On the real line, the expectation can be regarded as the center of mass, which is the
point where the “forces” between the two states are “balanced”. In Figure 3.17 we depict a
random variable with two states x1 and x2 . The state x1 has less influence (because pX (x1 )
is smaller) than x2 . Therefore the center of mass is shifted towards x2 . This result shows us
that the value E[X] is not necessarily in the sample space. E[X] is a deterministic number
with nothing to do with the sample space.

1
Example 3.10. Let X be a random variable with PMF pX (k) = 2k
, for k = 1, 2, 3, . . ..
The expectation is
1
X 1
X 1
E[X] = kpX (k) = k·
2k
k=1 k=1
1
X
1 1 1 1
= k· = · = 2.
2 2k 1 2 (1 12 )2
k=1

On MATLAB and Python, if you want to verify this answer you can use the following
code. Here, we approximate the infinite sum by a finite sum of k = 1, . . . , 100.

% MATLAB code to compute the expectation


k = 1:100;
p = 0.5.^k;
EX = sum(p.*k);

# Python code to compute the expectation


import numpy as np
k = np.arange(100)
p = np.power(0.5,k)
EX = np.sum(p*k)

Example 3.11. Roll a die twice. Let X be the first roll and Y be the second roll.
Let Z = max(X, Y ). To compute the expectation E[Z], we first construct the sample
space. Since there are two rolls, we can construct a table listing all possible pairs of
outcomes. This will give us {(1, 1), (1, 2), . . . , (6, 6)}. Now, we calculate Z, which is the
max of the two rolls. So if we have (1, 3), then the max will be 3, whereas if we have
(5, 2), then the max will be 5. We can complete a table as shown below.

128
3.4. EXPECTATION

1 2 3 4 5 6
1 1 2 3 4 5 6
2 2 2 3 4 5 6
3 3 3 3 4 5 6
4 4 4 4 4 5 6
5 5 5 5 5 5 6
6 6 6 6 6 6 6
This table tell us that Z has 6 states. The PMF of Z can be determined by
counting the number of times a state shows up in the table. Thus, we can show that
1 3 5
pZ (1) = , pZ (2) = , pZ (3) = ,
36 36 36
7 9 11
pZ (4) = , pZ (5) = , pZ (6) = .
36 36 36
The expectation of Z is therefore
✓ ◆ ✓ ◆ ✓ ◆
1 3 5
E[Z] = (1) + (2) + (3)
36 36 36
✓ ◆ ✓ ◆ ✓ ◆
7 9 11
+ (4) + (5) + (6)
36 36 36
161
= .
36

Example 3.12. Consider a game in which we flip a coin 3 times. The reward of the
game is
• 1 if there are 2 heads
• 8 if there are 3 heads
• 0 if there are 0 or 1 head
There is a cost associated with the game. To enter the game, the player has to pay
1.50. We want to compute the net gain, on average.
To answer this question, we first note that the sample space contains 8 elements:
HHH, HHT, HTH, THH, THT, TTH, HTT, TTT. Let X be the number of heads.
Then the PMF of X is
1 3 3 1
pX (0) = , pX (1) = , pX (2) = , pX (3) = .
8 8 8 8
We then let Y be the reward. The PMF of Y can be found by “adding” the probabilities
of X. This yields
4 3 1
pY (0) = pX (0) + pX (1) = , pY (1) = pX (2) = , pY (8) = pX (3) = .
8 8 8

129
CHAPTER 3. DISCRETE RANDOM VARIABLES

The expectation of Y is
✓ ◆ ✓ ◆ ✓ ◆
4 3 1 11
E[X] = (0) + (1) + (8) = .
8 8 8 8
12 1
Since the cost of the game is 8 , the net gain (on average) is 8.

3.4.2 Existence of expectation


Does every PMF have an expectation? No, because we can construct a PMF such that the
expectation is undefined.

Example 3.13. Consider a random variable X with the following PMF:


6
pX (k) = , k = 1, 2, . . . .
⇡2 k2
P1 1 ⇡2
Using a result from algebra,
P1one can show that k=1 k2 = 6 . Therefore, pX (k) is a
legitimate PMF because k=1 pX (k) = 1. However, the expectation diverges, because
1
X
E[X] = kpX (k)
k=1
1
6 X1
= ! 1,
⇡2 k
k=1

1 1
where the limit is due to the harmonic seriesa : 1 + 2 + 3 + · · · = 1.
a https://en.wikipedia.org/wiki/Harmonic_series_(mathematics)

A PMF has an expectation when it is absolutely summable.

Definition 3.5. A discrete random variable X is absolutely summable if


def
X
E[|X|] = |x| pX (x) < 1. (3.13)
x2X(⌦)

This definition tells us that not all random variables have a finite expectation. This
is a very important mathematical result, but its practical implication is arguably limited.
Most of the random variables we use in practice are absolutely summable. Also, note that
the property of absolute summability applies to discrete random variables. For continuous
random variables, we have a parallel concept called absolute integrability, which will be
discussed in the next chapter.

3.4.3 Properties of expectation


The expectation of a random variable has several useful properties. We list them below.
Note that these properties apply to both discrete and continuous random variables.

130
3.4. EXPECTATION

Theorem 3.4. The expectation of a random variable X has the following properties:
(i) Function. For any function g,
X
E[g(X)] = g(x) pX (x).
x2X(⌦)

(ii) Linearity. For any function g and h,

E[g(X) + h(X)] = E[g(X)] + E[h(X)].

(iii) Scale. For any constant c,


E[cX] = cE[X].

(iv) DC Shift. For any constant c,

E[X + c] = E[X] + c.

Proof of (i): A pictorial proof of (i) is shown in Figure 3.18. The key idea is a change of
variable.

Figure 3.18: By letting g(X) = Y , the PMFs are not changed. What changes are the states.

When we have a function Y = g(X), the PMF of Y will have impulses moved from x
(the horizontal axis) to g(x) (the vertical axis). The PMF values (i.e., the probabilities or
the height of the stems), however, are not changed. If the mapping g(X) is many-to-one,
multiple PMF values will add to the same position. Therefore, when we compute E[g(X)],
we compute the expectation along the vertical axis.

Practice Exercise 3.3. Prove statement (iii): For any constant c, E[cX] = cE[X].

Solution. Recall the definition of expectation:


X X
E[cX] = (cx)pX (x) = c xpX (x) = cE[X].
x2X(⌦) x2X(⌦)
| {z }
=E[X]

Statement (iii) is illustrated in Figure 3.19. Here, we assume that the original PMF has 3

131
CHAPTER 3. DISCRETE RANDOM VARIABLES

states X = 0, 1, 2. We multiply X by a constant c = 3. This changes X to cX = 0, 3, 6.


However, since the probabilities are not changed, the height of the PMF values remains.
Therefore, when computing the expectation, we just multiply E[X] by c to get cE[X].

Figure 3.19: Pictorial representation of E[cX] = cE[X]. When we multiply X by c, we fix the probabil-
ities but make the spacing between states wider/narrower.

Practice Exercise 3.4. Prove statement (ii): For any function g and h, E[g(X) +
h(X)] = E[g(X)] + E[h(X)].

Solution. Recall the definition of expectation:


X
E[g(X) + h(X)] = [g(x) + h(x)]pX (x)
x2X(⌦)
X X
= g(x)pX (x) + h(x)pX (x)
x2X(⌦) x2X(⌦)
| {z } | {z }
=E[g(X)] =E[h(X)]

= E[g(X)] + E[h(X)].

Practice Exercise 3.5. Prove statement (iv): For any constant c, E[X +c] = E[X]+c.

Solution. Recall the definition of expectation:


X
E[X + c] = (x + c)pX (x)
x2X(⌦)
X X
= xpX (x) + c · pX (x)
x2X(⌦) x2X(⌦)
| {z } | {z }
=E[X] =1

= E[X] + c.

This result is illustrated in Figure 3.20. As we add a constant to the random variable,
its PMF values remain the same but their positions are shifted. Therefore, when computing
the mean, the mean will be shifted accordingly.

132
3.4. EXPECTATION

Figure 3.20: Pictorial representation of E[X +c] = E[X]+c. When we add c to X, we fix the probabilities
and shift the entire PMF to the left or to the right.

Example 3.14. Let X be a random variable with four equally probable states 0, 1, 2, 3.
We want to compute the expectation E[cos(⇡X/2)]. To do so, we note that
X ✓ ◆
⇡X
E[cos(⇡X/2)] = cos pX (x)
2
x2X(⌦)
✓ ◆ ✓ ◆ ✓ ◆ ✓ ◆
1 ⇡ 1 2⇡ 1 3⇡ 1
= (cos 0) + (cos ) + (cos ) + (cos )
4 2 4 2 4 2 4
1 + 0 + ( 1) + 0
= = 0.
4

Example 3.15. Let X be a random variable with E[X] = 1 and E[X 2 ] = 3. We want
to find the expectation E[(aX + b)2 ]. To do so, we realize that
(a) (b)
E[(aX + b)2 ] = E[a2 X 2 + 2abX + b2 ] = a2 E[X 2 ] + 2abE[X] + b2 = 3a2 + 2ab + b2 ,

where (a) is due to expansion of the square, and (b) holds in two steps. The first step
is to apply statement (ii) for individual functions of expectations, and the second step
is to apply statement (iii) for scalar multiple of the expectations.

3.4.4 Moments and variance


Based on the concept of expectation, we can define a moment:

Definition 3.6. The kth moment of a random variable X is


X
E[X k ] = xk pX (x). (3.14)
x

Essentially, the kth moment is the expectation applied to X k . The definition follows from
statement (i) of the expectation’s properties. Using this definition, we note that E[X] is the
first moment and E[X 2 ] is the second moment. Higher-order moments can be defined, but
in practice they are less commonly used.

133
CHAPTER 3. DISCRETE RANDOM VARIABLES

Example 3.16. Flip a coin 3 times. Let X be the number of heads. Then
1 3 3 1
pX (0) = , pX (1) = , pX (2) = , pX (3) = .
8 8 8 8
The second moment E[X 2 ] is
✓ ◆ ✓ ◆ ✓ ◆ ✓ ◆
1 3 3 1
E[X 2 ] = (0)2 + (1)2 + (2)2 + (4)2 = 3.
8 8 8 8

Example 3.17. Consider a random variable X with PMF


1
pX (k) = , k = 1, 2, . . . .
2k
The second moment E[X 2 ] is
1
X ✓ ◆k 1 ✓ ◆k 2
2 2 1 1 X 1
E[X ] = k = 2 k(k 1 + 1)
2 2 2
k=1 k=1
1 ✓ ◆k 2 1 ✓ ◆k 2
1 X 1 1 X 1
= 2 k(k 1) + 2 k
2 2 2 2
k=1 k=1
✓ ◆ ✓ ◆
1 2 1 1
= 2 1 + = 6.
2 (1 2 ) 3 2 (1 12 )2

Using the second moment, we can define the variance of a random variable.

Definition 3.7. The variance of a random variable X is

Var[X] = E[(X µ)2 ], (3.15)

where µ = E[X] is the expectation of X.

We denote 2 by Var[X]. The square root of the variance, , is called the standard deviation
of X. Like the expectation E[X], the variance Var[X] is computed using the ideal histogram
PMF. It is the limiting object of the usual standard deviation we calculate from a dataset.
On a computer, computing the variance of a dataset is done by calling built-in com-
mands such as var in MATLAB and np.var in Python. The standard deviation is computed
using std and np.std, respectively.
% MATLAB code to compute the variance
X = rand(10000,1);
vX = var(X);
sX = std(X);

% Python code to compute the variance


import numpy as np

134
3.4. EXPECTATION

X = np.random.rand(10000)
vX = np.var(X)
sX = np.std(X)

What does the variance mean? It is a measure of the deviation of the random variable
X relative to its mean. This deviation is quantified by the squared di↵erence (X µ)2 . The
expectation operator takes the average of the deviation, giving us a deterministic number
E[(X µ)2 ].

Theorem 3.5. The variance of a random variable X has the following properties:
(i) Moment.
Var[X] = E[X 2 ] E[X]2 .

(ii) Scale. For any constant c,

Var[cX] = c2 Var[X].

(iii) DC Shift. For any constant c,

Var[X + c] = Var[X].

Figure 3.21: Pictorial representations of Var[cX] = c2 Var[X] and Var[X + c] = Var[X].

Practice Exercise 3.6. Prove Theorem 3.5 above.


Solution. For statement (i), we show that

Var[X] = E[(X µ)2 ] = E[X 2 2Xµ + µ2 ] = E[X 2 ] µ2 .

135
CHAPTER 3. DISCRETE RANDOM VARIABLES

Statement (ii) holds because E[cX] = cµ and

Var[cX] = E[(cX E[cX])2 ]


= E[(cX cµ)2 ] = c2 E[(X µ)2 ] = c2 Var[X].

Statement (iii) holds because

Var[X + c] = E[((X + c) E[X + c])2 ] = E[(X E[X])2 ] = Var[X].

The properties above are useful in various ways. The first statement provides a link connect-
ing variance and the second moment. Statement (ii) implies that when X is scaled by c, the
variance should be scaled by c2 because of the square in the second moment. Statement (iii)
says that when X is shifted by a scalar c, the variance is unchanged. This is true because
no matter how we shift the mean, the fluctuation of the random variable remains the same.

Practice Exercise 3.7. Flip a coin with probability p to get a head. Let X be a
random variable denoting the outcome. The PMF of X is

pX (0) = 1 p, pX (1) = p.

Find E[X], E[X 2 ] and Var[X].

Solution. The expectation of X is

E[X] = (0)pX (0) + (1)pX (1) = (0)(1 p) + (1)(p) = p.

The second moment is

E[X 2 ] = (0)2 pX (0) + (1)2 pX (1) = p.

The variance is

Var[X] = E[X 2 ] E[X]2 = p p2 = p(1 p).

3.5 Common Discrete Random Variables

In the previous sections, we have conveyed three key concepts: one about the random vari-
able, one about the PMF, and one about the mean. The next step is to introduce a few
commonly used discrete random variables so that you have something concrete in your “tool-
box.” As we have mentioned before, these predefined random variables should be studied
from a synthesis perspective (sometimes called generative). The plan for this section is to
introduce several models, derive their theoretical properties, and discuss examples.
Note that some extra e↵ort will be required to understand the origins of the random
variables. The origins of random variables are usually overlooked, but they are more impor-
tant than the equations. For example, we will shortly discuss the Poisson random variable

136
3.5. COMMON DISCRETE RANDOM VARIABLES

Figure 3.22: A Bernoulli random variable has two states with probability p and 1 p.

k
e
and its PMF pX (k) = k! . Why is the Poisson random variable defined in this way? If
you know how the Poisson PMF was originally derived, you will understand the assumptions
made during the derivation. Consequently, you will know why Poisson is a good model for
internet traffic, recommendation scores, and image sensors for computer vision applications.
You will also know under what situation the Poisson model will fail. Understanding the
physics behind the probability models is the focus of this section.

3.5.1 Bernoulli random variable


We start discussing the simplest random variable, namely the Bernoulli random variable.
A Bernoulli random variable is a coin-flip random variable. The random variable has two
states: either 1 or 0. The probability of getting 1 is p, and the probability of getting 0 is
1 p. See Figure 3.22 for an illustration. Bernoulli random variables are useful for all kinds
of binary state events: coin flip (H or T), binary bit (1 or 0), true or false, yes or no, present
or absent, Democrat or Republican, etc.
To make these notions more precise, we define a Bernoulli random variable as follows.

Definition 3.8. Let X be a Bernoulli random variable. Then, the PMF of X is

pX (0) = 1 p, pX (1) = p,

where 0 < p < 1 is called the Bernoulli parameter. We write

X ⇠ Bernoulli(p)

to say that X is drawn from a Bernoulli distribution with a parameter p.

In this definition, the parameter p controls the probability of obtaining 1. In a coin-flip event,
p is usually 12 , meaning that the coin is fair. However, for biased coins p is not necessarily 12 .
For other situations such as binary bits (0 or 1), the probability of obtaining 1 could be very
di↵erent from the probability of obtaining 0.
In MATLAB and Python, generating Bernoulli random variables can be done by call-
ing the binomial random number generator np.random.binomial (Python) and binornd
(MATLAB). When the parameter n is equal to 1, the binomial random variable is equiv-
alent to a Bernoulli random variable. The MATLAB and Python codes to synthesize a
Bernoulli random variable are shown below.

137
CHAPTER 3. DISCRETE RANDOM VARIABLES

% MATLAB code to generate 1000 Bernoulli random variables


p = 0.5;
n = 1;
X = binornd(n,p,[1000,1]);
[num, ~] = hist(X, 10);
bar(linspace(0,1,10), num,‘FaceColor’,[0.4, 0.4, 0.8]);

# Python code to generate 1000 Bernoulli random variables


import numpy as np
import matplotlib.pyplot as plt
p = 0.5
n = 1
X = np.random.binomial(n,p,size=1000)
plt.hist(X,bins=‘auto’)

An alternative method in Python is to call stats.bernoulli.rvs to generate random


Bernoulli numbers.
# Python code to call scipy.stats library
import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
p = 0.5
X = stats.bernoulli.rvs(p,size=1000)
plt.hist(X,bins=‘auto’);

Properties of Bernoulli random variables


Let us now derive a few key statistical properties of a Bernoulli random variable.

Theorem 3.6. If X ⇠ Bernoulli(p), then

E[X] = p, E[X 2 ] = p, Var[X] = p(1 p).

Proof. The expectation can be computed as


E[X] = (1)pX (1) + (0)pX (0) = (1)(p) + (0)(1 p) = p.
The second moment is
E[X 2 ] = (12 )(p) + (02 )(1 p) = p.
Therefore, the variance is
Var[X] = E[X 2 ] µ2 = p p2 = p(1 p).

A useful property of the Python code is that we can construct an object rv. Then we
can call rv’s attributes to determine its mean, variance, etc.

138
3.5. COMMON DISCRETE RANDOM VARIABLES

# Python code to generate a Bernoulli rv object


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
p = 0.5
rv = stats.bernoulli(p)
mean, var = rv.stats(moments=‘mv’)
print(mean, var)

In both MATLAB and Python, we can plot the PMF of a Bernoulli random variable,
such as the one shown in Figure 3.23. To do this in MATLAB, we call the function binopdf,
with the evaluation points specified by x.
1

0.8

0.6

0.4

0.2

0
-0.2 0 0.2 0.4 0.6 0.8 1 1.2

Figure 3.23: An example of a theoretical PMF (not the empirical histogram) plotted by MATLAB.

% MATLAB code to plot the PMF of a Bernoulli


p = 0.3;
x = [0,1];
f = binopdf(x,1,p);
stem(x, f, ‘bo’, ‘LineWidth’, 8);

In Python, we construct a random variable rv. With rv, we can call its PMF rv.pmf:

# Python code to plot the PMF of a Bernoulli


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
p = 0.3
rv = stats.bernoulli(p)
x = np.linspace(0, 1, 2)
f = rv.pmf(x)
plt.plot(x, f, ‘bo’, ms=10);
plt.vlines(x, 0, f, colors=‘b’, lw=5, alpha=0.5);

139
CHAPTER 3. DISCRETE RANDOM VARIABLES

When will a Bernoulli random variable have the maximum variance?


Let us take a look at the variance of the Bernoulli random variable. For any given p, the
variance is p(1 p). This is a quadratic equation. If we let V (p) = p(1 p), we can show that
the maximum is attained at p = 1/2. To see this, take the derivative of V (p) with respect
d
to p. This will give us dp V (p) = 1 2p. Equating to zero yields 1 2p = 0, so p = 1/2.
We know that p = 1/2 is a maximum and not a minimum point because the second order
derivative V 00 (p) = 2, which is negative. Therefore V (p) is maximized at p = 1/2. Now,
since 0  p  1, we also know that V (0) = 0 and V (1) = 0. Therefore, the variance is
minimized at p = 0 and p = 1. Figure 3.24 shows a graph of the variance.

Figure 3.24: The variance of a Bernoulli reaches maximum at p = 1/2.

Does this result make sense? Why is the variance maximized at p = 1/2? If we think
about this problem more carefully, we realize that a Bernoulli random variable represents a
coin-flip experiment. If the coin is biased such that it always gives heads, on the one hand,
it is certainly a bad coin. However, on the other hand, the variance is zero because there
is nothing to vary; you will certainly get heads. The same situation happens if the coin is
biased towards tails. However, if the coin is fair, i.e., p = 1/2, then the variance is large
because we only have a 50% chance of getting a head or a tail whenever we flip a coin.
Nothing is certain in this case. Therefore, the maximum variance happening at p = 1/2
matches our intuition.

Rademacher random variable


A slight variation of the Bernoulli random variable is the Rademacher random variable,
which has two states: +1 and 1. The probability getting +1 and 1 is 1/2. Therefore, the
PMF of a Rademacher random variable is
1 1
pX ( 1) = , and pX (+1) = .
2 2

Practice Exercise 3.8. Show that if X is a Rademacher random variable then


(X + 1)/2 ⇠ Bernoulli(1/2). Also show the converse: If Y ⇠ Bernoulli(1/2) then 2Y 1
is a Rademacher random variable.
Solution. Since X can either be +1 or 1, we show that if X = +1 then (X +1)/2 = 1
and if X = 1 then (X + 1)/2 = 0. The probabilities of getting +1 and 1 are equal.
Thus, the probabilities of getting (X + 1)/2 = 1 and 0 are also equal. So the resulting
random variable is Bernoulli(1/2). The other direction can be proved similarly.

140
3.5. COMMON DISCRETE RANDOM VARIABLES

Bernoulli in social networks: the Erdős-Rényi graph


The study of networks is a big branch of modern data science. It includes social networks,
computer networks, traffic networks, etc. The history of network science is very long, but
one of the most basic models of a network is the Erdős-Rényi graph, named after Paul
Erdős and Alfréd Rényi. The underlying probabilistic model of the Erdős-Rényi graph is
the Bernoulli random variable.
To see how a graph can be constructed from a Bernoulli random variable, we first
introduce the concept of a graph. A graph contains two elements: nodes and edges. For
node i and node j, we denote the edge connecting i and j as Aij . Therefore, if we have N
nodes, then we can construct a matrix A of size N ⇥ N . We call this matrix the adjacency
matrix. For example, the adjacency matrix
2 3
0 1 1 0
6 1 0 0 07
A=6 4 1 0 0 15
7

0 0 1 0

will have edges for node pairs (1, 2), (1, 3), and (3, 4). Note that in this example we assume
that the adjacency matrix is symmetric, meaning that the graph is undirected. The “1” in
the adjacency matrix indicates there is an edge, and “0” indicates there is no edge. So A
represents a binary graph.
The Erdős-Rényi graph model says that the probability of getting an edge is an inde-
pendent Bernoulli random variable. That is

Aij ⇠ Bernoulli(p),

for i < j. If we model the graph in this way, then the parameter p will control the density
of the graph. High values of p mean that there is a higher chance for an edge to be present.
p = 0.3 p = 0.5 p = 0.7 p = 0.9
4
2 35 33 3 4 3 12 14 28 5
7 24 38
23 7 31
29 6 33 20 36 28
27 3 20 19 2 3 2 15
21 1 39 1 13
1 34 40 15 27 26 10 2 29
10 18 1231 38 8
6 20 10
36 39 1 35 9 25 32
1 11 17 2 16
14 3
1 13 39 9 2
17 32 4 17 33 7 35 18
0 28 11 16 30 7
40 22 0 36 30 0 35
23 4 20 22 33 4 27
30 2 19 28 37 18 0 24 34
14 18 17
34 26 24 5 32
5 8 25
6 -1 1
27 -1 40 34 32 19 21
8
-1 9 37 26 24 21 38 36 40
15 13 10 3 19
16 31 25 29 31
25 148 -2 22 -2 16 26 39 30
29 15 22 -2
11 5 9 37
-2 2 37 6
23 12
38 -3 -3
21 12 23 13 11

-3 -4 -4 -4
-2 0 2 -2 0 2 -4 -2 0 2 4 -4 -2 0 2 4

Figure 3.25: The Erdős-Rényi graph. [Top] The graphs. [Bottom] The adjacency matrices.

141
CHAPTER 3. DISCRETE RANDOM VARIABLES

To illustrate the idea of an Erdős-Rényi graph, we show in Figure 3.25 a graph of


40 nodes. The edges are randomly selected by flipping a Bernoulli random variable with
parameter p = 0.3, 0.5, 0.7, 0.9. As we can see in the figure, a small value of p gives a graph
with very sparse connectivity, whereas a large value of p gives a very densely connected
graph. The bottom row of Figure 3.25 shows the corresponding adjacency matrices. Here,
a white pixel denotes “1” in the matrix and a black pixel denotes “0” in the matrix.
While Erdős-Rényi graphs are elementary, their variations can be realistic models of
social networks. The stochastic block model is one such model. In a stochastic block model,
nodes form small communities within a large network. For example, there are many majors
in a university. Students within the same major tend to have more interactions than with
students of another major. The stochastic block model achieves this goal by partitioning
the nodes into communities. Within each community, the nodes can have a high degree of
connectivity. Across di↵erent communities, the connectivity will be much lower. Figure 3.26
illustrates a network and the corresponding adjacency matrix. In this example, the network
has three communities.

4 12
10
11 25 5
7 24
4 87
14
13 22 23 99
93 79 100
19 89 74 75
2 21 83 95 67
8 18 20 15 78
84
2 96 86 82 88 72 66
6 16 85 80
9 71 68 69
17 92 77 73
1 3 90 76 97
98
70 94 81 91
0

43
55 32 65
37 47
42 63 28 41
31 50
-2 64 59 30 45 60
44 58
39 33 51 27
26 62 61 46
29 36 52
54 35
38 56
34 57
-4 48 53
40
49

-6
-4 -3 -2 -1 0 1 2 3 4

Figure 3.26: A stochastic block model containing three communities. [Left] The graph. [Right] The
adjacency matrix.

In network analysis, one of the biggest problems is determining the community struc-
ture and recovering the underlying probabilities. The former task is about grouping the
nodes into blocks. This is a nontrivial problem because in practice the nodes are never
arranged nicely, as shown in Figure 3.26. For example, why should Alice be node 1 and
Bob be node 2? Since we never know the correct ordering of the nodes, partitioning the
nodes into blocks requires various estimation techniques such as clustering or iterative esti-
mation. Recovering the underlying probability is also not easy. Given an adjacency matrix,
why can we assume that the underlying network is a stochastic block model? Even if the
model is correct, there will be imperfect grouping in the previous step. As such, estimat-
ing the underlying probability in the presence of these uncertainties would pose additional
challenges.
Today, network analysis remains one of the hottest areas in data science. Its importance
derives from its broad scope and impact. It can be used to analyze social networks, opinion
polls, marketing, or even genome analysis. Nevertheless, the starting point of these advanced
subjects is the Bernoulli random variable, the random variable of a coin flip!

142
3.5. COMMON DISCRETE RANDOM VARIABLES

3.5.2 Binomial random variable


Suppose we flip the coin n times count the number of heads. Since each coin flip is a random
variable (Bernoulli), the sum is also a random variable. It turns out that this new random
variable is the binomial random variable.

Definition 3.9. Let X be a binomial random variable. Then, the PMF of X is


✓ ◆
n k
pX (k) = p (1 p)n k , k = 0, 1, . . . , n,
k

where 0 < p < 1 is the binomial parameter, and n is the total number of states. We
write
X ⇠ Binomial(n, p)
to say that X is drawn from a binomial distribution with a parameter p of size n.

To understand the meaning of a binomial random variable, consider a simple experiment


consisting of flipping a coin three times. We know that all possible cases are HHH, HHT,
HTH, THH, TTH, THT, HTT and TTT. Now, suppose we define X = number of heads.
We want to write down the probability mass function. E↵ectively, we ask: What is the
probability of getting 0 head, one head, two heads, and three heads? We can, of course,
count and get the answer right away for a fair coin. However, suppose the coin is unfair,
i.e., the probability of getting a head is p whereas that of a tail is 1 p. The probability of
getting each of the 8 cases is shown in Figure 3.27 below.

Figure 3.27: The probability of getting k heads out of n = 3 coins.

Here are the detailed calculations. Let us start with X = 3.

pX (3) = P[{HHH}]
= P[{H} \ {H} \ {H}]
(a)
= P[{H}]P[{H}]P[{H}]
(b)
= p3 ,

where (a) holds because the three events are independent. (Recall that if A and B are
independent then P[A \ B] = P[A]P[B].) (b) holds because each P[{H}] = p by definition.
With exactly the same argument, we can show that pX (0) = P[{TTT}] = (1 p)3 .

143
CHAPTER 3. DISCRETE RANDOM VARIABLES

Now, let us look at pX (2), i.e., 2 heads. This probability can be calculated as follows:

pX (2) = P[{HHT} [ {HTH} [ {THH}]


(c)
= P[{HHT}] + P[{HTH}] + P[{THH}]
(d)
= p2 (1 p) + p2 (1 p) + p2 (1 p) = 3p2 (1 p),

where (c) holds because the three events HHT, HTH and THH are disjoint in the sample
space. Note that we are not using the independence argument in (c) but the disjoint argu-
ment. We should not confuse the two. The step in (d) uses independence, because each coin
flip is independent.
The above calculation shows an interesting phenomenon: Although the three events
HHT, HTH, and THH are di↵erent (in fact, disjoint), the number of heads in all the cases
is the same. This happens because when counting the number of heads, the ordering of the
heads and tails does not matter. So the same problem can be formulated as finding the
number of combinations of { 2 heads and 1 tail }, which in our case is 32 = 3.
To complete the story, let us also try pX (1). This probability is

pX (1) = P[{TTH} [ {HTT} [ {THT}] = 3p(1 p)2 .


3
Again, we see that the combination 1 = 3 appears in front of the p(1 p)2 .
In general, the way to interpret the binomial random variable is to decouple the prob-
abilities p, (1 p), and the number of combinations nk :
✓ ◆
n
pX (k) = pk (1 p)n k .
k | {z } | {z }
| {z } prob getting k H’s prob getting n k T’s
number of combinations

The running index k should go with 0, 1, . . . , n. It starts with 0 because there could be zero
heads in the sample space. Furthermore, we note that in this definition, two parameters are
driving a binomial random variable: the number of Bernoulli trials n and the underlying
probability for each coin flip p. As such, the notation for a binomial random variable is
Binomial(n, p), with two arguments.
The histogram of a binomial random variable is shown in Figure 3.28(a). Here, we con-
sider the example where n = 10 and p = 0.5. To generate the histogram, we use 5000 samples.
In MATLAB and Python, generating binomial random variables as in Figure 3.28(a) can
be done by calling binornd and np.random.binomial.
% MATLAB code to generate 5000 Binomial random variables
p = 0.5;
n = 10;
X = binornd(n,p,[5000,1]);
[num, ~] = hist(X, 10);
bar( num,‘FaceColor’,[0.4, 0.4, 0.8]);

# Python code to generate 5000 Binomial random variables


import numpy as np
import matplotlib.pyplot as plt

144
3.5. COMMON DISCRETE RANDOM VARIABLES

1200 0.25

1000
0.2

800
0.15
600
0.1
400

0.05
200

0 0
1 2 3 4 5 6 7 8 9 10 0 2 4 6 8 10

(a) Histogram based on 5000 samples (b) PMF

Figure 3.28: An example of a binomial distribution with n = 10, p = 0.5.

p = 0.5
n = 10
X = np.random.binomial(n,p,size=5000)
plt.hist(X,bins=‘auto’);

Generating the ideal PMF of a binomial random variable as shown in Figure 3.28(b)
can be done by calling binopdf in MATLAB. In Python, we can define a random variable
rv through stats.binom, and call the PMF using rv.pmf.

% MATLAB code to generate a binomial PMF


p = 0.5;
n = 10;
x = 0:10;
f = binopdf(x,n,p);
stem(x, f, ’o’, ’LineWidth’, 8, ’Color’, [0.8, 0.4, 0.4]);

# Python code to generate a binomial PMF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
p = 0.5
n = 10
rv = stats.binom(n,p)
x = np.arange(11)
f = rv.pmf(x)
plt.plot(x, f, ’bo’, ms=10);
plt.vlines(x, 0, f, colors=’b’, lw=5, alpha=0.5);

The shape of the binomial PMF is shown in Figure 3.29. In this set of figures, we vary
one of the two parameters n and p while keeping the other fixed. In Figure 3.29(a), we fix
n = 60 and plot three sets of p = 0.1, 0.5, 0.9. For small p the PMF is skewed towards the
left, and for large p the PMF is skewed toward the right. Figure 3.29(b) shows the PMF

145
CHAPTER 3. DISCRETE RANDOM VARIABLES

for a fixed p = 0.5. As we increase n, the centroid of the PMF moves towards the right.
Thus we should expect the mean of a binomial random variable to increase with p. Another
interesting observation is that as n increases, the shape of the PMF approaches the Gaussian
function (the bell-shaped curve). We will explain the reason for this when we discuss the
Central Limit Theorem.
0.2 0.4
p = 0.1 n=5
p = 0.5 n = 50
0.15 0.3 n = 100
p = 0.9

0.1 0.2

0.05 0.1

0 0
0 10 20 30 40 50 60 0 10 20 30 40 50 60
(a) n = 60 (b) p = 0.5

Figure 3.29: PMFs of a binomial random variable X ⇠ Binomial(n, p). (a) We assume that n = 60. By
varying the probability p, we see that the PMF shifts from the left to the right, and the shape changes.
(b) We assume that p = 0.5. By varying the number of trials, the PMF shifts and the shape becomes
more “bell-shaped.”

The expectation, second moment, and variance of a binomial random variable are
summarized in Theorem 3.7.

Theorem 3.7. If X ⇠ Binomial(n, p), then

E[X] = np,
E[X 2 ] = np(np + (1 p)),
Var[X] = np(1 p).

We will prove that E[X] = np using the first principle. For E[X 2 ] and Var[X], we will skip
the proofs here and will introduce a “shortcut” later.

Proof. Let us start with the definition.


Xn ✓ ◆
n k
E[X] = k· p (1 p)n k
k
k=0
Xn
n!
= k· pk (1 p)n k
k!(n k)!
k=0
n
X
n! n!
=0· p0 (1 p)n 0
+ k· pk (1 p)n k
0!(n 0)! k!(n k)!
| {z } k=1
0
n
X n!
= pk (1 p)n k
.
(k 1)!(n k)!
k=1

146
3.5. COMMON DISCRETE RANDOM VARIABLES

Note that we have shifted the index from k = 0 to k = 1. Now let us apply a trick:
n
X n!
E[X] = pk (1 p)n k
(k 1)!(n k)!
k=1
Xn
n!
= pk (1 p)n k
.
(k 1)!(n k 1 + 1)!
k=1

Using this trick, we can show that


n
X n!
pk (1 p)n k
(k 1)!(n k 1 + 1)!
k=1
n
X n!
= pk (1 p)n k
(k 1)!((n 1) (k 1))!
k=1
Xn
n(n 1)!
= pk (1 p)n k
(k 1)!((n 1) (k 1))!
k=1
n
X (n 1)!
= np pk 1
(1 p)n k
(k 1)!((n 1) (k 1))!
k=1

With a simple substitution of ` = k 1, the above equation can be rewritten as


n
X1 (n 1)!
E[X] = np · p` (1 p)n 1 `
`!((n 1) `)!
`=0
X1 ✓n 1◆
n
= np · p` (1 p)n 1 `
= np.
k
`=0
| {z }
summing PMF of Binomial(n 1,p)


In MATLAB, the mean and variance of a binomial random variable can be found by
calling the command binostat(n,p) (MATLAB).
In Python, the command is rv = stats.binom(n,p) followed by calling rv.stats.

% MATLAB code to compute the mean and var of a binomial rv


p = 0.5;
n = 10;
[M,V] = binostat(n, p)

# Python code to compute the mean and var of a binomial rv


import scipy.stats as stats
p = 0.5
n = 10
rv = stats.binom(n,p)
M, V = rv.stats(moments=‘mv’)
print(M, V)

147
CHAPTER 3. DISCRETE RANDOM VARIABLES

An alternative view of the binomial random variable. As we discussed, the origin of a


binomial random variable is the sum of a sequence of Bernoulli random variables. Because
of this intrinsic definition, we can derive some useful results by exploiting this fact. To do so,
let us define I1 , . . . , In as a sequence of Bernoulli random variables with Ij ⇠ Bernoulli(p)
for all i = 1, . . . , n. Then the resulting variable
X = I1 + I2 + · · · + In
is a binomial random variable of size n and parameter p. Using this definition, we can
compute the expectation as follows:
E[X] = E[I1 + I2 + · · · + In ]
(a)
= E[I1 ] + E[I2 ] + · · · + E[In ]
= p + p + ··· + p
= np.
In this derivation, the step (a) depends on a useful fact about expectation (which we have not
yet proved): For any two random variables X and Y , it holds that E[X + Y ] = E[X] + E[Y ].
Therefore, we can show that the expectation of X is np. This line of argument not only
simplifies the proof but also provides a good intuition of the expectation. If each coin flip
has an expectation of E[Ii ] = p, then the expectation of the sum should be simply n times
of p, given np.
How about the variance? Again, we are going to use a very useful fact about variance:
If two random variables X and Y are independent, then Var[X + Y ] = Var[X] + Var[Y ].
With this result, we can show that
Var[X] = Var[I1 + · · · + In ]
= Var[I1 ] + · · · + Var[In ]
= p(1 p) + · · · + p(1 p)
= np(1 p).
Finally, using the fact that Var[X] = E[X ] 2
µ2 , we can show that
E[X 2 ] = Var[X] + µ2
= np(1 p) + (np)2 .

Practice Exercise 3.9. Show that the binomial PMF sums to 1.


Solution. We use the binomial theorem to prove this result:
n
X n ✓ ◆
X n
pX (k) = pk (1 p)n k
= (p + (1 p))n = 1.
k
k=0 k=0

The CDF of the binomial random variable is not very informative. It is basically the
cumulative sum of the PMF:
k ✓ ◆
X n `
FX (k) = p (1 p)n ` .
`
`=0

148
3.5. COMMON DISCRETE RANDOM VARIABLES

0.2 1

0.8
0.15
0.6
0.1
0.4
0.05 0.2

0 0
0 5 10 15 20 25 30 0 5 10 15 20 25 30

Figure 3.30: PMF and CDF of a binomial random variable X ⇠ Binomial(n, p).

The shapes of the PMF and the CDF is shown in Figure 3.30.
In MATLAB, plotting the CDF of a binomial can be done by calling the function
binocdf. You may also call f = binopdf(x,n,p), and define F = cumsum(f) as the cumu-
lative sum of the PMF. In Python, the corresponding command is rv = stats.binom(n,p)
followed by rv.cdf.

% MATLAB code to compute the mean and var of a binomial rv


x = 0:10;
p = 0.5;
n = 10;
F = binocdf(x,n,p);
figure; stairs(x,F,‘.-’,‘LineWidth’,4,‘MarkerSize’,30);

# Python code to compute the mean and var of a binomial rv


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
p = 0.5
n = 10
rv = stats.binom(n,p)
x = np.arange(11)
F = rv.cdf(x)
plt.plot(x, F, ’bo’, ms=10);
plt.vlines(x, 0, F, colors=’b’, lw=5, alpha=0.5);

3.5.3 Geometric random variable


In some applications, we are interested in trying a binary experiment until we succeed. For
example, we may want to keep calling someone until the person picks up the call. In this
case, the random variable can be defined as the outcome of many failures followed by a final
success. This is called the geometric random variable.

Definition 3.10. Let X be a geometric random variable. Then, the PMF of X is

pX (k) = (1 p)k 1
p, k = 1, 2, . . . ,

149
CHAPTER 3. DISCRETE RANDOM VARIABLES

where 0 < p < 1 is the geometric parameter. We write

X ⇠ Geometric(p)

to say that X is drawn from a geometric distribution with a parameter p.

A geometric random variable is easy to understand. We define it as Bernoulli trials with


k 1 consecutive failures followed by one success. This can be seen from the definition:
pX (k) = (1 p)k 1
p .
| {z }| {z }
k 1 failures final success

Note that in geometric random variables, there is no nk because we must have k 1


consecutive failures before one success. There is no alternative combination of the sequence.
The histogram and PMF of a geometric random variable are illustrated in Figure 3.31.
Here, we assume that p = 0.5.

3000 0.5

2500 0.4

2000
0.3
1500
0.2
1000

0.1
500

0 0
0 1 2 3 4 5 6 7 8 9 10 0 2 4 6 8 10
(a) Histogram based on 5000 samples (b) PMF

Figure 3.31: An example of a geometric distribution with p = 0.5.

In MATLAB, generating geometric random variables can be done by calling the com-
mands geornd. In Python, it is np.random.geometric.

% MATLAB code to generate 1000 geometric random variables


p = 0.5;
X = geornd(p,[5000,1]);
[num, ~] = hist(X, 0:10);
bar(0:10, num, ‘FaceColor’,[0.4, 0.4, 0.8]);

# Python code to generate 1000 geometric random variables


import numpy as np
import matplotlib.pyplot as plt
p = 0.5
X = np.random.geometric(p,size=1000)
plt.hist(X,bins=‘auto’);

To generate the PMF plots, in MATLAB we call geopdf and in Python we call
rv = stats.geom followed by rv.pmf.

150
3.5. COMMON DISCRETE RANDOM VARIABLES

% MATLAB code to generate geometric PMF


p = 0.5; x = 0:10;
f = geopdf(x,p);
stem(x, f, ‘o’, ‘LineWidth’, 8, ‘Color’, [0.8, 0.4, 0.4]);

# Python code to generate 1000 geometric random variables


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.arange(1,11)
rv = stats.geom(p)
f = rv.pmf(x)
plt.plot(x, f, ‘bo’, ms=8, label=‘geom pmf’)
plt.vlines(x, 0, f, colors=‘b’, lw=5, alpha=0.5)

Practice Exercise 3.10. Show that the geometric PMF sums to one.
Solution. We can apply infinite series to show the result:
1
X 1
X
pX (k) = (1 p)k 1
p
k=1 k=1
1
X
=p· (1 p)k 1
, `=k 1
k=1
X1
=p· (1 p)`
`=0
1
=p· = 1.
1 (1 p)

It is interesting to compare the shape of the PMFs for various values of p. In Figure 3.32
we show the PMFs. We vary the parameter p = 0.25, 0.5, 0.9. For small p, the PMF starts
with a low value and decays at a slow speed. The opposite happens for a large p, where the
PMF starts with a high value and decays rapidly.
Furthermore, we can derive the following properties of the geometric random variable.

Theorem 3.8. If X ⇠ Geometric(p), then


1 2 1
E[X] = , E[X 2 ] = 2 , (3.16)
p p p
1 p
Var[X] = .
p2

Proof. We will prove that the mean is 1/p and leave the second moment and variance as

151
CHAPTER 3. DISCRETE RANDOM VARIABLES

1 1 1
p = 0.25 p = 0.5 p = 0.9

0.8 0.8 0.8

0.6 0.6 0.6

0.4 0.4 0.4

0.2 0.2 0.2

0 0 0
0 2 4 6 8 0 2 4 6 8 0 2 4 6 8

Figure 3.32: PMFs of a geometric random variable X ⇠ Geometric(p).

an exercise.
1 1
! ✓ ◆
X X (a) 1 1
k 1 k 1
E[X] = kp(1 p) =p k(1 p) = p = ,
(1 (1 p))2 p
k=1 k=1

where (a) follows from the infinite series identity in Chapter 1.


3.5.4 Poisson random variable


In many physical systems, the arrivals of events are typically modeled as a Poisson ran-
dom variable, e.g., photon arrivals, electron emissions, and telephone call arrivals. In social
networks, the number of conversations per user can also be modeled as a Poisson. In e-
commerce, the number of transactions per paying user is again modeled using a Poisson.

Definition 3.11. Let X be a Poisson random variable. Then, the PMF of X is


k
pX (k) = e , k = 0, 1, 2, . . . ,
k!
where > 0 is the Poisson rate. We write

X ⇠ Poisson( )

to say that X is drawn from a Poisson distribution with a parameter .

In this definition, the parameter determines the rate of the arrival. The histogram and
PMF of a Poisson random variable are illustrated in Figure 3.33. Here, we assume that
= 1.
The MATLAB code and Python code used to generate the histogram are shown below.

% MATLAB code to generate 5000 Poisson numbers


lambda = 1;
X = poissrnd(lambda,[5000,1]);

152
3.5. COMMON DISCRETE RANDOM VARIABLES

2000 0.4

1500 0.3

1000 0.2

500 0.1

0 0
0 1 2 3 4 5 6 7 8 9 10 0 2 4 6 8 10
(a) Histogram based on 5000 samples (b) PMF

Figure 3.33: An example of a Poisson distribution with = 1.

[num, ~] = hist(X, 0:10);


bar(0:10, num, ‘FaceColor’,[0.4, 0.4, 0.8]);

# Python code to generate 5000 Poisson random variables


import numpy as np
import matplotlib.pyplot as plt
lambd = 1
X = np.random.poisson(lambd,size=5000)
plt.hist(X,bins=‘auto’);

For the PMF, in MATLAB we can call poisspdf, and in Python we can call rv.pmf
with rv = stats.poisson.

% MATLAB code to plot the Poisson PMF


lambda = 1;
x = 0:10;
f = poisspdf(x,lambda);
stem(x, f, ‘o’, ‘LineWidth’, 8, ‘Color’, [0.8, 0.4, 0.4]);

# Python code to plot the Poisson PMF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.arange(0,11)
rv = stats.poisson(lambd)
f = rv.pmf(x)
plt.plot(x, f, ‘bo’, ms=8, label=‘geom pmf’)
plt.vlines(x, 0, f, colors=‘b’, lw=5, alpha=0.5)

The shape of the Poisson PMF changes with . As illustrated in Figure 3.34, pX (k) is
more concentrated at lower values for smaller and becomes spread out for larger . Thus,
we should expect that the mean and variance of a Poisson random variable will change

153
CHAPTER 3. DISCRETE RANDOM VARIABLES

together as a function of . In the same figure, we show the CDF of a Poisson random
variable. The CDF of a Poisson is
k
X `
FX (k) = P[X  k] = e . (3.17)
`!
`=0

0.4 1
=1
=4
= 10 0.8
0.3

0.6
0.2
0.4

0.1
0.2 =1
=4
= 10
0 0
0 5 10 15 20 0 5 10 15 20

Figure 3.34: A Poisson random variable using di↵erent ’s. [Left] Probability mass function pX (k).
[Right] Cumulative distribution function FX (k).

Example 3.18. Let X be a Poisson random variable with parameter . Find P[X > 4]
and P[X  5].
Solution.
4
X k
P[X > 4] = 1 P[X  4] = 1 e ,
k!
k=0
5
X k
P[X  5] = e .
k!
k=0

Practice Exercise 3.11. Show that the Poisson PMF sums to 1.


Solution. We use the exponential series to prove this result:
1
X 1
X k 1
X k
pX (k) = e =e · = 1.
k! k!
k=0 k=0 k=0
| {z }
=e

Poisson random variables in practice


(1) Computational photography. In computational photography, the Poisson random vari-
able is one of the most widely used models for photon arrivals. The reason pertains to the

154
3.5. COMMON DISCRETE RANDOM VARIABLES

origin of the Poisson random variable, which we will discuss shortly. When photons are emit-
ted from the source, they travel through the medium as a sequence of independent events.
During the integration period of the camera, the photons are accumulated to generate a
voltage that is then translated to digital bits.

Figure 3.35: The Poisson random variable can be used to model photon arrivals.

If we assume that the photon arrival rate is ↵ (photons per second), and suppose that
the total amount of integration time is t, then the average number of photons that the sensor
can see is ↵t. Let X be the number of photons seen during the integration time. Then if we
follow the Poisson model, we can write down the PMF of X:

(↵t)k ↵t
P[X = k] = e .
k!
Therefore, if a pixel is bright, meaning that ↵ is large, then X will have a higher likelihood
of landing on a large number.
(2) Traffic model. The Poisson random variable can be used in many other problems. For
example, we can use it to model the number of passengers on a bus or the number of spam
phone calls. The required modification to Figure 3.35 is almost trivial: merely replace the
photons with your favorite cartoons, e.g., a person or a phone, as shown in Figure 3.36. In
the United States, shared-ride services such as Uber and Lyft need to model the vacant cars
and the passengers. As long as they have an arrival rate and certain degrees of independence
between events, the Poisson random variable will be a good model.
As you can see from these examples, the Poisson random variable has broad applica-
bility. Before we continue our discussion of its applications, let us introduce a few concepts
related to the Poisson random variable.

Properties of a Poisson random variable


We now derive the mean and variance of a Poisson random variable.

Theorem 3.9. If X ⇠ Poisson( ), then

E[X] = , E[X 2 ] = + 2
, (3.18)
Var[X] = .

155
CHAPTER 3. DISCRETE RANDOM VARIABLES

Figure 3.36: The Poisson random variable can be used to model passenger arrivals and the number of
phone calls, and can be used by Uber or Lyft to provide shared rides.

Proof. Let us first prove the mean. It can be shown that


1
X k 1
X k
E[X] = k· e = e
k! (k 1)!
k=0 k=1
1
X k 1 1
X `
= e = e = e e = .
(k 1)! `!
k=1 `=0

The second moment can be computed as


1
X k
E[X 2 ] = k2 · e
k!
k=0
X1 k
= k· e
(k 1)!
k=0
X1 k
= (k 1 + 1) · e
(k 1)!
k=0
X1 k 1
X k
= (k 1) · e + e
(k 1)! (k 1)!
k=1 k=1
1
X k 2 1
X k 1
2 e e
= · + · .
(k 2)! (k 1)!
k=2 k=1
| {z } | {z }
=1 =1

The variance can be computed using Var[X] = E[X ] 2


µ2 .

To compute the mean and variance of a Poisson random variable, we can call poisstat
in MATLAB and rv.stats(moments=‘mv’) in Python.
% MATLAB code to compute Poisson statistics
lambda = 1;
[M,V] = poisstat(lambda);

156
3.5. COMMON DISCRETE RANDOM VARIABLES

# Python code to compute Poisson statistics


import scipy.stats as stats
lambd = 1
rv = stats.poisson(lambd)
M, V = rv.stats(moments=’mv’)

The Poisson random variable is special in the sense that the mean and the variance are
equal. That is, if the mean arrival number is higher, the variance is also higher. This is very
di↵erent from some other random variables, e.g., the normal random variable where the mean
and variance are independent. For certain engineering applications such as photography, this
plays an important role in defining the signal-to-noise ratio. We will come back to this point
later.

Origin of the Poisson random variable


We now address one of the most important questions about the Poisson random variable:
Where does it come from? Answering this question is useful because the derivation process
will reveal the underlying assumptions that lead to the Poisson PMF. When you change
the problem setting, you will know when the Poisson PMF will hold and when the Poisson
PMF will fail.
Our approach to addressing this problem is to consider the photon arrival process.
(As we have shown, there is conceptually no di↵erence if you replace the photons with
pedestrians, passengers, or phone calls.) Our derivation follows the argument of J. Goodman,
Statistical Optics, Section 3.7.2.
To begin with, we consider a photon arrival process. The total number of photons
observed over an integration time t is defined as X(t). Because X(t) is a Poisson random
variable, its arguments must be integers. The probability of observing X(t) = k is therefore
P[X(t) = k]. Figure 3.37 illustrates the notations and concepts.

Figure 3.37: Notations for deriving the Poisson PMF.

We propose three hypotheses with the photon arrival process:


For sufficiently small t, the probability of a small impulse occurring in the time
interval [t, t + t] is equal to the product of t and the rate , i.e.,

P[X(t + t) X(t) = 1] = t.

This is a linearity assumption, which typically holds for a short duration of time.

157
CHAPTER 3. DISCRETE RANDOM VARIABLES

For sufficiently small t, the probability that more than one impulse falls in t is
negligible. Thus, we have that P[X(t + t) X(t) = 0] = 1 t.
The number of impulses in non-overlapping time intervals is independent.
The significance of these three hypotheses is that if the underlying photon arrival process
violates any of these assumptions, then the Poisson PMF will not hold. One example is the
presence of scattering e↵ects, where a photon has a certain probability of going o↵ due to
the scattering medium and a certain probability of coming back. In this case, the events will
no longer be independent.
Assuming that these hypotheses hold, then at time t + t, the probability of observing
X(t + t) = k can be computed as

P[X(t + t) = k]
= P[X(t) = k] · (1 t) + P[X(t) = k 1] · ( t)
| {z } | {z }
=P[X(t+ t) X(t)=0] =P[X(t+ t) X(t)=1]

= P[X(t) = k] P[X(t) = k] t + P[X(t) = k 1] t.

By rearranging the terms we show that


✓ ◆
P[X(t + t) = k] P[X(t) = k]
= P[X(t) = k 1] P[X(t) = k] .
t
Setting the limit of t ! 0, we arrive at an ordinary di↵erential equation
✓ ◆
d
P[X(t) = k] = P[X(t) = k 1] P[X(t) = k] . (3.19)
dt
We claim that the Poisson PMF, i.e.,
( t)k t
P[X(t) = k] = e ,
k!
would solve this di↵erential equation. To see this, we substitute the PMF into the equation.
The left-hand side gives us
✓ ◆
d d ( t)k
P[X(t) = k] = e t
dt dt k!
( t)k 1 t ( t)k t
= k e +( ) e
k! k!
( t)k 1 t ( t)k t
= e e
✓ k! k! ◆
= P[X(t) = k 1] P[X(t) = k] ,

which is the right-hand side of the equation. To retrieve the basic form of Poisson, we can
just set t = 1 in the PMF so that
k
P[X(1) = k] = e .
k!

158
3.5. COMMON DISCRETE RANDOM VARIABLES

The origin of Poisson random variables


We assume independent arrivals.
Probability of seeing one event is linear with the arrival rate.
Time interval is short enough so that you see either one event or no event.
Poisson is derived by solving a di↵erential equation based on these assumptions.
Poisson becomes invalid when these assumptions are violated, e.g., in the case
of scattering of photons due to turbid medium.

There is an alternative approach to deriving the Poisson PMF. The idea is to drive
the parameter n in the binomial random variable to infinity while pushing p to zero. In this
limit, the binomial PMF will converge to the Poisson PMF. We will discuss this shortly.
However, we recommend the physics approach we have just described because it has a rich
meaning and allows us to validate our assumptions.

Poisson approximation to binomial


We present one additional result about the Poisson random variable. The result shows that
Poisson can be regarded as a limiting distribution of a binomial random variable.

Theorem 3.10. (Poisson approximation to binomial). For small p and large n,


✓ ◆ k
n k
p (1 p)n k ⇡ e ,
k k!
def
where = np.

Before we prove the result, let us see how close the approximation can be. In Figure 3.38,
we show a binomial distribution and a Poisson approximation. The closeness of the approx-
imation can easily be seen.
In MATLAB, the code to approximate a binomial distribution with a Poisson formula
is shown below. Here, we draw 10,000 random binomial numbers and plot their histogram.
On top of the plot, we use poisspdf to compute the Poisson PMF. This gives us Figure 3.38.
A similar set of commands can be called in Python.

% MATLAB code to approximate binomial using Poisson


n = 1000; p = 0.05;
X = binornd(n,p,[10000,1]);
t = 0:100;
[num,val] = hist(X,t);
lambda = n*p;
f_pois = poisspdf(t,lambda);
bar(num/10000,‘FaceColor’,[0.9 0.9 0],‘BarWidth’,1); hold on;
plot(f_pois, ‘LineWidth’, 4);

159
CHAPTER 3. DISCRETE RANDOM VARIABLES

0.06
Binomial, n = 5000, p = 0.01
Poisson, = 50
Probability

0.04

0.02

0
0 20 40 60 80 100 120
k
Figure 3.38: Poisson approximation of binomial distribution.

# Python code to approximate binomial using Poisson


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
n = 1000; p = 0.05
rv1 = stats.binom(n,p)
X = rv1.rvs(size=10000)
plt.figure(1); plt.hist(X,bins=np.arange(0,100));
rv2 = stats.poisson(n*p)
f = rv2.pmf(bin)
plt.figure(2); plt.plot(f);

Proof. Let = np. Then,


✓ ◆ ✓ ◆k ✓ ◆n k
n k n!
p (1 p)n k = 1
k k!(n k)! n n
k
✓ ◆n k
1) · · · (n k + 1)
n(n
= 1
k! n · n···n n
k
✓ ◆ ✓ ◆✓ ◆ k✓ ◆n
1 k 1
= (1) 1 ··· 1 1 1
k! n n n n
| {z }| {z }
!1 as n!1 !1 as n!1
k
✓ ◆n
= 1 .
k! n
n
We claim that 1 n !e . This can be proved by noting that

log(1 + x) ⇡ x, x ⌧ 1.
n
It then follows that log 1 n ⇡ n. Hence, 1 n ⇡e

160
3.5. COMMON DISCRETE RANDOM VARIABLES

Example 3.19. Consider an optical communication system. The bit arrival rate is 109
bits/sec, and the probability of having one error bit is 10 9 . Suppose we want to find
the probability of having five error bits in one second.

Let X be the number of error bits. In one second there are 109 bits. Since we
do not know the location of these 5 bits, we have to enumerate all possibilities. This
leads to a binomial distribution. Using the binomial distribution, we know that the
probability of having k error bits is
✓ ◆
n k
P[X = k] = p (1 p)n k
k
✓ 9◆
10 9
= (10 9 )k (1 10 9 )10 k .
k

This quantity is difficult to calculate in floating-point arithmetic.

Using the Poisson to binomial approximation, we can see that the probability can
be approximated by
k
P[X = k] ⇡ e ,
k!
where = np = 109 (10 9
) = 1. Setting k = 5 yields P[X = 5] ⇡ 0.003.

Photon arrival statistics

Poisson random variables are useful in computer vision, but you may skip this discussion
if it is your first reading of the book.

The strong connection between Poisson statistics and physics makes the Poisson ran-
dom variable a very good fit for many physical experiments. Here we demonstrate an appli-
cation in modeling photon shot noise.
An image sensor is a photon sensitive device which is used to detect incoming photons.
In the simplest setting, we can model a pixel in the object plane as Xm,n , for some 2D
coordinate [m, n] 2 R2 . Written as an array, an M ⇥ N image in the object plane can be
visualized as 2 3
X1,1 X1,2 · · · X1,N
6 .. 7 .
X = object = 4 ... ..
.
..
. . 5
XM,1 XM,2 ··· XM,N
Without loss of generality, we assume that Xm,n is normalized so that 0  Xm,n  1 for
every coordinate [m, n]. To model the brightness, we multiply Xm,n by a scalar ↵ > 0. If
a pixel ↵Xm,n has a large value, then it is a bright pixel; conversely, if ↵Xm,n has a small
value, then it is a dark pixel. At a particular pixel location [m, n] 2 R2 , the observed pixel
value Ym,n is a random variable following the Poisson statistics. This situation is illustrated

161
CHAPTER 3. DISCRETE RANDOM VARIABLES

in Figure 3.39, where we see that an object-plane pixel will generate an observed pixel
through the Poisson PMF.1

Figure 3.39: The image formation process is governed by the Poisson random variable. Given a pixel
in the object plane Xm,n , the observed pixel Ym,n is a Poisson random variable with mean ↵Xm,n .
Therefore, a brighter pixel will have a higher Poisson mean, whereas a darker pixel will have a lower
Poisson mean.

Written as an array, the image is



Y = observed image = Poisson ↵X
2 3
Poisson{↵X1,1 } Poisson{↵X1,2 } ··· Poisson{↵X1,N }
6 Poisson{↵X2,1 } Poisson{↵X2,2 } ··· Poisson{↵X2,N } 7
6 7
=6 .. .. .. .. 7.
4 . . . . 5
Poisson{↵XM,1 } Poisson{↵XM,2 } ··· Poisson{↵XM,N }

Here, by Poisson{↵Xm,n } we mean that Ym,n is a random integer with probability mass

[↵Xm,n ]k ↵Xm,n
P[Ym,n = k] = e .
k!

Note that this model implies that the images seen by our cameras are more or less
an array of Poisson random variables. (We say “more or less” because of other sources of
uncertainties such as read noise, dark current, etc.) Because the observed pixels Ym,n are
random variables, they fluctuate about the mean values, and hence they are noisy. We refer
to this type of random fluctuation as the shot noise. The impact of the shot noise can be
seen in Figure 3.40. Here, we vary the sensor gain level ↵. We see that for small ↵ the image
is dark and has much random fluctuation. As ↵ increases, the image becomes brighter and
the fluctuation becomes smaller.
In MATLAB, simulating the Poisson photon arrival process for an image requires the
image-processing toolbox. The command to read an image is imread. Depending on the data
type, the input array could be unit8 integers. To convert them to floating-point numbers
between 0 and 1, we use the command im2double. Drawing Poisson measurements from the
clean image is done using poissrnd. Finally, we can use imshow to display the image.

% MATLAB code to simulate a photon arrival process


x0 = im2double(imread(’cameraman.tif’));
1 The color of an image is often handled by a color filter array, which can be thought of as a wavelength

selector that allows a specific wavelength to pass through.

162
3.5. COMMON DISCRETE RANDOM VARIABLES

= 10 = 100 = 1000

Figure 3.40: Illustration of the Poisson random variable in photographing images. Here, ↵ denotes the
gain level of the sensor: Larger ↵ means that there are more photons coming to the sensor.

X = poissrnd(10*x0);
figure(1); imshow(x0, []);
figure(2); imshow(X, []);

Similar commands can be found in Python with the help of the cv2 library. When
reading an image, we call cv2.imread. The option 0 is used to read a gray-scale image;
otherwise, we will have a 3-channel color image. The division /255 ensures that the input
array ranges between 0 to 1. Generating the Poisson random numbers can be done using
np.random.poisson, or by calling the statistics library with stats.poisson.rvs(10*x0).
To display the images, we call plt.imshow, with the color map option set to cmap = ’gray’.

# Python code code to simulate a photon arrival process


import numpy as np
import matplotlib.pyplot as plt
import cv2
x0 = cv2.imread(’./cameraman.tif’, 0)/255
plt.figure(1); plt.imshow(x0,cmap=’gray’);
X = np.random.poisson(10*x0)
plt.figure(2); plt.imshow(X, cmap=’gray’);

Why study Poisson? What is shot noise?


The Poisson random variable is used to model photon arrivals.
Shot noise is the random fluctuation of the photon counts at the pixels. Shot
noise is present even if you have an ideal sensor.

Signal-to-noise ratio of Poisson


Now let us answer a question we asked before. A Poisson random variable has a variance
equal to the mean. Thus, if the scene is brighter, the variance will be larger. How come our
simulation in Figure 3.40 shows that the fluctuation becomes smaller as the scene becomes
brighter?

163
CHAPTER 3. DISCRETE RANDOM VARIABLES

The answer to this question lies in the signal-to-noise ratio (SNR) of the Poisson
random variable. The SNR of an image defines its quality. The higher the SNR, the better
the image. The mathematical definition of SNR is the ratio between the signal power and
the noise power. In our case, the SNR is

signal power def E[Y ] (a) p


SNR = = p = p = ,
noise power Var[Y ]

where Y = Ym,n is one of the observed pixels and = ↵Xm,n is the the corresponding object
pixel. In this equation, the step (a) uses the properties
p of the Poisson random variable Y
where E[Y ] = Var[Y ] = . The result SNR = is very informative. It says that if p
the
underlying mean photon flux (which is ) increases, the SNR increases at a rate of .
So, yes, the variance becomes larger
p when the scene is brighter. However, the gain in signal
E[Y ] overrides the gain in noise Var[Y ]. As a result, the big fluctuation in bright images
is compensated by the strong signal. Thus, to minimize the shot noise one has to use a
longer exposure to increase the mean photon flux. When the scene is dark and the aperture
is small, shot noise is unavoidable.
Poisson modeling is useful for describing the problem. However, the actual engineering
question is that, given a noise observation Ym,n , how would you reconstruct the clean image
Xm,n ? This is a very difficult inverse problem. The typical strategy is to exploit the spatial
correlations between nearby pixels, e.g., usually smooth except along some sharp edges.
Other information about the image, e.g., the likelihood of obtaining texture patterns, can
also be leveraged. Modern image-processing methods are rich, ranging from classical filtering
techniques to deep neural networks. Static images are easier to recover because we can often
leverage multiple measurements of the same scene to boost the SNR. Dynamic scenes are
substantially harder when we need to track the motion of any underlying objects. There are
also newer image sensors with better photon sensitivity. The problem of imaging in the dark
is an important research topic in computational imaging. New solutions are developed at
the intersection of optics, signal processing, and machine learning.

The end of our discussions on photon statistics.

3.6 Summary

A random variable is so called because it can take more than one state. The probability mass
function specifies the probability for it to land on a particular state. Therefore, whenever
you think of a random variable you should immediately think of its PMF (or histogram
if you prefer). The PMF is a unique characterization of a random variable. Two random
variables with the same PMF are e↵ectively the same random variables. (They are not
identical because there could be measure-zero sets where the two di↵er.) Once you have the
PMF, you can derive the CDF, expectation, moments, variance, and so on.
When your boss hands a dataset to you, which random variable (which model) should
you use? This is a very practical and deep question. We highlight three steps for you to
consider:

164
3.7. REFERENCES

(i) Model selection: Which random variable is the best fit for our problem? Some-
times we know by physics that, for example, photon arrivals or internet traffic follow a
Poisson random variable. However, not all datasets can be easily described by simple
models. The models we have learned in this chapter are called the parametric mod-
els because they are characterized by one or two parameters. Some datasets require
nonparametric models, e.g., natural images, because they are just too complex. Some
data scientists refer to deep neural networks as parametric models because the net-
work weights are essentially the parameters. Some do not because when the number
of parameters is on the order of millions, sometimes even more than the number of
training samples, it seems more reasonable to call these models nonparametric. How-
ever, putting this debate aside, shortlisting a few candidate models based on prior
knowledge is essential. Even if you use deep neural networks, selecting between con-
volutional structures versus long short-term memory models is still a legitimate task
that requires an understanding of your problem.
(ii) Parameter estimation: Suppose that you now have a candidate model; the next
task is to estimate the model parameter using the available training data. For example,
for Poisson we need to determine , and for binomial we need to determine (n, p). The
estimation problem is an inverse problem. Often we need to use the PMF to construct
certain optimization problems. By solving the optimization problem we will find the
best parameter (for that particular candidate model). Modern machine learning is
doing significantly better now than in the old days because optimization methods
have advanced greatly.
(iii) Validation. When each candidate model has been optimized to best fit the data,
we still need to select the best model. This is done by running various testings. For
example, we can construct a validation set and check which model gives us the best
performance (such as classification rate or regression error). However, a model with
the best validation score is not necessarily the best model. Your goal should be to seek
a good model and not the best model because determining the best requires access to
the testing data, which we do not have. Everything being equal, the common wisdom
is to go with a simpler model because it is generally less susceptible to overfitting.

3.7 References

Probability textbooks
3-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 2.
3-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 3.
3-3 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapters 3 and 4.
3-4 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 2 and3.

165
CHAPTER 3. DISCRETE RANDOM VARIABLES

3-5 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chap-
ter 4.
3-6 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapters 2 and 4.

Advanced probability textbooks


3-7 William Feller, An Introduction to Probability Theory and Its Applications, Wiley and
Sons, 3rd Edition, 1950.
3-8 Andrey Kolmogorov, Foundations of the Theory of Probability, 2nd English Edition,
Dover 2018. (Translated from Russian to English. Originally published in 1950 by
Chelsea Publishing Company New York.)

Cross-validation
3-9 Larry Wasserman, All of Statistics, Springer 2004. Chapter 20.
3-10 Mats Rudemo, “Empirical Choice of Histograms and Kernel Density Estimators,”
Scandinavian Journal of Statistics, Vol. 9, No. 2 (1982), pp. 65-78.
3-11 David W. Scott, Multivariate Density Estimation: Theory, Practice, and Visualization,
Wiley, 1992.

Poisson statistics
3-12 Joseph Goodman, Statistical Optics, Wiley, 2015. Chapter 3.
3-13 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd edition, 2001. Section 1.10.

3.8 Problems

Exercise 1. (Video Solution)


Consider an information source that produces numbers k in the set SX = {1, 2, 3, 4}. Find
and plot the PMF in the following cases:
(a) pk = p1 /k, for k = 1, 2, 3, 4. Hint: Find p1 .
(b) pk+1 = pk /2 for k = 1, 2, 3.
(c) pk+1 = pk /2k for k = 1, 2, 3.
(d) Can the random variables in parts (a)-(c) be extended to take on values in the set
{1, 2, . . .}? Why or why not? Hint: You may use the fact that the series 1 + 12 + 13 + · · ·
diverges.

Exercise 2. (Video Solution)


Two dice are tossed. Let X be the absolute di↵erence in the number of dots facing up.

166
3.8. PROBLEMS

(a) Find and plot the PMF of X.


(b) Find the probability that X  2.
(c) Find E[X] and Var[X].

Exercise 3. (Video Solution)


Let X be a random variable with PMF pk = c/2k for k = 1, 2, . . ..
(a) Determine the value of c.
(b) Find P(X > 4) and P(6  X  8).

(c) Find E[X] and Var[X].

Exercise 4.
Let X be a random variable with PMF pk = c/2k for k = 1, 0, 1, 2, 3, 4, 5.

(a) Determine the value of c.


(b) Find P(1  X < 3) and P(1 < X  5).
(c) Find P[X 3 < 5].
(d) Find the PMF and the CDF of X.

Exercise 5. (Video Solution)


A modem transmits a +2 voltage signal into a channel. The channel adds to this sig-
nal a noise term that is drawn from the set {0, 1, 2, 3} with respective probabilities
{4/10, 3/10, 2/10, 1/10}.

(a) Find the PMF of the output Y of the channel.


(b) What is the probability that the channel’s output is equal to the input of the channel?
(c) What is the probability that the channel’s output is positive?
(d) Find the expected value and variance of Y .

Exercise 6.
On a given day, your golf score takes values from numbers 1 through 10, with equal proba-
bility of getting each one. Assume that you play golf for three days, and assume that your
three performances are independent. Let X1 , X2 , and X3 be the scores that you get, and
let X be the minimum of these three numbers.
(a) Show that for any discrete random variable X, pX (k) = P(X > k 1) P(X > k).
(b) What is the probability P(X1 > k) for k = 1, . . . , 10?
(c) Use (a), determine the PMF pX (k), for k = 1, . . . , 10.

167
CHAPTER 3. DISCRETE RANDOM VARIABLES

(d) What is the average score improvement if you play just for one day compared with
playing for three days and taking the minimum?

Exercise 7. (Video Solution)


Let ( (
1, if X > 10 X 10, if X 10 > 0
g(X) = and h(X) =
0, otherwise. 0, otherwise.

(a) Find E[g(X)] for X as in Problem 1(a) with SX = {1, . . . , 15}.

(b) Find E[h(X)] for X as in Problem 1(b) with SX = {1, . . . , 15}.

Exercise 8. (Video Solution)


A voltage X is uniformly distributed in the set { 3, . . . , 3, 4}.
(a) Find the mean and variance of X.

(b) Find the mean and variance of Y = 2X 2 + 3.


(c) Find the mean and variance of W = cos(⇡X/8).
(d) Find the mean and variance of Z = cos2 (⇡X/8).

Exercise 9. (Video Solution)


(a) If X is Poisson( ), compute E[1/(X + 1)].
(b) If X is Bernoulli(p) and Y is Bernoulli(q), compute E[(X + Y )3 ] if X and Y are
independent.

(c) Let X be a random variable with mean µ and variance 2


. Let (✓) = E[(X ✓)2 ].
Find ✓ that minimizes the error (✓).
(d) Suppose that X1 , . . . , Xn are independent uniform random variables in {0, 1, . . . , 100}.
Evaluate P[min(X1 , . . . , Xn ) > `] for any ` 2 {0, 1, . . . , 100}.

Exercise 10. (Video Solution)


n
(a) Consider the binomial probability mass function pX (k) = k pk (1 p)n k
. Show that
the mean is E[X] = np.
(b) Consider the geometric probability mass function pX (k) = p(1 p)k for k = 0, 1, . . ..
Show that the mean is E[X] = (1 p)/p.
k
(c) Consider the Poisson probability mass function pX (k) = k! e . Show that the vari-
ance is Var[X] = .
(d) Consider the uniform probability mass function pX (k) = L1 for k = 1, . . . , L. Show that
2
the variance is Var[X] = L 12 1 . Hint: 1 + 2 + · · · + n = n(n+1)
2 and 12 + 22 + · · · + n2 =
3 2
n n n
3 + 2 + 6.

168
3.8. PROBLEMS

Exercise 11. (Video Solution)


An audio player uses a low-quality hard drive. The probability that the hard drive fails after
being used for one month is 1/12. If it fails, the manufacturer o↵ers a free-of-charge repair
for the customer. For the cost of each repair, however, the manufacturer has to pay 20.
The initial cost of building the player is 50, and the manufacturer o↵ers a 1-year warranty.
Within one year, the customer can ask for a free repair up to 12 times.
(a) Let X be the number of months when the player fails. What is the PMF of X? Hint:
P[X = 1] may not be very high because if the hard drive fails it will be fixed by the
manufacturer. Once fixed, the drive can fail again in the remaining months. So saying
X = 1 is equivalent to saying that there is only one failure in the entire 12-month
period.

(b) What is the average cost per player?

Exercise 12. (Video Solution)


A binary communication channel has a probability of bit error of p = 10 6 . Suppose that
transmission occurs in blocks of 10,000 bits. Let N be the number of errors introduced by
the channel in a transmission block.
(a) What is the PMF of N ?
(b) Find P[N = 0] and P[N  3].

(c) For what value of p will the probability of 1 or more errors in a block be 99%?
Hint: Use the Poisson approximation to binomial random variables.

Exercise 13. (Video Solution)


The number of orders waiting to be processed is given by a Poisson random variable with
parameter ↵ = /nµ, where is the average number of orders that arrive in a day, µ is the
number of orders that an employee can process per day, and n is the number of employees.
Let = 5 and µ = 1. Find the number of employees required so the probability that more
than four orders are waiting is less than 10%.
Hint: You need to use trial and error for a few n’s.

Exercise 14.
Let X be the number of photons counted by a receiver in an optical communication system.
It is known that X is a Poisson random variable with a rate 1 when a signal is present and a
Poisson random variable with the rate 0 < 1 when a signal is absent. The probability that
the signal is present is p. Suppose that we observe X = k photons. We want to determine a
threshold T such that if k T we claim that the signal is present, and if k < T we claim
that the signal is absent. What is the value of T ?

169
CHAPTER 3. DISCRETE RANDOM VARIABLES

170
Chapter 4

Continuous Random Variables

If you are coming to this chapter from Chapter 3, we invite you to take a 30-second pause
and switch your mind from discrete events to continuous events. Everything is continuous
now. The sample space is continuous, the event space is continuous, and the probability
measure is continuous. Continuous random variables are similar in many ways to discrete
random variables. They are characterized by the probability density functions (the continu-
ous version of the probability mass functions); they have cumulative distribution functions;
they have means, moments, and variances. The most significant di↵erence is perhaps the use
of integration instead of summation, but this change is conceptually straightforward, aside
from the difficulties associated with integrating functions. So why do we need a separate
chapter for continuous random variables? There are several reasons.
First, how would you define the probability of a continuous event? Note that we cannot
count because a continuous event is uncountable. There is also nothing called the
probability mass because there are infinitely many masses. To define the probability
of continuous events, we need to go back to our “slogan”: probability is a measure
of the size of a set. Because probability is a measure, we can speak meaningfully
about the probability of continuous events so long as we have a well-defined measure
for them. Defining such a measure requires some e↵ort. We will develop the intuitions
and the formal definitions in Section 4.1. In Section 4.2, we will discuss the expectation
and variance of continuous random variables.
The second challenge is the unification between continuous and discrete random vari-
ables. Since the two types of random variables ultimately measure the size of a set, it
is natural to ask whether we can unify them. Our approach to unifying them is based
on the cumulative distribution functions (CDFs), which are well-defined functions for
discrete and continuous random variables. Based on the CDF and the fundamental
theorem of calculus, we can show that the probability density functions and proba-
bility mass functions can be derived from the derivative of the CDFs. These will be
discussed in Section 4.3, and in Section 4.4 we will discuss some additional results
about the mode and median.
The third challenge is to understand several widely used continuous random variables.
We will discuss the uniform random variable and the exponential random variable
in Section 4.5. Section 4.6 deals with the important topic of the Gaussian random
variable. Where does a Gaussian random variable come from? Why does it have a bell

171
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

shape? Why are Gaussian random variables so popular in data science? What are the
useful properties of Gaussian random variables? What are the relationships between
a Gaussian random variable and other random variables? These important questions
will be answered in Section 4.6.
The final challenge is the transformation of random variables. Imagine that you have a
random variable X and a function g. What will the probability mass/density function
of g(X) be? Addressing this problem is essential because almost all practical engineer-
ing problems involve the transformation of random variables. For example, suppose
we have voltage measurements and we would like to compute the power. This requires
taking the square of the voltage. We will discuss the transformation in Section 4.7,
and we will also discuss an essential application in generating random numbers in
Section 4.8.

4.1 Probability Density Function

4.1.1 Some intuitions about probability density functions


Let’s begin by outlining some intuitive reasoning, which is needed to define the probability
of continuous events properly. These intuitions are based on the fact that probability is a
measure. In the following discussion you will see a sequence of logical arguments for con-
structing such a measure for continuous events. Some arguments are discussed in Chapter 2,
but now we place them in the context of continuous random variables.
Suppose we are given an event A that is a subset in the sample space ⌦, as illustrated
in Figure 4.1. In order to calculate the probability of A, the measure perspective suggests
that we consider the relative size of the set
“size” of A
P[{x 2 A}] = .
“size” of ⌦
The right-hand side of this equation captures everything about the probability: It is a
measure of the size of a set. It is relative to the sample space. It is a number between 0 and
1. It can be applied to discrete sets, and it can be applied to continuous sets.

Figure 4.1: [Left] An event A in the sample space ⌦. The probability that A happens can be calculated
as the “size” of A relative to the “size” of ⌦. [Right] A specific example on the real line. Note that the
same definition of probability applies: The probability is the size of the interval A relative to that of the
sample space ⌦.

172
4.1. PROBABILITY DENSITY FUNCTION

How do we measure the “size” of a continuous set? One possible way is by means of
integrating the length, area, or volume covered by the set. Consider an example: Suppose
that the sample space is the interval ⌦ = [0, 5] and the event is A = [2, 3]. To measure the
“size” of A, we can integrate A to determine the length. That is,
R R3
“size” of A dx dx 1
P[{x 2 [2, 3]}] = = R A
= R25 = .
“size” of ⌦ ⌦
dx dx 5
0

Therefore, we have translated the “size” of a set to an integration. However, this definition
is a very special case because when we calculate the “size” of a set, we treat all the elements
in the set with equal importance. This is a strong assumption that will be relaxed later. But
if you agree with this line of reasoning, we can rewrite the probability as
R R
dx dx
P[{x 2 A}] = RA = A

dx |⌦|
Z
1
= dx.
A |⌦|
| {z }
equally important over ⌦

This equation says that under our assumption (that all elements are equiprobable), the
probability of A is calculated as the integration of A using an integrand 1/|⌦| (note that
1/|⌦| is a constant with respect to x). If we evaluateR the probability of another event B, all
1
we need to do is to replace A with B and compute B |⌦| dx.
What happens if we want to relax the “equiprobable” assumption? Perhaps we can
adopt something similar to the probability mass function (PMF). Recall that a PMF pX
evaluated at a point x is the probability that the state x happens, i.e., pX (x) = P[X = x].
So, pX (x) is the relative frequency of x. Following the same line of thinking, we can define a
function fX such that fX (x) tells us something related to the “relative frequency”. To this
end, we can treat fX as a continuous histogram with infinitesimal bin width as shown in
Figure 4.2. Using this fX , we can replace the constant function 1/|⌦| with the new function
fX (x). This will give us Z
P[{x 2 A}] = fX (x) dx. (4.1)
A | {z }
replace 1/|⌦|

If we compare it with a PMF, we note that when X is discrete,


X
P[{x 2 A}] = pX (x).
x2A

Hence, fX can be considered a continuous version of pX , although we do not recommend


this way of thinking for the following reason: pX (x) is a legitimate probability, but fX (x) is
not a probability. Rather, fX is the probability per unit length, meaning that we need to
integrate fX (times dx) in order to generate a probability value. If we only look at fX at
a point x, then this point is a measure-zero set because the length of this set is zero.
Equation (4.1) should be familiar to you from Chapter 2. The function fX (x) is pre-
cisely the weighting function we described in that chapter.

173
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Figure 4.2: [Left] A probability mass function (PMF) tells us the relative frequency of a state when
computing the probability. In this example, the “size” of A is pX (x2 ) + pX (x3 ). [Right] A probability
density function (PDF) is the infinitesimal version of the PMF. Thus, the “size” of A is the integration
over the PDF.

What is a PDF?
A PDF is the continuous version of a PMF.
We integrate a PDF to compute the probability.
We integrate instead of sum because continuous events are not countable.

To summarize, we have learned that when measuring the size of a continuous event,
the discrete technique (counting the number of elements) does not work. Generalizing to
continuous space requires us to integrate the event. However, since di↵erent elements in an
event have di↵erent relative emphases, we use the probability density function fX (x) to tell
us the relative frequency for a state x to happen. This PDF serves the role of the PMF.

4.1.2 More in-depth discussion about PDFs


A continuous random variable X is defined by its probability density function fX . This
function has to satisfy several criteria, summarized as follows.

Definition 4.1. A probability density function fX of a random variable X is a map-


ping fX : ⌦ ! R, with the properties

Non-negativity: fX (x) 0 for all x 2 ⌦


R
Unity: ⌦ fX (x) dx = 1
R
Measure of a set: P[{x 2 A}] = A
fX (x) dx

If all elements of the sample space are equiprobable, then the PDF is f (x) = 1/|⌦|. You can
easily check that it satisfies all three criteria.
Let us take a closer look at the three criteria:
Non-negativity: The non-negativity criterion fX (x) 0 is reminiscent of Probability
Axiom I. It says that no matter what x we are looking at, the probability density
function fX evaluated at x should never give a negative value. Axiom I ensures that
we will not get a negative probability.

174
4.1. PROBABILITY DENSITY FUNCTION

R
Unity: The unity criterion ⌦ f (x) dx = 1 is reminiscent of Probability Axiom II,
which says that measuring over the entire sample space will give 1.
Measure of a set: The third criterion gives us a way to measure the size of an event A.
It says that since each x 2 ⌦ has a di↵erent emphasis when calculating the size of
A, we need to scale the elements properly. This scaling is done by the PDF fX (x),
which can be regarded as a histogram with a continuous x-axis. The third criterion
is a consequence of Probability Axiom III, becauseR if there are Rtwo events A and B
that are disjoint, then P[{x 2 A} [ {x 2 B}] = A fX (x) dx + B fX (x) dx because
fX (x) 0 for all x.
If the random variable X takes real numbers in 1D, then a more “user-friendly” definition
of the PDF can be given.

Definition 4.2. Let X be a continuous random variable. The probability density


function (PDF) of X is a function fX : ⌦ ! R that, when integrated over an interval
[a, b], yields the probability of obtaining a  X  b:
Z b
P[a  X  b] = fX (x) dx. (4.2)
a

This definition is just a rewriting of the previous definition by explicitly writing out
the definition of A as an interval [a, b]. Here are a few examples.

Example 4.1. Let fX (x) = 3x2 with ⌦ = [0, 1]. Let A = [0, 0.5]. Then the probability
P[{X 2 A}] is
Z 0.5
1
P[0  X  0.5] = 3x2 dx = .
0 8

Example 4.2. Let fX (x) = 1/|⌦| with ⌦ = [0, 5]. Let A = [3, 5]. Then the probability
P[{X 2 A}] is
Z 5 Z 5
1 1 2
P[3  X  5] = dx = dx = .
3 |⌦| 3 5 5

Example 4.3. Let fX (x) = 2x with ⌦ = [0, 1]. Let A = {0.5}. Then the probability
P[{X 2 A}] is
Z 0.5
P[X = 0.5] = P[0.5  X  0.5] = 2x dx = 0.
0.5

This example shows that evaluating the probability at an isolated point for a contin-
uous random variable will yield 0.

175
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Practice Exercise 4.1. Let X be the phase angle of a voltage signal. Without any
prior knowledge about X we may assume that X has an equal probability of any value
between 0 to 2⇡. Find the PDF of X and compute P[0  X  ⇡/2].

Solution. Since X has an equal probability for any value between 0 to 2⇡, the PDF
of X is
1
fX (x) = , for 0  x  2⇡.
2⇡
Therefore, the probability P[0  X  ⇡/2] can be computed as
h Z
⇡i ⇡/2
1 1
P 0X = dx = .
2 0 2⇡ 4

Looking at Equation (4.2), you may wonder: If the PDF fX is analogous to PMF
pX , why didn’t we require 0  fX (x)  1 instead of requiring only fX (x) 0? This is
an excellent question, and it points exactly to the di↵erence between a PMF and a PDF.
Notice that fX is a mapping from the sample space ⌦ to the real line R. It does not map
⌦ to [0, 1]. On the other hand, since pX (x) is the actual probability, it maps ⌦ to [0, 1].
Thus, fX (x)R can take very large values but will not explode, because we have the unity
constraint ⌦ fX (x) dx = 1. Even if fX (x) takes a large value, it will be compensated by the
small dx. If you recall, there is nothing like dx in the definition of a PMF. Whenever there
is a probability mass, we need to sum or, putting it another way, the dx in the discrete case
is always 1. Therefore, while the probability mass PMF must not exceed 1, a probability
density PDF can exceed 1.
If fX (x) 1, then what is the meaning of fX (x)? Isn’t it representing the probability
of having an element X = x? If it were a discrete random variable, then yes; pX (x) is the
probability of having X = x (so the probability mass cannot go beyond 1). However, for a
continuous random variable, fX (x) is not the probability of having X = x. The probability
of having X = x (i.e., exactly at x) is 0 because an isolated point has zero measure in the
continuous space. Thus, even though fX (x) takes a value larger than 1, the probability of
X being x is zero.
At this point you can see why we call PDF a density, or density function, because each
value fX (x) is the probability per unit length. If we want to calculate the probability of
x  X  x + , for example, then according to our definition, we have
Z x+
P[x  X  x + ] = fX (x) dx ⇡ fX (x) · .
x

Therefore, the probability of P[x  X  x + ] can be regarded as the “per unit length”
density fX (x) multiplied with the “length” . As ! 0, we can see that P[X = x] = 0. See
Figure 4.3 for an illustration.

Why are PDFs called a density function?


Because fX (x) is the probability per unit length.
You need to integrate fX (x) to obtain a probability.

176
4.1. PROBABILITY DENSITY FUNCTION

Figure 4.3: The probability P[x  X  x + ] can be approximated by the density fX (x) multiplied by
the length .

1
Example 4.4. Consider a random variable X with PDF fX (x) = 2p x
for any
0 < x  1, and is 0 otherwise. We can show that fX (x) ! 1 as x ! 0. However,
fX (x) remains a valid PDF because
Z 1 Z 1 1
1 p
fX (x) dx = p dx = x = 1.
1 0 2 x 0

Remark. Since isolated points have zero measure in the continuous space, the probability
of an open interval (a, b) is the same as the probability of a closed interval:

P[[a, b]] = P[(a, b)] = P[(a, b]] = P[[a, b)].

The exception is that when the PDF of fX (x) has a delta function at a or b. In this case,
the probability measure at a or b will be non-zero. We will discuss this when we talk about
the CDFs.

Practice Exercise 4.2. Let fX (x) = c(1 x2 ) for 1  x  1, and 0 otherwise. Find
the constant c.
R
Solution. Since ⌦ fX (x) dx = 1, it follows that
Z Z 1
4c
fX (x) dx = c(1 x2 ) dx = ) c = 3/4.
⌦ 1 3

Practice Exercise 4.3. Let fX (x) = x2 for |x|  a, and 0 otherwise. Find a.
Solution. Note that
Z Z a a
x3 2a3
fX (x) dx = x2 dx = = .
⌦ a 3 a 3
q
2a3 3 3
Setting 3 = 1 yields a = 2.

177
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

4.1.3 Connecting with the PMF


The probability density function is more general than the probability mass function. To see
this, consider a discrete random variable X with a PMF pX (x). Because pX is defined on
a countable set ⌦, we can write it as a train of delta functions and define a corresponding
PDF: X
fX (x) = pX (xk ) (x xk ).
xk 2⌦

Example 4.5. If X is a Bernoulli random variable with PMF pX (1) = p and pX (0) =
1 p, then the corresponding PDF can be written as

fX (x) = p (x 1) + (1 p) (x 0).

n
Example 4.6. If X is a binomial random variable with PMF pX (k) = k pk (1 p)n k
,
then the corresponding PDF can be written as
n
X
fX (x) = pX (k) (x k)
k=0
Xn ✓ ◆
n k
= p (1 p)n k
(x k).
k
k=0

Strictly speaking, delta functions are not really functions. They are defined through
integrations. They satisfy the properties that (x xk ) = 1 if x = xk , (x xk ) = 0 if
x 6= xk , and Z xk +✏
(x xk ) dx = 1,
xk ✏

for any ✏ > 0. Suppose we ignore the fact that delta functions are not functions and merely
treat them as ordinary functions with some interesting properties. In this case, we can
imagine that for every probability mass pX (xk ), there exists an interval [a, b] such that
there is one and only one state xk that lies in [a, b], as shown in Figure 4.4.

Figure 4.4: We can view a PMF as a train of impulses. When computing the probability X = xk , we
integrate the PMF over the interval [a, b].

178
4.1. PROBABILITY DENSITY FUNCTION

If we want to calculate the probability of obtaining X = xk , we can show that


(a)
P[X = xk ] = P[a  X  b]
Z b
= fX (x) dx
a
Z b
(b)
= pX (xk ) (x xk ) dx
a
Z b
(c)
= pX (xk ) (x xk ) dx = pX (xk ).
|a {z }
=1

Here, step (a) holds because within [a, b], there is no other event besides X = xk . Step (b)
is just the definition of our fX (x) (inside the interval [a, b]). Step (c) shows that the delta
function integrates to 1, thus leaving the probability mass pX (xk ) as the final result. Let us
look at an example and then comment on this intuition.

Example 4.7. Let X be a discrete random variable with PMF


1
pX (k) = , k = 1, 2, . . .
2k
The continuous representation of the PMF can be written as
1
X 1 ✓
X ◆
1
fX (x) = pX (k) (x k) = (x k).
2k
k=1 k=1

Suppose we want to compute the probability P[1  X  2]. This can be computed as
Z 2 Z 1 ✓
2X ◆
1
P[1  X  2] = fX (x) dx = (x k) dx
1 1 k=1 2k
Z 2 ⇢
1 1
= (x (x 2) + · · · dx
1) +
1 2 4
Z 2 Z
1 1 2
= (x 1) dx + (x 2) dx
2 4 1
|1 {z } | {z }
=1 =1
Z 2
1
+ ···
(x 3) dx + |{z}
8
|1 {z } =0
=0
1 1 3
= + = .
2 4 4
However, if we want to compute the probability P[1 < X  2], then the integration

179
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

limit will not include the number 1 and so the delta function will remain 0. Thus,
Z 2
P[1 < X  2] = fX (x) dx
1+
Z 2 Z
1 1 2 1
= (x 1) dx + (x 2) dx = .
2 + 4 1+ 4
|1 {z } | {z }
=0 =1

Closing remark. To summarize, we see that a PMF can be “regarded” as a PDF. We are
careful to put a quotation around “regarded” because PMF and PDF are defined for di↵erent
events. A PMF uses a discrete measure (i.e., a counter) for countable events, whereas a PDF
uses a continuous measure (i.e., integration) for continuous events. The way we link the two is
by using the delta functions. Using the delta functions is valid, but the argument we provide
here is intuitive rather than rigorous. It is not rigorous because the integration we use is still
the Riemann-Stieltjes integration, which does not handle delta functions. Therefore, while
you can treat a discrete PDF as a train of delta functions, it is important to remember the
limitations of the integrations we use.

4.2 Expectation, Moment, and Variance

4.2.1 Definition and properties


As with discrete random variables, we can define expectation for continuous random vari-
ables. The definition is analogous: Just replace the summation with integration.

Definition 4.3. The expectation of a continuous random variable X is


Z
E[X] = x fX (x) dx. (4.3)

Example 4.8. (Uniform random variable) Let X be a continuous random variable


with PDF fX (x) = b 1 a for a  x  b, and 0 otherwise. The expectation is
Z Z b Z b
1 1
E[X] = xfX (x) dx = x· dx = x dx
⌦ a b a b a a
| {z }
2 b
= x2
a

1 b2 a2 a+b
= · = .
b a 2 2

180
4.2. EXPECTATION, MOMENT, AND VARIANCE

Example 4.9. (Exponential random variable) Let X be a continuous random variable


with PDF fX (x) = e x , for x 0. The expectation is
Z 1
E[X] = x e x dx
0
Z 1
= x de x
0
1 Z 1
= xe x + e x dx
0
| {z 0}
=0
1
1 1
= e x = ,
| {z 0}
= 1

where the colored step is due to integration by parts.

If a function g is applied to the random variable X, the expectation can be found using
the following theorem.

Theorem 4.1. Let g : ⌦ ! R be a function and X be a continuous random variable.


Then Z
E[g(X)] = g(x) fX (x) dx. (4.4)

Example 4.10. (Uniform random variable) Let X be a continuous random variable


with fX (x) = b 1 a for a  x  b, and 0 otherwise. If g(·) = (·)2 , then
Z
E[g(X)] = E[X 2 ] = x2 fX (x) dx

Z b
1 a2 + ab + b2
= · x2 dx = .
b a 3
|a {z }
3 a3
=b 3

1
Practice Exercise 4.4. Let ⇥ be a continuous random variable with PDF f⇥ (✓) = 2⇡
for 0  ✓  2⇡ and is 0 otherwise. Let Y = cos(!t + ⇥). Find E[Y ].

Solution. Referring to Equation (4.4), the function g is

g(✓) = cos(!t + ✓).

181
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Therefore, the expectation E[Y ] is


Z 2⇡
E[Y ] = cos(!t + ✓) f⇥ (✓) d✓
0
Z 2⇡
1
= cos(!t + ✓) d✓ = 0,
2⇡ 0

where the last equality holds because the integral of a sinusoid over one period is 0.

Practice Exercise 4.5. Let A ✓ ⌦. Let IA (X) be an indicator function such that
(
1, if X 2 A,
IA (X) =
0, if X 62 A.

Find E[IA (X)].

Solution. The expectation is


Z Z
E[IA (X)] = IA (x)fX (x) dx = fX (x) dx = P[X 2 A].
⌦ x2A

So the probability of {X 2 A} can be equivalently represented in terms of expectation.

Practice Exercise 4.6. Is it true that E[1/X] = 1/E[X]?

Solution. No. This is because


 Z
1 1 1 1
E = fX (x) dx 6= R = .
X ⌦ x ⌦
xfX (x) dx E[X]

All the properties of expectation we learned in the discrete case can be translated to
the continuous case. Specifically, we have that

E[aX] = aE[X]: A scalar multiple of a random variable will scale the expectation.
E[X +a] = E[X]+a: Constant addition of a random variable will o↵set the expectation.
E[aX + b] = aE[X] + b: Affine transformation of a random variable will translate to
the expectation.

Practice Exercise 4.7. Prove the above three statements.

Solution. The third statement is just the sum of the first two statements, so we just

182
4.2. EXPECTATION, MOMENT, AND VARIANCE

need to show the first two:


Z Z
E[aX] = axfX (x) dx = a xfX (x) dx = aE[X],
⌦ ⌦
Z Z
E[X + a] = (x + a)fX (x) dx = xfX (x) dx + a = E[X] + a.
⌦ ⌦

4.2.2 Existence of expectation


As we discussed in the discrete case, not all random variables have an expectation.

Definition 4.4. A random variable X has an expectation if it is absolutely integrable,


i.e., Z
E[|X|] = |x|fX (x) dx < 1. (4.5)

Being absolutely integrable implies that the expectation is that E[|X|] is the upper
bound of E[X].

Theorem 4.2. For any random variable X,

|E[X]|  E[|X|]. (4.6)

Proof. Note that fX (x) 0. Therefore,

|x| fX (x)  x fX (x)  |x|, fX (x), 8x.

Thus, integrating all three terms yields


Z Z Z
|x|fX (x) dx  x fX (x) dx  |x|fX (x) dx,
⌦ ⌦ ⌦

which is equivalent to E[|X|]  E[X]  E[|X|].


Example 4.11. Here is a random variable whose expectation is undefined. Let X be


a random variable with PDF
1
fX (x) = , x 2 R.
⇡(1 + x2 )

This random variable is called the Cauchy random variable. We can show that
Z 1 Z Z
1 1 1 x 1 0 x
E[X] = x· 2)
dx = 2)
dx + dx.
1 ⇡(1 + x ⇡ 0 (1 + x ⇡ 1 (1 + x2 )

183
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

The first integral gives


Z 1 1
x 1
2
dx = log(1 + x2 ) = 1,
0 (1 + x ) 2 0

and the second integral gives 1. Since neither integral is finite, the expectation is
undefined. We can also check the absolutely integrability criterion:
Z 1
1
E[|X|] = |x| · dx
1 ⇡(1 + x2 )
Z 1 Z 1
(a) x x
= 2 2)
dx 2 dx
0 ⇡(1 + x 1 ⇡(1 + x2 )
(b)
Z 1 1
x 1
2 dx = log(x) = 1,
1 ⇡(x2 + x2 ) ⇡ 1

where in (a) we use the fact that the function being integrated is even, and in (b) we
1 1
lower-bound 1+x 2 x2 +x2 if x > 1.

4.2.3 Moment and variance


The moment and variance of a continuous random variable can be defined analogously to
the moment and variance of a discrete random variable, replacing the summations with
integrations.

Definition 4.5. The kth moment of a continuous random variable X is


Z
E[X k ] = xk fX (x) dx. (4.7)

Definition 4.6. The variance of a continuous random variable X is


Z
Var[X] = E[(X µ) ] = (x µ)2 fX (x) dx,
2
(4.8)

def
where µ = E[X].

It is not difficult to show that the variance can also be expressed as

Var[X] = E[X 2 ] µ2 ,

because

Var[X] = E[(X µ)2 ] = E[X 2 ] 2E[X]µ + µ2 = E[X 2 ] µ2 .

184
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Practice Exercise 4.8. (Uniform random variable) Let X be a continuous random


variable with PDF fX (x) = b 1 a for a  x  b, and 0 otherwise. Find Var[X].
a2 +ab+b2
Solution. We have shown that E[X] = a+b
2 and E[X 2 ] = 3 . Therefore, the
variance is

Var[X] = E[X 2 ] E[X]2


✓ ◆2
a2 + ab + b2 a+b
=
3 2
(b a)2
= .
12

Practice Exercise 4.9. (Exponential random variable) Let X be a continuous ran-


dom variable with PDF fX (x) = e x for x 0, and 0 otherwise. Find Var[X].

Solution. We have shown that E[X] = 1 . The second moment is


Z 1
E[X 2 ] = x2 e x dx
0
Z 1
⇥ ⇤1
= x2 e x 0 + 2xe x dx
0
Z
2 1
= x e x dx
0
2 1 2
= · = 2
.

Therefore,

Var[X] = E[X 2 ] E[X]2


2 1 1
= 2 2
= 2.

4.3 Cumulative Distribution Function

When we discussed discrete random variables, we introduced the concept of cumulative


distribution functions (CDFs). One of the motivations was that if we view a PMF as a train
of delta functions, they are technically not well-defined functions. However, it turns out that
the CDF is always a well-defined function. In this section, we will complete the story by first
discussing the CDF for continuous random variables. Then, we will come back and show
you how the CDF can be derived for discrete random variables.

185
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

4.3.1 CDF for continuous random variables

Definition 4.7. Let X be a continuous random variable with a sample space ⌦ = R.


The cumulative distribution function (CDF) of X is
Z x
def
FX (x) = P[X  x] = fX (x0 ) dx0 . (4.9)
1

The interpretation of the CDF can be seen from Figure 4.5. Given a PDF fX , the CDF
FX evaluated at x is the integration of fX from 1 up to a point x. The integration of fX
from 1 to x is nothing but the area under the curve of fX . Since fX is non-negative, the
larger value x we use to evaluate in FX (x), the more area under the curve we are looking
at. In the extreme whenR 1x = 1, we can see that FX ( 1) = 0, and when x = +1 we
have that FX (+1) = 1 fX (x) dx = 1.

Figure 4.5: A CDF is the integral of the PDF. Thus, the height of a stem in the CDF corresponds to
the area under the curve of the PDF.

Practice Exercise 4.10. (Uniform random variable) Let X be a continuous random


variable with PDF fX (x) = b 1 a for a  x  b, and is 0 otherwise. Find the CDF of X.
Solution. The CDF of X is given by
8
>
<0, x  a,
Rx Rx 1 x a
FX (x) = 1
fX (x0 ) dx0 = a b a dx0 = b a, a < x  b,
>
:
1, x > b.

As you can see from this practice exercise, we explicitly break the CDF into three segments.
The first segment gives FX (x) = 0 because for any x  a, there is nothing to integrate,
since fX (x) = 0 for any x  a. Similarly, for the last segment, FX (x) = 1 for all x > b
because once x goes beyond b, the integration will cover all the non-zeros of fX . Figure 4.6
illustrates the PDF and CDF for this example.
In MATLAB, we can generate the PDF and CDF using the commands pdf and cdf
respectively. For the particular example shown in Figure 4.6, the following code can be used.
A similar set of commands can be implemented in Python.

186
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Figure 4.6: Example: fX (x) = 1/(b a) for a  x  b. The CDF has three segments.

% MATLAB code to generate the PDF and CDF


unif = makedist(’Uniform’,’lower’,-3,’upper’,4);
x = linspace(-5, 10, 1500)’;
f = pdf(unif, x);
F = cdf(unif, x);
figure(1); plot(x, f, ’LineWidth’, 6);
figure(2); plot(x, F, ’LineWidth’, 6);

# Python code to generate the PDF and CDF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.linspace(-5,10,1500)
f = stats.uniform.pdf(x,-3,4)
F = stats.uniform.cdf(x,-3,4)
plt.plot(x,f); plt.show()
plt.plot(x,F); plt.show()

Practice Exercise 4.11. (Exponential random variable) Let X be a continuous


random variable with PDF fX (x) = e x for x 0, and 0 otherwise. Find the CDF
of X.
Solution. Clearly, for x < 0, we have FX (x) = 0. For x 0, we can show that
Z x Z x
0
0 0
FX (x) = fX (x ) dx = e x dx0 = 1 e x .
0 0

Therefore, the complete CDF is (see Figure 4.7 for illustration):


(
0, x < 0,
FX (x) =
1 e x, x 0.

The MATLAB code and Python code to generate this figure are shown below.

187
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

x
Figure 4.7: Example: fX (x) = e for x 0. The CDF has two segments.

% MATLAB code to generate the PDF and CDF


pd = makedist(’exp’,2);
x = linspace(-5, 10, 1500)’;
f = pdf(pd, x);
F = cdf(pd, x);
figure(1); plot(x, f, ’LineWidth’, 6);
figure(2); plot(x, F, ’LineWidth’, 6);

# Python code to generate the PDF and CDF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.linspace(-5,10,1500)
f = stats.expon.pdf(x,2)
F = stats.expon.cdf(x,2)
plt.plot(x,f); plt.show()
plt.plot(x,F); plt.show()

4.3.2 Properties of CDF


Let us now describe the properties of a CDF. If we compare these with those for the discrete
cases, we see that the continuous cases simply replace the summations by integrations.
Therefore, we should expect to inherit most of the properties from the discrete cases.

Proposition 4.1. Let X be a random variable (either continuous or discrete), then


the CDF of X has the following properties:

(i) The CDF is nondecreasing.


(ii) The maximum of the CDF is when x = 1: FX (+1) = 1.
(iii) The minimum of the CDF is when x = 1: FX ( 1) = 0.

188
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Rx
Proof. For (i), we notice that FX (x) = 1
fX (x0 ) dx0 . Therefore, if s  t then
Z s Z t
FX (s) = fX (x0 ) dx0  fX (x0 ) dx0 = FX (t).
1 1

Thus it shows that FX is nondecreasing. (It does not need to be increasing because a CDF
can have a steady state.) For (ii) and (iii), we can show that
Z +1 Z 1
FX (+1) = fX (x0 ) dx0 = 1, and FX ( 1) = fX (x0 ) dx0 = 0. ⇤
1 1

Example 4.12. We can show that the CDF we derived for the uniform random variable
satisfies these three properties. To see this, we note that
x a
FX (x) = , a  x  b.
b a

The derivative of this function FX 0


(x) = b 1 a > 0 for a  x  b. Also, note that
FX (x) = 0 for x < a and x > b, so FX is nondecreasing. The other two properties
follow because if x = b, then FX (b) = 1, and if x = a then FX (a) = 0. Together with
the nondecreasing property, we show (ii) and (iii).

Proposition 4.2. Let X be a continuous random variable. If the CDF FX is contin-


uous at any a  x  b, then

P[a  X  b] = FX (b) FX (a). (4.10)

Proof. The proof follows from the definition of the CDF, which states that
Z b Z a
FX (b) FX (a) = fX (x0 ) dx0 fX (x0 ) dx0
1 1
Z b
= fX (x0 ) dx0 = P[a  X  b]. ⇤
a

This result provides a very handy tool for calculating the probability of an event
a  X  b using the CDF. It says that P[a  X  b] is the di↵erence between FX (b) and
FX (a). So, if we are given FX , calculating the probability of a  X  b just involves
evaluating the CDF at a and b. The result also shows that for a continuous random vari-
able X, P[X = x0 ] = FX (x0 ) FX (x0 ) = 0. This is consistent with our arguments from the
measure’s point of view.

Example 4.13. (Exponential random variable) We showed that the exponential ran-
dom variable X with a PDF fX (x) = e x for x 0 (and fX (x) = 0 for x < 0)
has a CDF given by FX (x) = 1 e x for x 0. Suppose we want to calculate the

189
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

probability P[1  X  3]. Then the PDF approach gives us


Z 3 Z 3 3
x x 3
P[1  X  3] = fX (x) dx = e dx = e =e e .
1 1 1

If we take the CDF approach, we can show that

P[1  X  3] = FX (3) FX (1)


3 3
= (1 e ) (1 e )=e e ,

which yields the same as the PDF approach.

Example 4.14. Let X be a random variable with PDF fX (x) = 2x for 0  x  1,


and is 0 otherwise. We can show that the CDF is
Z x Z x x
FX (x) = fX (t) dt = 2t dt = t2 = x2 , 0  x  1.
0 0 0

Therefore, to compute the probability P[1/3  X  1/2], we have


 ✓ ◆ ✓ ◆ ✓ ◆2 ✓ ◆2
1 1 1 1 1 1 5
P X = FX FX = = .
3 2 2 3 2 3 36

A CDF can be used for both continuous and discrete random variables. However, before
we can do that, we need a tool to handle the discontinuities. The following definition is a
summary of the three types of continuity.

Definition 4.8. A function FX (x) is said to be


def
Left-continuous at x = b if FX (b) = FX (b ) = limh!0 FX (b h);
def
Right-continuous at x = b if FX (b) = FX (b+ ) = limh!0 FX (b + h);
Continuous at x = b if it is both right-continuous and left-continuous at x = b.
In this case, we have

lim FX (b h) = lim FX (b + h) = F (b).


h!0 h!0

In this definition, the step size h > 0 is shrinking to zero. The point b h stays at the left of
b, and b+h stays at the right of b. Thus, if we set the limit h ! 0, b h will approach a point
b whereas b + h will approach a point b+ . If it happens that FX (b ) = FX (b) then we say
that FX is left-continuous at b. If FX (b+ ) = FX (b) then we say that FX is right-continuous
at b. These are summarized in Figure 4.8.
Whenever FX has a discontinuous point, it can be left-continuous, right-continuous, or
neither. (“Neither” happens if FX (b) take a value other than FX (b+ ) or FX (b ). You can

190
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Figure 4.8: The definition of left- and right-continuous at a point b.

always create a nasty function that satisfies this condition.) For continuous functions, it is
necessary that FX (b ) = FX (b+ ). If this happens, there is no gap between the two points.

Theorem 4.3. For any random variable X (discrete or continuous), FX (x) is always
right-continuous. That is,
def
FX (b) = FX (b+ ) = lim FX (b + h) (4.11)
h!0

Right-continuous means that if FX (x) is piecewise, it must have a solid left end and an
empty right end. Figure 4.9 shows an example of a valid CDF and an invalid CDF.

Figure 4.9: A CDF must be right-continuous.

The reason why FX is always right-continuous is that the inequality X  x has a


closed right-hand limit. Imagine the following situation: A discrete random variable X has
four states: 1, 2, 3, 4. Then,
“3X
+ h”
lim FX (3 + h) = lim pX (k) = pX (1) + pX (2) + pX (3) = FX (3).
h!0 h!0
k=1

Similarly, if you have a continuous random variable X with a PDF fX , then


Z b+h Z b
lim FX (b + h) = lim fX (t) dt = fX (t) dt = FX (b).
h!0 h!0 1 1

191
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

In other words, the “” ensures that the rightmost state is included. If we defined CDF
using <, we would have gotten left-hand continuous, but this would be inconvenient because
the < requires us to deal with limits whenever we evaluate X < x.

Theorem 4.4. For any random variable X (discrete or continuous), P[X = b] is


(
FX (b) FX (b ), if FX is discontinuous at x = b
P[X = b] = (4.12)
0, otherwise.

This proposition states that when FX (x) is discontinuous at x = b, then P[X = b] is


the di↵erence between FX (b) and the limit from the left. In other words, the height of the
gap determines the probability at the discontinuity. If FX (x) is continuous at x = b, then
FX (b) = limh!0 FX (b h) and so P[X = b] = 0.

Figure 4.10: Illustration of Equation (4.12). Since the CDF is discontinuous at a point x = b, the gap
FX (b) FX (b ) will define the probability P[X = b].

Example 4.15. Consider a random variable X with a PDF


8
>
<x, 0  x  1,
fX (x) = 12 , x = 3,
>
:
0, otherwise.

The CDF FX (x) will consist of a few segments. The first segment is 0  x < 1. We
can show that
Z x Z x x
t2 x2
FX (x) = fX (t) dt = t dt = = , 0  x < 1.
0 0 2 0 2

The second segment is when 1  x < 3. Since there is no new fX to integrate, the
CDF stays at FX (x) = FX (1) = 12 for 1  x < 3. The third segment is x > 3. Because
this range has covered the entire sample space, we have FX (x) = 1 for x > 3. How
about x = 3? We can show that

FX (3) = FX (3+ ) = 1.

192
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Therefore, to summarize, the CDF is


8
>
> 0, x < 0,
> x2
< , 2 0  x < 1,
FX (x) = 1
>
> , 1  x < 3,
>
:2
1, x 3.

A graphical illustration is shown in Figure 4.11.

Figure 4.11: An example of converting a PDF to a CDF.

4.3.3 Retrieving PDF from CDF


Thus far, we have only seen how to obtain FX (x) from fX (x). In order to go in the reverse
direction, we recall the fundamental theorem of calculus. This states that if a function f is
continuous, then Z x
d
f (x) = f (t) dt
dx a
for some constant a. Using this result for CDF and PDF, we have the following:

Theorem 4.5. The probability density function (PDF) is the derivative of the cu-
mulative distribution function (CDF):
Z x
dFX (x) d
fX (x) = = fX (x0 ) dx0 , (4.13)
dx dx 1

provided FX is di↵erentiable at x. If FX is not di↵erentiable at x = x0 , then,

fX (x0 ) = P[X = x0 ] (x x0 ).

Example 4.16. Consider a CDF


(
0, x < 0,
FX (x) = 1 2x
1 4e , x 0.

3
We want to find the PDF fX (x). To do so, we first show that FX (0) = 4. This

193
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

corresponds to a discontinuity at x = 0, as shown in Figure 4.12.

Figure 4.12: An example of converting a PDF to a CDF.


Because of the discontinuity, we need to consider three cases:
8 dF (x)
> X
< dx , x < 0,
fX (x) = P[X = 0] (x 0), x = 0,
>
: dFX (x)
dx , x > 0.

dFX (x) 1 2x
When x < 0, FX (x) = 0, so dx = 0. When x > 0, FX (x) = 1 4e , so

dFX (x) 1 2x
= e .
dx 2
When x = 0, the probability P[X = 0] is determined by the gap between the solid dot
and the empty dot. This yields
3 3
P[X = 0] = FX (0) lim FX (0 h) = 0= .
h!0 4 4
Therefore, the overall PDF is
8
>
<0, x < 0,
3
fX (x) = 4 (x 0), x = 0,
>
: 1 2x
2e , x > 0.

Figure 4.12 illustrates this example.

4.3.4 CDF: Unifying discrete and continuous random variables


The CDF is always a well-defined function. It is integrable everywhere. If the underlying
random variable is continuous, the CDF is also continuous. If the underlying random variable
is discrete, the CDF is a staircase function. We have seen enough CDFs for continuous
random variables. Let us (re)visit a few discrete random variables.

Example 4.17. (Geometric random variable) Consider a geometric random variable


with PMF pX (k) = (1 p)k 1 p, for k = 1, 2, . . ..

194
4.3. CUMULATIVE DISTRIBUTION FUNCTION

Figure 4.13: PMF and CDF of a geometric random variable.


We can show that the CDF is
k
X k
X 1 (1 p)k
FX (k) = pX (`) = (1 p)` 1
p=p· =1 (1 p)k .
1 (1 p)
`=1 `=1

For a sanity check, we can try to retrieve the PMF from the CDF:

pX (k) = FX (k) FX (k 1)
k
= (1 (1 p) ) (1 (1 p)k 1
)
k 1
= (1 p) p.

A graphical portrayal of this example is shown in Figure 4.13.

If we treat the PMFs as delta functions in the above example, then the continuous
definition also applies. Since the CDF is a piecewise constant function, the derivative is
exactly a delta function. For some problems, it is easier to start with CDF and then compute
the PMF or PDF. Here is an example.

Example 4.18. Let X1 , X2 and X3 be three independent discrete random variables


with sample space ⌦ = {1, 2, . . . , 10}. Define X = max{X1 , X2 , X3 }. We want to
find the PMF of X. To tackle this problem, we first observe that the PMF for X1 is
1
pX1 (k) = 10 . Thus, the CDF of X1 is

k
X k
FX1 (k) = pX1 (`) = .
10
`=1

Then, we can show that the CDF of X is

FX (k) = P[X  k] = P[max{X1 , X2 , X3 }  k]


(a)
= P[X1  k \ X2  k \ X3  k]
(b)
= P[X1  k]P[X2  k]P[X3  k]
✓ ◆3
k
= ,
10

195
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

where in (a) we use the fact that max{X1 , X2 , X3 }  k if and only if all three elements
are less than k, and in (b) we use independence. Consequently, the PMF of X is
✓ ◆3 ✓ ◆3
k k 1
pX (k) = FX (k) FX (k 1) = .
10 10

What is a CDF?
CDF is FX (x) = P[X  x]. It is the cumulative sum of the PMF/PDF.
CDF is either a staircase function, a smooth function, or a hybrid. Unlike a
PDF, which is not defined for discrete random variables, the CDF is always well
defined.
d
CDF dx
! PDF.
R
CDF PDF.
Gap of jump in CDF = height of delta in PDF.

4.4 Median, Mode, and Mean


There are three statistical quantities that we are frequently interested in: mean, mode, and
median. We all know how to compute these from a dataset. For example, to compute the
median of a dataset, we sort the data and pick the number that sits in the 50th percentile.
However, the median computed in this way is the empirical median, i.e., it is a value
computed from a particular dataset. If the data is generated from a random variable (with
a given PDF), how do we compute the mean, median, and mode?

4.4.1 Median
Imagine you have a sequence of numbers as shown below.

n 1 2 3 4 5 6 7 8 9 ··· 100
xn 1.5 2.5 3.1 1.1 0.4 4.1 0.5 2.2 3.4 ··· 1.4

How do we compute the median? We first sort the sequence (either in ascending order
or descending order), and then pick the middle one. On computer, we permute the samples

{x10 , x20 , . . . , xN 0 } = sort{x1 , x2 , . . . , xN },

such that x10 < x20 < . . . < xN 0 is ordered. The median is the one positioned at the middle.
There are, of course, built-in commands such as median in MATLAB and np.median in
Python to perform the median operation.
Now, how do we compute the median if we are given a random variable X with a PDF
fX (x)? The answer is by integrating the PDF.

196
4.4. MEDIAN, MODE, AND MEAN

Definition 4.9. Let X be a continuous random variable with PDF fX . The median
of X is a point c 2 R such that
Z c Z 1
fX (x) dx = fX (x) dx. (4.14)
1 c

Rc
Why is the median defined in this way? This is because f (x) dx is the area under
1 X
R1
the curve on the left of c, and c fX (x) dx is the area under the curve on the right of c.
The area under the curve tells us the percentage of numbers that are less than the cuto↵.
Therefore, if the left area equals the right area, then c must be the median.

How to find the median from the PDF


Find a point c that separates the PDF into two equal areas

Figure 4.14: [Left] The median is computed as the point such that the two areas under the curve are
equal. [Right] The median is computed as the point such that FX hits 0.5.

The median can also be evaluated from the CDF as follows.

Theorem 4.6. The median of a random variable X is the point c such that
1
FX (c) = . (4.15)
2
Rx
Proof. Since FX (x) = 1
fX (x0 ) dx0 , we have
Z c
FX (c) = fX (x) dx
1
Z 1
= fX (x) dx = 1 FX (c).
c

Rearranging the terms shows that FX (c) = 12 . ⇤

197
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

How to find median from CDF


Find a point c such that FX (c) = 0.5.

Example 4.19. (Uniform random variable) Let X be a continuous random variable


with PDF fX (x) = b 1 a for a  x  b, and is 0 otherwise. We know that the CDF of
X is FX (x) = xb aa for a  x  b. Therefore, the median of X is the number c 2 R
such that FX (c) = 12 . Substituting into the CDF yields cb aa = 12 , which gives c = a+b
2 .

Example 4.20. (Exponential random variable) Let X be a continuous random vari-


able with PDF fX (x) = e x for x 0. We know that the CDF of X is FX (x) =
1 e x for x 0. The median of X is the point c such that FX (c) = 12 . This gives
1 e c = 12 , which is c = log 2 .

4.4.2 Mode
The mode is the peak of the PDF. We can see this from the definition below.

Definition 4.10. Let X be a continuous random variable. The mode is the point c
such that fX (x) attains the maximum:

d
c = argmax fX (x) = argmax FX (x). (4.16)
x2⌦ x2⌦ dx

0 d
Rx
The second equality holds because fX (x) = FX (x) = dx 1 X
f (t) dt. A pictorial illustra-
tion of mode is given in Figure 4.15. Note that the mode of a random variable is not unique,
e.g., a mixture of two identical Gaussians with di↵erent means has two modes.

Figure 4.15: [Left] The mode appears at the peak of the PDF. [Right] The mode appears at the steepest
slope of the CDF.

198
4.4. MEDIAN, MODE, AND MEAN

How to find mode from PDF


Find a point c such that fX (c) is maximized.
How to find mode from CDF
Continuous: Find a point c such that FX (c) has the steepest slope.
Discrete: Find a point c such that FX (c) has the biggest gap in a jump.

Example 4.21. Let X be a continuous random variable with PDF fX (x) = 6x(1 x)
for 0  x  1. The mode of X happens at argmax fX (x). To find this maximum, we
x
take the derivative of fX . This gives
d d
0= fX (x) = 6x(1 x) = 6(1 2x).
dx dx
Setting this equal to zero yields x = 12 .
To ensure that this point is a maximum, we take the second-order derivative:

d2 d
2
fX (x) = 6(1 2x) = 12 < 0.
dx dx
1
Therefore, we conclude that x = 2 is a maximum point. Hence, the mode of X is
x = 12 .

4.4.3 Mean
We have defined the mean as the expectation of X. Here, we show how to compute the
expectation from the CDF. To simplify the demonstration, let us first assume that X > 0.

Lemma 4.1. Let X > 0. Then E[X] can be computed from FX as


Z 1
E[X] = (1 FX (t)) dt. (4.17)
0

Proof. The trick is to change the integration order:


Z 1 Z 1 Z 1
(1 FX (t)) dt = [1 P[X  t]] dt = P[X > t] dt
0
Z0 1 Z 1 Z0 1 Z x
(a)
= fX (x) dx dt = fX (x) dt dx
Z0 1 Zt x Z 10 0

= dtfX (x) dx = xfX (x) dx = E[X].


0 0 0

Here, step (a) is due to the change of integration order. See Figure 4.16 for an illustration.

We draw a picture to illustrate the above lemma. As shown in Figure 4.17, the mean
of a positive random variable X > 0 is equivalent to the area above the CDF.

199
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Figure 4.16: The double integration can be evaluated by x then t, or t then x.

Figure 4.17: The mean of a positive random variable X > 0 can be calculated by integrating the CDF’s
complement.

Lemma 4.2. Let X < 0. Then E[X] can be computed from FX as


Z 0
E[X] = FX (t) dt. (4.18)
1

Proof. The idea here is also to change the integration order.


Z 0 Z 0 Z 0 Z t
FX (t) dt = P[X  t] dt = fX (x) dx dt
1 1 1 1
Z 0 Z 0 Z 0
= fX (x) dt dx = xfX (x) dx = E[X].
1 x 1

Theorem 4.7. The mean of a random variable X can be computed from the CDF as
Z 1 Z 0
E[X] = (1 FX (t)) dt FX (t) dt. (4.19)
0 1

200
4.5. UNIFORM AND EXPONENTIAL RANDOM VARIABLES

Proof. For any random variable X, we can partition X = X + X where X + and X are
the positive and negative parts, respectively. Then, the above two lemmas will give us

E[X] = E[X + X ] = E[X + ] E[X ]


Z 1 Z 0
= (1 FX (t)) dt FX (t) dt.
0 1


As illustrated in Figure 4.18, this equation is equivalent to computing the areas above
and below the CDF and taking the di↵erence.

Figure 4.18: The mean of a random variable X can be calculated by computing the area in the CDF.

How to find the mean from the CDF


A formula is given by Equation (4.20):
Z 1 Z 0
E[X] = (1 FX (t)) dt FX (t) dt. (4.20)
0 1

This result is not commonly used, but the proof technique of switching the inte-
gration order is important.

4.5 Uniform and Exponential Random Variables

There are many useful continuous random variables. In this section, we discuss two of them:
uniform random variables and exponential random variables. In the next section, we will
discuss the Gaussian random variables. Similarly to the way we discussed discrete random
variables, we take a generative / synthesis perspective when studying continuous random
variables. We assume we have access to the PDF of the random variables so we can derive
the theoretical mean and variance. The opposite direction, namely inferring the underlying
model parameters from a dataset, will be discussed later.

201
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

4.5.1 Uniform random variables

Definition 4.11. Let X be a continuous uniform random variable. The PDF of X is


(
1
, a  x  b,
fX (x) = b a (4.21)
0, otherwise,

where [a, b] is the interval on which X is defined. We write

X ⇠ Uniform(a, b)

to mean that X is drawn from a uniform distribution on an interval [a, b].

3 1.2

2.5 1

2 0.8

1.5 0.6

1 0.4

0.5 0.2

0 0
0 0.2 0.4 0.6 0.8 1 0 0.2 0.4 0.6 0.8 1
(a) PDF (b) CDF

Figure 4.19: The PDF and CDF of X ⇠ Uniform(0.2, 0.6).

The shape of the PDF of a uniform random variable is shown in Figure 4.19. In this
figure, we assume that the random variables X ⇠ Uniform(0.2, 0.6) are taken from the
sample space ⌦ = [0, 1]. Note that the height of the uniform distribution is greater than 1,
since (
1
= 2.5, 0.2  x  0.6,
fX (x) = 0.6 0.2
0, otherwise.
There is nothing wrong with this PDF, because fX (x) is the probability per unit length. If we
integrate fX (x) over any sub-interval between 0.2 and 0.6, we can show that the probability
is between 0 and 1.
The CDF of a uniform random variable can be determined by integrating fX (x):
Z x
FX (x) = fX (t) dt
1
Z x
1
= dt
a b a
x a
= , a  x  b.
b a

202
4.5. UNIFORM AND EXPONENTIAL RANDOM VARIABLES

Therefore, the complete CDF is


8
>
<0, x < a,
x a
FX (x) = , a  x  b,
>b a
:
1, x > b.

The corresponding CDF for the PDF we showed in Figure 4.19(a) is shown in Figure 4.19(b).
It can be seen that although the height of the PDF exceeds 1, the CDF grows linearly and
saturates at 1.
Remark. The uniform distribution can also be defined for discrete random variables. In
this case, the probability mass function is given by
1
pX (k) = , k = a, a + 1, . . . , b.
b a+1
The presence of “1” in the denominator of the PMF is because k runs from a to b, including
the two endpoints.
In MATLAB and Python, generating uniform random numbers can be done by calling
commands unifrnd (MATLAB), and stats.uniform.rvs (Python). For discrete uniform
random variables, in MATLAB the command is unidrnd, and in Python the command is
stats.randint.

% MATLAB code to generate 1000 uniform random numbers


a = 0; b = 1;
X = unifrnd(a,b,[1000,1]);
hist(X);

# Python code to generate 1000 uniform random numbers


import scipy.stats as stats
a = 0; b = 1;
X = stats.uniform.rvs(a,b,size=1000)
plt.hist(X);

To compute the empirical average and variance of the random numbers in MATLAB
we can call the command mean and var. The corresponding command in Python is np.mean
and np.var. We can also compute the median and mode, as shown below.

% MATLAB code to compute empirical mean, var, median, mode


X = unifrnd(a,b,[1000,1]);
M = mean(X);
V = var(X);
Med = median(X);
Mod = mode(X);

# Python code to compute empirical mean, var, median, mode


X = stats.uniform.rvs(a,b,size=1000)
M = np.mean(X)
V = np.var(X)

203
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Med = np.median(X)
Mod = stats.mode(X)

The mean and variance of a uniform random variable are given by the theorem below.

Theorem 4.8. If X ⇠ Uniform(a, b), then

a+b (b a)2
E[X] = and Var[X] = . (4.22)
2 12

Proof. We have derived these results before. Here is a recap for completeness:
Z 1 Z b
x a+b
E[X] = xfX (x) dx = dx = ,
1 a b a 2
Z 1 Z b
2 2 x2 a2 + ab + b2
E[X ] = x fX (x) dx = dx = ,
1 a b a 3
2
(b a)
Var[X] = E[X 2 ] E[X]2 = .
12

The result should be intuitive because it says that the mean is the midpoint of the
PDF.
When will we encounter a uniform random variable? Uniform random variables are one
of the most elementary continuous random variables. Given a uniform random variable, we
can construct any random variable by using an appropriate transformation. We will discuss
this technique as part of our discussion about generating random numbers.
In MATLAB, computing the mean and variance of a uniform random variable can be
done using the command unifstat. The Python coommand is stats.uniform.stats.

% MATLAB code to compute mean and variance


a = 0; b = 1;
[M,V] = unifstat(a,b)

# Python code to compute mean and variance


import scipy.stats as stats
a = 0; b = 1;
M, V = stats.uniform.stats(a,b,moments=’mv’)

To evaluate the probability P[`  X  u] for a uniform random variable, we can call
unifcdf in MATLAB and

% MATLAB code to compute the probability P(0.2 < X < 0.3)


a = 0; b = 1;
F = unifcdf(0.3,a,b) - unifcdf(0.2,a,b)

204
4.5. UNIFORM AND EXPONENTIAL RANDOM VARIABLES

# Python code to compute the probability P(0.2 < X < 0.3)


a = 0; b = 1;
F = stats.uniform.cdf(0.3,a,b)-stats.uniform.cdf(0.2,a,b)

An alternative is to define an object rv = stats.uniform, and call the CDF attribute:

# Python code to compute the probability P(0.2 < X < 0.3)


a = 0; b = 1;
rv = stats.uniform(a,b)
F = rv.cdf(0.3)-rv.cdf(0.2)

4.5.2 Exponential random variables

Definition 4.12. Let X be an exponential random variable. The PDF of X is


(
e x, x 0,
fX (x) = (4.23)
0, otherwise,

where > 0 is a parameter. We write

X ⇠ Exponential( )

to mean that X is drawn from an exponential distribution of parameter .

In this definition, the parameter of the exponential random variable determines the rate
of decay. A large implies a faster decay. The PDF of an exponential random variable is
illustrated in Figure 4.20. We show two values of . Note that the initial value fX (0) is
0
fX (0) = e = .

Therefore, as long as > 1, fX (0) will exceed 1.


The CDF of an exponential random variable can be determined by
Z x
FX (x) = fX (t) dt
1
Z x
= e t dt = 1 e x , x 0.
0

Therefore, if we consider the entire real line, the CDF is


(
0, x < 0,
FX (x) = x
1 e , x 0.

The corresponding CDFs for the PDFs shown in Figure 4.20(a) are shown in Fig-
ure 4.20(b). For larger , the PDF fX (x) decays faster but the CDF FX (x) increases faster.

205
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

6
1.2
=2
5 =5
1

4 0.8

3 0.6

2 0.4

1 0.2 =2
=5
0 0
0 0.2 0.4 0.6 0.8 1 0 0.2 0.4 0.6 0.8 1
(a) PDF (b) CDF

Figure 4.20: (a) The PDF and (c) the CDF of X ⇠ Exponential( ).

In MATLAB, the code used to generate Figure 4.20(a) is shown below. There are
multiple ways of doing this. An alternative way is to call exppdf, which will return the same
result. In Python, the corresponding command is stats.expon.pdf. Note that in Python
the parameter is specified in scale option.

% MATLAB code to plot the exponential PDF


lambda1 = 1/2; lambda2 = 1/5;
x = linspace(0,1,1000);
f1 = pdf(’exp’,x, lambda1);
f2 = pdf(’exp’,x, lambda2);
plot(x, f1, ’LineWidth’, 4, ’Color’, [0 0.2 0.8]); hold on;
plot(x, f2, ’LineWidth’, 4, ’Color’, [0.8 0.2 0]);

# Python code to plot the exponential PDF


lambd1 = 1/2
lambd2 = 1/5
x = np.linspace(0,1,1000)
f1 = stats.expon.pdf(x,scale=lambd1)
f2 = stats.expon.pdf(x,scale=lambd2)
plt.plot(x, f1)
plt.plot(x, f2)

To plot the CDF, we replace pdf by cdf. Similarly, in Python we replace expon.pdf
by expon.cdf.

% MATLAB code to plot the exponential CDF


F = cdf(’exp’,x, lambda1);
plot(x, F, ’LineWidth’, 4, ’Color’, [0 0.2 0.8]);

# Python code to plot the exponential CDF


F = stats.expon.cdf(x,scale=lambd1)
plt.plot(x, F)

206
4.5. UNIFORM AND EXPONENTIAL RANDOM VARIABLES

Theorem 4.9. If X ⇠ Exponential( ), then


1 1
E[X] = and Var[X] = 2
. (4.24)

Proof. We have discussed this proof before. Here is a recap for completeness:
Z 1 Z 1
E[X] = xfX (x) dx = xe x dx
1 0
Z 1
= xde x
0
1
Z 1
x 1
= xe + e x dx = ,
0 0

Z 1 Z 1
2 2
E[X ] = x fX (x) dx = x2 e x
dx
1 0
Z 1
= x2 de x
0
1
Z 1
2 x x
= x e + 2xe dx
0 0
2 2
=0+ E[X] = 2
.

Thus, Var[X] = E[X 2 ] E[X]2 = 1


2 .

Computing the mean and variance of an exponential random variable in MATLAB and
Python follows the similar procedures that we described above.

4.5.3 Origin of exponential random variables


Exponential random variables are closely related to Poisson random variables. Recall that
the definition of a Poisson random variable is a random variable that describes the number
of events that happen in a certain period, e.g., photon arrivals, number of pedestrians, phone
calls, etc. We summarize the origin of an exponential random variable as follows.

What is the origin of exponential random variables?


An exponential random variable is the interarrival time between two consecutive
Poisson events.
That is, an exponential random variable is how much time it takes to go from N
Poisson counts to N + 1 Poisson counts.

An example will clarify this concept. Imagine that you are waiting for a bus, as illus-
trated in Figure 4.21. Passengers arrive at the bus stop with an arrival rate per unit time.
Thus, for some time t, the average number of people that arrive is t. Let N be a random

207
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

variable denoting the number of people. We assume that N is Poisson with a parameter t.
That is, for any duration t, the probability of observing n people follows the PMF

( t)n t
P[N = n] = e .
n!

Figure 4.21: For any fixed period of time t, the number of people N is modeled as a Poisson random
variable with a parameter t.

Figure 4.22: The interarrival time T between two consecutive Poisson events is an exponential random
variable.

Let T be the interarrival time between two people, by which we mean the time between
two consecutive arrivals, as shown in Figure 4.22. Note that T is a random variable because
T depends on N , which is itself a random variable. To find the PDF of T , we first find the
CDF of T . We note that
(a)
P[T > t] = P[interarrival time > t]
(b) (c) ( t)0 t t
= P[no arrival in t] = P[N = 0] = e =e .
0!
In this set of arguments, (a) holds because T is the interarrival time, and (b) holds be-
cause interarrival time is between two consecutive arrivals. If the interarrival time is larger
than t, there is no arrival during the period. Equality (c) holds because N is the number of
passengers.
Since P[T > t] = 1 FT (t), where FT (t) is the CDF of T , we can show that

FT (t) = 1 e t ,
d t
fT (t) = FT (t) = e .
dt
Therefore, the interarrival time T follows an exponential distribution.

Since exponential random variables are tightly connected to Poisson random variables,
we should expect them to be useful for modeling temporal events. We discuss two examples.

208
4.5. UNIFORM AND EXPONENTIAL RANDOM VARIABLES

4.5.4 Applications of exponential random variables

Example 4.22. (Photon arrivals) Single-photon image sensors are designed to op-
erate in the photon-limited regime. The number-one goal of using these sensors is to
count the number of arriving photons precisely. However, for some applications not
all single-photon image sensors are used to count photons. Some are used to measure
the time between two photon arrivals, such as time-of-flight systems. In this case, we
are interested in measuring the time it takes for a pulse to bounce back to the sensor.
The more time it takes for a pulse to come back, the greater the distance between the
object and the sensor. Other applications utilize the time information. For example,
high-dynamic-range imaging can be achieved by recording the time between two pho-
ton arrivals because brighter regions have a higher Poisson rate and darker regions
have a lower .

The figure above illustrates an example of high-dynamic-range imaging. When the


scene is bright, the large will generate more photons. Therefore, the interarrival time
between the consecutive photons will be relatively short. If we plot the histogram of
the interarrival time, we observe that most of the interarrival time will be concentrated
at small values. Dark regions behave in the opposite manner. The interarrival time will
typically be much longer. In addition, because there is more variation in the photon
arrival times, the histogram will look shorter and wider. Nevertheless, both cases are
modeled by the exponential random variable.

Example 4.23. (Energy-efficient escalator) Many airports today have installed variable-
speed escalators. These escalators change their speeds according to the traffic. If there
are no passengers for more than a certain period (say, 60 seconds), the escalator will
switch from the full-speed mode to the low-speed mode. For moderately busy esca-
lators, the variable-speed configuration can save energy. The interesting data-science
problem is to determine, given a traffic pattern, e.g., the one shown in Figure 4.23,
whether we can predict the amount of energy savings?
We will not dive into the details of this problem, but we can briefly discuss the
principle. Consider a fixed arrival rate (say, the average from 07:00 to 08:00). The in-
terarrival time, according to our discussion above, follows an exponential distribution.

209
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

So we know that
t
fT (t) = e .
Suppose that the escalator switches to low-speed mode when the interarrival time
exceeds ⌧ . Then we can define a new variable Y to denote the amount of time that
the escalator will operate in the low-speed mode. This new variable is
(
T ⌧, T > ⌧,
Y =
0, T  ⌧.

In other words, if the interarrival time T is more than ⌧ , then the amount of time
saved Y takes the value T ⌧ , but if the interarrival time is less than ⌧ , then there is
no saving.

Figure 4.23: The variable-speed escalator problem. [Left] We model the passengers as independent
Poisson arrivals. Thus, the interarrival time is exponential. [Right] A hypothetical passenger arrival
rate (number of people per minute), from 06:00 to 23:00.

Figure 4.24: The escalator problem requires modeling the cuto↵ threshold ⌧ such that if T > ⌧ ,
the savings are Y = T ⌧ . If T < ⌧ , then Y = 0. The left-hand side of the figure shows how the
PDF of Y is constructed.
The PDF of Y can be computed according to Figure 4.24. There are two parts
to the calculation. When Y = 0, there is a probability mass such that
Z ⌧ Z ⌧
fY (0) = P[Y = 0] = fT (t) dt = e t dt = 1 e ⌧ .
0 0

For other values of y, we can show that


(y+⌧ )
fY (y) = fT (y + ⌧ ) = e .

Therefore, to summarize, we can show that the PDF of Y is


(
(1 e ⌧ ) (y), y = 0,
fY (y) = (y+⌧ )
e , y > 0.

210
4.6. GAUSSIAN RANDOM VARIABLES

Consequently, we can compute E[Y ] and Var[Y ] and analyze how these values change
for (which itself changes with the time of day). Furthermore, we can analyze the
amount of savings in terms of dollars. We leave these problems as an exercise.

Closing remark. The photon arrival problem and the escalator problem are two of many
examples we can find in which exponential random variables are useful for modeling a
problem. We did not go into the details of the problems because each of them requires some
additional modeling to address the real practical problem. We encourage you to explore these
problems further. Our message is simple: Many problems can be modeled by exponential
random variables, most of which are associated with time.

4.6 Gaussian Random Variables

We now discuss the most important continuous random variable — the Gaussian random
variable (also known as the normal random variable). We call it the most important random
variable because it is widely used in almost all scientific disciplines. Many of us have used
Gaussian random variables before, and perhaps its bell shape is the first lesson we learn in
statistics. However, there are many mysteries about Gaussian random variables which you
may have missed, such as: Where does the Gaussian random variable come from? Why does
it take a bell shape? What are the properties of a Gaussian random variable? The objective
of this section is to explain everything you need to know about a Gaussian random variable.

4.6.1 Definition of a Gaussian random variable

Definition 4.13. A Gaussian random variable is a random variable X such that its
PDF is ⇢
1 (x µ)2
fX (x) = p exp , (4.25)
2⇡ 2 2 2
2
where (µ, ) are parameters of the distribution. We write
2 2
X ⇠ Gaussian(µ, ) or X ⇠ N (µ, )
2
to say that X is drawn from a Gaussian distribution of parameter (µ, ).

Gaussian random variables have two parameters (µ, 2 ). It is noteworthy that the mean
is µ and the variance is 2 — these two parameters are exactly the first moment and the
second central moment of the random variable. Most other random variables do not have
this property.
Note that a Gaussian random variable is positive from 1 to 1. Thus, fX (x) has
a non-zero value for any x, even though the value may be extremely small. A Gaussian
random variable is also symmetric about µ. If µ = 0, then fX (x) is an even function.
The shape of the Gaussian is illustrated in Figure 4.25. When we fix the variance and
change the mean, the PDF of the Gaussian moves left or right depending on the sign of the
mean. When we fix the mean and change the variance, the PDF of the Gaussian changes

211
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

its width. Since any PDF should integrate to unity, a wider Gaussian means that the PDF
is shorter. Note also that if is very small, it is possible that fX (x) > 1 although the
integration over ⌦ will still be 1.
0.5 0.5
= -3 = 0.8
= -0.3 =1
0.4 =0 0.4 =2
= 1.2 =3
=4 =4
0.3 0.3

0.2 0.2

0.1 0.1

0 0
-10 -5 0 5 10 -10 -5 0 5 10
µ changes, =1 µ = 0, changes

Figure 4.25: A Gaussian random variable with di↵erent µ and .

On a computer, plotting the Gaussian PDF can be done by calling the function
pdf(’norm’,x) in MATLAB, and stats.norm.pdf in Python.

% MATLAB to generate a Gaussian PDF


x = linspace(-10,10,1000);
mu = 0; sigma = 1;
f = pdf(’norm’,x,mu,sigma);
plot(x, f);

# Python to generate a Gaussian PDF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.linspace(-10,10,1000)
mu = 0; sigma = 1;
f = stats.norm.pdf(x,mu,sigma)
plt.plot(x,f)

Our next result concerns the mean and variance of a Gaussian random variable. You
may wonder why we need this theorem when we already know that µ is the mean and 2 is
the variance. The answer is that we have not proven these two facts.

2
Theorem 4.10. If X ⇠ Gaussian(µ, ), then
2
E[X] = µ, and Var[X] = . (4.26)

212
4.6. GAUSSIAN RANDOM VARIABLES

Proof. The expectation can be derived via substitution:


Z 1
1 (x µ)2
E[X] = p xe 2 2 dx
2⇡ 2 1
Z 1
(a) 1 y2
= p (y + µ)e 2 2 dy
2⇡ 2 1
Z 1 Z 1
1 y2 1 y2
=p ye 2 dy + p
2
µe 2 2 dy
2⇡ 2 1 2⇡ 2 1
✓ Z 1 ◆
(b) 1 y 2
= 0+µ p e 2 dy2

2⇡ 2 1
(c)
= µ,

where in (a) we substitute y = x µ, in (b) we use the fact that the first integrand is odd
so that the integration is 0, and in (c) we observe that integration over the entire sample
space of the PDF yields 1.

The variance is also derived by substitution.


Z 1
1 (x µ)2
Var[X] = p (x µ)2 e 2 2 dx
2⇡ 2 1
2 Z 1 y2
(a)
= p y 2 e 2 dy
2⇡ 1
2
✓ ◆ 2 Z 1
y2 1 y2
=p ye 2 +p e 2 dy
2⇡ 1 2⇡ 1
✓ Z 1 ◆
1 y2
=0+ 2 p e 2 dy
2⇡ 1
2
= ,

where in (a) we substitute y = (x µ)/ .

4.6.2 Standard Gaussian


We need to evaluate the probability P[a  X  b] of a Gaussian random variable X in many
practical situations. This involves the integration of the Gaussian PDF, i.e., determining the
CDF. Unfortunately, there is no closed-form expression of P[a  X  b] in terms of (µ, 2 ).
This leads to what we call the standard Gaussian.

Definition 4.14. The standard Gaussian (or standard normal) random variable X
has a PDF
1 x2
fX (x) = p e 2 . (4.27)
2⇡
2
That is, X ⇠ N (0, 1) is a Gaussian with µ = 0 and = 1.

The CDF of the standard Gaussian can be determined by integrating the PDF. We have a
special notation for this CDF. Figure 4.26 illustrates the idea.

213
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Definition 4.15. The CDF of the standard Gaussian is defined as the (·) function
Z x
def 1 t2
(x) = FX (x) = p e 2 dt. (4.28)
2⇡ 1

Figure 4.26: Definition of the CDF of the standard Gaussian (x).

% MATLAB code to generate standard Gaussian PDF and CDF


x = linspace(-5,5,1000);
f = normpdf(x,0,1);
F = normcdf(x,0,1);
figure; plot(x, f);
figure; plot(x, F);

# Python code to generate standard Gaussian PDF and CDF


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.linspace(-10,10,1000)
f = stats.norm.pdf(x)
F = stats.norm.cdf(x)
plt.plot(x,f); plt.show()
plt.plot(x,F); plt.show()

The standard Gaussian’s CDF is related to a so-called error function defined as


Z x
2 2
erf(x) = p e t dt. (4.29)
⇡ 0

It is easy to link (x) with erf(x):


 ✓ ◆
1 x p
(x) = 1 + erf p , and erf(x) = 2 (x 2) 1.
2 2

With the standard Gaussian CDF, we can define the CDF of an arbitrary Gaussian.

214
4.6. GAUSSIAN RANDOM VARIABLES

2
Theorem 4.11 (CDF of an arbitrary Gaussian). Let X ⇠ N (µ, ). Then
✓ ◆
x µ
FX (x) = . (4.30)

Proof. We start by expressing FX (x):


FX (x) = P[X  x]
Z x
1 (t µ)2
= p e 2 2 dt.
2⇡ 2
1
t µ
Substituting y = , and using the definition of standard Gaussian, we have
Z x Z x µ
1 (t µ)2 1 y2
p e 2 2 dt = p e 2 dy
1 2⇡ 2 1 2⇡
✓ ◆
x µ
= .

If you would like to verify this on a computer, you can try the following code.
% MATLAB code to verify standardized Gaussian
x = linspace(-5,5,1000);
mu = 3; sigma = 2;
f1 = normpdf((x-mu)/sigma,0,1); % standardized
f2 = normpdf(x, mu, sigma); % raw

# Python code to verify standardized Gaussian


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
x = np.linspace(-5,5,1000)
mu = 3; sigma = 2;
f1 = stats.norm.pdf((x-mu)/sigma,0,1) # standardized
f2 = stats.norm.cdf(x,mu,sigma) # raw

An immediate consequence of this result is that


✓ ◆ ✓ ◆
b µ a µ
P[a < X  b] = . (4.31)

To see this, note that


P[a < X  b] = P[X  b] P[X  a]
✓ ◆ ✓ ◆
b µ a µ
= .

The inequality signs of the two end points are not important. That is, the statement also
holds for P[a  X  b] or P[a < X < b], because X is a continuous random variable at
every x. Thus, P[X = a] = P[X = b] = 0 for any a and b. Besides this, has several
properties of interest. See if you can prove these:

215
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

2
Corollary 4.1. Let X ⇠ N (µ, ). Then the following results hold:
(y) = 1 ( y).
⇣ ⌘
b µ
P[X b] = 1 .
⇣ ⌘ ⇣ ⌘
b µ b µ
P[|X| b] = 1 + .

4.6.3 Skewness and kurtosis


In modern data analysis we are sometimes interested in high-order moments. Here we con-
sider two useful quantities: skewness and kurtosis.

Definition 4.16. For a random variable X with PDF fX (x), define the following
central moments as
def
mean = E[X] = µ,
h i
2 def
variance = E (X µ) = 2 ,
"✓ ◆3 #
X µ def
skewness = E = ,
"✓ ◆4 #
X µ def def
kurtosis = E = , excess kurtosis =  3.

As you can see from the definitions above, skewness is the third central moment,
whereas kurtosis is the fourth central moment. Both skewness and kurtosis can be regarded
as “deviations” from a standard Gaussian —not in terms of mean and variance but in terms
of shape.
Skewness measures the asymmetry of the distribution. Figure 4.27 shows three di↵er-
ent distributions: one with left skewness, one with right skewness, and one symmetric. The
skewness of a curve is
Skewed towards left: positive
Skewed towards right: negative
Symmetric: zero

What is skewness?
⇣ ⌘3
E X µ .

Measures the asymmetry of the distribution.


Gaussian has skewness 0.

216
4.6. GAUSSIAN RANDOM VARIABLES

0.4
positive skewness
symmetric
0.3 negative skewness

0.2

0.1

0
0 5 10 15 20

Figure 4.27: Skewness of a distribution measures the asymmetry of the distribution. In this example
the skewnesses are: orange = 0.8943, black = 0, blue = -1.414.

Kurtosis measures how heavy-tailed the distribution is. There are two forms of kurtosis:
one is the standard kurtosis, which is the fourth central moment, and the other is the excess
kurtosis, which is excess =  3. The constant 3 comes from the kurtosis of a standard
Gaussian. Excess kurtosis is more widely used in data analysis. The interpretation of kurtosis
is the comparison to a Gaussian. If the kurtosis is positive, the distribution has a tail that
decays faster than a Gaussian. If the kurtosis is negative, the distribution has a tail that
decays more slowly than a Gaussian. Figure 4.28 illustrates the (excess) kurtosis of three
di↵erent distributions.
1
kurtosis > 0
0.8 kurtosis = 0
kurtosis < 0
0.6

0.4

0.2

0
-5 -4 -3 -2 -1 0 1 2 3 4 5

Figure 4.28: Kurtosis of a distribution measures how heavy-tailed the distribution is. In this example,
the (excess) kurtoses are: orange = 2.8567, black = 0, blue = 0.1242.

What is kurtosis?
⇣ ⌘4
=E X µ .

Measures how heavy-tailed the distribution is. Gaussian has kurtosis 3.


Some statisticians prefer excess kurtosis  3, so that Gaussian has excess
kurtosis 0.

217
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Random variable Mean Variance Skewness Excess kurtosis


2
µ  3
Bernoulli p p(1 p) p1 2p 1
1 p + 1
p 6
p(1 p)

p1 2p 6p2 6p+1
Binomial np np(1 p) np(1 p)
np(1 p)
1 1 p p2 p p2 6p+6
Geometric p p2 1 p 1 p

Poisson p1 1

a+b (b a)2 6
Uniform 2 12 0 5
1 1
Exponential 2 2 6
2
Gaussian µ 0 0

Table 4.1: The first few moments of commonly used random variables.

On a computer, computing the empirical skewness and kurtosis is done by built-in


commands. Their implementations are based on the finite-sample calculations
N ✓ ◆3
1 X Xn µ
⇡ ,
N n=1
N ✓ ◆4
1 X Xn µ
⇡ .
N n=1

The MATLAB and Python built-in commands are shown below, using a gamma distribution
as an example.

% MATLAB code to compute skewness and kurtosis


X = random(’gamma’,3,5,[10000,1]);
s = skewness(X);
k = kurtosis(X);

# Python code to compute skewness and kurtosis


import scipy.stats as stats
X = stats.gamma.rvs(3,5,size=10000)
s = stats.skew(X)
k = stats.kurtosis(X)

Example 4.24. To further illustrate the behavior of skewness and kurtosis, we consider
an example using the gamma random variable X. The PDF of X is given by the
equation
1 x
fX (x) = xk 1 e ✓ , (4.32)
(k)✓k
where (·) is known as the gamma function. If k is an integer, the gamma function is

218
4.6. GAUSSIAN RANDOM VARIABLES

just the factorial: (k) = (k 1)!. A gamma random variable is parametrized by two
parameters (k, ✓). As k increases or decreases, the shape of the PDF will change. For
example, when k = 1, the distribution is simplified to an exponential distribution.
Without going through the (tedious) integration, we can show that the skewness
and the (excess) kurtosis of Gamma(k, ✓) are
2
skewness = p ,
k
6
(excess) kurtosis = .
k
As we can see from these results, the skewness and kurtosis diminish as k grows. This
can be confirmed from the PDF of Gamma(k, ✓) as shown in Figure 4.29.
0.4
k=2
k=5
0.3 k = 10
k = 15
k = 20
0.2

0.1

0
0 5 10 15 20 25 30

Figure 4.29: The PDF of a gamma distribution Gamma(k, ✓), where ✓ = 1. The skewness and
the kurtosis are decaying to zero.

Example 4.25. Let us look at a real example. On April 15, 1912, RMS Titanic sank
after hitting an iceberg. The disaster killed 1502 out of 2224 passengers and crew. A
hundred years later, we want to analyze the data. At https://www.kaggle.com/c/
titanic/ there is a dataset collecting the identities, age, gender, etc., of the passengers.
We partition the dataset into two: one for those who died and the other one for those
who survived. We plot the histograms of the ages of the two groups and compute
several statistics of the dataset. Figure 4.30 shows the two datasets.

40 40

30 30

20 20

10 10

0 0
0 20 40 60 80 0 20 40 60 80
age age

Group 1 (died) Group 2 (survived)

219
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Figure 4.30: The Titanic dataset https://www.kaggle.com/c/titanic/.

Statistics Group 1 (Died) Group 2 (Survived)


Mean 30.6262 28.3437
Standard Deviation 14.1721 14.9510
Skewness 0.5835 0.1795
Excess Kurtosis 0.2652 0.0772
Note that the two groups of people have very similar means and standard devia-
tions. In other words, if we only compare the mean and standard deviation, it is nearly
impossible to di↵erentiate the two groups. However, the skewness and kurtosis provide
more information related to the shape of the histograms. For example, Group 1 has
more positive skewness, whereas Group 2 is almost symmetrical. One interpretation is
that more young people o↵ered lifeboats to children and older people. The kurtosis of
Group 1 is slightly positive, whereas that of Group 2 is slightly negative. Therefore,
high-order moments can sometimes be useful for data analysis.

4.6.4 Origin of Gaussian random variables


The Gaussian random variable has a long history. Here, we provide one perspective on why
Gaussian random variables are so useful. We give some intuitive arguments but leave the
formal mathematical treatment for later when we introduce the Central Limit Theorem.
Let’s begin with a numerical experiment. Consider throwing a fair die. We know that
this will give us a (discrete) uniform random variable X. If we repeat the experiment many
times we can plot the histogram, and it will return us a plot of 6 impulses with equal height,
as shown in Figure 4.31(a).
Now, suppose we throw two dice. Call them X1 and X2 , and let Z = X1 + X2 , i.e.,
the sum of two dice. We want to find the distribution of Z. To do so, we first list out all
the possible outcomes in the sample space; this gives us {(1, 1), (1, 2), . . . , (6, 6)}. We then
sum the numbers, which gives us a list of states of Z: {2, 3, 4, . . . , 12}. The probability of
getting these states is shown in Figure 4.31(b), which has a triangular shape. The triangular
shape makes sense because to get the state “2”, we must have the pair (1, 1), which is quite
unlikely. However, if we want to get the state 7, it would be much easier to get a pair, e.g.,
(6, 1), (5, 2), (4, 3), (3, 4), (2, 5), (1, 6) would all do the job.
Now, what will happen if we throw 5 dice and consider Z = X1 +X2 +· · ·+X5 ? It turns
out that the distribution will continue to evolve and give something like Figure 4.31(c).
This is starting to approximate a bell shape. Finally, if we throw 100 dice and consider
Z = X1 + X2 + · · · + X100 , the distribution will look like Figure 4.31(d). The shape is
becoming a Gaussian! This numerical example demonstrates a fascinating phenomenon: As
we sum more random variables, the distribution of the sum will eventually converge to a
Gaussian.
If you are curious about how we plot the above figures, the following MATLAB and
Python code can be useful.

% MATLAB code to show the histogram of Z = X1+X2+X3


N = 10000;
X1 = randi(6,1,N);
X2 = randi(6,1,N);

220
4.6. GAUSSIAN RANDOM VARIABLES

(a) X1 (b) X1 + X2 (c) X1 + · · · + X5 (d) X1 + · · · + X100

Figure 4.31: When adding uniform random variables, the overall distribution approaches a Gaussian as
the number of summed variables increase.

X3 = randi(6,1,N);
Z = X1 + X2 + X3;
histogram(Z, 2.5:18.5);

# Python code to show the histogram of Z = X1+X2+X3


import numpy as np
import matplotlib.pyplot as plt
N = 10000
X1 = np.random.randint(1,6,size=N)
X2 = np.random.randint(1,6,size=N)
X3 = np.random.randint(1,6,size=N)
Z = X1 + X2 + X3
plt.hist(Z,bins=np.arange(2.5,18.5))

Can we provide a more formal description of this? Yes, but we need some new mathe-
matical tools that we have not yet developed. So, for the time being, we will outline the flow
of the arguments and leave the technical details to a later chapter. Suppose we have two
independent random variables with identical distributions, e.g., X1 and X2 , where both are
uniform. This gives us PDFs fX1 (x) and fX2 (x) that are two identical rectangular functions.
By what operation can we combine these two rectangular functions and create a triangle
function? The key lies in the concept of convolution. If you convolve two rectangle functions,
you will get a triangle function. Here we define the convolution of fX as
Z 1
(fX ⇤ fX )(x) = fX (⌧ )fX (x ⌧ ) d⌧.
1

In fact, for any pair of random variables X1 and X2 (not necessarily uniform random vari-
ables), the sum Z = X1 +X2 will have a PDF given by the convolution of the two PDFs. We
have not yet proven this, but if you trust what we are saying, we can e↵ectively generalize
this argument to many random variables. If we have N random variables, then the sum
Z = X1 + X2 + · · · + XN will have a PDF that is the result of N convolutions of all the
individual PDFs.

What is the PDF of X + Y ?


Summing X + Y is equivalent to convolving the PDFs fX ⇤ fY .

221
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

If you sum many random variables, you convolve all their PDFs.

How do we analyze these convolutions? We need a second set of tools related to Fourier
transforms. The Fourier transform of a PDF is known as the characteristic function, which
we will discuss later, but the name is not important now. What matters is the important
property of the Fourier transform, that a convolution in the original space is multiplication
in the Fourier space. That is,

F {(fX ⇤ fX ⇤ · · · ⇤ fX )} = F{fX } · F{fX } · · · · · F{fX }.

Multiplication in the Fourier space is much easier to analyze. In particular, for independent
and identically distributed random variables, the multiplication will easily translate to ad-
dition in the exponent. Then, by truncating the exponent to the second order, we can show
that the limiting object in the Fourier space is approaching a Gaussian. Finally, since the
inverse Fourier transform of a Gaussian remains a Gaussian, we have shown that the infinite
convolution will give us a Gaussian.
Here is some numerical evidence for what we have just described. Recall that the
Fourier transform of a rectangle function is the sinc function. Therefore, if we have an
infinite convolution of rectangular functions, equivalently, we have an infinite product of sinc
functions in the Fourier space. Multiplying sinc functions is reasonably easy. See Figure 4.32
for the first three sincs. It is evident that with just three sinc functions, the shape closely
approximates a Gaussian.

1.25
(sin x)/x
1
(sin x) 2 /x2
0.75 (sin x) 3 /x3
0.5
0.25
0
-0.25
-0.5
-10 -8 -6 -4 -2 0 2 4 6 8 10

Figure 4.32: Convolving the PDF of a uniform distribution is equivalent to multiplying their Fourier
transforms in the Fourier space. As the number of convolutions grows, the product is gradually becoming
Gaussian.

How about distributions that are not rectangular? We invite you to numerically visu-
alize the e↵ect when you convolve the function many times. You will see that as the number
of convolutions grows, the resulting function will become more and more like a Gaussian.
Regardless of what the input random variables are, as long as you add them, the sum will
have a distribution that looks like a Gaussian:

X1 + X2 + · · · + XN Gaussian.

We use the notation to emphasize that the convergence is not the usual form of conver-
gence. We will make this precise later.

222
4.7. FUNCTIONS OF RANDOM VARIABLES

The implication of this line of discussion is important. Regardless of the underlying


true physical process, if we are only interested in the sum (or average), the distribution
will be more or less Gaussian. In most engineering problems, we are looking at the sum
or average. For example, when generating an image using an image sensor, the sensor will
add a certain amount of read noise. Read noise is caused by the random fluctuation of the
electrons in the transistors due to thermal distortions. For high-photon-flux situations, we
are typically interested in the average read noise rather than the electron-level read noise.
Thus Gaussian random variables become a reasonable model for that. In other applications,
such as imaging through a turbulent medium, the random phase distortions (which alter
the phase of the wavefront) can also be modeled as a Gaussian random variable. Here is the
summary of the origin of a Gaussian random variable:

What is the origin of Gaussian?

When we sum many independent random variables, the resulting random vari-
able is a Gaussian.
This is known as the Central Limit Theorem. The theorem applies to any ran-
dom variable.
Summing random variables is equivalent to convolving the PDFs. Convolving
PDFs infinitely many times yields the bell shape.

4.7 Functions of Random Variables

One common question we encounter in practice is the transformation of random variables.


The question can be summarized as follows: Given a random variable X with PDF fX (x)
and CDF FX (x), and supposing that Y = g(X) for some function g, what are fY (y) and
FY (y)? This is a prevalent question. For example, we measure the voltage V , and we want
to analyze the power P = V 2 /R. This involves taking the square of a random variable.
Another example: We know the distribution of the phase ⇥, but we want to analyze the
signal cos(!t + ⇥). This involves a cosine transformation. How do we convert one variable
to another? Answering this question is the goal of this section.

4.7.1 General principle


We will first outline the general principle for tackling this type of problem. In the following
subsection, we will give a few concrete examples.
Suppose we are given a random variable X with PDF fX (x) and CDF FX (x). Let Y =
g(X) for some known and fixed function g. For simplicity, we assume that g is monotonically

223
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

increasing. In this case, the CDF of Y can be determined as follows.


(a) (b)
FY (y) = P[Y  y] = P[g(X)  y]
(c) 1
= P[X  g (y)]
(d) 1
= FX (g (y)).
This sequence of steps is not difficult to understand. Step (a) is the definition of CDF. Step
(b) substitutes g(X) for Y . Step (c) uses the fact that since g is invertible, we can apply
the inverse of g to both sides of g(X)  y to yield X  g 1 (y). Step (d) is the definition of
the CDF, but this time applied to P[X  |] = FX (|), for some |.
It will be useful to visualize the situation in Figure 4.33. Here, we consider a uniformly
distributed X so that the CDF FX (x) is a straight line. According to FX , any samples
drawn according to FX are equally likely, as illustrated by the yellow dots on the x-axis.
As we transform the X’s through Y = g(X), we increase/decrease the spacing between
two samples. Therefore, some samples become more concentrated while some become less
concentrated. The distribution of these transformed samples (the yellow dots on the y-axis)
forms a new CDF FY (y). The result FY (y) = FX (g 1 (y)) holds when we look at Y . The
samples are traveling with g 1 in order to go back to FX . Therefore, we need g 1 in the
formula.

Figure 4.33: When transforming a random variable X to Y = g(X), the distributions are defined
according to the spacing between samples. In this figure, a uniformly distributed X will become squeezed
by some parts of g and widened in other parts of g.

Why should we use the CDF and not the PDF in Figure 4.33? The advantage of the
CDF is that it is an increasing function. Therefore, no matter what the function g is, the
input and the output functions will still be increasing. If we use the PDF, then the non-
monotonic behavior of the PDF will interact with another nonlinear function g. It becomes
much harder to decouple the two.
We can carry out the integrations to determine FX (g 1 (y)). It can be shown that
Z g 1
(y)
FX (g 1
(y)) = fX (x0 ) dx0 , (4.33)
1

224
4.7. FUNCTIONS OF RANDOM VARIABLES

and hence, by the fundamental theorem of calculus, we have


Z g 1
(y)
d d d
fY (y) = FY (y) = FX (g 1
(y)) = fX (x0 ) dx0
dy dy dy 1
✓ 1

dg (y)
= · fX (g 1 (y)), (4.34)
dy

where the last step is due to the chain rule. Based on this line of reasoning we can summarize
a “recipe” for this problem.

How to find the PDF of Y = g(X)


Step 1: Find the CDF FY (y), which is FY (y) = FX (g 1 (y)).
⇣ 1

Step 2: Find the PDF fY (y), which is fY (y) = d g dy (y) · fX (g 1
(y)).

This recipe works when g is a one-to-one mapping. If g is not one-to-one, e.g., g(x) = x2
p
implies g 1 (y) = ± y, then we will have some issues with the above two steps. When this
happens, then instead of writing X  g 1 (y) we need to determine the set {x | g(x)  y}.

4.7.2 Examples

Example 4.26. (Linear transform) Let X be a random variable with PDF fX (x) and
CDF FX (x). Let Y = 2X + 3. Find fY (y) and FY (y). Express the answers in terms of
fX (x) and FX (x).

Solution. We first note that

FY (y) = P[Y  y]
= P[2X + 3  y]
 ✓ ◆
y 3 y 3
=P X = FX .
2 2

Therefore, the PDF is


d
fY (y) = FY (y)
dy
✓ ◆
d y 3
= FX
dy 2
✓ ◆ ✓ ◆ ✓ ◆
0 y 3 d y 3 1 y 3
= FX = fX .
2 dy 2 2 2

Follow-Up. (Linear transformation of a Gaussian random variable).Suppose X is a Gaus-


sian random variable with zero mean and unit variance, and let Y = aX + b. Then the CDF

225
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

and PDF of Y are respectively


✓ ✓ ◆◆
y b
y b
FY (y) = FX = ,
a a
✓ ◆
1 y b 1 (y b)2
fY (y) = fX =p e 2a2 .
a a 2⇡a

Follow-Up. (Linear transformation of an exponential random variable). Suppose X is an


exponential random variable with parameter , and let Y = aX + b. Then the CDF and
PDF of Y are respectively
✓ ◆
y b
FY (y) = FX
a
=1 e a (y b) , y b,
✓ ◆
1 y b
fY (y) = fX
a a

= e a (y b)
, y b.
a

Example 4.27. Let X be a random variable with PDF fX (x) and CDF FX (x). Sup-
posing that Y = X 2 , find fY (y) and FY (y). Express the answers in terms of fX (x)
and FX (x).
Solution. We note that
p p
FY (y) = P[Y  y] = P[X 2  y] = P[ y  X  y]
p p
= FX ( y) FX ( y).

Therefore, the PDF is


d
fY (y) = FY (y)
dy
d p p
= (FX ( y) FX ( y))
dy
0 p dp 0 p d p
= FX ( y) y FX ( y) ( y)
dy dy
1 p p
= p (fX ( y) + fX ( y)) .
2 y

226
4.7. FUNCTIONS OF RANDOM VARIABLES

Figure
p
4.34: When transforming a random variable X to Y = X 2 , the CDF becomes FY (y) =
y a
b a
and the PDF becomes fY (y) = py(b1 a) .

Follow Up. (Square of a uniform random variable) Suppose X is a uniform random variable
in [a, b] (assume a > 0), and let Y = X 2 . Then the CDF and PDF of Y are respectively
p
y a
FY (y) = , a2  y  b2 ,
b a
1
fY (y) = p , a2  y  b2 .
y(b a)

Example 4.28. Let X ⇠ Uniform(0, 2⇡). Suppose Y = cos X. Find fY (y) and FY (y).
Solution. First, we need to find the CDF of X. This can be done by noting that
Z x Z x
0 0 1 x
FX (x) = fX (x ) dx = dx0 = .
1 0 2⇡ 2⇡

Thus, the CDF of Y is

FY (y) = P[Y  y] = P[cos X  y]


1 1
= P[cos y  X  2⇡ cos y]
1 1
= FX (2⇡ cos y) FX (cos y)
1
cos y
=1 .

The PDF of Y is
✓ ◆
d d cos 1 y
fY (y) = FY (y) = 1
dy dy ⇡
1
= p ,
⇡ 1 y2

227
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

d 1 1
where we used the fact that dy cos y=p .
1 y2

Example 4.29. Let X be a random variable with PDF


aex
fX (x) = aex e .

Let Y = eX , and find fY (y).


Solution. We first note that

FY (y) = P[Y  y] = P[eX  y]


Z log y
aex
= P[X  log y] = aex e dx.
1

To find the PDF, we recall the fundamental theorem of calculus. This gives us
Z log y
d x
fY (y) = aex e ae dx
dy 1
✓ ◆ Z !
log y
d d x aex
= log y ae e dx
dy d log y 1
1 log y aelog y ay
= ae e = ae .
y

Closing remark. The transformation of random variables is a fundamental technique in


data science. The approach we have presented is the most rudimentary yet the most intuitive.
The key is to visualize the transformation and how the random samples are allocated after
the transformation. Note that the density of the random samples is related to the slope of
the CDF. Therefore, if the transformation maps many samples to similar values, the slope
of the CDF will be steep. Once you understand this picture, the transformation will be a
lot easier to understand.
Is it possible to replace the paper-and-pencil derivation of a transformation with a
computer? If the objective is to transform random realizations, then the answer is yes
because your goal is to transform numbers to numbers, which can be done on a computer.
p
For example, transforming a sample x1 to x1 is straightforward on a computer. However,
if the objective is to derive the theoretical expression of the PDF, then the answer is no.
Why might we want to derive the theoretical PDF? We might want to analyze the mean,
variance, or other statistical properties. We may also want to reverse-engineer and determine
a transformation that can yield a specific PDF. This would require a paper-and-pencil
derivation. In what follows, we will discuss a handy application of the transformations.

What are the rules of thumb for transformation of random variables?


Always find the CDF FY (y) = P[g(X)  y]. Ask yourself: What are the values
of X such that g(X)  y? Think of the cosine example.

228
4.8. GENERATING RANDOM NUMBERS

Sometimes you do not need to solve for FY (y) explicitly. The fundamental the-
orem of calculus can help you find fY (y).
Draw pictures. Ask yourself whether you need to squeeze or stretch the samples.

4.8 Generating Random Numbers

Most scientific computing software nowadays has built-in random number generators. For
common types of random variables, e.g., Gaussian or exponential, these random number
generators can easily generate numbers according to the chosen distribution. However, if we
are given an arbitrary PDF (or PMF) that is not among the list of predefined distributions,
how can we generate random numbers according to the PDF or PMF we want?

4.8.1 General principle


Generating random numbers according to the desired distribution can be formulated as
an inverse problem. Suppose that we can generate uniformly random numbers according
to Uniform(0,1). This is a fragile assumption, and this process can be done on almost all
computers today. Let us call this random variable U and its realization u. Suppose that we
also have a desired distribution fX (x) (and its CDF FX (x)). We can put the two random
variables U and X on the two axes of Figure 4.35, yielding an input-output relationship.
The inverse problem is: By using what transformation g, such that X = g(U ), can we make
sure that X is distributed according to fX (x) (or FX (x))?

Figure 4.35: Generating random numbers according to a known CDF. The idea is to first generate a
uniform(0,1) random variable, then do an inverse mapping FX 1 .

Theorem 4.12. The transformation g that can turn a uniform random variable into

229
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

a random variable following a distribution FX (x) is given by

g(u) = FX 1 (u). (4.35)

That is, if g = FX 1 , then g(U ) will be distributed according to fX (or FX ).

Proof. First, we know that if U ⇠ Uniform(0, 1), then fU (u) = 1 for 0  u  1, so


Z u
FU (u) = fU (u) du = u,
1

for 0  u  1. Let g = FX 1 and define Y = g(U ). Then the CDF of Y is

FY (y) = P[Y  y] = P[g(U )  y]


= P[FX 1 (U )  y]
= P[U  FX (y)] = FX (y).

Therefore, we have shown that the CDF of Y is the CDF of X. ⇤

The theorem above states that if we want a distribution FX , then the transformation
should be g = FX 1 . This suggests a two-step process for generating random numbers.

How do we generate random numbers from an arbitrary distribution FX ?


Step 1: Generate a random number U ⇠ Uniform(0, 1).
Step 2: Let
Y = FX 1 (U ). (4.36)
Then the distribution of Y is FX .

4.8.2 Examples

Example 4.30. How can we generate Gaussian random numbers with mean µ and
variance 2 from uniform random numbers?

First, we generate U ⇠ Uniform(0, 1). The CDF of the ideal distribution is


✓ ◆
x µ
FX (x) = .

Therefore, the transformation g is

g(U ) = FX 1 (U ) = 1
(U ) + µ.

In Figure 4.36, we plot the CDF of FX and the transformation g.

230
4.8. GENERATING RANDOM NUMBERS

1 -4
10
0.9 9
0.8 8
7
0.7
6
0.6 5
0.5 4
3
0.4
2
0.3 1
0.2 0
-1
0.1 -2
0 -3
-10 -8 -6 -4 -2 0 2 4 6 8 10 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1

(a) FX (·) (b) g(·)

Figure 4.36: To generate random numbers according to Gaussian(0, 1), we plot its CDF in (a)
and the transformation g in (b).

To visualize the random variables before and after the transformation, we plot
the histograms in Figure 4.37.
400 1200

1000
300
800

200 600

400
100
200

0 0
0 0.2 0.4 0.6 0.8 1 -5 0 5 10

(a) PDF of U (b) PDF of g(U )

Figure 4.37: (a) PDF of the uniform random variable. (b) The PDF of the transformed random
variable.

The MATLAB and Python codes used to generate the histograms above are shown
below.

% MATLAB code to generate Gaussian from uniform


mu = 3;
sigma = 2;
U = rand(10000,1);
gU = sigma*icdf(’norm’,U,0,1)+mu;
figure; hist(U);
figure; hist(gU);

# Python code to generate Gaussian from uniform


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats

231
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

mu = 3
sigma = 2
U = stats.uniform.rvs(0,1,size=10000)
gU = sigma*stats.norm.ppf(U)+mu
plt.hist(U); plt.show()
plt.hist(gU); plt.show()

Example 4.31. How can we generate exponential random numbers with parameter
from uniform random numbers?

First, we generate U ⇠ Uniform(0, 1). The CDF of the ideal distribution is


x
FX (x) = 1 e .
Therefore, the transformation g is
1
g(U ) = FX 1 (U ) = log(1 U ).

The CDF of the exponential random variable and the transformation g are shown
in Figure 4.38.
4
1
0.9 3
0.8
2
0.7
0.6 1
0.5
0
0.4
0.3 7
0.2
6
0.1
0 5
0 1 2 3 4 5 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1

(a) FX (·) (b) g(·)

Figure 4.38: To generate random numbers according to Exponential(1), we plot its CDF in (a)
and the transformation g in (b).

The PDF of the uniform random variable U and the PDF of the transformed
variable g(U ) are shown in Figure 4.39.

232
4.8. GENERATING RANDOM NUMBERS

400 3000

2500
300
2000

200 1500

1000
100
500

0 0
0 0.2 0.4 0.6 0.8 1 0 2 4 6 8 10

(a) PDF of U (b) PDF of g(U )

Figure 4.39: (a) PDF of the uniform random variable. (b) The PDF of the transformed random
variable.

The MATLAB and Python codes for this transformation are shown below.

% MATLAB code to generate exponential random variables


lambda = 1;
U = rand(10000,1);
gU = -(1/lambda)*log(1-U);

# Python code to generate exponential random variables


import numpy as np
import scipy.stats as stats

lambd = 1;
U = stats.uniform.rvs(0,1,size=10000)
gU = -(1/lambd)*np.log(1-U)

Example 4.32. How can we generate the 4 integers 1, 2, 3, 4, according to the his-
togram [0.1 0.5 0.3 0.1], from uniform random numbers?

First, we generate U ⇠ Uniform(0, 1). The CDF of the ideal distribution is


8
>
> 0.1, x = 1,
>
<0.1 + 0.5 = 0.6, x = 2,
FX (x) =
>
> 0.1 + 0.5 + 0.3 = 0.9, x = 3,
>
:
0.1 + 0.5 + 0.3 + 0.1 = 1.0, x = 4.

This CDF is not invertible. However, we can still define the “inverse” mapping

233
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

as

g(U ) = FX 1 (U )
8
>
> 1, 0.0  U  0.1,
>
<2, 0.1 < U  0.6,
=
>
> 3, 0.6 < U  0.9,
>
:
4, 0.9 < U  1.0.

For example, if 0.1 < U  0.6, then on the black curve shown in Figure 4.40(a), we
are looking at the second vertical line from the left. This will go to “2” on the x-axis.
Therefore, the inversely mapped value is 2 for 0.1 < U  0.6.
4
1
0.9

0.6
2

0.1
0
0 1 2 3 4 5 0 0.1 0.6 0.9 1

(a) FX (·) (b) g(·)

Figure 4.40: To generate random numbers according to a predefined histogram, we first define
the CDF in (a) and the corresponding transformation in (b).
The PDFs of the transformed variables, before and after, are shown in Fig-
ure 4.41.
400 6000

5000
300
4000

200 3000

2000
100
1000

0 0
0 0.2 0.4 0.6 0.8 1 0 1 2 3 4 5

(a) PDF of U (b) PDF of g(U )

Figure 4.41: (a) PDF of the uniform random variable. (b) The PDF of the transformed random
variable.

In MATLAB, the above PDFs can be plotted using the commands below. In Python,
we need to use the logical comparison np.logical_and to identify the indices. An alternative
is to use gU[((U<=0.5)*(U>=0.0)).astype(np.bool)]=1.

234
4.9. SUMMARY

% MATLAB code to generate the desired random variables


U = rand(10000,1);
gU = zeros(10000,1);
gU((U>=0) & (U<=0.1)) = 1;
gU((U>0.1) & (U<=0.6)) = 2;
gU((U>0.6) & (U<=0.9)) = 3;
gU((U>0.9) & (U<=1)) = 4;

# Python code to generate the desired random variables


import numpy as np
import scipy.stats as stats

U = stats.uniform.rvs(0,1,size=10000)
gU = np.zeros(10000)
gU[np.logical_and(U >= 0.0, U <= 0.1)] = 1
gU[np.logical_and(U > 0.1, U <= 0.6)] = 2
gU[np.logical_and(U > 0.6, U <= 0.9)] = 3
gU[np.logical_and(U > 0.9, U <= 1)] = 4

4.9 Summary

Let us summarize this chapter by revisiting the four bullet points from the beginning of the
chapter.
Definition of a continuous random variable. Continuous random variables are mea-
sured by lengths, areas, and volumes, which are all defined by integrations. This makes
them di↵erent from discrete random variables, which are measured by counts (and
summations). Because of the di↵erent measures being used to define random variables,
we consequently have di↵erent ways of defining expectation, variance, moments, etc.,
all in terms of integrations.
Unification of discrete and continuous random variables. The unification is done by
the CDF. The CDF of a discrete random variable can be written as a train of step
functions. After taking the derivative, we will obtain the PDF, which is a train of
impulses.
Origin of Gaussian random variables. The origin of the Gaussian random variable lies
in the fact that many observable events in engineering are sums of independent events.
The summation of independent random variables is equivalent to taking convolutions
of the PDFs. At the limit, they will converge to a bell-shaped function, which is the
Gaussian. Gaussians are everywhere because we observe sums more often than we
observe individual states.
Transformation of random variables. Transformation of random variables is done
in the CDF space. The transformation can be used to generate random numbers

235
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

according to a predefined distribution. Specifically, if we want to generate random


numbers according to FX , then the transformation is g = FX 1 .

4.10 Reference

PDF, CDF, expectation


4-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 3.1, 3.2.
4-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 4.1 - 4.3.
4-3 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 4.
4-4 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapter 4.1, 4.2, 5.1, 5.3, 5.5.
4-5 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
4.10, 5.1, 5.2, 5.3.
4-6 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd edition, 2001. Chapter 2.4, 2.5, 4.1, 4.4.

Gaussian random variables


4-7 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 3.3.
4-8 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 4.4.
4-9 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
5.4.
4-10 Mark D. Ward and Ellen Gundlach, Introduction to Probability, W.H. Freeman and
Company, 2016. Chapter 35.

Transformation of random variables


4-11 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 4.1.
4-12 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 4.5.
4-13 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 5.
4-14 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapter 5.4.

236
4.11. PROBLEMS

4-15 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
5.7.
4-16 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd edition, 2001. Chapter 3.1, 3.2.

Advanced probability textbooks


4-17 William Feller, An Introduction to Probability Theory and Its Applications, Wiley and
Sons, 3rd Edition, 1950.
4-18 Andrey Kolmogorov, Foundations of the Theory of Probability, 2nd English Edition,
Dover 2018. (Translated from Russian to English. Originally published in 1950 by
Chelsea Publishing Company New York.)

4.11 Problems

Exercise 1. (Video Solution)


2
Let X be a Gaussian random variable with µ = 5 and = 16.

(a) Find P[X > 4] and P[2  X  7].


(b) If P[X < a] = 0.8869, find a.
(c) If P[X > b] = 0.1131, find b.

(d) If P[13 < X  c] = 0.0011, find c.

Exercise 2. (Video Solution)


Compute E[Y ] and E[Y 2 ] for the following random variables:
2
(a) Y = A cos(!t + ✓), where A ⇠ N (µ, ).

(b) Y = a cos(!t + ⇥), where ⇥ ⇠ Uniform(0, 2⇡).


⇡ ⇡
(c) Y = a cos(!T + ✓), where T ⇠ Uniform !, ! .

Exercise 3. (Video Solution)


Consider a CDF 8
>0,
>
>
if x < 1,
<0.5, if 1  x < 0,
FX (x) =
>(1 + x)/2,
> if 0  x < 1,
>
:
1, otherwise.

(a) Find P[X < 1], P[ 0.5 < X < 0.5] and P[X > 0.5].
(b) Find fX (x).

237
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

Exercise 4. (Video Solution)


A random variable X has CDF:
(
0, if x < 0,
FX (x) = 1 2x
1 4e , if x 0.

(a) Find P[X  2], P[X = 0], P[X < 0], P[2 < X < 6] and P[X > 10].
(b) Find fX (x).

Exercise 5. (Video Solution)


A random variable X has PDF
(
cx(1 x2 ), 0  x  1,
fX (x) =
0, otherwise.

Find c, FX (x), and E[X].

Exercise 6. (Video Solution)


A continuous random variable X has a cumulative distribution
8
>
<0, x < 0,
2
FX (x) = 0.5 + c sin (⇡x/2), 0  x  1,
>
:
1, x > 1.

(a) What values can c assume?


(b) Find fX (x).

Exercise 7. (Video Solution)


A continuous random variable X is uniformly distributed in [ 2, 2].
(a) Let Y = sin(⇡X/8). Find fY (y).
(b) Let Z = 2X 2 + 3. Find fZ (z).
d 1 1
Hint: Compute FY (y) from FX (x), and use dy sin y=p .
1 y2

Exercise 8.
Let Y = eX .
(a) Find the CDF and PDF of Y in terms of the CDF and PDF of X.
(b) Find the PDF of Y when X is a Gaussian random variable. In this case, Y is said to
be a lognormal random variable.

Exercise 9.
The random variable X has the PDF
(
1
p
2 x
, 0  x  1,
fX (x) =
0, otherwise.

238
4.11. PROBLEMS

Let Y be a new random variable


8
>
<0, X < 0,
p
Y = X, 0  X  1,
>
:
1, X > 1.
Find FY (y) and fY (y), for 1 < y < 1.

Exercise 10.
A random variable X has the PDF
(
x2
2xe , x 0,
fX (x) =
0, x < 0.
Let (
X2
1 e , X 0,
Y = g(X) =
0, X < 0.
Find the PDF of Y .

Exercise 11.
A random variable X has the PDF
1 |x|
fX (x) = e , 1 < x < 1.
2
X
Let Y = g(X) = e . Find the PDF of Y .

Exercise 12.
A random variable X has the PDF
1 x2
fX (x) = p e 2 2 , 1 < x < 1.
2⇡ 2

Find the PDF of Y where


(
X, |X| > K,
Y = g(X) =
X, |X| < K.

Exercise 13.
A random variable X has the PDF
1 x2
fX (x) = p e 2 , 1 < x < 1.
x2 2⇡
1
Let Y = g(X) = X. Find the PDF of Y .

Exercise 14.
A random variable X has the CDF
8
>
<0, x < 0,
FX (x) = x↵ , 0  x  1,
>
:
1, x > 1,

239
CHAPTER 4. CONTINUOUS RANDOM VARIABLES

with ↵ > 0. Find the CDF of Y if

Y = g(X) = log X.

Exercise 15.
Energy efficiency is an important aspect of designing electrical systems. In some modern
buildings (e.g., airports), traditional escalators are being replaced by a new type of “smart”
escalator which can automatically switch between a normal operating mode and a standby
mode depending on the flow of pedestrians.
(a) The arrival of pedestrians can be modeled as a Poisson random variable. Let N be the
number of arrivals, and let be the arrival rate (people per minute). For a period of
t minutes, show that the probability that there are n arrivals is

( t)n t
P(N = n) = e .
n!

(b) Let T be a random variable denoting the interarrival time (i.e., the time between two
consecutive arrivals). Show that
t
P(T > t) = e .

Also, determine FT (t) and fT (t). Sketch fT (t).


(Hint: Note that P(T > t) = P(no arrival in t minutes).)
(c) Suppose that the escalator will go into standby mode if there are no pedestrians for
t0 = 30 seconds. Let Y be a random variable denoting the amount of time that the
escalator is in standby mode. That is, let
(
0, if T  t0 ,
Y =
T t0 , if T > t0 .

Find E[Y ].

240
Chapter 5

Joint Distributions

When you go to a concert hall, sometimes you may want to see a solo violin concert, but other
times you may want to see a symphony. Symphonies are appealing because many instruments
are playing together. Random variables are similar. While single random variables are useful
for modeling simple events, we use multiple random variables to describe complex events.
The multiple random variables can be either independent or correlated. When many random
variables are present in the problem, we enter the subject of joint distribution.

What are joint distributions?


In the simplest sense, joint distributions are extensions of the PDFs and PMFs we studied
in the previous chapters. We summarize them as follows.

Joint distributions are high-dimensional PDFs (or PMFs or CDFs).

What do we mean by a high-dimensional PDF? We know that a single random variable is


characterized by a 1-dimensional PDF fX (x). If we have a pair of random variables, then
we use a 2-dimensional function fX,Y (x, y), and if we have a triplet of random variables,
we use a 3-dimensional function fX,Y,Z (x, y, z). In general, the dimensionality of the PDF
grows as the number of variables:

fX (x) =) fX1 ,X2 (x1 , x2 ) =) · · · =) fX1 ,...,XN (x1 , . . . , xN ).


| {z } | {z } | {z }
one variable two variables N variables

For busy engineers like us, fX1 ,...,XN (x1 , . . . , xN ) is not a friendly notation. A more con-
cise way to write fX1 ,...,XN (x1 , . . . , xN ) is to define a vector of random variables X =
[X1 , X2 , . . . , XN ]T with a vector of states x = [x1 , x2 , . . . , xN ]T , and to define the PDF as

fX (x) = fX1 ,...,XN (x1 , . . . , xN ).

Under what circumstance will we encounter creatures like fX (x)? Believe it or not,
these high-dimensional PDFs are everywhere. In 2010, computer-vision scientists created
the ImageNet dataset, containing 14 million images with ground-truth class labels. This
enormous dataset has enabled a great blossoming of machine learning over the past several

241
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.1: Joint distributions are ubiquitous in modern data analysis. For example, an image from a
dataset can be represented by a high-dimensional vector x. Each vector has a certain probability of
being present. This probability is described by the high-dimensional joint PDF fX (x). The goal of this
chapter is to understand the properties of this fX .

0.5 0.5

0.1 0.4 0.4

0.3 0.3
0.05

0.2 0.2

0 0.1
5 4 0.1
3 2 5
1 0 3 4
-1 1 2 0 0
-2 -3 -2 -1 0 -5 -4 -3 -2 -1 0 1 2 3 4 5
-4 -5 -3 -5 -4 -3 -2 -1 0 1 2 3 4 5
y -5 -4 y
x x

Figure 5.2: A 2-dimensional PDF fX,Y (x, y) of a pair of random variables (X, Y ) and their respective
1D PDFs fX (x) and fY (y).

decades, in which many advances in deep learning have been made. Fundamentally, the
ImageNet dataset provides a large collection of samples drawn from a latent distribution
that is high-dimensional. Each sample in the ImageNet dataset is a 224 ⇥ 224 ⇥ 3 image (the
three numbers stand for the image’s height, width, and color). If we convert this image into
a vector, then the sample will have a dimension of 224 ⇥ 224 ⇥ 3 = 150,528. In other words,
the sample is a vector x 2 R150528⇥1 . The probability of obtaining a particular sample x
is determined by probability density function fX (x). For example, it is more likely to get
an image containing trees than one containing a Ferrari. The manifold generated by fX (x)
can be extremely complex, as illustrated in Figure 5.1.
The story of ImageNet is just one of the many instances for which we use a joint
distribution fX (x). Joint distributions are ubiquitous. If you do data science, you must
understand joint distributions. However, extending a 1-dimensional function fX (x) to a
2-dimensional function fX,Y (x, y) and then to a N -dimensional function fX (x) is not trivial.
The goal of this chapter is to guide you through these important steps.

Plan of Part 1 of this chapter: Two variables


This chapter is broadly divided into two halves. In the first half, we will look at a pair of
random variables.
Definition of fX,Y (x, y). The first thing we need to learn is the definition of a joint
distribution with two variables. Since we have two variables, the joint probability
density function (or probability mass function) is a 2-dimensional function. A point

242
on this 2D function is the probability density evaluated by a pair of variables X = x
and Y = y, as illustrated in Figure 5.2. However, how do we formally define this 2D
function? How is it related to the probability measure? Is there a way we can retrieve
fX (x) and fY (y) from fX,Y (x, y), as illustrated on the right-hand sides of Figure 5.2?
These questions will be answered in Section 5.1.
Joint expectation E[XY ]. When we have a pair of random variables, how should we
define the expectation? In Section 5.2, we will show that the most natural way to define
the joint expectation is in terms of E[XY ], i.e., the expectation of the product. There
is a surprising and beautiful connection between this “expectation of the product” and
the cosine angle between two vectors, thereby showing that E[XY ] is the correlation
between X and Y .
The reason for studying a pair of random variables is to spell out the cause-e↵ect
relationship between the variables. This cannot be done without conditional distri-
butions; this will be explained in Section 5.3. Conditional distributions provide an
extremely important computational tool for decoupling complex events into simpler
events. Such decomposition allows us to solve difficult joint expectation problems via
simple conditional expectations; this subject will be covered in Section 5.4.
If you recall our discussions about the origin of a Gaussian random variable, we claimed
that the PDF of X + Y is the convolution between fX and fY . Why is this so? We
will answer this question in terms of joint distributions in Section 5.5.

Plan of Part 2 of this chapter: N variables


The second half of the chapter focuses on the general case of N random variables. This
requires the definitions of a random vector X = [X1 , . . . , XN ]T , a joint distribution fX (x),
and the corresponding expectations E[X]. To make our discussions concrete, we will focus
on the case of high-dimensional Gaussian random variables and discuss the following topics.
Covariance matrices/correlation matrices. If a pair of random variables can define
the correlation through the expectation of the product E[X1 X2 ], then for a vector of
random variables we can consider a matrix of correlations in the form
2 3
E[X1 X1 ] E[X1 X2 ] · · · E[X1 XN ]
6 E[X2 X1 ] E[X2 X2 ] · · · E[X2 XN ] 7
6 7
R=6 .. .. .. .. 7.
4 . . . . 5
E[XN X1 ] E[XN X2 ] · · · E[XN XN ]

What are the properties of the matrix? How does it a↵ect the shape of the high-
dimensional Gaussian? If we have a dataset of vectors, how do we estimate this matrix
from the data? We will answer these questions in Section 5.6 and Section 5.7.
Principal-component analysis. Given the covariance matrix, we can perform some
very useful data analyses, such as the principal-component analysis in Section 5.8.
The question we will ask is: Among the many components, which one is the principal
component? If we can find the principal component(s), we can e↵ectively perform
dimensionality reduction by projecting a high-dimensional vector into low-dimensional
representations. We will introduce an application for face detection.

243
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.3: When there is a pair of random variables, we can regard the sample space as a set of
coordinates. The random variables are 2D mappings from a coordinate ! in ⌦X ⇥ ⌦Y to another
coordinate X(!) in R2 .

5.1 Joint PMF and Joint PDF

Probability is a measure of the size of a set. This principle applies to discrete random vari-
ables, continuous random variables, single random variables, and multiple random variables.
In situations with a pair of random variables, the measure should be applied to the coordi-
nate (X, Y ) represented by the random variables X and Y . Consequently, when measuring
the probability, we either count these coordinates or integrate the area covered by these
coordinates. In this section, we formalize this notion of measuring 2D events.

5.1.1 Probability measure in 2D


Consider two random variables X and Y . Let the sample space of X and Y be ⌦X and
⌦Y , respectively. Define the Cartesian product of ⌦X and ⌦Y as ⌦X ⇥ ⌦Y = {(x, y) | x 2
⌦X and y 2 ⌦Y }. That is, ⌦X ⇥ ⌦Y contains all possible pairs (X, Y ).

Example 5.1. If ⌦X = {1, 2} and ⌦Y = {4, 5}, then ⌦X ⇥ ⌦Y = {(1, 4), (1, 5),
(2, 4), (2, 5)}.

244
5.1. JOINT PMF AND JOINT PDF

Example 5.2. If ⌦X = [3, 4] and ⌦Y = [1, 2], then ⌦X ⇥ ⌦Y = a rectangle with two
diagonal vertices as (3, 1) and (4, 2).

Random variables are mappings from the sample space to the real line. If ! 2 ⌦X is
mapped to X(!) 2 R, and ⇠ 2 ⌦Y is mapped to Y (⇠) 2 R, then a coordinate ! = (!, ⇠) in
the sample space ⌦X ⇥ ⌦Y should be mapped to a coordinate (X(!), Y (⇠)) in the 2D plane.
 
def ! X(!) def
! = 7 ! = X(!).
⇠ Y (⇠)
We denote such a vector-to-vector mapping as X(·) : ⌦X ⇥ ⌦Y ! R ⇥ R, as illustrated in
Figure 5.3.
Therefore, if we have an event A 2 R2 , the probability that A happens is

P[A] = P[{! | X(!) 2 A}]


⇢  
! X(!)
=P 2A
⇠ Y (⇠)
⇢ 
!
=P 2 X 1 (A)

1
= P[! 2 X (A)].

In other words, we take the coordinate X(!) and find its inverse image X 1 (A). The size
of this inverse image X 1 (A) in the sample space ⌦X ⇥ ⌦Y is then the probability. We
summarize this general principle as follows.

How to measure probability in 2D


For a pair of random variables X = (X, Y ), the probability of an event A is measured
in the product space ⌦X ⇥ ⌦Y with the size
1
P[{! | X (A)}].

This definition is quite abstract. To make it more concrete, we will look at discrete and
continuous random variables.

5.1.2 Discrete random variables


Suppose that the random variables X and Y are discrete. Let A = {X(!) = x, Y (⇠) = y}
be a discrete event. Then the above definition tells us that the probability of A is

P[A] = P (!, ⇠) X(!) = x, and Y (⇠) = y = P[X = x and Y = y].
| {z }
def
= pX,Y (x,y)

We define this probability as the joint probability mass function (joint PMF) pX,Y (x, y).

245
CHAPTER 5. JOINT DISTRIBUTIONS

Definition 5.1. Let X and Y be two discrete random variables. The joint PMF of X
and Y is defined as

pX,Y (x, y) = P[X = x and Y = y] = P (!, ⇠) X(!) = x, and Y (⇠) = y . (5.1)

We sometimes write the joint PMF as pX,Y (x, y) = P[X = x, Y = y].

Figure 5.4: A joint PMF for a pair of discrete random variables consists of an array of impulses. To
measure the size of the event A, we sum all the impulses inside A.

Figure 5.4 shows a graphical portrayal of the joint PMF. In a nutshell, pX,Y (x, y)
can be considered as a 2D extension of a single variable PMF. The probabilities are still
represented by the impulses, but the domain of these impulses is now a 2D plane. If we have
an event A, then the size of the event is
X
P[A] = pX,Y (x, y).
(x,y)2A

Example 5.3. Let X be a coin flip, Y be a die. The sample space of X is {0, 1},
whereas the sample space of Y is {1, 2, 3, 4, 5, 6}. The joint PMF, according to our
definition, is the probability P[X = x and Y = y], where x takes a binary state and Y
takes one of the 6 states. The following table summarizes all the 12 states of the joint
distribution.
Y
1 2 3 4 5 6
1 1 1 1 1 1
X = 0 12 12 12 12 12 12
1 1 1 1 1 1
X = 1 12 12 12 12 12 12
In this table, since there are 12 coordinates, and each coordinate has an equal
chance of appearing, the probability for each coordinate becomes 1/12. Therefore, the
joint PMF of X and Y is
1
pX,Y (x, y) = , x = 0, 1, y = 1, 2, 3, 4, 5, 6.
12

246
5.1. JOINT PMF AND JOINT PDF

In this example, we observe that if X and Y are not interacting with each other (for-
mally, independent), the joint PMF is the product of the two individual probabilities.

Example 5.4. In the previous example, if we define A = {X + Y = 3}, the probability


P[A] is
X
P[A] = pX,Y (x, y) = pX,Y (0, 3) + pX,Y (1, 2)
(x,y)2A
2
= .
12
If B = {min(X, Y ) = 1}, the probability P[B] is
X
P[B] = pX,Y (x, y)
(x,y)2B

= pX,Y (1, 1) + pX,Y (1, 2) + pX,Y (1, 3)


+ pX,Y (1, 4) + pX,Y (1, 5) + pX,Y (1, 6)
6
= .
12

5.1.3 Continuous random variables


The continuous version of the joint PMF is called the joint probability density function
(joint PDF), denoted by fX,Y (x, y). A joint PDF is analogous to a joint PMF. For example,
integrating it will give us the probability.

Definition 5.2. Let X and Y be two continuous random variables. The joint PDF of
X and Y is a function fX,Y (x, y) that can be integrated to yield a probability
Z
P[A] = fX,Y (x, y) dx dy, (5.2)
A

for any event A ✓ ⌦X ⇥ ⌦Y .

Pictorially, we can view fX,Y as a 2D function where the height at a coordinate (x, y) is
fX,Y (x, y), as can be seen from Figure 5.5. To compute the probability that (X, Y ) 2 A,
we integrate the function fX,Y with respect to the area covered by the set A. For example,
if the set A is a rectangular box A = [a, b] ⇥ [c, d], then the integration becomes

P[A] = P[a  X  b, c  Y  d]
Z dZ b
= fX,Y (x, y) dx dy.
c a

247
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.5: A joint PDF for a pair of continuous random variables is a surface in the 2D plane. To
measure the size of the event A, we integrate fX,Y (x, y) inside A.

Example 5.5. Consider a uniform joint PDF fX,Y (x, y) defined on [0, 2]2 with fX,Y (x, y) =
4 . Let A = [a, b] ⇥ [c, d]. Find P[A].
1

Solution.

P[A] = P[a  X  b, c  X  d]
Z dZ b Z d Z b
1 (d c)(b a)
= fX,Y (x, y) dx dy = dx dy = .
c a c a 4 4

Practice Exercise 5.1. In the previous example, let B = {X + Y  2}. Find P[B].

Solution.
Z Z 2 Z 2 y
P[B] = fX,Y (x, y) dx dy = fX,Y (x, y) dx dy
B 0 0
Z 2 Z 2 y Z 2
1 2 y 1
= dx dy = dy = .
0 0 4 0 4 2

Here, the limits of the integration can be determined from Figure 5.6. The inner
integration (with respect to x) should start from 0 and end at 2 y, which is the line
defining the set x + y  2. Since the inner integration is performed for every y, we
need to enumerate all the possible y’s to complete the outer integration. This leads to
the outer limit from 0 to 2.

5.1.4 Normalization
The normalization property of a two-dimensional PMF and PDF is the property that, when
we enumerate all outcomes of the sample space, we obtain 1.

248
5.1. JOINT PMF AND JOINT PDF

Figure 5.6: To calculate P[X + Y  2], we perform a 2D integration over a triangle.

Theorem 5.1. Let ⌦ = ⌦X ⇥ ⌦Y . All joint PMFs and joint PDFs satisfy
X Z
pX,Y (x, y) = 1 or fX,Y (x, y) dx dy = 1. (5.3)
(x,y)2⌦ ⌦

Example 5.6. Consider a joint uniform PDF defined in the shaded area [0, 3] ⇥ [0, 3]
with PDF defined below. Find the constant c.
(
c if (x, y) 2 [0, 3] ⇥ [0, 3],
fX,Y (x, y) =
0 otherwise.

Solution. To find the constant c, we note that


Z 3Z 3 Z 3 Z 3
1= fX,Y (x, y) dx dy = c dx dy = 9c.
0 0 0 0

Equating the two sides gives us c = 19 .

Practice Exercise 5.2. Consider a joint PDF


(
ce x e y 0  y  x < 1,
fX,Y (x, y) =
0 otherwise.

Find the constant c. Tip: Consider the area of integration as shown in Figure 5.7.

Solution. There are two ways to take the integration shown in Figure 5.7. We choose
the inner integration w.r.t. y first.
Z Z 1Z x Z 1
x y c
fX,Y (x, y) dx dy = ce e dy dx = ce x (1 e x ) = .
⌦ 0 0 0 2

Therefore, c = 2.

249
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.7: To integrate the probability P[0  Y  X], we perform a 2DRintegration over a triangle.
R
The twoR subfigures show theR two ways of integrating the triangle. [Left] dx first, and then dy.
[Right] dy first, and then dx.

5.1.5 Marginal PMF and marginal PDF


If we only sum / integrate for one random variable, we obtain the PMF / PDF of the other
random variable. The resulting PMF / PDF is called the marginal PMF / PDF.

Definition 5.3. The marginal PMF is defined as


X X
pX (x) = pX,Y (x, y) and pY (y) = pX,Y (x, y), (5.4)
y2⌦Y x2⌦X

and the marginal PDF is defined as


Z Z
fX (x) = fX,Y (x, y) dy and fY (y) = fX,Y (x, y) dx. (5.5)
⌦Y ⌦X

Since fX,Y (x, y) is a two-dimensional function, when integrating over y from 1 to 1, we


project fX,Y (x, y) onto the x-axis. Therefore, the resulting function depends on x only.

1
Example 5.7. Consider the joint PDF fX,Y (x, y) = 4 shown below. Find the marginal
PDFs.

250
5.1. JOINT PMF AND JOINT PDF

Solution. If we integrate over x and y, we have


8
8 > 1, if 1 < x  2,
> if 1 < x  2, >
>
<3, <2, if 2 < x  3,
fX (x) = 1, if 2 < x  3, and fY (y) =
>
: >
> 1, if 3 < x  4,
0, otherwise. >
:
0, otherwise.

So the marginal PDFs are the projection of the joint PDFs onto the x- and y-axes.

Practice Exercise 5.3. A joint Gaussian random variable (X, Y ) has a joint PDF
given by ⇢
1 ((x µX )2 + (y µY )2 )
fX,Y (x, y) = 2
exp .
2⇡ 2 2
Find the marginal PDFs fX (x) and fY (y).

Solution.
Z 1
fX (x) = fX,Y (x, y) dy
1
Z 1 ⇢
1 ((x µX )2 + (y µY )2 )
= 2
exp dy
1 2⇡ 2 2
⇢ Z 1 ⇢
1 (x µX )2 1 (y µY )2
=p exp 2
· p exp dy.
2⇡ 2 2 1 2⇡ 2 2 2

Recognizing that the last integral is equal to unity because it integrates a Gaussian
PDF over the real line, it follows that

1 (x µX )2
fX (x) = p exp .
2⇡ 2 2 2

Similarly, we have ⇢
1 (y µY ) 2
fY (y) = p exp 2
.
2⇡ 2 2

5.1.6 Independent random variables


Two random variables are said to be independent if and only if the joint PMF or PDF can
be factorized as a product of the marginal PMF / PDFs.

Definition 5.4. Random variables X and Y are independent if and only if

pX,Y (x, y) = pX (x) pY (y), or fX,Y (x, y) = fX (x) fY (y).

This definition is consistent with the definition of independence of two events. Recall that
two events A and B are independent if and only if P[A\B] = P[A]P[B]. Letting A = {X = x}

251
CHAPTER 5. JOINT DISTRIBUTIONS

and B = {Y = y}, we see that if A and B are independent then P[X = x \ Y = y] is the
product P[X = x]P[Y = y]. This is precisely the relationship pX,Y (x, y) = pX (x) pY (y).

Example 5.8. Consider two random variables with a joint PDF given by

1 (x µX )2 + (y µY )2
fX,Y (x, y) = 2
exp .
2⇡ 2 2

Are X and Y independent?

Solution. We know that


⇢ ⇢
1 (x µX )2 1 (y µY )2
fX,Y (x, y) = p exp ⇥ p exp .
2⇡ 2 2 2⇡ 2 2
| {z } | {z }
fX (x) fY (y)

Therefore, the random variables X and Y are independent.

Practice Exercise 5.4. Let X be a coin and Y be a die. Then the joint PMF is given
by the table below.
Y
1 2 3 4 5 6
1 1 1 1 1 1
X=0 12 12 12 12 12 12
1 1 1 1 1 1
X=1 12 12 12 12 12 12
Are X and Y independent?

Solution. For any x and y, we have that


1 1 1
pX,Y (x, y) = = ⇥ .
12 2
|{z} 6
|{z}
pX (x) pY (y)

Therefore, the random variables X and Y are independent.

Example 5.9. Consider two random variables X and Y with a joint PDF given bya

fX,Y (x, y) / exp (x y)2 = exp x2 + 2xy y2


= exp x2 exp {2xy} exp y2 .
| {z } | {z } | {z }
fX (x) extra term fY (y)

This PDF cannot be factorized into a product of two marginal PDFs. Therefore, the
random variables are dependent.
a We use the notation “/” to denote “proportional to”. It implies that the normalization constant

is omitted.

252
5.1. JOINT PMF AND JOINT PDF

We can extrapolate the definition of independence to multiple random variables. If


there are many random variables X1 , X2 , . . . , XN , they will have a joint PDF
fX1 ,...,XN (x1 , . . . , xN ).
If these random variables X1 , X2 , . . . , XN are independent, then the joint PDF can be
factorized as
fX1 ,...,XN (x1 , . . . , xN ) = fX1 (x1 ) · fX2 (x2 ) · · · fXN (xN )
N
Y
= fXn (xn ).
n=1

This gives us the definition of independence for N random variables.

Definition 5.5. A sequence of random variables X1 , . . . , XN is independent if and


only if their joint PDF (or joint PMF) can be factorized.
N
Y
fX1 ,...,XN (x1 , . . . , xN ) = fXn (xn ). (5.6)
n=1

Example 5.10. Throw a die 4 times. Let X1 , X2 , X3 and X4 be the outcomes. Then,
since these four throws are independent, the probability mass function of any quadrable
(x1 , x2 , x3 , x4 ) is

pX1 ,X2 ,X3 ,X4 (x1 , x2 , x3 , x4 ) = pX1 (x1 ) pX2 (x2 ) pX3 (x3 ) pX4 (x4 ).

For example, the probability of getting (1, 5, 2, 6) is


✓ ◆4
1
pX1 ,X2 ,X3 ,X4 (1, 5, 2, 6) = pX1 (1) pX2 (5) pX3 (2) pX4 (6) = .
6

The example above demonstrates an interesting phenomenon. If the N random vari-


ables are independent, and if they all have the same distribution, then the joint PDF/PMF
is just one of the individual PDFs taken to the power N . Random variables satisfying this
property are known as independent and identically distributed random variables.

Definition 5.6 (Independent and Identically Distributed (i.i.d.)). A collection of


random variables X1 , . . . , XN is called independent and identically distributed (i.i.d.)
if
All X1 , . . . , XN are independent; and
All X1 , . . . , XN have the same distribution, i.e., fX1 (x) = · · · = fXN (x).

If X1 , . . . , XN are i.i.d., we have that


N
Y
fX1 ,...,XN (x1 , . . . , x1 ) = fX1 (xn ),
n=1

253
CHAPTER 5. JOINT DISTRIBUTIONS

where the particular choice of X1 is unimportant because fX1 (x) = · · · = fXN (x).

Why is i.i.d. so important?


If a set of random variables are i.i.d., then the joint PDF can be written as a
product of PDFs.
Integrating a joint PDF is difficult. Integrating a product of PDFs is much easier.

Example 5.11. Let X1 , X2 , . . . , XN be a sequence of i.i.d. Gaussian random variables


where each Xi has a PDF
⇢ 2
1 x
fXi (x) = p exp .
2⇡ 2

The joint PDF of X1 , X2 , . . . , XN is

YN ⇢ ⇢ 2
1 xi
fX1 ,...,XN (x1 , . . . , xN ) = p exp
i=1
2⇡ 2
✓ ◆N ( N
)
1 X x2i
= p exp ,
2⇡ i=1
2

whichPis a function depending not on the individual values of x1 , x2 , . . . , xN but on the


N
sum i=1 x2i . So we have “compressed” an N -dimensional function into a 1D function.

Example 5.12. Let ✓ be a deterministic number that was sent through a noisy channel.
We model the noise as an additive Gaussian random variable with mean 0 and variance
2
. Supposing we have observed measurements Xi = ✓ + Wi , for i = 1, . . . , N , where
Wi ⇠ Gaussian(0, 2 ), then the PDF of each Xi is

1 (x ✓)2
fXi (x) = p exp .
2⇡ 2 2 2

Thus the joint PDF of (X1 , X2 , . . . , XN ) is


N ⇢
Y ⇢
1 (xi ✓)2
fX1 ,...,XN (x1 , . . . , xN ) = p exp
i=1 2⇡ 2 2 2
✓ ◆N ( N
)
1 X (xi ✓)2
= p exp 2
.
2⇡ 2
i=1
2

Essentially, this joint PDF tells us the probability density of seeing sample data
x1 , . . . , x N .

254
5.1. JOINT PMF AND JOINT PDF

5.1.7 Joint CDF


We now introduce the cumulative distribution function (CDF) for multiple variables.

Definition 5.7. Let X and Y be two random variables. The joint CDF of X and Y
is the function FX,Y (x, y) such that

FX,Y (x, y) = P[X  x \ Y  y]. (5.7)

This definition can be more explicitly written as follows.

Definition 5.8. If X and Y are discrete, then


X X
FX,Y (x, y) = pX,Y (x0 , y 0 ). (5.8)
y 0 y x0 x

If X and Y are continuous, then


Z y Z x
FX,Y (x, y) = fX,Y (x0 , y 0 ) dx0 dy 0 . (5.9)
1 1

If the two random variables are independent, then we have


Z x Z y
FX,Y (x, y) = fX (x0 ) dx0 fY (y 0 ) dy 0 = FX (x)FY (y).
1 1

Example 5.13. Let X and Y be two independent uniform random variables


Uniform(0, 1). Find the joint CDF.

Solution.
Z x Z y
0 0
FX,Y (x, y) = FX (x)FY (y) = fX (x ) dx fY (y 0 ) dy 0
0 0
Z x Z y
0
= 1 dx 1 dy 0 = xy.
0 0

Practice Exercise 5.5. Let X and Y be two independent uniform random variables
Gaussian(µ, 2 ). Find the joint CDF.

Solution. Let (·) be the CDF of the standard Gaussian.

FX,Y (x, y) = FX (x)FY (y)


Z x Z y ✓ ◆ ✓ ◆
x µ y µ
= fX (x0 ) dx0 fY (y 0 ) dy 0 = .
1 1

255
CHAPTER 5. JOINT DISTRIBUTIONS

Here are a few properties of the CDF:


Z 1Z x Z x
FX,Y (x, 1) = fX,Y (x0 , y 0 ) dx0 dy 0 = 0 dx0 = 0,
1 1 1
Z y Z 1 Z y
FX,Y ( 1, y) = fX,Y (x0 , y 0 ) dx0 dy 0 = 0 dy 0 = 0,
1 1 1
Z 1 Z 1
FX,Y ( 1, 1) = fX,Y (x0 , y 0 ) dx0 dy 0 = 0,
1 1
Z 1 Z 1
FX,Y (1, 1) = fX,Y (x0 , y 0 ) dx0 dy 0 = 1.
1 1

In addition, we can obtain the marginal CDF as follows.

Proposition 5.1. Let X and Y be two random variables. The marginal CDF is

FX (x) = FX,Y (x, 1), (5.10)


FY (y) = FX,Y (1, y). (5.11)

Proof. We prove only the first case. The second case is similar.
Z x Z 1 Z y
FX,Y (x, 1) = fX,Y (x0 , y 0 ) dy 0 dx0 = fX (x0 ) dx0 = FX (x). ⇤
1 1 1

By the fundamental theorem of calculus, we can derive the PDF from the CDF.

Definition 5.9. Let FX,Y (x, y) be the joint CDF of X and Y . Then, the joint PDF
is
@2
fX,Y (x, y) = FX,Y (x, y). (5.12)
@y @x

The order of the partial derivatives can be switched, yielding a symmetric result:

@2
fX,Y (x, y) = FX,Y (x, y).
@x @y

Example 5.14. Let X and Y be two uniform random variables with joint CDF
FX,Y (x, y) = xy for 0  x  1 and 0  y  1. Find the joint PDF.
Solution.
@2 @2
fX,Y (x, y) = FX,Y (x, y) = xy = 1,
@x@y @x@y
which is consistent with the definition of a joint uniform random variable.

256
5.2. JOINT EXPECTATION

Practice Exercise 5.6. Let X and Y be two exponential random variables with joint
CDF
FX,Y (x, y) = (1 e x )(1 e y ), x 0, y 0.
Find the joint PDF.

Solution.
@2 @2 x y
fX,Y (x, y) = FX,Y (x, y) = (1 e )(1 e )
@x@y @x@y
@ x y x y
= (1 e )( e ) = e e .
@x
which is consistent with the definition of a joint exponential random variable.

5.2 Joint Expectation

5.2.1 Definition and interpretation


When we have a single random variable, the expectation is defined as
Z
E[X] = xfX (x) dx.

For a pair of random variables, what would be a good way of defining the expectation?
Certainly, we cannot just replace fX (x) by fX,Y (x, y) because the integration has to be-
come a double integration. However, if it is a double integration, where should we put the
variable y? It turns out that a useful way of defining the expectation for X and Y is as
follows.

Definition 5.10. Let X and Y be two random variables. The joint expectation is
X X
E[XY ] = xy · pX,Y (x, y) (5.13)
y2⌦Y x2⌦X

if X and Y are discrete, or


Z Z
E[XY ] = xy · fX,Y (x, y) dx dy (5.14)
y2⌦Y x2⌦X

if X and Y are continuous. Joint expectation is also called correlation.

The double summation and integration on the right-hand side of the equation is nothing
but the state times the probability. Here, the state is the product xy, and the probability is
the joint PMF pX,Y (x, y) (or PDF). Therefore, as long as you agree that joint expectation
should be defined as E[XY ], the double summation and the double integration make sense.

257
CHAPTER 5. JOINT DISTRIBUTIONS

The biggest mystery here is E[XY ]. You may wonder why the joint expectation should
be defined as the expectation of the product E[XY ]. Why not the sum E[X + Y ], or the
di↵erence E[X Y ], or the quotient E[X/Y ]? Why are we so deeply interested in X times Y ?
These are excellent questions. That the joint expectation is defined as the product has to do
with the correlation between two random variables. We will take a small detour into linear
algebra.
Let us consider two discrete random variables X and Y , both with N states. So X
will take the states {x1 , x2 , . . . , xN } and Y will take the states {y1 , y2 , . . . , yN }. Let’s define
def def
them as two vectors: x = [x1 , . . . , xN ]T and y = [y1 , . . . , yN ]T . Since X and Y are random
variables, they have a joint PMF pX,Y (x, y). The array of the PMF values can be written
as a matrix:
2 3
pX,Y (x1 , y1 ) pX,Y (x1 , y2 ) · · · pX,Y (x1 , yN )
6p (x2 , y1 ) pX,Y (x2 , y2 ) · · · pX,Y (x2 , yN ) 7
def 6 X,Y 7
PMF as a matrix = P = 6 .. .. .. .. 7.
4 . . . . 5
pX,Y (xN , y1 ) pX,Y (xN , y2 ) ··· pX,Y (xN , yN )

Let’s try to write the joint expectation in terms of matrices and vectors. The definition
of a joint expectation tells us that
N X
X N
E[XY ] = xi yj · pX,Y (xi , yj ),
i=1 j=1

which can be written as


2 32 3
pX,Y (x1 , y1 ) · · · pX,Y (x1 , yN ) y1
⇥ ⇤6 .. .. .. 76 .. 7 T
E[XY ] = x1 · · · xN 4 . . . 54 . 5 = x P y.
| {z }
x T p X,Y (x N , y1 ) · · · pX,Y (xN , yN ) yN
| {z }| {z }
P y

This is a weighted inner product between x and y using the weight matrix P .

Why correlation is defined as E[XY ]


E[XY ] is a weighted inner product between the states:

E[XY ] = xT P y.

x and y are the states of the random variables X and Y .


The inner product measures the similarity between two vectors.

Example 5.15. Let X be a discrete random variable with N states, where each state
has an equal probability. Thus, pX (x) = 1/N for all x. Let Y = X be another variable.

258
5.2. JOINT EXPECTATION

Then the joint PMF of (X, Y ) is


(
1
pX,Y (x, y) = N, x = y,
0, x 6= y.

It follows that the joint expectation is


N X
X N N
1 X
E[XY ] = xi yj · pX,Y (xi , yj ) = x i yi .
i=1 j=1
N i=1

Equivalently, we can obtain the result via the inner product by defining
21 3
N 0 ··· 0
60 1
··· 0 7 1
6 N 7
P =6. .. .. .. 7 = I.
4 .. . . .5 N
1
0 ··· ··· N

In this case, the weighted inner product is


N
xT y 1 X
xT P y = = xi yi = E[XY ].
N N i=1

How do we understand the inner product? Ignoring the matrix P for a moment, we
recall an elementary result in linear algebra.

Definition 5.11. Let x 2 RN and y 2 RN be two vectors. Define the cosine angle
cos ✓ as
xT y
cos ✓ = , (5.15)
kxkkyk
qP qP
N 2 N 2
where kxk = i=1 xi is the norm of the vector x, and kyk = i=1 yi is the
norm of the vector y.

This definition can be understood as the geometry between two vectors, as illustrated in
Figure 5.8. If the two vectors x and y are parallel so that x = ↵y for some ↵, then the
angle ✓ = 0. If x and y are orthogonal so that xT y = 0, then ✓ = ⇡/2. Therefore, the inner
product xT y tells us the degree of correlation between the vectors x and y.

Now let’s come back to our discussion about the joint expectation. The cosine angle
definition tells us that if E[XY ] = xT P y, the following form would make sense:

xT P y E[XY ]
cos ✓ = = .
kxkkyk kxkkyk

That is, as long as we can find out the norms kxk and kyk, we will be able to interpret
E[XY ] from the cosine angle perspective. But what would be a reasonable definition of kxk

259
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.8: The geometry of joint expectation. E[XY ] gives us the cosine angle between the two random
variables. This, in turn, tells us the correlation between the two random variables.

and kyk? We define the norm by first considering the variance of the random variable X
and Y :
N
X
E[X 2 ] = xi xi · pX (xi )
i=1
2 32 3
pX (x1 ) ··· 0 x1
⇥ ⇤6 . .. .. 76 .. 7
= x1 · · · xN 4 .. . . 54 . 5
| {z }
xT 0 · · · pX (xN ) xN
| {z }| {z }
PX x
T
= x P Xx = kxk2P X ,
where P X is the diagonal matrix storing the probability masses of the random variable X.
It is not difficult to show that P X = diag(P 1) by following the definition of the marginal
distributions (which are the column and row sums of the joint PMF). Similarly we can define
N
X
E[Y 2 ] = yj yj · pY (yj )
j=1
2 32 3
pY (y1 ) ··· 0 y1
⇥ ⇤6 . .. .. 76 .. 7
= y1 · · · yN 4 .. . . 54 . 5
| {z }
yT 0 · · · pY (yN ) yN
| {z }| {z }
PY y
T
= y PY y = kyk2P Y .
Therefore, one way to define the cosine angle is to start with
xT P XY y
cos ✓ = ,
kxkP X kykP Y
p p
where P XY = P , kxkP X = xT P X x and kykP Y = y T P Y y. But writing it in terms of
the expectation, we observe that this cosine angle is exactly
xT P XY y E[XY ]
cos ✓ = =p p .
kxkP X kykP Y E[X 2 ] E[Y 2 ]

260
5.2. JOINT EXPECTATION

Therefore, E[XY ] defines the cosine angle between the two random variables, which, in turn,
defines the correlation between the two. A large |E[XY ]| means that X and Y are highly
correlated, and a small |E[XY ]| means that X and Y are not very correlated. If E[XY ] = 0,
then the two random variables are uncorrelated. Therefore, E[XY ] tells us how the two
random variables are related to each other.
E[XY ]
To further convince you that p p can be interpreted as a cosine angle, we
E[X 2 ] E[Y 2 ]
show that
E[XY ]
1 p p  1,
E[X 2 ] E[Y 2 ]
because if this ratio can go beyond +1 and 1, it makes no sense to call it a cosine angle.
The argument follows from a very well-known inequality in probability, called the Cauchy-
Schwarz inequality (for expectation), which states that 1  p E[XYp ] 2  1:
2 E[X ] E[Y ]

Theorem 5.2 (Cauchy-Schwarz inequality). For any random variables X and Y ,

(E[XY ])2  E[X 2 ]E[Y 2 ]. (5.16)

The following proof can be skipped if you are reading the book the first time.

Proof. Let t 2 R be a constant. Consider E[(X + tY )2 ] = E[X 2 + 2tXY + t2 Y 2 ]. Since


E[(X + tY )2 ] 0 for any t, it follows that

E[X 2 + 2tXY + t2 Y 2 ] 0.

Expanding the left-hand side yields t2 E[Y 2 ] + 2tE[XY ] + E[X 2 ] 0. This is a quadratic
equation in t, and we know that for any quadratic equation at2 + bt + c 0 we must have
b2 4ac  0. Therefore, in our case, we have that

(2E[XY ])2 4E[Y 2 ]E[X 2 ]  0,

which means (E[XY ])2  E[X 2 ]E[Y 2 ]. The equality holds when E[(X + tY )2 ] = 0. In this
case, X = tY for some t, i.e., the random variable X is a scaled version of Y so that the
vector formed by the states of X is parallel to that of Y .

End of the proof.

5.2.2 Covariance and correlation coefficient


In many practical problems, we prefer to work with central moments, i.e., E[(X µX )2 ] in-
stead of E[X 2 ]. This essentially means that we subtract the mean from the random variable.
If we adopt such a centralized random variable, we can define the covariance as follows.

261
CHAPTER 5. JOINT DISTRIBUTIONS

Definition 5.12. Let X and Y be two random variables. Then the covariance of X
and Y is
Cov(X, Y ) = E[(X µX )(Y µY )], (5.17)
where µX = E[X] and µY = E[Y ].

It is easy to show that if X = Y , then the covariance simplifies to the variance:

Cov(X, X) = E[(X µX )(X µX )]


= Var[X].

Thus, covariance is a generalization of variance. The former can handle a pair of variables,
whereas the latter is only for a single variable. We can also demonstrate the following result.

Theorem 5.3. Let X and Y be two random variables. Then

Cov(X, Y ) = E[XY ] E[X]E[Y ] (5.18)

Proof. Just apply the definition of covariance:

Cov(X, Y ) = E[(X µX )(Y µY )]


= E[XY XµY Y µ X + µX µY ]
= E[XY ] µX µY .


The next theorem concerns the sum of two random variables.

Theorem 5.4. For any X and Y ,


a. E[X + Y ] = E[X] + E[Y ].
b. Var[X + Y ] = Var[X] + 2Cov(X, Y ) + Var[Y ].

Proof. Recall the definition of joint expectation:


XX
E[X + Y ] = (x + y)pX,Y (x, y)
y x
XX XX
= xpX,Y (x, y) + ypX,Y (x, y)
y x y x
! !
X X X X
= x pX,Y (x, y) + y pX,Y (x, y)
x y y x
X X
= xpX (x) + ypY (y)
x y

= E[X] + E[Y ].

262
5.2. JOINT EXPECTATION

Similarly,

Var[X + Y ] = E[(X + Y )2 ] E[X + Y ]2


= E[(X + Y )2 ] (µX + µY )2
= E[X 2 + 2XY + Y 2 ] (µ2X + 2µX µY + µ2Y )
= E[X 2 ] µ2X + E[Y 2 ] µ2Y + 2(E[XY ] µX µY )
= Var[X] + 2Cov(X, Y ) + Var[Y ].


With covariance defined, we can now define the correlation coefficient ⇢, which is the
cosine angle of the centralized variables. That is,

⇢ = cos ✓
E[(X µX )(Y µY )]
=p .
E[(X µX )2 ]E[(Y µY ) 2 ]

Recognizing that the denominator of this expression is just the variance of X and Y , we
define the correlation coefficient as follows.

Definition 5.13. Let X and Y be two random variables. The correlation coefficient
is
Cov(X, Y )
⇢= p . (5.19)
Var[X]Var[Y ]

Since 1  cos ✓  1, ⇢ is also between 1 and 1. The di↵erence between ⇢ and E[XY ]
is that ⇢ is normalized with respect to the variance of X and Y , whereas E[XY ] is not
normalized. The correlation coefficient has the following properties:

⇢ is always between 1 and 1, i.e., 1  ⇢  1. This is due to the cosine angle


definition.
When X = Y (fully correlated), ⇢ = +1.
When X = Y (negatively correlated), ⇢ = 1.
When X and Y are uncorrelated, ⇢ = 0.

5.2.3 Independence and correlation


If two random variables X and Y are independent, the joint expectation can be written as
a product of two individual expectations.

Theorem 5.5. If X and Y are independent, then

E[XY ] = E[X]E[Y ]. (5.20)

263
CHAPTER 5. JOINT DISTRIBUTIONS

Proof. We only prove the discrete case because the continuous can be proved similarly. If
X and Y are independent, we have pX,Y (x, y) = pX (x) pY (y). Therefore,
XX XX
E[XY ] = xypX,Y (x, y) = xypX (x)pY (y)
y x y x
! !
X X
= xpX (x) ypY (y) = E[X]E[Y ].
x y


In general, for any two independent random variables and two functions f and g,

E[f (X)g(Y )] = E[f (X)]E[g(Y )].

The following theorem illustrates a few important relationships between independence


and correlation.

Theorem 5.6. Consider the following two statements:


a. X and Y are independent;
b. Cov(X, Y ) = 0.

Statement (a) implies statement (b), but (b) does not imply (a). Thus, independence
is a stronger condition than correlation.

Proof. We first prove that (a) implies (b). If X and Y are independent, then E[XY ] =
E[X]E[Y ]. In this case,

Cov(X, Y ) = E[XY ] E[X]E[Y ] = E[X]E[Y ] E[X]E[Y ] = 0.

To prove that (b) does not imply (a), we show a counterexample. Consider a discrete
random variable Z with PMF
⇥ ⇤
pZ (z) = 41 14 14 14 .

Let X and Y be
⇡ ⇡
X = cos Z and Y = sin Z.
2 2
Then we can show that E[X] = 0 and E[Y ] = 0. The covariance is

Cov(X, Y ) = E[(X 0)(Y 0)]


h ⇡ ⇡ i
= E cos Z sin Z
 2 2
1
=E sin ⇡Z
2

1 1 1 1 1
= (sin ⇡0) + (sin ⇡1) + (sin ⇡2) + (sin ⇡3) = 0.
2 4 4 4 4

264
5.2. JOINT EXPECTATION

The next step is to show that X and Y are dependent. To this end, we only need to show
that pX,Y (x, y) 6= pX (x)pY (y). The joint PMF pX,Y (x, y) can be found by noting that

Z = 0 ) X = 1, Y = 0,
Z = 1 ) X = 0, Y = 1,
Z=2)X= 1, Y = 0,
Z = 3 ) X = 0, Y = 1.

Thus, the PMF is 2 3


1
0 4 0
pX,Y (x, y) = 4 14 0 15
4 .
1
0 4 0
The marginal PMFs are
⇥1 1 1
⇤ ⇥1 1 1

pX (x) = 4 2 4 , pY (y) = 4 2 4 .

The product pX (x) pY (y) is


21 1 1 3
16 8 16
61 1 1 7
pX (x)pY (y) = 48 4 8 5.
1 1 1
16 8 16

Therefore, pX,Y (x, y) 6= pX (x)pY (y), although E[XY ] = E[X]E[Y ].


What is the relationship between independent and uncorrelated?


Independent ) uncorrelated.
Independent : uncorrelated.

5.2.4 Computing correlation from data


We close this section by discussing a very practical problem: Given a dataset containing two
columns of data points, how do we determine whether the two columns are correlated?
Recall that the correlation coefficient is defined as
E[XY ] µX µY
⇢= .
X Y

If we have a dataset containing (xn , yi )N


n=1 , then the correlation coefficient can be approxi-
mated by
1
PN
x n yn x y
⇢b = q P N n=1 q P ,
1 N 2 1 N 2
N (x
n=1 n x) N (y
n=1 n y)
P N P N
where x = N1 n=1 xn and y = N1 n=1 yn are the means. This equation should not be a
surprise because essentially all terms are the empirical estimates. Thus, ⇢b is the empirical
correlation coefficient determined from the dataset. As N ! 1, we expect ⇢b ! ⇢.

265
CHAPTER 5. JOINT DISTRIBUTIONS

5 5 5
4 4 4
3 3 3
2 2 2
1 1 1
0 0 0
-1 -1 -1
-2 -2 -2
-3 -3 -3
-4 -4 -4
-5 -5 -5
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
(a) ⇢b = 0.0038 (b) ⇢b = 0.5321 (c) ⇢b = 0.9656

Figure 5.9: Visualization of correlated variables. Each of these figures represent a scattered plot of a
dataset containing (xn , yn )N
n=1 . (a) is uncorrelated. (b) is somewhat correlated. (c) is strongly correlated.

Figure 5.9 shows three example datasets. We plot the (xn , yn ) pairs as coordinates in
the 2D plane. The first dataset contains samples that are almost uncorrelated. We can see
that xn does not tell us anything about yn . The second dataset is moderately correlated.
The third dataset is highly correlated: If we know xn , we are almost certain to know the
corresponding yn , with a small number of perturbations.
On a computer, computing the correlation coefficient can be done using built-in com-
mands such as corrcoef in MATLAB and stats.pearsonr in Python. The codes to gen-
erate the results in Figure 5.9(b) are shown below.

% MATLAB code to compute the correlation coefficient


x = mvnrnd([0,0],[3 1; 1 1],1000);
figure(1); scatter(x(:,1),x(:,2));
rho = corrcoef(x)

# Python code to compute the correlation coefficient


import numpy as np
import scipy.stats as stats
import matplotlib.pyplot as plt
x = stats.multivariate_normal.rvs([0,0], [[3,1],[1,1]], 10000)
plt.figure(); plt.scatter(x[:,0],x[:,1])
rho,_ = stats.pearsonr(x[:,0],x[:,1])
print(rho)

5.3 Conditional PMF and PDF

Whenever we have a pair of random variables X and Y that are correlated, we can define
their conditional distributions, which quantify the probability of X = x given Y = y. In
this section, we discuss the concepts of conditional PMF and PDF.

266
5.3. CONDITIONAL PMF AND PDF

5.3.1 Conditional PMF


We start by defining the conditional PMF for a pair of discrete random variables.

Definition 5.14. Let X and Y be two discrete random variables. The conditional
PMF of X given Y is
pX,Y (x, y)
pX|Y (x|y) = . (5.21)
pY (y)

The simplest way to understand this is to view pX|Y (x|y) as P[X = x | Y = y]. That is,
given that Y = y, what is the probability for X = x? To see why this perspective makes
sense, let us recall the definition of a conditional probability:

pX,Y (x, y)
pX|Y (x|y) =
pY (y)
P[X = x \ Y = y]
= = P[X = x | Y = y].
P[Y = y]

As we can see, the last two equalities are essentially the definitions of conditional probability
and the joint PMF.
How should we understand the notation pX|Y (x|y)? Is it a one-variable function in x or
a two-variable function in (x, y)? What does pX|Y (x|y) tell us? To answer these questions,
let us first try to understand the randomness exhibited in a conditional PMF. In pX|Y (x|y),
the random variable Y is fixed to a specific value Y = y. Therefore there is nothing random
about Y . All the possibilities of Y have already been taken care of by the denominator
pY (y). Only the variable x in pX|Y (x|y) has randomness. What do we mean by “fixed at a
value Y = y”? Consider the following example.

Example 5.16. Suppose there are two coins. Let

X = the sum of the values of two coins,


Y = the value of the first coin.

Clearly, X has 3 states: 0, 1, 2, and Y has two states: either 0 or 1. When we say
pX|Y (x|1), we refer to the probability mass function of X when fixing Y = 1. If we do
not impose this condition, the probability mass of X is simple:

1 1 1
pX (x) = , , .
4 2 4

However, if we include the conditioning, then

pX,Y (x, 1)
pX|Y (x|1) =
pY (1)
⇥ 2 1⇤ 
0, 4 , 4 2 1
= 1 = 0, , .
6
3 3

267
CHAPTER 5. JOINT DISTRIBUTIONS

To put this in plain words, when Y = 1, there is no way for X to take the state 0. The
chance for X to take the state 1 is 2/3 because either (0, 1) or (1, 0) can give X = 1.
The chance for X to take the state 2 is 1/3 because it has to be (1, 1) in order to give
X = 2. Therefore, when we say “conditioned on Y = 1”, we mean that we limit our
observations to cases where Y = 1. Since Y is already fixed at Y = 1, there is nothing
random about Y . The only variable is X. This example is illustrated in Figure 5.10.

Figure 5.10: Suppose X is the sum of two coins with PMF 0.25, 0.5, 0.25. Let Y be the first coin.
When X is unconditioned, the PMF is just [0.25, 0.5, 0.25]. When X is conditioned on Y = 1,
then “X = 0” cannot happen. Therefore, the resulting PMF pX|Y (x|1) only has two states. After
normalization we obtain the conditional PMF [0, 0.66, 0.33].

Since Y is already fixed at a particular value Y = y, pX|Y (x|y) is a probability mass


function of x (we want to emphasize again that it is x and not y). So pX|Y (x|y) is a one-
variable function in x. It is not the same as the usual PMF pX (x). pX|Y (x|y) is conditioned
on Y = y. For example, pX|Y (x|1) is the PMF of X restricted to the condition that Y = 1.
In fact, it follows that
P
X X pX,Y (x, y) pX,Y (x, y) pY (y)
pX|Y (x|y) = = x2⌦X = = 1,
pY (y) pY (y) pY (y)
x2⌦X x2⌦X

but this tells us that pX|Y (x|y) is a legitimate probability mass of X. If we sum over the y’s
instead, then we will hit a bump:
X X pX,Y (x, y)
pX|Y (x|y) = 6= 1.
pY (y)
y2⌦Y y2⌦Y

Therefore, while pX|Y (x|y) is a legitimate probability mass function of X, it is not a prob-
ability mass function of Y .

Example 5.17. Consider a joint PMF given in the following table. Find the conditional
PMF pX|Y (x|1) and the marginal PMF pX (x).
Y=
1 2 3 4
1 1 1 0
X=1 20 20 20 20
1 2 3 1
2 20 20 20 20
1 2 3 1
3 20 20 20 20
0 1 1 1
4 20 20 20 20

268
5.3. CONDITIONAL PMF AND PDF

Solution. To find the marginal PMF, we sum over all the y’s for every x:
4
X 1 1 1 0 3
x=1: pX (1) = pX,Y (1, y) = + + + = ,
y=1
20 20 20 20 20
4
X 1 2 2 1 6
x=2: pX (2) = pX,Y (2, y) = + + + = ,
y=1
20 20 20 20 20
4
X 1 3 3 1 8
x=3: pX (3) = pX,Y (3, y) = + + + = ,
y=1
20 20 20 20 20
4
X 0 1 1 1 3
x=4: pX (4) = pX,Y (4, y) = + + + = .
y=1
20 20 20 20 20

Hence, the marginal PMF is


⇥ 3 6 8 3

pX (x) = 20 20 20 20 .

The conditional PMF pX|Y (x|1) is


⇥1 1 1 0

pX,Y (x, 1) ⇥1 ⇤
pX|Y (x|1) = = 20 20
3
20 20
= 3
1
3
1
3 0 .
pY (1) 20

Practice Exercise 5.7. Consider two random variables X and Y defined as follows.
8
( > 4
2
10 , with prob 5/6, <10 Y, with prob 1/2,
Y = X = 3
10 Y, with prob 1/3,
104 , with prob 1/6. >
: 2
10 Y, with prob 1/6.

Find pX|Y (x|y), pX (x) and pX,Y (x, y).

Solution. Since Y takes two di↵erent states, we can enumerate Y = 102 and Y = 104 .
This gives us
8
>
<1/2, if x = 0.01,
2
pX|Y (x|10 ) = 1/3, if x = 0.1,
>
:
1/6, if x = 1.
8
>
<1/2, if x = 1,
4
pX|Y (x|10 ) = 1/3, if x = 10,
>
:
1/6, if x = 100.

269
CHAPTER 5. JOINT DISTRIBUTIONS

The joint PMF pX,Y (x, y) is


8
> 1 5
< 2 6 , x = 0.01,
2 2 2 1 5
pX,Y (x, 10 ) = pX|Y (x|10 )pY (10 ) = 3 6 , x = 0.1,
>
: 1 5
6 6 , x = 1.

8
> 1 1
< 2 6 , x = 1,
4 4 4 1 1
pX,Y (x, 10 ) = pX|Y (x|10 )pY (10 ) = 3 6 , x = 10,
>
: 1 1
6 6 , x = 100.

Therefore, the joint PMF is given by the following table.


1 1 1
104 0 0 12 18 36
5 5 5
102 12 18 36 0 0
0.01 0.1 1 10 100

The marginal PMF pX (x) is thus


X ⇥5 ⇤
5 2 1 1
pX (x) = pX,Y (x, y) = 12 18 9 18 36 .
y

In the previous two examples, what is the probability P[X 2 A | Y = y] or the proba-
bility P[X 2 A] for some events A? The answers are giving by the following theorem.

Theorem 5.7. Let X and Y be two discrete random variables, and let A be an event.
Then
X
(i) P[X 2 A | Y = y] = pX|Y (x|y)
x2A
X X X
(ii) P[X 2 A] = pX|Y (x|y)pY (y) = P[X 2 A | Y = y]pY (y).
x2A y2⌦Y y2⌦Y

Proof. The first statement is based on the


Pfact that if A contains a finite number of elements,
then P[X 2 A] is equivalent to the sum x2A P[X = x]. Thus,

P[X 2 A \ Y = y]
P[X 2 A | Y = y] =
P[Y = y]
P
P[X = x \ Y = y]
= x2A
P[Y = y]
X
= pX|Y (x|y).
x2A
P
The second statement holds because the inner summation y2⌦Y pX|Y (x|y)pY (y) is just
the marginal PMF pX (x). Thus the outer summation yields the probability.

270
5.3. CONDITIONAL PMF AND PDF

Example 5.18. Let us follow up on Example 5.17. What is the probability that
P[X > 2|Y = 1]? What is the probability that P[X > 2]?
Solution. Since the problem asks about the conditional probability, we know that it
can be computed by using the conditional PMF. This gives us
X
P[X > 2|Y = 1] = pX|Y (x|1)
x>2

⇠⇠+ p ⇠ ⇠⇠+ p 1
=⇠ ⇠⇠
pX|Y (1|1) ⇠ (2|1)
⇠X|Y X|Y (3|1) + pX|Y (4|1) = .
| {z } | {z } 3
1 0
3

The other probability is


X
P[X > 2] = pX (x)
x>2

pX⇠
=⇠ ⇠+⇠
(1) pX⇠⇠ + pX (3) + pX (4) = 11 .
(2)
| {z } | {z } 20
8 3
20 20

What is the rule of thumb for conditional distribution?


The PMF/PDF should match with the probability you are finding.
If you want to find the conditional probability P[X 2 A|Y = y], use the condi-
tional PMF pX|Y (x|y).
If you want to find the probability P[X 2 A], use the marginal PMF pX (x).

Finally, we define the conditional CDF for discrete random variables.

Definition 5.15. Let X and Y be discrete random variables. Then the conditional
CDF of X given Y = y is
X
FX|Y (x|y) = P[X  x | Y = y] = pX|Y (x0 |y). (5.22)
x0 x

5.3.2 Conditional PDF


We now discuss the conditioning of a continuous random variable.

Definition 5.16. Let X and Y be two continuous random variables. The conditional
PDF of X given Y is
fX,Y (x, y)
fX|Y (x|y) = . (5.23)
fY (y)

271
CHAPTER 5. JOINT DISTRIBUTIONS

Example 5.19. Let X and Y be two continuous random variables with a joint PDF
(
2e x e y , 0  y  x < 1,
fX,Y (x, y) =
0, otherwise.

Find the conditional PDFs fX|Y (x|y) and fY |X (y|x).

Solution. We first find the marginal PDFs.


Z 1 Z x
fX (x) = fX,Y (x, y) dy = 2e x e y dy = 2e x (1 e x
),
1 0
Z 1 Z 1
fY (y) = fX,Y (x, y) dx = 2e x e y dx = 2e 2y .
1 y

Thus, the conditional PDFs are

fX,Y (x, y)
fX|Y (x|y) =
fY (y)
2e x e y
= = e (x+y) , x y,
2e 2y
fX,Y (x, y)
fY |X (y|x) =
fX (x)
2e x e y e y
= = , 0  y < x.
2e x (1 e x ) 1 e x

Where does the conditional PDF come from? We cannot duplicate the argument
we used for the discrete case because the denominator of a conditional PMF becomes
P[Y = y] = 0 when Y is continuous. To answer this question, we first define the conditional
CDF for continuous random variables.

Definition 5.17. Let X and Y be continuous random variables. Then the conditional
CDF of X given Y = y is
Rx
fX,Y (x0 , y) dx0
FX|Y (x|y) = 1 . (5.24)
fY (y)

Why should the conditional CDF of continuous random variable be defined in this way? One
way to interpret FX|Y (x|y) is as the limiting perspective. We can define the conditional CDF
as

FX|Y (x|y) = lim P(X  x | y  Y  y + h)


h!0
P(X  x \ y  Y  y + h)
= lim .
h!0 P[y  Y  y + h]

272
5.3. CONDITIONAL PMF AND PDF

With some calculations, we have that


R x R y+h
P(X  x \ y  Y  y + h) 1 y
fX,Y (x0 , y 0 ) dy 0 dx0
lim = lim R y+h
h!0 P[y  Y  y + h] h!0 fY (y 0 ) dy 0
y
Rx
1
fX,Y (x0 , y 0 ) dx0 · h
= lim
h!0 fY (y) · h
Rx
1
fX,Y (x0 , y 0 ) dx0
= .
fY (y)
The key here is that the small step size h in the numerator and the denominator will
cancel each other out. Now, given the conditional CDF, we can verify the definition of the
conditional PDF. It holds that
d
fX|Y (x|y) = FX|Y (x|y)
dx ( )
Rx
d f
1 X,Y
(x0 , y) dx0 (a) fX,Y (x, y)
= = ,
dx fY (y) fY (y)

where (a) follows from the fundamental theorem of calculus.

Just like the conditional PMF, we can calculate the probabilities using the conditional
PDFs. In particular, if we evaluate the probability where X 2 A given that Y takes a
particular value Y = y, then we can integrate the conditional PDF fX|Y (x|y), with respect
to x.

Theorem 5.8. Let X and Y be continuous random variables, and let A be an event.
R
(i) P[X 2 A | Y = y] = A fX|Y (x|y) dx,
R
(ii) P[X 2 A] = ⌦Y P[X 2 A | Y = y]fY (y) dy.

Example 5.20. Let X be a random bit such that


(
+1, with prob 1/2,
X=
1, with prob 1/2.

Suppose that X is transmitted over a noisy channel so that the observed signal is

Y = X + N,

where N ⇠ Gaussian(0, 1) is the noise, which is independent of the signal X. Find the
probabilities P[X = +1 | Y > 0] and P[X = 1 | Y > 0].

Solution. First, we know that


1 (y 1)2 1 (y+1)2
fY |X (y| + 1) = p e 2 and fY |X (y| 1) = p e 2 .
2⇡ 2⇡

273
CHAPTER 5. JOINT DISTRIBUTIONS

Therefore, integrating y from 0 to 1 gives us


Z 1
1 (y 1)2
P[Y > 0 | X = +1] = p e 2 dy
0 2⇡
Z 0
1 (y 1)2
=1 p e 2 dy
1 2⇡
✓ ◆
0 1
=1 =1 ( 1).
1

Similarly, we have P[Y > 0 | X = 1] = 1 (+1). The probability we want to find is


P[X = +1 | Y > 0], which can be determined using Bayes’ theorem.

P[Y > 0 | X = +1]P[X = +1]


P[X = +1 | Y > 0] = .
P[Y > 0]

The denominator can be found by using the law of total probability:

P[Y > 0] = P[Y > 0 | X = +1]P[X = +1]


+ P[Y > 0 | X = 1]P[X = 1]
1
=1 ( (+1) + ( 1))
2
1
= ,
2
since (+1) + ( 1) = (+1) + 1 (+1) = 1. Therefore,

P[X = +1 | Y > 0] = 1 ( 1)
= 0.8413.

The implication is that if Y > 0, the probability P[X = +1 | Y > 0] = 0.8413. The
complement of this result gives P[X = 1 | Y > 0] = 1 0.8413 = 0.1587.

Practice Exercise 5.8. Find P[Y > y], where

X ⇠ Uniform[1, 2], Y | X ⇠ Exponential(x).

Solution. The tricky part of this problem is the tendency to confuse the two variables
X and Y . Once you understand their roles the problem becomes easy. First notice that
Y | X ⇠ Exponential(x) is a conditional distribution. It says that given X = x, the
probability distribution of Y is exponential, with the parameter x. Thus, we have that
xy
fY |X (y|x) = xe .

Why? Recall that if Y ⇠ Exponential( ) then fY (y) = e y . Now if we replace


with x, we have xe xy . So the role of x in this conditional density function is as a
parameter.

274
5.4. CONDITIONAL EXPECTATION

Given this property, we can compute the conditional probability:


Z 1
P[Y > y | X = x] = fY |X (y 0 |x) dy 0
y
Z 1  1
xy 0 xy 0
= xe dy 0 = e =e xy
.
y y 0 =y

Finally, we can compute the marginal probability:


Z
P[Y > y] = P[Y > 0|X = x0 ]fX (x0 ) dx0
⌦X
Z 1
x0 y
= e dx0
0
 x0 =1
1 x0 y 1 y
= e = 1 e .
y x0 =0 y

We can double-check this result by noting that the problem asks about the probability
P[Y > y]. Thus, the answer must be a function of y but not of x.

5.4 Conditional Expectation

5.4.1 Definition
When dealing with two dependent random variables, at times we would like to determine
the expectation of a random variable when the second random variable takes a particular
state. The conditional expectation is a formal way of doing so.

Definition 5.18. The conditional expectation of X given Y = y is


X
E[X | Y = y] = xpX|Y (x|y) (5.25)
x

for discrete random variables, and


Z 1
E[X | Y = y] = xfX|Y (x|y) dx (5.26)
1

for continuous random variables.

There are two points to note here. First, the expectation of E[X | Y = y] is taken with respect
to fX|Y (x|y). We assume that the random variable Y is already fixed at the state Y = y.
Thus, the only source of randomness is X. Secondly, since the expectation E[X | Y = y] has
eliminated the randomness of X, the resulting function is in y.

275
CHAPTER 5. JOINT DISTRIBUTIONS

What is conditional expectation?


E[X|Y = y] is the expectation using fX|Y (x|y).
The integration is taken w.r.t. x, because Y = y is given and fixed.

5.4.2 The law of total expectation

Theorem 5.9. The law of total expectation states that


X Z 1
E[X] = E[X|Y = y]pY (y), or E[X] = E[X|Y = y]fY (y) dy. (5.27)
y 1

Proof. We will prove the discrete case only, as the continuous case can be proved by replacing
summation with integration.
!
X X X
E[X] = xpX (x) = x pX,Y (x, y)
x x y
XX
= xpX|Y (x|y)pY (y)
x y
!
X X X
= xpX|Y (x|y) pY (y) = E[X|Y = y]pY (y).
y x y


Figure 5.11 illustrates the idea behind the proof. Essentially, we decompose the expec-
tation E[X] into “subexpectations” E[X|Y = y]. The probability of each subexpectation is
pY (y). By summing the subexpectation multiplied by pY (y), we obtain the overall expecta-
tion.

P The expectation E[X] can be decomposed into a set of subexpectations. This gives us
Figure 5.11:
E[X] = y E[X|Y = y]pY (y).

276
5.4. CONDITIONAL EXPECTATION

What is the law of total expectation?


The law of total expectation is a decomposition rule.
It decomposes E[X] into smaller/easier conditional expectations.

This law can also be written in a more compact form.

Corollary 5.1. Let X and Y be two random variables. Then


⇥ ⇤
E[X] = EY EX|Y [X|Y ] . (5.28)

P
Proof. The previous theorem states that E[X] = y E[X|Y = y]pY (y). If we treat E[X|Y =
y] as a function of y, for instance h(y), then
X X
E[X] = E[X|Y = y]pY (y) = h(y)pY (y) = E[h(Y )] = E [E[X|Y ]] .
y y

Example 5.21. Suppose there are two classes of cars. Let X be the speed of a car
and C be the class. When C = 1, we know that X ⇠ Gaussian(µ1 , 1 ). We know that
P[C = 1] = p. When C = 2, X ⇠ Gaussian(µ2 , 2 ). Also, P[C = 2] = 1 p. If you see
a car on the freeway, what is its average speed?
Solution. The problem has given us everything we need. In particular, we know that
the conditional PDFs are:

1 (x µ1 )2
fX|C (x | 1) = p exp ,
2⇡ 12 2 12

1 (x µ2 )2
fX|C (x | 2) = p exp .
2⇡ 22 2 22

Therefore, conditioned on C, we have two expectations:


Z 1
E[X | C = 1] = x fX|C (x | 1) dx = µ1 ,
1
Z 1
E[X | C = 2] = x fX|C (x | 2) dx = µ2 .
1

The overall expectation E[X] is


2
X
E[X] = E[X|C = c]pC (c)
c=1
= E[X | C = 1]P[C = 1] + E[X | C = 2]P[C = 2]
= pµ1 + (1 p)µ2 .

277
CHAPTER 5. JOINT DISTRIBUTIONS

Practice Exercise 5.9. Consider a joint PMF given by the following table. Find
E[X|Y = 102 ] and E[X|Y = 104 ].
1 1 1
Y 104 0 0 12 18 36
5 5 5
102 12 18 36 0 0
0.01 0.1 1 10 100
X
Solution. To find the conditional expectation, we first need to know the conditional
PMF.
⇥ ⇤
pX|Y (x|102 ) = 12 13 16 0 0 ,
⇥ ⇤
pX|Y (x|104 ) = 0 0 12 13 16 .

Therefore, the conditional expectations are


✓ ◆ ✓ ◆ ✓ ◆
2 2 1 1 1 1
E[X | Y = 10 ] = (10 ) + (10 ) + (1)
2 3 6
123
= ,
600✓ ◆ ✓ ◆ ✓ ◆
4 1 1 1
E[X | Y = 10 ] = (1) + (10) + (100)
2 3 6
123
= .
6
From the conditional expectations we can also find E[X]:

E[X] = E[X | Y = 102 ]pY (102 )


+ E[X | Y = 104 ]pY (104 )
✓ ◆✓ ◆ ✓ ◆✓ ◆
123 5 123 1
= +
600 6 6 6
= 3.5875.

Example 5.22. Consider two random variables X and Y . The random variable X
is Gaussian-distributed with X ⇠ Gaussian(µ, 2 ). The random variable Y has a
conditional distribution Y |X ⇠ Gaussian(X, X 2 ). Find E[Y ].

Solution. The notation Y |X ⇠ Gaussian(X, X 2 ) means that given the variable X,


the other variable Y has a conditional distribution Gaussian(X, X 2 ). That is, the
variable Y is a Gaussian with mean X and variance X 2 . How can the mean be a
random variable X and the variance be another random variable X 2 ? Because X is
the conditional variable. Y |X means that you have already chosen one state of X.
Given that particular state, the distribution of Y follows fY |X . Therefore, for this

278
5.4. CONDITIONAL EXPECTATION

problem, we know the PDFs:



1 (x µ)2
fX (x) = p exp 2
,
2⇡ 2 2

1 (y x)2
fY |X (y|x) = p exp .
2⇡x2 2x2

The conditional expectation of Y given X is


Z 1 ⇢
1 (y x)2
E[Y |X = x] = yp exp dy
1 2⇡x2 2x2
= E[Gaussian(x, x2 )] = x.

The last equality holds because we are computing the expectation of a Gaussian ran-
dom variable with mean x. Finally, applying the law of total expectation, we can show
that
Z 1
E[Y ] = E[Y |X = x]fX (x) dx
1
Z 1 ⇢
1 (x µ)2
= x p exp dx
1 2⇡ 2 2 2
= E[Gaussian(µ, 2 )] = µ,

where the last equality is based on the fact that it is the mean of a Gaussian.

Practice Exercise 5.10. Find E[sin(X + Y )], if X ⇠ Gaussian(0, 1), and Y | X ⇠


Uniform[x ⇡, x + ⇡].

Solution. We know that the conditional density is


1
fY |X (y|x) = , x ⇡  y  x + ⇡.
2⇡
Therefore, we can compute the probability
Z x+⇡
E[sin(X + Y )|X = x] = sin(x + y)fY |X (y|x) dy
x ⇡
Z x+⇡
1
= sin(x + y) dy = 0.
2⇡ x ⇡
| {z }
=0

Hence, the overall expectation is


Z 1
1 x2
E[sin(X + Y )] = E[sin(X + Y )|X = x] p e 2 dx = 0.
0 | {z } 2⇡
=0

279
CHAPTER 5. JOINT DISTRIBUTIONS

5.5 Sum of Two Random Variables

One typical problem we encounter in engineering is to determine the PDF of the sum of
two random variables X and Y , i.e., X + Y . Such a problem arises naturally when we want
to evaluate the average of many random variables, e.g., the sample mean of a collection of
data points. This section will discuss a general principle for determining the PDF of a sum
of two random variables.

5.5.1 Intuition through convolution


First, consider two random variables, X and Y , both discrete uniform random variables
in the range of 0, 1, 2, 3. That is, pX (x) = pY (y) = [1/4, 1/4, 1/4, 1/4]. Since this is such a
simple problem we can enumerate all the possible cases of the sum Z = X +Y . The resulting
probabilities are shown in the following table.

Z =X +Y Cases, written in terms of (X, Y) Probability


0 (0,0) 1/16
1 (0,1), (1,0) 2/16
2 (1,1), (2,0), (0,2) 3/16
3 (3,0), (2,1), (1,2), (0,3) 4/16
4 (3,1), (2,2), (1,3) 3/16
5 (3,2), (2,3) 2/16
6 (3,3) 1/16
Clearly, the PMF of Z is not fZ (z) = fX (x) + fY (y). (Caution! Do not write this.) The
PMF of Z looks like a triangle distribution. How can we get to this triangle distribution
from two uniform distributions? The key is the idea of convolution. Let us start with the
PMF of X, which is pX (x). Let us also flip pY (y) over the y-axis. As we shift the flipped pY ,
we multiply and add the PMF values as shown in Figure 5.12. This gives us

pZ (0) = P[X + Y = 0]
= P[(X, Y ) = (0, 0)]
= pX (0)pY (0)
1
= .
16
Now, if we shift towards the right by 1, we have

pZ (1) = P[X + Y = 1]
= P[(X, Y ) = (0, 1) [ (0, 1)]
2
= pX (0)pY (1) + pX (1)pY (0) = .
16
By continuing our argument, you can see that we will obtain the same PMF as the one
shown in the table.

280
5.5. SUM OF TWO RANDOM VARIABLES

Figure 5.12: When summing two random variables X and Y , we are e↵ectively taking the convolutions
of the two respective PMF / PDFs.

5.5.2 Main result


We can show that for any arbitrary random variable X and Y , the sum Z = X + Y has a
distribution that is the convolution of two individual PDFs.

Theorem 5.10. Let X and Y be two independent random variables with PDFs fX (x)
and fY (y) respectively. Let Z = X + Y . The PDF of Z is given by
Z 1
fZ (z) = (fX ⇤ fY )(z) = fX (z y)fY (y) dy, (5.29)
1

where “⇤” denotes the convolution.

Proof. We begin by analyzing the CDF of Z. The CDF of Z is

FZ (z) = P[Z  z] = P[X + Y  z].

We now draw a picture to illustrate the line under which we want to integrate. As shown in
Figure 5.13, the equation X + Y  z defines a straight line in the xy plane. You can think
of it as Y  X + z, so that the slope is 1 and the y-intercept is z.
Now, shall we take the upper half of the triangle or the lower half? Since the equation
is Y  X + z, a value of Y has to be less than that of the line. Another easy way to check
is to assume z > 0 so that we have a positive y-intercept. Then we check where the origin

281
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.13: The shaded region highlights the set X + Y  Z. To integrate the PDF over this region,
we first take the inner integration over dx and then take the outer integration over dy.

(0, 0) belongs. In this case, if z > 0, the origin (0, 0) will satisfy the equation Y  X + z,
and so it must be included. Thus, we conclude that the area is below the line.
Once we have determined the area to be integrated, we can write down the integration:
Z 1Z z y
P[X + Y  z] = fX,Y (x, y) dx dy
1 1
Z 1 Z z y
= fX (x)fY (y) dx dy, (independence)
1 1

where the integration limits are just a rewrite of X + Y  z (in this case since we are
integrating x first we have X  Y + z). Then, by the fundamental theorem of calculus,
we can show that
Z 1Z z y
d d
fZ (z) = FZ (z) = fX (x)fY (y) dx dy
dz dz 1 1
Z 1✓ Z z y ◆
d
= fX (x)fY (y) dx dy
1 dz 1
Z 1
= fX (z y)fY (y) dy = (fX ⇤ fY )(z),
1

where “⇤” denotes the convolution.

How is convolution related to random variables?


If you sum X and Y , the resulting PDF is the convolution of fX and fY .
E.g., convolving two uniform random variables gives you a triangle PDF.

5.5.3 Sum of common distributions

Theorem 5.11 (Sum of two Poissons). Let X1 ⇠ Poisson( 1) and X2 ⇠ Poisson( 2 ).


Then
X1 + X2 ⇠ Poisson( 1 + 2 ). (5.30)

282
5.5. SUM OF TWO RANDOM VARIABLES

Proof. Let us apply the convolution principle.

pY (k) = P[X1 + X2 = k]
= P[X1 = ` \ X2 = k `]
k
X ` k `
1e e
1 2
2
= ·
`! (k `)!
`=0
k
X ` k `
( 1+ 2) 1 2
=e ·
`! (k `)!
`=0
k
( 1+ 2)
1X k! ` k `
=e · 1 2
k! `!(k `)!
`=0
| {z }
P k k `
= k `=0 ( ` ) 1
`
2

k
( 1 + 2) ( 1+ 2)
= e ,
k!
Pk k
where the last step is based on the binomial identity `=0 ` a ` bk `
= (a + b)k .

Theorem 5.12 (Sum of two Gaussians). Let X1 and X2 be two Gaussian random
variables such that
2 2
X1 ⇠ Gaussian(µ1 , 1) and X2 ⇠ Gaussian(µ2 , 2 ).

Then
2 2
X1 + X2 ⇠ Gaussian(µ1 + µ2 , 1 + 2 ). (5.31)

Proof. Let us apply the convolution principle.


Z 1
fZ (z) = fX (t)fY (z t) dt
1
Z 1 ⇢ ⇢
1 (t µ1 )2 1 (z t µ2 )2
= p exp 2
· p exp dt
1 2⇡ 2 2 2⇡ 2 2 2
Z 1 ⇢
1 1 (t µ1 )2 + (z t µ2 )2
=p p exp dt.
2⇡ 2 1 2⇡ 2 2 2

We now complete the square:

(t µ1 )2 + (z t µ2 )2 = [t2 2µ1 t + µ21 ] + [t2 + 2t(µ2 z) + (µ2 z)2 ]


= 2t2 2t(µ1 µ2 + z) + µ21 + (µ2 z)2

µ1 µ2 + z
= 2 t2 2t · + µ21 + (µ2 z)2
2
 2  2
µ1 µ2 + z µ1 µ2 + z
=2 t 2 + µ21 + (µ2 z)2 .
2 2

283
CHAPTER 5. JOINT DISTRIBUTIONS

The last term can be simplified to


 2
µ1 µ2 + z
2 + µ21 + (µ2 z)2
2
µ21 2µ1 (µ2 z) + (µ2 z)2
= + µ21 + (µ2 z)2
2
µ2 + 2µ1 (µ2 z) + (µ2 z)2 (µ1 + µ2 z)2
= 1 = .
2 2
Substituting these into the integral, we can show that
Z 1 ( ⇥ ⇤2 2 )
1 1 2 t µ1 µ2 2 +z + (µ1 +µ22 z)
fZ (z) = p p exp dt
2⇡ 2 1 2⇡ 2 2 2
⇢ Z 1 ( ⇥ ⇤2 )
1 (µ1 + µ2 z)2 1 t µ1 µ2 2 +z
=p exp p exp dt
2⇡ 2 2(2 2 ) 1 2⇡ 2 2
| {z }
= p12

1 (µ1 + µ2 z)2
=p exp .
2⇡(2 )2 2(2 2 )
Therefore, we have shown that the resulting distribution is a Gaussian with mean µ1 + µ2
and variance 2 2 . ⇤

Practice Exercise 5.11. Let X and Y be independent, and let


( (
xe x , x 0, ye y , y 0,
fX (x) = and fY (y) =
0, x < 0, 0, y < 0.

Find the PDF of Z = X + Y .


Solution. Using the results derived above, we see that
Z 1
fZ (z) = fX (z y)fY (y) dy
1
Z z
= fX (z y)fY (y) dy,
1

where the upper limit z came from the fact that x 0. Therefore, since Z = X +Y , we
must have Z Y = X 0 and so Z Y . This is portrayed graphically in Figure 5.14.
Substituting the PDFs into the integration yields
Z z
z3
fZ (z) = (z y)e (z y) ye y dy = e z , z 0.
0 6

For z < 0, fZ (z) = 0.

The functions of two random variables are not limited to summation. The following
example illustrates the case of the product of two random variables.

284
5.5. SUM OF TWO RANDOM VARIABLES

Figure 5.14: [Left] The outer integral goes from 0 to z because the triangle stops at y = z. [Right] If
the triangle is unbounded, then the integral goes from 1 to 1.

Example 5.23. Let X and Y be two independent random variables such that
( (
2x, if 0  x  1, 1, if 0  y  1,
fX (x) = and fY (y) =
0, otherwise, 0, otherwise.

Let Z = XY . Find fZ (z).


Solution. The CDF of Z can be evaluated as
Z 1 Z z
y
FZ (z) = P[Z  z] = P[XY  z] = fX (x)fY (y) dx dy.
1 1

Taking the derivative yields


Z 1 Z yz
d d
fZ (z) = FZ (z) = fX (x)fY (y) dx dy
dz dz 1 1
Z 1 ✓ ◆
(a) 1 z
= fX fY (y) dy,
1 y y

where (a) holds by the fundamental theorem of calculus. The upper and lower limit of
this integration can be determined by noting that
z
0 = x  1,
y
which implies that z  y. Since y  1, we have that z  y  1. Therefore, the PDF is
Z 1 ✓ ◆
1 z
fZ (z) = fX fY (y) dy
z y y
Z 1
2z
= 2
dy = 2(1 z), z 0.
z y

For z < 0, fZ (z) = 0.

285
CHAPTER 5. JOINT DISTRIBUTIONS

Closing remark. For some random variables, summing two i.i.d. copies remain the same
random variable (but with di↵erent parameters). For other random variables, summing
two i.i.d. copies gives a di↵erent random variable. Table 5.1 summarizes some of the most
commonly used random variable pairs.

X1 X2 Sum X1 + X2
Bernoulli(p) Bernoulli(p) Binomial(2, p)
Binomial(n, p) Binomial(m, p) Binomial(m + n, p)
Poisson( 1) Poisson( 2) Poisson( 1 + 2)
Exponential( ) Exponential( ) Erlang(2, )
2 2 2 2
Gaussian(µ1 , 1) Gaussian(µ2 , 2) Gaussian(µ1 + µ2 , 1 + 2)

Table 5.1: Common distributions of the sum of two random variables.

5.6 Random Vectors and Covariance Matrices

We now enter the second part of this chapter. In the first part, we were mainly interested
in a pair of random variables. In the second part, however, we will study vectors of N
random variables. To understand a vector of random variables, we will not drill down to
the integrations of the PDFs (which you would certainly not enjoy). Instead, we will blend
linear algebra tools and probabilistic tools to learn a few practical data analysis techniques.

5.6.1 PDF of random vectors


Joint distributions can be generalized to more than two random variables. The most conve-
nient way is to consider a vector of random variables and their corresponding states.
2 3 2 3
X1 x1
6 X2 7 6 x2 7
6 7 6 7
X = 6 . 7 and x = 6 . 7 .
4 .. 5 4 .. 5
XN xN
Our notation here is unconventional since bold upper case letters usually represent matrices.
Here, X denotes a vector, specifically a random vector. Its state is a vector x. In this chapter,
we will use the following notational convention: X and Y represent random vectors while
A represents a matrix.
One way to think about X is to imagine that if you put your hand into the sample
space, you will pick up a vector x. This random realization x has N entries, and so you
need to specify the probability of getting all these entries simultaneously. Accordingly, we
should expect that X is characterized by an N -dimensional PDF

fX (x) = fX1 ,X2 ,...,XN (x1 , x2 , . . . , xN ).

286
5.6. RANDOM VECTORS AND COVARIANCE MATRICES

Essentially, this PDF tells us the probability density for random variable X1 = x1 , random
variable X2 = x2 , etc. It is a coordinate-wise description. For example, if X contains three
elements such that X = [X1 , X2 , X3 ]T , and if the state we are looking at is x = [3, 1, 7]T ,
then fX (x) is the probability density such that this 3D coordinate (X1 , X2 , X3 ) takes the
value [3, 1, 7]T .
To compute the probability, we can integrate fX (x) with respect to x. Let A be the
event. Then
Z
P[X 2 A] = fX (x) dx
A
Z Z
= ··· fX1 ,...,XN (x1 , . . . , xN ) dx1 . . . dxN .
A

If the random coordinates X1 , . . . , XN are independent, the PDF can be written as a prod-
uct of N individual PDFs:

fX1 ,...,XN (x1 , . . . , xN ) = fX1 (x1 )fX2 (x2 ) · · · fXN (xN ), and so
Z Z
P[X 2 A] = · · · fX1 (x1 )fX2 (x2 ) · · · fXN (xN ) dx1 · · · dxN .
A

However, this does not necessarily simplify the calculation unless A is separable, e.g., A =
[a1 , b1 ] ⇥ [a2 , b2 ] ⇥ · · · ⇥ [aN , bN ]. In this case the integration becomes
N
"Z #
Y bi
P[X 2 A] = fXi (xi ) dxi ,
i=1 ai

which is obviously manageable.

Example 5.24. Let X = [X1 , . . . , XN ]T be a vector of zero-mean unit variance Gaus-


sian random vectors. Let A = [ 1, 2]N . Then
Z
P[X 2 A] = fX (x)dx
ZA Z
= ··· fX1 ,··· ,XN (x1 , . . . , xN ) dx1 · · · dxN
A
Z 2 N
N
= fX1 (x1 ) dx1 = [ (2) ( 1)] ,
1

where (·) is the standard Gaussian CDF.

As you can see from the definition of a vector random variable, computing the proba-
bility typically involves integrating a high-dimensional function, which is tedious. However,
the good news is that in practice we seldom need to perform such calculations. Often we are
more interested in the mean and the covariance of the random vectors because they usually
carry geometric meanings. The next subsection explores this topic.

287
CHAPTER 5. JOINT DISTRIBUTIONS

5.6.2 Expectation of random vectors


Let X = [X1 , . . . , XN ]T be a random vector. We define the expectation of a random vector
as follows.

Definition 5.19. Let X = [X1 , . . . , XN ]T be a random vector. The expectation is


2 3
E[X1 ]
6 E[X2 ] 7
def 6 7
µ = E[X] = 6 . 7 . (5.32)
4 . 5.
E[XN ]

The resulting vector is called the mean vector. Since the mean vector is a vector of
individual elements, we need to compute the marginal PDFs before computing the expec-
tations: 2 3 2 R 3
E[X1 ] x f (x1 ) dx1
⌦ 1 X1
6 7 6 7
E[X] = 4 ... 5 = 4 ..
. 5,
R
E[XN ] x f (xN ) dxN
⌦ N XN
where the marginal PDF is determined by
Z
fXn (xn ) = fX \n (x\n )dx\n .

In the equation above, x\n = [x1 , . . . , xn 1 , xn+1 , . . . , xN ]T contains all the elements with-
out xn . For example, if the PDF is fX1 ,X2 ,X3 (x1 , x2 , x3 ), then
Z Z
E[X1 ] = x1 fX1 ,X2 ,X3 (x1 , x2 , x3 ) dx2 dx3 dx1 .
| {z }
fX1 (x1 )

Again, this will become tedious when there are many variables.

While the definition of the expectation may be challenging to understand, some prob-
lems using it are straightforward. We will first demonstrate the case of independent Poisson
random variables, and then we will discuss joint Gaussians.

Example 5.25. Let X = [X1 , . . . , XN ]T be a random vector such that Xn are inde-
pendent Poissons with Xn ⇠ Poisson( n ). Then
2 3 2 P1 k
1e
1
3 2 3
E[X1 ] k=0 k · k! 1
6 .. 7 6 6 . 7 6 . 7
7
E[X] = 4 . 5 = 4 .
. .
5 = 4 . 5.
E[XN ] P1 k
Ne
N
k=0 k ·
N
k!

On computers, computing the mean vector can be done using built-in commands such
as mean in MATLAB and np.mean in Python. However, caution is needed when performing
the calculation. In MATLAB, mean computes along first dimension (rows index). Thus, if we

288
5.6. RANDOM VECTORS AND COVARIANCE MATRICES

have an N ⇥ 2 array, applying mean will give us a 1 ⇥ 2 vector. To obtain the column mean
vector of size N ⇥ 1, we need to specify the direction as mean(X,2). Similarly, in Python,
when calling np.mean, we need to specify the axis.
% MATLAB code to compute a mean vector
X = randn(100,2);
mX = mean(X,2);

# Python code to compute a mean vector


import numpy as np
import scipy.stats as stats
X = stats.multivariate_normal.rvs([0,0],[[1,0],[0,1]],100)
mX = np.mean(X,axis=1)

5.6.3 Covariance matrix

Definition 5.20. The covariance matrix of a random vector X = [X1 , . . . , XN ]T is


2 3
Var[X1 ] Cov(X1 , X2 ) · · · Cov(X1 , XN )
6 Cov[X2 , X1 ] Var[X2 ] · · · Cov(X2 , XN )7
def 6 7
⌃ = Cov(X) = 6 .. .. .. .. 7. (5.33)
4 . . . . 5
Cov(XN , X1 ) Cov(XN , X2 ) ··· Var[XN ]

A more compact way of writing the covariance matrix is

⌃ = Cov(X) = E[(X µ)(X µ)T ],

where µ = E[X] is the mean vector. The notation abT means the outer product, defined
as
2 3 2 3
a1 a 1 b1 a 1 b2 · · · a 1 bN
6 7 ⇥ ⇤ 6 .. 7 .
abT = 4 ... 5 b1 · · · bN = 4 ... ..
.
..
. . 5
aN a N b1 a N b 2 · · · a N bN

It is easy to show that Cov(X) = Cov(X)T , i.e., they are symmetric.

Theorem 5.13. If the coordinates X1 , . . . , XN are independent, then the covariance


matrix Cov(X) = ⌃ is a diagonal matrix:
2 3
Var[X1 ] 0 ··· 0
6 0 Var[X 2] ··· 0 7
6 7
⌃ = Cov(X) = 6 .. .. .. .. 7.
4 . . . . 5
0 0 ··· Var[XN ]

289
CHAPTER 5. JOINT DISTRIBUTIONS

Proof. If all Xi ’s are independent, then Cov(Xi , Xj ) = 0 for all i 6= j. Substituting this
into the definition of the covariance matrix, we obtain the result.

If we ignore the mean vector µ, we obtain the autocorrelation matrix R.

Definition 5.21. Let X = [X1 , . . . , XN ]T be a random vector. The autocorrelation


matrix is
2 3
E[X1 X1 ] E[X1 X2 ] · · · E[X1 XN ]
6 E[X2 X1 ] E[X2 X2 ] · · · E[X2 XN ] 7
6 7
R = E[XX T ] = 6 .. .. .. .. 7. (5.34)
4 . . . . 5
E[XN X1 ] E[XN X2 ] ··· E[XN XN ]

We state without proof that


⌃=R µµT ,
which corresponds to the single-variable case where 2 = E[X 2 ] µ2 .
On computers, computing the covariance matrix is done using built-in commands cov
in MATLAB and np.cov in Python. Like the mean vectors, when computing the covariance,
we need to specify the direction. For example, for an N ⇥ 2 data matrix X, the covariance
needs to be a 2 ⇥ 2 matrix. If we compute the covariance along the wrong direction, we will
obtain an N ⇥ N matrix, which is incorrect.
% MATLAB code to compute covariance matrix
X = randn(100,2);
covX = cov(X);

# Python code to compute covariance matrix


import numpy as np
import scipy.stats as stats
X = stats.multivariate_normal.rvs([0,0],[[1,0],[0,1]],100)
covX = np.cov(X,rowvar=False)
print(covX)

5.6.4 Multidimensional Gaussian


With the above tools in hand, we can now define a high-dimensional Gaussian. The PDF of
a high-dimensional Gaussian is defined as follows.

Definition 5.22. A d-dimensional joint Gaussian has the PDF



1 1
fX (x) = p exp (x µ)T ⌃ 1 (x µ) , (5.35)
(2⇡)d |⌃| 2

where d denotes the dimensionality of the vector x.

290
5.6. RANDOM VECTORS AND COVARIANCE MATRICES

The mean vector and the covariance matrix of a joint Gaussian is readily available from the
definition.

E[X] = µ and Cov(X) = ⌃.

It is easy to show that if X is a scalar X, then d = 1, µ = µ, and ⌃ = 2 . Substituting


these into the above definition returns us the familiar 1D Gaussian.
The d-dimensional Gaussian is a generalization of the 1D Gaussian(s). Suppose that Xi
and Xj are independent for all i 6= j. Then E[Xi Xj ] = E[Xi ]E[Xj ] and hence Cov(Xi , Xj ) =
0. Consequently, the covariance matrix ⌃ is a diagonal matrix:
2 2 3
1 ··· 0
6 7
⌃ = 4 ... . . . ... 5 ,
2
0 ··· d

2
where i = Var[Xi ]. When this occurs, the exponential term in the Gaussian PDF is
2 3T 2 2
3 1 2 3
x1 µ1 1 ··· 0 x1 µ1 d
1 6 .. 7 6 .. .. .. 7 6 .. 7 X (xi µi ) 2
(x µ)T ⌃ (x µ) = 4 . 5 4. . .5 4 . 5= 2 .
2 i=1 i
xd µd 0 ··· d xd µd

Moreover, the determinant |⌃| is


2 2
3
1 ··· 0 d
6
|⌃| = 4 ... .. .. 7 = Y 2
. . 5 i.
2 i=1
0 ··· d

Substituting these results into the joint Gaussian PDF, we obtain


Yn ⇢
1 (x µi )2
fX (x) = p exp ,
i=1
2
(2⇡) i 2 i2

which is a product of individual Gaussians.


The Gaussian has di↵erent o↵sets and orientations for di↵erent choices of µ and ⌃.
Figure 5.15 shows a few examples. Note that for ⌃ to be valid ⌃ has to be “symmetric
positive semi-definite”, the meaning of which will be explained shortly.
Generating random numbers from a multidimensional Gaussian can be done by calling
built-in commands. In MATLAB, we use mvnrnd. In Python, we have a similar command.

% MATLAB code to generate random numbers from multivariate Gaussian


mu = [0 0];
Sigma = [.25 .3; .3 1];
X = mvnrnd(mu,Sigma,100);

# Python code to generate random numbers from multivariate Gaussian


import numpy as np
import scipy.stats as stats
X = stats.multivariate_normal.rvs([0,0],[[0.25,0.3],[0.3,1.0]],100)

291
CHAPTER 5. JOINT DISTRIBUTIONS

5 5 5
4 4 4
3 3 3
2 2 2
1 1 1
0 0 0
-1 -1 -1
-2 -2 -2
-3 -3 -3
-4 -4 -4
-5 -5 -5
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
     
0 5 0 1 1 0.5 0 2 1.9
(µ, ⌃) = , (µ, ⌃) = , (µ, ⌃) = ,
2 0 0.5 2 0.5 1 0 1.9 2

Figure 5.15: Visualization of 2D Gaussians with di↵erent means and covariances.

To display the data points and overlay with the contour, we can use MATLAB com-
mands such as contour. The resulting plot looks like the one shown in Figure 5.16. In
Python the corresponding command is plt.contour. To set up the plotting environment
we use the commands np.meshgrid. The grid points are used to evaluate the PDF values,
thus giving us the contour.

% MATLAB code: Overlay random numbers with the Gaussian contour.


X = mvnrnd([0 0],[.25 .3; .3 1],1000);
x1 = -2.5:.01:2.5;
x2 = -3.5:.01:3.5;
[X1,X2] = meshgrid(x1,x2);
F = mvnpdf([X1(:) X2(:)],[0 0],[.25 .3; .3 1]);
F = reshape(F,length(x2),length(x1));
figure(1);
scatter(x(:,1),x(:,2),’rx’, ’LineWidth’, 1.5); hold on;
contour(x1,x2,F,[.001 .01 .05:.1:.95 .99 .999], ’LineWidth’, 2);

# Python code: Overlay random numbers with the Gaussian contour.


import numpy as np
import scipy.stats as stats
import matplotlib.pyplot as plt
X = stats.multivariate_normal.rvs([0,0],[[0.25,0.3],[0.3,1.0]],1000)
x1 = np.arange(-2.5, 2.5, 0.01)
x2 = np.arange(-3.5, 3.5, 0.01)
X1, X2 = np.meshgrid(x1,x2)
Xpos = np.empty(X1.shape + (2,))
Xpos[:,:,0] = X1
Xpos[:,:,1] = X2
F = stats.multivariate_normal.pdf(Xpos,[0,0],[[0.25,0.3],[0.3,1.0]])
plt.scatter(X[:,0],X[:,1])
plt.contour(x1,x2,F)

292
5.7. TRANSFORMATION OF MULTIDIMENSIONAL GAUSSIANS

0
y

-1

-2

-3

-2.5 -2 -1.5 -1 -0.5 0 0.5 1 1.5 2 2.5


x
Figure 5.16: 1000 random numbers drawn from a 2D Gaussian, overlaid with the contour plot.

5.7 Transformation of Multidimensional Gaussians

As we have seen in Figure 5.15, the shape and orientation of a multidimensional Gaussian
are determined by the mean vector µ and the covariance matrix ⌃. This means that if we
can somehow transform the mean vector and the covariance matrix, we will get another
Gaussian. A few practical questions are:
How do we shift and rotate a Gaussian random variable?
If we have an arbitrary Gaussian, how do we go back to zero-mean unit-variance
Gaussian?
How do we generate random vectors according to a predefined Gaussian?
These questions come up frequently in data analysis. Answering the first two questions will
help us transform Gaussians back and forth, while answering the last question will help us
with generating random samples.

5.7.1 Linear transformation of mean and covariance


Suppose we have an arbitrary (not necessarily a Gaussian) random vector X = [X1 , . . . , XN ]T
with mean µX and covariance ⌃X . Entries of X are not necessarily independent. Let
A 2 RN ⇥N be a transformation, and let Y = AX. That is,
2 3 2 32 3
Y1 a11 a12 · · · a1N X1
6 Y2 7 6 a21 a22 · · · a2N 7 6 X2 7
6 7 6 76 7
Y =6 . 7=6 . .. .. .. 7 6 .. 7 = AX.
4 .. 5 4 .. . . . 54 . 5
YN aN 1 aN 2 ··· aN N XN

Then we can show the following result.

293
CHAPTER 5. JOINT DISTRIBUTIONS

Theorem 5.14. The mean vector and covariance matrix of Y = AX are

µY = AµX , ⌃Y = A⌃X AT . (5.36)

Proof. We first show the mean. Consider the nth element of Y :


"N # N
X X
E[Yn ] = E ank Xk = ank E[Xk ].
k=1 k=1

Therefore,
2 3 2 PN 3
E[Y1 ]
P k=1 a1k E[Xk ]
6 E[Y2 ] 7 6 N a2k E[Xk ] 7
6 7 6 k=1 7
µY = 6 . 7 = 6 .. 7
4 .. 5 4 . 5
PN
E[YN ]
k=1 aN k E[Xk ]
2 32 3
a11 a12 · · · a1N E[X1 ]
6 a21 a22 · · · a2N 7 6 E[X2 ] 7
6 76 7
=6 . .. .. .. 7 6 .. 7 = AµX .
4 .. . . . 54 . 5
aN 1 aN 2 ··· aN N E[XN ]

The covariance matrix follows from the fact that

⌃Y = E[(Y µY )(Y µY )T ]
= E[(AX AµX )(AX AµX )T ]
= E[A(X µX )(X µ X ) T AT ]
= AE[(X µX )(X µX )T ]AT
= A⌃X AT .


What if we shift the random vector by defining Y = X + b? We state the following
result without proof (try proving it as an exercise).

Theorem 5.15. The mean vector and covariance matrix of Y = X + b are

µY = µX + b, ⌃Y = ⌃X . (5.37)

For a Gaussian random vector, the linear transformations either shifts the Gaussian or
rotates the Gaussian, as shown in Figure 5.17:
If we add b to X, the resulting operation is a translation.
If we multiply A by X, then the resulting operation is a rotation and scaling.

294
5.7. TRANSFORMATION OF MULTIDIMENSIONAL GAUSSIANS

Figure 5.17: Transforming a Gaussian. [Left] Translation by a vector b. [Right] Rotation and scaling by
a matrix X.

How to rotate, scale, and translate a Gaussian random variable


We rotate and scale a Gaussian by Y = AX.
We translate a Gaussian by Y = X + b.

5.7.2 Eigenvalues and eigenvectors


As our next step, we need to understand eigendecomposition. You can easily find relevant
background in any undergraduate linear algebra textbook. Here we provide a summary for
completeness.
When applying a matrix A to a vector x, a typical engineering question is: what x
would be invariant to A? Or in other words, for what x can we make sure that Ax = x,
for some scalar ? If we can find such a vector x, we say that x is the eigenvector of A.
Eigenvectors are useful for seeking principal components of datasets or finding efficient signal
representations. They are defined as follows:

Definition 5.23. Given a square matrix A 2 RN ⇥N , the vector u 2 RN (with u 6= 0)


is called the eigenvector of A if
Au = u, (5.38)
for some 2 R. The scalar is called the eigenvalue associated with u.

An N ⇥ N matrix has N eigenvectors and N eigenvalues. Therefore, the above equation can
be generalized to
Aui = i ui ,
for i = 1, . . . , N , or more compactly as AU = ⇤U . The eigenvalues 1 , . . . , N are not
necessarily distinct. There are matrices with identical eigenvalues, the identity matrix being
a trivial example.
 On the other hand, not all square matrices have eigenvectors. For example,
0 1
the matrix does not have an eigenvalue. Matrices that have eigenvalues must be
0 0
diagonalizable.

295
CHAPTER 5. JOINT DISTRIBUTIONS

There are a number of equivalent conditions for to be an eigenvalue:


• There exists u 6= 0 such that Au = u;
• There exists u 6= 0 such that (A I)u = 0;
• (A I) is not invertible;
• det(A I) = 0.
We are mostly interested in symmetric matrices. If A is symmetric, then all the eigen-
values are real, and the following result holds.

Theorem 5.16. If A is symmetric, all the eigenvalues are real, and there exists U
such that U T U = I and A = U ⇤U T . Then
2 32 32 3
2 3 1 — uT1 —
| | | 6 | | | 7
6 76 76— uT2 —7
4 a 1 a 2 · · · a N 5 = 6 u1 u2 · · · uN 7 6 76 7
2
6 746 .. 7 6 .. 7.
| | | 4 | | | 5 . 5 4 . 5
| {z } N
T
— uN —
A | {z }| {z }| {z }
U ⇤ UT
(5.39)

We call such a decomposition the eigendecomposition. In MATLAB, we can compute the


eigenvalues of a matrix by using the eig command. In Python, the corresponding command
is np.linalg.eig. Note that in our demonstration below we symmetrize the matrix. This
step is needed, for otherwise the eigenvalues will contain complex numbers.
% MATLAB Code to perform eigendecomposition
A = randn(100,100);
A = (A + A’)/2; % symmetrize because A is not symmetric
[U,S] = eig(A); % eigendecomposition
s = diag(S); % extract eigenvalue

# Python Code to perform eigendecomposition


import numpy as np
A = np.random.randn(100,100)
A = (A + np.transpose(A))/2
S, U = np.linalg.eig(A)
s = np.diag(S)

The condition that U T U = I is the result of an orthonormal matrix. Equivalently,


uTi uj = 1 if i = j and uTi uj = 0 if i 6= j. Since {ui }Ni=1 is orthonormal, it can serve as a
basis of any vector in Rn :
N
X
x= ↵ j uj ,
j=1

where ↵j = uTj xis called the basis coefficient. Basis vectors are useful in that they can
provide alternative representations of a vector.

296
5.7. TRANSFORMATION OF MULTIDIMENSIONAL GAUSSIANS

Figure 5.18: The center and the radius of the ellipse is determined by µ and ⌃.

The geometry of the joint Gaussian is determined by its eigenvalues and eigenvectors.
Consider the eigendecomposition of ⌃:

⌃ = U ⇤U T
2 32 3
2 3 1 0 ··· 0 uT1
| | | 60 ··· 07 6 uT2 7
6 2 76 7
= 4u1 u2 ··· ud 5 6 . .. .. .. 7 6 .. 7,
.
| | | 4. . . . 54 . 5
0 ··· ··· d uTd

for some unitary matrix U and diagonal matrix ⇤. The columns of U are called the eigen-
vectors, and the entries of ⇤ are called the eigenvalues. Since ⌃ is symmetric, all i ’s are
real. In addition, since ⌃ is positive semi-definite, all i ’s are non-negative. Accordingly, the
volume defined by the multidimensional Gaussian is always a convex object, e.g., an ellipse
in 2D or an ellipsoid in 3D.
The orientation of the axes is defined by the column vectors ui . In the case of d = 2,
the major axis is defined by u1 and the minor axis is defined by u2 . The corresponding radii
of each axis are specified by the eigenvalues 1 and 2 . Figure 5.18 provides an illustration.

5.7.3 Covariance matrices are always positive semi-definite

The following subsection about positive semi-definite matrices can be skipped if it is your
first time reading the book.

Now that we understand eigendecomposition, what can we do with it? Here is one practical
problem. Given a matrix ⌃, how do you know whether this ⌃ is valid? For example, if we
give you a singular matrix, then ⌃ 1 may not exist. Checking the validity of ⌃ requires the
concept of positive semi-definite.
Given a square matrix A 2 RN ⇥N , it is important to check the positive semi-definiteness
of A. There are two practical scenarios where we need positive semi-definiteness. (1) If
we are estimating the covariance matrix ⌃ from a dataset, we need to ensure that ⌃ =
E[(X µ)(X µ)T ] is positive semi-definite because all covariance matrices are positive

297
CHAPTER 5. JOINT DISTRIBUTIONS

semi-definite. Otherwise, the matrix we estimate is not a legitimate covariance matrix. (2)
If we solve an optimization problem involving a function f (x) = xT Ax, then having A
being positive semi-definite, we can guarantee that the problem is convex. Convex problems
ensure that a local minimum is also global, and convex problems can be solved efficiently
using known algorithms.

Definition 5.24 (Positive Semi-Definite). A matrix A 2 RN ⇥N is positive semi-


definite if
xT Ax 0 (5.40)
for any x 2 RN . A is positive definite if xT Ax > 0 for any x 2 RN .

Using eigendecomposition, it is not difficult to show that positive semi-definiteness is equiv-


alent to having non-negative eigenvalues.

Theorem 5.17. A matrix A 2 RN ⇥N is positive semi-definite if and only if

i (A) 0 (5.41)

for all i = 1, . . . , N , where i (A) denotes the ith eigenvalue of A.

Proof. By the definitions of eigenvalue and eigenvector, we have that

Aui = i ui ,

where i is the eigenvalue and ui is the corresponding eigenvector. If A is positive semi-


definite, then uTi Aui 0 since ui is a particular vector in Rn . So we have

0  uTi Aui = kui k2 ,


PN T
and hence i 0. Conversely, if i 0 for all i, then since A = i=1 i ui ui we can
conclude that
N
! N
X X
T T T T 2
x Ax = x i ui ui x= i (ui x) 0.
i=1 i=1


The following corollary shows that if A 2 Rn⇥n is positive definite, it must be invert-
ible. Being invertible also means that the columns of A are linearly independent.

Corollary 5.2. If a matrix A 2 RN ⇥N is positive definite (but not semi-definite),


then A must be invertible, i.e., there exists A 1 2 RN ⇥N such that
1 1
A A = AA = I. (5.42)

The next theorem tells us that the covariance matrix is always positive semi-definite.

298
5.7. TRANSFORMATION OF MULTIDIMENSIONAL GAUSSIANS

Theorem 5.18. The covariance matrix Cov(X) = ⌃ is symmetric positive semi-


definite, i.e.,
⌃T = ⌃, and v T ⌃v 0, 8v 2 Rd .

Proof. Symmetry follows immediately from the definition, because Cov(Xi , Xj ) = Cov(Xj , Xi ).
The positive semi-definiteness comes from the fact that

v T ⌃v = v T E[(X µ)(X µ)T ]v


= E[v T (X µ)(X µ)T v]
= E[bT b] = E[kbk2 ] 0,

where b = (X µ)T v. ⇤

End of the discussion.

5.7.4 Gaussian whitening


Besides checking positive semi-definiteness, another typical problem we encounter is how to
generate random samples according to some Gaussian distributions.

From Gaussian(0, I) to Gaussian(µ, ⌃). If we are given zero-mean unit-variance Gaus-


sian X ⇠ Gaussian(0, I), how do we generate Y ⇠ Gaussian(µ, ⌃) from X?
The idea is to define a transformation
1
Y = ⌃ 2 X + µ,
1 1
where ⌃ 2 = U ⇤ 2 U T . Then the mean of Y is
1 1 1
E[Y ] = E[⌃ 2 X + µ] = ⌃ 2 E[X] + µ = ⌃ 2 0 + µ = µ,

and the covariance matrix is


1 1
E[(Y µ)(Y µ)T ] = E[(⌃ 2 X + µ µ)(⌃ 2 X + µ µ)T ]
1 1 1 1
= E[(⌃ 2 X)(⌃ 2 X)T ] = ⌃ 2 E[XX T ]⌃ 2
1 1
= ⌃ 2 I⌃ 2 = ⌃.

The following theorem summarizes this result.

Theorem 5.19. Let X be X ⇠ Gaussian(0, I). Consider a mean vector µ and a


covariance matrix ⌃ with eigendecomposition ⌃ = U ⇤U T . If
1
Y = ⌃ 2 X + µ, (5.43)
1 1
where ⌃ 2 = U ⇤ 2 U T , then Y ⇠ Gaussian(µ, ⌃).

299
CHAPTER 5. JOINT DISTRIBUTIONS

Therefore, the two steps for doing this Gaussian whitening are:
Step 1: Generate samples {x1 , . . . , xN } that are distributed according to Gaussian(0, I).
Step 2: Define y n where
1
y n = ⌃ 2 xn + µ.

These two steps are portrayed in Figure 5.19.

Figure 5.19: Generating an arbitrary Gaussian from Gaussian(0, I).

Example 5.26. Consider a set of N = 1000 i.i.d. Gaussian(0, I) data points as shown
in Figure 5.20, for example,
  
0.5377 2.2588 0.3188
x1 = , x2 = , ... , x1000 = .
1.8399 0.8622 1.3077

5 5
4 4
3 3
2 2
1 1
0 0
-1 -1
-2 -2
-3 -3
-4 -4
-5 -5
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
(a) Before (b) After

Figure 5.20: Generating arbitrary Gaussian random variables from Gaussian(0, I).
Transform these data points so that the new distribution is a Gaussian with
 
1 3 0.5
µ= and ⌃ = .
2 0.5 1

300
5.7. TRANSFORMATION OF MULTIDIMENSIONAL GAUSSIANS

Solution. To perform the transformation, we first perform eigendecomposition of ⌃ =


1 1
U ⇤U T . Then ⌃ 2 = U ⇤ 2 U T . For our problem, we compute

1 1.722 0.1848
⌃2 = .
0.1848 0.9828
1
Multiplying this matrix to yield y n = ⌃ 2 xn + µ, we obtain
  
1.5870 3.0495 1.7907
y1 = , y2 = , ... , y 1000 = .
0.2971 0.7351 3.3441

In MATLAB, the above whitening procedure can be realized using the following com-
mands.

% MATLAB code to perform the whitening


x = mvnrnd([0,0],[1 0; 0 1],1000);
Sigma = [3 -0.5; -0.5 1];
mu = [1; -2];
y = Sigma^(0.5)*x’ + mu;

The Python implementation is similar, although one needs to be careful with the
more complicated syntax. For example, Sigma^(0.5) in MATLAB does the eigen-based
matrix power automatically, whereas in Python we need to call a specific built-in command
fractional_matrix_power. In MATLAB, broadcasting a vector to a matrix can be rec-
ognized. In Python, we need to call repmat explicitly to control the shape of the mean
vectors.

# Python code to perform the whitening


import numpy as np
import scipy.stats as stats
from scipy.linalg import fractional_matrix_power

x = np.random.multivariate_normal([0,0],[[1,0],[0,1]],1000)
mu = np.array([1,-2])
Sigma = np.array([[3, -0.5],[-0.5, 1]])
Sigma2 = fractional_matrix_power(Sigma,0.5)
y = np.dot(Sigma2, x.T) + np.matlib.repmat(mu,1000,1).T

From Gaussian(µ, ⌃) to Gaussian(0, I). The reverse direction can be done as follows.
Supposing that we have Y ⇠ Gaussian(µ, ⌃), we define
1
X=⌃ 2 (Y µ). (5.44)

Then
1
E[X] = E[⌃ 2 (Y µ)]
1
=⌃ 2 (E[Y ] µ) = 0.

301
CHAPTER 5. JOINT DISTRIBUTIONS

The covariance is

Cov(X) = E[(X µX )(X µX )T ]


= E[XX T ]
h 1 T
i
= E ⌃ 2 (Y µ)(Y µ)T ⌃ 2
1 ⇥ ⇤ T
= ⌃ 2 E (Y µ)(Y µ)T ⌃ 2
1 1
=⌃ 2 ⌃⌃ 2 = I.

The following theorem summarizes this result.

Theorem 5.20. Let Y be a Gaussian Y ⇠ Gaussian(µ, ⌃). If


1
X=⌃ 2 (Y µ), (5.45)

then X ⇠ Gaussian(0, I).

Thus the two steps of doing this reversed Gaussian whitening are:
Step 1: Assuming that y 1 , . . . , y N are distributed as Gaussian(µ, ⌃), estimate µ
and ⌃.
Step 2: Define xn where
1
xn = ⌃ 2 (y n µ). (5.46)

These two steps are shown pictorially in Figure 5.21.

Figure 5.21: Converting an arbitrary Gaussian back to Gaussian(0, I).

In practice, if we are given {y n }N


n=1 , we need to estimate µ and ⌃. The estimations
are quite straightforward.
N
1 X
b=
µ y ,
N n=1 n
XN
b = 1
⌃ (y b )(y n
µ b )T .
µ
N n=1 n

302
5.8. PRINCIPAL-COMPONENT ANALYSIS

On computers, these can be obtained using the command mean and cov. Once we have
b we can define xn as
b and ⌃,
calculated µ
1
b
xn = ⌃ 2
(y n b ).
µ

On computers, the codes for the whitening procedure that uses the estimated mean
and covariance are shown below.

% MATLAB code to perform whitening


y = mvnrnd([1; -2],[3 -0.5; -0.5 1],100);
mY = mean(y);
covY = cov(y);
x = covY^(-0.5)*(y-mY)’;

# Python code to perform whitening


import numpy as np
import scipy.stats as stats
from scipy.linalg import fractional_matrix_power
y = np.random.multivariate_normal([1,-2],[[3,-0.5],[-0.5,1]],100)
mY = np.mean(y,axis=0)
covY = np.cov(y,rowvar=False)
covY2 = fractional_matrix_power(covY,-0.5)
x = np.dot(covY2, (y-np.matlib.repmat(mY,100,1)).T)

5.8 Principal-Component Analysis

We have studied the covariance matrix ⌃ in some depth. It has many other uses besides
transforming Gaussian random variables, and in this section we present one of them, called
the principal-component analysis (PCA). PCA is a widely used tool for dimension reduc-
tion. Instead of using N features to describe a data point, PCA allows us to use the leading
p principal components to describe the same data point. In many problems in machine
learning, this makes the learning task easier and the inference task more efficient.

5.8.1 The main idea: Eigendecomposition


PCA can be summarized in one sentence:

The key idea of PCA is the eigendecomposition of the covariance matrix ⌃.

This is a condensed summary of PCA: It is just the eigendecomposition of the co-


variance. However, before we discuss the computational procedure, we will explain why we
would want to perform the eigendecomposition of the covariance matrix.

303
CHAPTER 5. JOINT DISTRIBUTIONS

Consider a set of data points {x(1) , . . . , x(N ) }, where each x(n) 2 Rd is a d-dimensional
vector. The dimension d is often high. For example, if we have an image of size 1024⇥1024⇥3,
then d = 3,145,728 — not a huge number, but enough to make you feel dizzy. The goal
of PCA is to find a low-dimensional representation in Rp where p ⌧ d. If we can find
this low-dimensional representation, we can represent the d-dimensional input using only p
coefficients. Since p ⌧ d, we can “compress” the data by using a compact representation. In
modern data science, such a dimension reduction scheme is useful for handling large-scale
datasets.
Mathematically, we define a set of basis vector v 1 , . . . , v p , where each v i 2 Rd . Our
goal is to approximate an input data point x(n) 2 Rd by these basis vectors:
p
X
(n)
x ⇡ ↵i v i ,
i=1

where {↵i }pi=1 are called the representation coefficients. The representation described by
this equation is a linear representation. Linear representation is extremely common in prac-
tice. For example, a data point x(n) = [7, 1, 4]T can be represented as
2 3 2 3 2 3
7 1 1
415 = 3 4 15 + 4 415.
|{z} |{z}
4 ↵1 0 ↵2 1
|{z} | {z } |{z}
x(n) v1 v2

Therefore, the 3-dimensional input x(n) can now be represented by two coefficients ↵1 = 3
and ↵2 = 4. This is called dimensionality reduction.
Pictorially, if we have already determined the basis vectors, we can compute the co-
efficients for every data point in the dataset. However, not all basis vectors are good. As
illustrated in Figure 5.22, an elongated dataset will be of the greatest benefit if the basis
vectors are oriented according to the data geometry. If we can find such basis vectors, then
the data points will have a large coefficient and a small coefficient, corresponding to the
major and the minor axes. Dimensionality reduction can thus be achieved by, for example,
only keeping the larger coefficients.

Figure 5.22: PCA aims at finding a low-dimensional representation of a high-dimensional dataset. In


this figure, the 2D data points can be well represented by the 1D space spanned by v 1 .

The challenge here is that, given the dataset {x(1) , . . . , x(N ) }, we need to determine
both the basis vectors {v i }pi=1 and the coefficients {↵i }pi=1 . Fortunately, this can be formu-
lated as an eigendecomposition problem.

304
5.8. PRINCIPAL-COMPONENT ANALYSIS

To see how this problem can be thus formulated, we consider the simplest case as
illustrated in Figure 5.22, where we want to find the leading principal component. That is,
we find (↵, v) such that x ⇡ ↵v. This amounts to solving the optimization problem
2 3 2 3 2
| |
(b b) = argmin 4x5 ↵ 4v 5 .
v, ↵
kvk2 =1,↵ | |
The notation “argmin” means the argument that minimizes the function. The equation
says that we find the (↵, v) that minimizes the distance between x and ↵v. The constraint
kvk2 = 1 limits the search to within a unit circle; otherwise our solution will not be unique.
Solving the optimization problem is not difficult. If we take the derivative w.r.t. ↵ and
set it to zero, we have that
2v T (x ↵v) = 0 ) ↵ = v T x.
Substituting ↵ = xT v into the objective function again, we show that

argmin kx ↵vk = argmin xT x 2↵xT v + ↵2 v T v ,
2
kvk2 = 1
kvk2 =1 kvk2 =1

= argmin 2↵xT v + ↵2 , drop xT x
kvk2 =1

= argmin 2(xT v)xT v + (xT v)2 , substitute ↵ = xT v
kvk2 =1

= argmax v T xxT v , change min to max.
kvk2 =1

Let us pause for a second. We have shown that if we have one data point x, the leading
principal component v can be determined by maximizing v T xxT v. What have we gained?
We have transformed the original optimization, which contains two variables (v, ↵), to a new
optimization that contains one variable v. Thus if we know how to solve the one-variable
problem we are done.
However, there is one more issue we need to address before we discuss how to solve
for the problem. The issue is that the formulation is about one data sample, not the entire
dataset. To include all the samples, we need to assume that x is a realization of a random
vector X. Then the above optimization can be formulated in the expectation sense as

argmin EkX ↵vk2 = argmax v T E XX T v
kvk2 =1 kvk2 =1

= argmax v T ⌃v,
kvk2 =1

def
where ⌃ = E[X T X].1 Therefore, if we can maximize v T ⌃v we will be able to determine
the principal component.
Now comes the main result. The following theorem shows that the maximization is
equivalent to eigendecomposition. The proof requires Lagrange multipliers, which are beyond
the scope of this book.
1 Here we assume that⇢X is zero-mean, i.e., E[X] = 0. If it is not, then we can subtract the mean by
considering argmax v T E (X µ)(X µ)T v.
kvk2 =1

305
CHAPTER 5. JOINT DISTRIBUTIONS

Theorem 5.21. Let ⌃ be a d ⇥ d matrix with eigendecomposition ⌃ = U SU T . Then


the optimization

b = argmax v T ⌃v
v (5.47)
kvk2 =1

b = u1 , i.e., the first column of the eigenvector matrix U .


has a solution v

The following proof requires an understanding of Lagrange multipliers and constrained


optimizations. It is not essential for understanding this chapter.

We want to prove that the solution to the problem


b = argmax v T ⌃v
v
kvk2 =1

is the eigenvector of the matrix ⌃. To show that, we first write down the Lagrangian:
L(v, ) = v T ⌃v (kvk2 1)
Taking the derivative w.r.t. v and setting to zero yields
rv L(v, ) = 2⌃v 2 v = 0.

This is equivalent to ⌃v = v. So if ⌃ = U SU T , then by letting v = ui and = si we can


satisfy the condition since ⌃ui = U SU T ui = U Sei = si ui .

End of the proof.

This theorem can be extended to the second (and other) principal components of
the covariance matrix. In fact, given the covariance matrix ⌃ we can follow the procedure
outlined in Figure 5.23 to determine the principal components. The eigendecomposition of a
d⇥d matrix ⌃ will give us a d⇥d eigenvector matrix U and an eigenvalue matrix S. To keep
the p leading eigenvectors, we truncate the U matrix to only use the first p eigenvectors. Here,
we assume that the eigenvectors are ordered according to the magnitude of the eigenvalues,
from large to small.
In practice, if we are given a dataset {x(1) , . . . , x(N ) }, we can first estimate the covari-
ance matrix ⌃ by
XN
b = 1
⌃ (x(n) µ b )(x(n) µ b )T ,
N n=1
P
where µ b = N1 N n=1 x
(n)
is the mean vector. Afterwards, we can compute the eigendecom-
b
position of ⌃ by
[U , S] = eig(⌃). b
On a computer, the principal components are obtained through eigendecomposition.
A MATLAB example and a Python example are shown below. We explicitly show the two
principal components in this example. The magnitudes of these two vectors are determined
by the eigenvalues diag(s).

306
5.8. PRINCIPAL-COMPONENT ANALYSIS

Figure 5.23: The principal components are the eigenvectors of the covariance matrix. In this figure ⌃
denotes the covariance matrix, u1 , . . . , up denote the p leading eigenvectors, and s denotes the diagonal
of the eigenvalue matrix.

% MATLAB code to perform the principal-component analysis


x = mvnrnd([0,0],[2 -1.9; -1.9 2],1000);
covX = cov(x);
[U,S] = eig(covX);
u(:,1) % Principle components
u(:,2) % Principle components

# Python code to perform the principal-component analysis


import numpy as np
x = np.random.multivariate_normal([1,-2],[[3,-0.5],[-0.5,1]],1000)
covX = np.cov(x,rowvar=False)
S, U = np.linalg.eig(covX)
print(U)

Example 5.27. Suppose we have a dataset containing N = 1000 samples, drawn from
an unknown distribution. The first few samples are
  
0.5254 0.4040 1.4165
x1 = , x2 = , . . . , x1000 = .
0.6930 0.3724 1.5463

We can compute the mean and covariance using MATLAB commands mean and cov.
This will return us
 
0.0561 b = 2.0460 1.9394
b=
µ and ⌃ .
0.0303 1.9394 2.0426

b we show that
Applying eigendecomposition on ⌃,
b
[U , S] = eig(⌃),
 
0.7068 0.7074 0.1049 0
=) U = and S= .
0.7074 0.7068 0 3.9837

307
CHAPTER 5. JOINT DISTRIBUTIONS

Therefore, we have obtained two principal components


 
0.7068 0.7074
u1 = and u2 = .
0.7074 0.7068

As seen in the figure below, these two principal components make sense. The vector
u1 is the orange line and is the minor axis. The vector u2 is the blue line and is the
major axis. Again, the ordering of the vectors is determined by the eigenvalues. Since
u2 has a larger eigenvalue (=3.9837), it is the leading principal component.
5
4
3
2
1
0
-1
-2
-3
-4
-5
-5 -4 -3 -2 -1 0 1 2 3 4 5

Figure 5.24: To determine the representation coefficients, we solve an inverse problem by finding the
vector ↵ in the equation x(n) = U p ↵(n) .

Why do we call our method principal component analysis? The analysis part comes
from the fact that we can compress a data vector x(n) from a high dimension d to a low
dimension p. Defining U p = [u1 , . . . , up ], a matrix containing the p leading eigenvectors of
the matrix U , we solve the inverse problem:

x(n) = U p ↵(n) ,

where the goal is to determine the coefficient vector ↵(n) 2 Rp . Since U p is an orthonormal
matrix (i.e., U Tp U p = I), it follows that

U Tp x(n) = U Tp U p ↵(n) ,
| {z }
=I

308
5.8. PRINCIPAL-COMPONENT ANALYSIS

as illustrated in Figure 5.24. Hence,


↵(n) = U Tp x(n) .

This equation is a projection operation that projects a data point x(n) onto the space
spanned by the p leading principal components. Repeating the procedure for all the data
points x(1) , . . . , x(N ) in the dataset, we have compressed the dataset.

Example 5.28. Using the example above, we can show that


  
(1) T (1) 0.1189 (2) 0.0221 (1000) 0.0927
↵ =U x = , ↵ = , ... , ↵ = .
0.8615 0.5491 2.0950

The principal-component analysis says that since the leading components represent the
data, we only need to keep the blue-colored values because they are the coefficients
associated with the leading principal component.

5.8.2 The eigenface problem


As a concrete example of PCA, we consider a computer vision problem called the eigen-
face problem. In 2001, researchers at Yale University published the Yale Database, and
a few years later they extended it to a larger one (http://vision.ucsd.edu/~leekc/
ExtYaleDatabase/ExtYaleB.html). The dataset, now known as the Yale Face Dataset, con-
tains 16,128 images of 28 human subjects under nine poses and 64 illumination conditions.
The sizes of the images are d = 168 ⇥ 192 = 32,256 pixels. Treating these N =16,128 images
as vectors in R32,256⇥1 , we have 16,128 of these vectors. Let us call them {x(1) , . . . , x(N ) }.
Following the procedure we described above, we estimate the covariance matrix by
computing
N
b = E[(X µ 1 X (n)
⌃ b )(X µ b )T ] ⇡ (x b )(x(n) µ
µ b )T , (5.48)
N n=1
P
where µb = E[X] ⇡ N1 N n=1 x
(n)
is the mean vector. Note that the size of µb is 32,256⇥1
b
and the size of ⌃ is 32,256 ⇥ 32,256.

Figure 5.25: The extended Yale Face Database B.

Once we obtain an estimate of the covariance matrix, we can perform an eigendecom-


position to get
b
[U , S] = eig(⌃).
b These eigenvectors are the basis
The columns of U , i.e., {ui }di=1 , are the eigenvectors of ⌃.
of a testing face image.

309
CHAPTER 5. JOINT DISTRIBUTIONS

Figure 5.26: Given a face image, the learned basis vectors (from the eigendecomposition of the covari-
ance matrix) can be used to compress the image x into a feature vector ↵ where the dimension of ↵ is
significantly lower than that of x.

With the basis vectors u1 , . . . , up we can project every image in the dataset using a
low-dimensional representation. Specifically, for an image x we compute the coefficients

↵i = uTi x, i = 1, . . . , p

or more compactly ↵ = U T x. Note that the dimension of x is d ⇥ 1 (which in our case is


d = 32,526), and the dimensions of ↵ can be as few as p = 100. Therefore, we are using a
100-dimensional vector to represent a 32,526-dimensional data. This is a huge dimensionality
reduction.
The process repeats for all the samples x(1) , . . . , x(N ) . This gives us a collection of rep-
resentation coefficients ↵(1) , . . . , ↵(N ) , where each ↵(n) is 100-dimensional (see Figure 5.26).
Notice that the basis vectors ui appear more or less “face images,” but they are the features
of the faces. PCA says that a real face can be written as a linear combination of these basis
vectors.

How to solve the eigenface problem


Compute the covariance matrix of all the images.
Apply eigendecomposition to the covariance matrix.
Project onto the basis vectors and find the coefficients.
The coefficients are the low-dimensional representation of the images.
We use the coefficients to perform downstream tasks, such as classification.

310
5.8. PRINCIPAL-COMPONENT ANALYSIS

5.8.3 What cannot be analyzed by PCA?


PCA is a dimension reduction tool. It compresses a raw data vector x 2 Rd into a smaller
feature vector ↵ 2 Rp . The advantage is that the downstream learning problems are much
easier because p ⌧ d. For example, classification using ↵ is more efficient than classification
using x since there is very little information loss from x to ↵.

There are three limitations of PCA:


PCS fails when the raw data are not orthogonal. The basis vectors ui returned
by PCA are orthogonal, meaning that uTi uj = 0 as long as i 6= j. As a result, if
the data intrinsically have this orthogonality property, then PCA will work very well.
However, if the data live in a space such as a donut shape as illustrated in Figure 5.27,
then PCA will fail. Here, by failure, we mean that p is not much smaller than d. To
handle datasets behaving like Figure 5.27 we need advanced tools. One of these is the
kernel-PCA. The idea is to apply a nonlinear transformation to the data before you
run PCA.

Figure 5.27: [Left] PCA works when the data has redundant dimensions or is living on orthogonal
spaces. [Right] PCA fails when the data does not have easily decomposable spaces.

Basis vectors returned by PCA are not interpretable. A temptation with PCA is to
think that the basis vectors ui o↵er meaningful information because they are the “prin-
cipal components”. However, since PCA is the eigendecomposition of the covariance
matrix, which is purely a mathematical operation, there is no guarantee that the basis
vectors contain any semantic meaning. If we look at the basis vectors shown in Fig-
ure 5.26, there is almost no information one can draw. Therefore, in the data-science
literature alternative methods such as non-negative matrix factorization and the more
recent deep neural network embedding are more attractive because the feature vectors
sometimes (not always) have meanings.
PCA does not return you the most influential “component”. Imagine that you
are analyzing medical data for research on a disease, in which each data vector x(n)
contains height, weight, BMI, blood pressure, etc. When you run PCA on the dataset,
you will obtain some “principal components”. However, these principal components
will likely have everything, e.g., the height entry of the principal component will have
some values, the weight will have some values, etc. If you have found a principal
component, it does not mean that you have identified the leading risk factor of the
disease. If you want to identify the leading risk factor of the disease, e.g., whether
the height or weight is more important, you need to resort to advanced tools such as
variable selection or the LASSO type of regression analysis (see Chapter 7).

311
CHAPTER 5. JOINT DISTRIBUTIONS

Closing remark. PCAs are powerful computational tools based on the simplest concept of
covariance matrices because, as our derivation showed, covariance matrices encode the “vari-
ation” of the data. Therefore, by finding a vector that aligns with the maximum variation
of the data, we can find the principal component.

5.9 Summary

As you were reading this chapter, you may have felt that the first and second parts discuss
distinctly di↵erent subjects, and in fact many books treat them as separate topics. We take
a di↵erent approach. We think that they are essentially the same thing if you understand
the following chain of distributions:

fX (x) =) fX1 ,X2 (x1 , x2 ) =) · · · =) fX1 ,...,XN (x1 , . . . , xN ).


| {z } | {z } | {z }
one variable two variables N variables

The first part exclusively deals with two variables. The generalization from two variables to
N variables is straightforward for PDFs and CDFs:
PDF: fX1 ,X2 (x1 , x2 ) =) fX1 ,...,XN (x1 , . . . , xN ).
CDF: FX1 ,X2 (x1 , x2 ) =) FX1 ,...,XN (x1 , . . . , xN ).
The joint expectation can also be generalized from two variables to N variables:
2 3
 Var[X12 ] · · · Cov(X1 , XN )
2
Var[X1 ] Cov(X1 , X2 ) 6 .. .. .. 7
=) 4 . . . 5.
Cov(X2 , X1 ) Var[X22 ]
2
Cov(XN , X1 ) · · · Var[XN ]

Conditional PDFs and conditional expectations are powerful tools for decomposing
complex events into simpler events. Specifically, the law of total expectation,
Z
E[X] = E[X|Y = y]fY (y) dy = EY [EX|Y [X|Y ]],

is instrumental for evaluating variables defined through conditional relationships. The idea
is also extendable to more random variables, such as
Z Z
E[X1 ] = E[X1 |X2 = x2 , X3 = x3 ]fX2 ,X3 (x2 , x3 ) dx2 dx3 ,

where E[X1 |X2 = x2 , X3 = x3 ] can be evaluated through


Z
E[X1 |X2 = x2 , X3 = x3 ] = x1 fX1 |X2 ,X3 (x1 | x2 , x3 ) dx1 .

This type of chain relationship can generalize to other high-order cases.


It is important to remember that for any high-dimensional random variables, the char-
acterization is always made by the PDF fX (x) (or the CDF). We did not go into the details

312
5.10. REFERENCES

of analyzing fX (x) but have only discussed the mean vector E[X] = µ and the covariance
matrix Cov(X) = ⌃. We have been focusing exclusively on the high-dimensional Gaussian
random variables

1 1
fX (x) = p exp (x µ)T ⌃(x µ) ,
d
(2⇡) |⌃| 2

because they are ubiquitous in data science today. We discussed the linear transformations
from a zero-mean unit-variance Gaussian to another Gaussian, and vice versa.

5.10 References

Joint Distributions and Correlation


5-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapters 2.5, 3.4, 4.2.
5-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapters 5.1 – 5.6.
5-3 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapters 6.1 – 6.4.
5-4 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 7.1 – 7.2.
5-5 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapters
6.1 – 6.3.
5-6 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapter 2.6.

Conditional Distributions and Expectations


5-7 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapters 2.6, 3.5, 3.6, 4.3.
5-8 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 5.7.
5-9 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapters 6.6 – 6.7.
5-10 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 7.3 – 7.5.
5-11 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapters
7.5 – 7.6.
5-12 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapter 4.2.

313
CHAPTER 5. JOINT DISTRIBUTIONS

Sum of Random Variables


5-13 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 4.5.
5-14 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 7.1.
5-15 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapters 3.3 and 3.4.

Vector Random Variables


5-16 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapters 6.1 – 6.6.
5-17 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 8.1 – 8.3, 9.
5-18 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapters 5.1 – 5.6.

Principal-Component Analysis
PCA is often taught in machine learning courses. For first-time readers, we suggest reviewing
the linear algebraic tools in Moon and Stirling. Then, the tutorial by Shlens and the chapter
in Bishop would be sufficient to cover most of the materials. More advanced topics, such as
kernel PCA, can be found in the following references.
5-19 Todd K. Moon and Wynn C. Stirling, Mathematical Methods and Algorithms for Signal
Processing, Prentice-Hall, 2000. Chapter 7.
5-20 Christopher Bishop, Pattern Recognition and Machine Leanring, Springer, 2006. Chap-
ter 12.
5-21 Jonathon Shlens (2014) “A Tutorial on Principal Component Analysis”, https://
arxiv.org/pdf/1404.1100.pdf
5-22 Paul Honeine (2014), “An eigenanalysis of data centering in machine learning”, https:
//arxiv.org/pdf/1407.2904.pdf
5-23 Quan Wang (2012), “Kernel Principal Component Analysis and its Applications”,
https://arxiv.org/abs/1207.3538
5-24 Schölkopf et al. (2005), “Kernel Principal Component Analysis”, https://link.springer.
com/chapter/10.1007/BFb0020217

5.11 Problems

Exercise 1. (Video Solution)


Alex and Bob each flips a fair coin twice. Use “1” to denote heads and “0” to denote tails.
Let X be the maximum of the two numbers Alex gets, and let Y be the minimum of the
two numbers Bob gets.

314
5.11. PROBLEMS

(a) Find and sketch the joint PMF pX,Y (x, y).
(b) Find the marginal PMF pX (x) and pY (y).
(c) Find the conditional PMF PX|Y (x | y). Does PX|Y (x | y) = PX (x)? Why or why not?

Exercise 2.
Two fair dice are rolled. Find the joint PMF of X and Y when
(a) X is the larger value rolled, and Y is the sum of the two values.
(b) X is the smaller, and Y is the larger value rolled.

Exercise 3.
The amplitudes of two signals X and Y have joint PDF
x/2 y2
fXY (x, y) = e ye
for x > 0, y > 0.
(a) Find the joint CDF.
(b) Find P(X 1/2 > Y ).

(c) Find the marginal PDFs.

Exercise 4. (Video Solution)


Find the marginal CDFs FX (x) and FY (y) and determine whether or not X and Y are
independent, if
8
e y e xy
>
<x 1 y , if 1  x  2, y 0
y 2y
FXY (x, y) = 1 e e
, if x > 2, y 0,
>
:
y
0, otherwise.

Exercise 5. (Video Solution)


(a) Find the marginal PDF fX (x) if

exp{ |y x| x2 /2}
fXY (x, y) = p .
2 2⇡

(b) Find the marginal PDF fY (y) if


(x y)2 /2
4e
fXY (x, y) = p .
y 2 2⇡

315
CHAPTER 5. JOINT DISTRIBUTIONS

Exercise 6. (Video Solution)


Let X, Y be two random variables with joint CDF

y + e x(y+1)
FX,Y (x, y) = .
y+1
Show that
@2 @2
FX,Y (x, y) = FX,Y (x, y).
@x@y @y@x
What is the implication of this result?

Exercise 7. (Video Solution)


Let X and Y be two random variables with joint PDF
1 1 2 2
fX,Y (x, y) = e 2 (x +y ) .
2⇡
(a) Find the PDF of Z = max(X, Y ).
(b) Find the PDF of Z = min(X, Y ).
You may leave your answers in terms of the (·) function.

Exercise 8.
The random vector (X, Y ) has a joint PDF
x 2y
fXY (x, y) = 2e e

for x > 0, y > 0. Find the probability of the following events:

(a) {X + Y  8}.
(b) {X Y  10}.
(c) {X 2 < Y }.

Exercise 9.
Let X and Y be zero-mean, unit-variance independent Gaussian random variables. Find the
value of r for which the probability that (X, Y ) falls inside a circle of radius r is 1/2.

Exercise 10.
The input X to a communication channel is +1 or 1 with probabilities p and 1 p,
respectively. The received signal Y is the sum of X and noise N , which has a Gaussian
distribution with zero mean and variance 2 = 0.25.
(a) Find the joint probability P(X = j, Y  y).
(b) Find the marginal PMF of X and the marginal PDF of Y .
(c) Suppose we are given that Y > 0. Which is more likely, X = 1 or X = 1?

316
5.11. PROBLEMS

Exercise 11. (Video Solution)


Let (
x
ce e y , if 0  y  x < 1,
fX,Y (x, y) =
0, otherwise.

(a) Find c.
(b) Find fX (x) and fY (y).
(c) Find E[X] and E[Y ], Var[X] and Var[Y ].
(d) Find E[XY ], Cov(X, Y ) and ⇢.

Exercise 12. (Video Solution)


In class, we have used the Cauchy-Schwarz inequality to show that 1  ⇢  1. This exercise
asks you to prove the Cauchy-Schwarz inequality:

(E[XY ])2  E[X 2 ]E[Y 2 ].

Hint: Consider the expectation E[(tX + Y )2 ]. Note that this is a quadratic equation in t and
E[(tX + Y )2 ] 0 for all t. Consider the discriminant of this quadratic equation.

Exercise 13. (Video Solution)


Let ⇥ ⇠ Uniform[0, 2⇡].

(a) If X = cos ⇥, Y = sin ⇥. Are X and Y uncorrelated?


(b) If X = cos(⇥/4), Y = sin(⇥/4). Are X and Y uncorrelated?

Exercise 14. (Video Solution)


Let X and Y have a joint PDF

fX,Y (x, y) = c(x + y),

for 0  x  1 and 0  y  1.
(a) Find c, fX (x), fY (y), and E[Y ].

(b) Find fY |X (y|x).


(c) Find P[Y > X | X > 1/2].
(d) Find E[Y |X = x].

(e) Find E[E[Y |X]], and compare with the E[Y ] computed in (a).

Exercise 15. (Video Solution)


Use the law of total expectation to compute the following:

317
CHAPTER 5. JOINT DISTRIBUTIONS

1. E[sin(X + Y )], where X ⇠ N (0, 1), and Y | X ⇠ Uniform[x ⇡, x + ⇡]


2. P[Y < y], where X ⇠ Uniform[0, 1], and Y | X ⇠ Exponential(x)
3. E[XeY ], where X ⇠ Uniform[ 1, 1], and Y | X ⇠ N (0, x2 )

Exercise 16.
Let Y = X+N , where X is the input, N is the noise, and Y is the output of a system. Assume
that X and N are independent random variables. It is given that E[X] = 0, Var[X] = X 2
,
E[N ] = 0, and Var[N ] = N .
2

(a) Find the correlation coefficient ⇢ between the input X and the output Y .

(b) Suppose we estimate the input X by a linear function g(Y ) = aY . Find the value of
a that minimizes the mean squared error E[(X aY )2 ].
2 2
(c) Express the resulting mean squared error in terms of ⌘ = X/ N.

Exercise 17. (Video Solution)


Two independent random variables X and Y have PDFs
( (
e x, x 0, 0, y > 0,
fX (x) = fY (y) =
0, x < 0, ey , y  0.

Find the PDF of Z = X Y.

Exercise 18.
Let X and Y be two independent random variables with densities
( (
xe x , x 0, ye y , y 0,
fX (x) = and fY (y) =
0, x < 0, 0, y < 0.

Find the PDF of Z = X + Y .

Exercise 19.
The random variables X and Y have the joint PDF
(x+y)
fXY (x, y) = e

for 0 < y < x < 1. Find the PDF of Z = X + Y .

Exercise 20.
The joint density function of X and Y is given by
(x+y)
fXY (x, y) = e

for x > 0, y > 0. Find the PDF of the random variable Z = X/Y .

318
Chapter 6

Sample Statistics

When we think about probability, the first thing that likely comes to mind is flipping a coin,
throwing a die, or playing a card game. These are excellent examples of the subject. However,
they seldom fit in the context of modern data science, which is concerned with drawing
conclusions from data. In our opinion, the power of probability is its ability to summarize
microstates using macro descriptions. This statement will take us some e↵ort to elaborate.
We study probability because we want to analyze the uncertainties. However, when we
have many data points, analyzing the uncertainties of each data point (the microstates)
is computationally very difficult. Probability is useful here because it allows us to bypass
the microstates and summarize the macro behavior. Instead of reporting the states of each
individual, we report their sample average. Instead of o↵ering the worst-case guarantee,
we o↵er a probabilistic guarantee. You ask: so what? If we can o↵er you a performance
guarantee at 99.99% confidence but one-tenth of the cost of a 100% performance guarantee,
would you consider our o↵er? The goal of this chapter is to outline the concepts of these
probabilistic arguments.

The significance of sample average


Imagine that you have a box containing many tiny magnets. (You can also think of a dataset
containing two classes of labels.) In condensed matter physics, these are known as the spin
glasses. The orientations of the magnets depend on the magnetic field. Under an extreme
condition where the magnetic field is strong, all magnets will point in the same direction.
When the magnetic field is not as strong, some will align with the field but some will not,
as we show in Figure 6.1.
If we try to study every single magnet in this box, the correlation of the magnets will
force us to consider a joint distribution, since if one magnet points to the right it is likely
that another magnet will also point to the right. The simultaneous description of all magnets
is modeled through a joint probability distribution

fX1 ,X2 ,...,XN (x1 , x2 , . . . , xN ).

Like any joint PDF, this PDF tells us the probability density that the magnets will take
a collection of states simultaneously. If N is large (say, on the order of millions), this joint
distribution will be very complicated.

319
CHAPTER 6. SAMPLE STATISTICS

Figure 6.1: Imagine that we have a box of magnets and we want to measure their orientation angles.
The data points have individual randomness and correlations. Studying each one individually could be
computationally infeasible, as we need to estimate the joint PDF fX1 ,...,XN (x1 , . . . , xN ) across all the
data points. Probability o↵ers a tool to summarize these individual states using a macro description.
For example, we can analyze the sample average X N of the data points and derive conclusions from
the PDF of X N , i.e., fX N (x). The objective of this chapter is to present a few probabilistic tools to
analyze macro descriptions, such as the sample average.

Since the joint PDF is very difficult to obtain computationally, physicists proposed
to study the sample statistics. Instead of looking at the individual states, they look at the
sample average of the states. If we define X1 , . . . , XN as the states of the magnets, then
the sample average is
N
1 X
XN = Xn .
N n=1
Since each magnet is random, the sample average is also random, and therefore it is granted
a PDF:
fX N (x).
Thus, X N has a PDF, a mean, a variance, and so on.
We call X N a sample statistic. It is called a statistic because it is a summary of the
microstates, and a sample statistic because the statistic is based on random samples, not on
the underlying theoretical distributions. We are interested in knowing the behavior of X N
because it is the summary of the observations. If we know the PDF of X N , we will know
the mean, the variance, and the value of X N when the magnetic field increases or decreases.

Why study the sample average X N ?


Analyzing individual variables is not feasible because the joint PDF can be ex-
tremely high-dimensional.
Sample average is a macro description of the data.
If you know the behavior of the sample average, you know most of the data.

Probabilistic guarantee versus worst-case guarantee


Besides the sample average, we are also interested in the di↵erence between a probabilistic
guarantee and a deterministic guarantee.

320
Consider the birthday paradox (see Chapter 1 for details). Suppose there are 50 stu-
dents in a room. What is the probability that at least two students have the same birthday?
A naive thought would suggest that we need 366 students to guarantee a pair of the same
birthday because there are 365 days. So, with only 50 students, it would seem unlikely to
have a pair with the same birthday. However, it turns out that with just 50 students, the
probability of having at least one pair with the same birthday is more than 97%. Figure 6.2
below shows a calculation by a computer, where we plot the estimated probability as a func-
tion of the number of students. What is more surprising is that with as few as 23 students,
the probability is greater than 50%. There is no need for there to be 365 students in order
to o↵er a guarantee.

1
0.9
0.8
Probability

0.7
0.6
0.5
0.4
0.3
0.2
0.1
0
0 10 20 30 40 50 60 70 80 90 100
Number of people

Figure 6.2: The birthday paradox asks the question of how many people we need to ask in order to have
at least two of them having the same birthday. While we tend to think that the answer is 366 (because
there are 365 days), the actual probability, as we have calculated (see Chapter 1), is more than 97%,
even if we have only asked 50 people. The curve above shows the probability of having at least one pair
of people having the same birthday as a function of the number of people. The plot highlights the gap
between the worst-case performance and an average-case performance.

Why does this happen? Certainly, we can trace back to the formulae in Chapter 1 and
argue through the lens of combinations and permutations. However, the more important
message is about the di↵erence between the worst-case guarantee and the average-case
guarantee.

Worst case versus average case

Worst-case guarantee: You need to ensure that the worst one is protected. This
requires an exhaustive search until hitting 100%. It is a deterministic guarantee.
Average-case guarantee: You guarantee that with a high probability (e.g., 99.99%),
the undesirable event does not happen. This is a probabilistic guarantee.

Is there a di↵erence between 99.99% and 100%? If the probability is 99.99%, there is
one failure every 10,000 trials on average. You are unlikely to fail, but it is still possible.
A 100% guarantee says that no matter how many trials you make you will not fail. The
99.99% guarantee is much weaker (yes, much weaker, not just a little bit weaker) than the
deterministic guarantee. However, in practice, people might be willing to pay for the risk in
exchange for efficiency. This is the principle behind insurance. Automobile manufacturing

321
CHAPTER 6. SAMPLE STATISTICS

also uses this principle — your chance of purchasing a defective car is non-zero, but if the
manufacturer can sell enough cars to compensate for the maintenance cost of fixing your
car, they might be willing to o↵er a limited warranty in exchange for a lower selling price.
How do we analyze the probabilistic guarantee, e.g., for the sample average? Remember
that the sample average X N is a random variable. Since it is a random variable, it has a
mean, variance, and PDF.1 To measure the probabilistic guarantee, we consider the event
def
B = {|X N µ| ✏},

where µ = E[X N ] is the true population mean, and ✏ > 0 is a very small number. This
probability is illustrated in Figure 6.3, assuming that X N has the PDF of a Gaussian. The
probability of B is the two tails under the PDF. Therefore, B is a bad event because in
principle X N should be close to µ. The probability P[B] measures situations where X N
stays very far from µ. If we can show that P[B] is small (e.g., < 0.01%), then we can say
that we have obtained a probabilistic guarantee at 99.99%.

Figure 6.3: The probabilistic guarantee of a sample average X N is established by computing the
probability of the tails. In this example, we assume that fX N (x) take a Gaussian shape, and we define
✏ = 1. Anything belonging to |X N µ| ✏ is called a undesired event B. If the probability of a
undesired event is small, we say that we can o↵er a probabilistic guarantee.

The moment we compute P[|X N µ| ✏], we enter the race of probabilistic guarantee
(e.g., 99.99%). Why? If the probability P[|X N µ| ✏] is less than 0.01%, it still does not
exclude the possibility that something bad will happen once every 10,000 trials on average.
The chance is low, but it is still possible. We will learn some mathematical tools for analyzing
this type of probabilistic guarantee.

Plan for this chapter


With these two main themes in mind, we now discuss the organization of this chapter. There
are four sections: two for mathematical tools and two for main results.
Moment-generating functions: We have seen in Chapter 5 that the PDF of a sum of
two random variables X +Y is the convolution of the two PDFs fX ⇤fY . Convolutions
are non-trivial, especially when we have more random variables to sum. The moment-
generating functions provide a convenient way of summing N random variables. They
are the transform domain techniques (e.g., Fourier transforms). Since convolutions in
1 Not all random variables have mean and variance, e.g., a Cauchy random variable, but most of them
do.

322
time are multiplications in frequency, the moment-generating functions allow us to
multiply PDFs in the transformed space. In this way, we can sum as many random
variables as we want. We will discuss this idea in Section 6.1.

Key Concept 1: Why study moment-generating functions?


Moment-generating functions help us determine the PDF of X1 +X2 +· · ·+XN .

Probability inequalities: When analyzing sample statistics such as X N , evaluating the


exact probability could be difficult because it requires integrating the PDFs. However,
if our ultimate goal is to estimate the probability, deriving an upper bound might be
sufficient to achieve the goal. The probability inequalities are designed for this purpose.
In Section 6.2, we discuss several of the most basic probability inequalities. We will
use some of them to prove the law of large numbers.

Key Concept 2: How can probability inequalities be useful?


Probability inequalities help us upper-bound the bad event P[|X N µ| ✏].

Law of large numbers: This is the first main result of the chapter. The law of large
numbers says that the sample average X N converges to the population mean µ when
the number of samples grows to infinity. The law of large numbers comes in two
versions: the weak law of large numbers and the strong law of large numbers. The
di↵erence is the type of convergence they guarantee. The weak law is based on con-
vergence in probability, whereas the strong law is based on almost sure convergence.
We will discuss these types of convergence in Section 6.3.

Key Concept 3: What is the law of large numbers?


There is a weak law and a strong law of large numbers. The weak law of large
numbers says that X N converges to the true mean µ, as N grows:

lim P[|X N µ| > ✏] = 0.


N !1

Central Limit Theorem: The Central Limit Theorem says that the probability of
X N can be approximated by the probability of a Gaussian. You can also think of
this as saying that the PDF of X N is converging to a distribution that can be well
approximated by a bell-shaped Gaussian. If we have many random variables and their
sum is becoming a Gaussian, we can ignore the individual PDFs and focus on the
Gaussian. Thus it explains why Gaussian is so popular. We will discuss this theorem
in detail in Section 6.4.

Key Concept 4: What is the Central Limit Theorem?


The CDF of X N can be approximated by the CDF of a Gaussian, as N grows.

323
CHAPTER 6. SAMPLE STATISTICS

6.1 Moment-Generating and Characteristic Functions

Consider two independent random variables X and Y with PDFs fX (x) and fY (y), respec-
tively. Let Z = X + Y be the sum of the two random variables. We know from Chapter 5
that the PDF of Z, fZ , is the convolution of fX and fY . However, we think you will agree
that convolutions are not easy to compute. Especially when the sum involves more random
variables, computing the convolution would be tedious. So how should we proceed in this
case? One approach is to use some kind of “frequency domain” method that transforms
the PDFs to another domain and then perform multiplication instead of the convolution
to make the calculations easy or at least easier. The moment-generating functions and the
characteristic functions are designed for this purpose.

6.1.1 Moment-generating function

Definition 6.1. For any random variable X, the moment-generating function (MGF)
MX (s) is ⇥ ⇤
MX (s) = E esX . (6.1)

The definition says that the moment-generating function (MGF) is the expectation of the
random variable taken to the power esX for some s. E↵ectively, it is the expectation of a
function of random variables. The meaning of the expectation can be seen by writing out
the definition. For the discrete case, the MGF is
X
MX (s) = esx pX (x), (6.2)
x2⌦

whereas in the continuous case, the MGF is


Z 1
MX (s) = esx fX (x) dx. (6.3)
1

The continuous case should remind us of the definition of a Laplace transform. For any
function f (t), the Laplace transform is
Z 1
L[f ](s) = f (t)est dt.
1

From this perspective, we can interpret the MGF as the Laplace transform of the PDF.
The argument s of the output can be regarded as the coordinate in the Laplace space. If
s = j!, then MX (j!) becomes the Fourier transform of the PDF.

Example 6.1. Consider a random variable X with three states 0, 1, 2 and with prob-
ability masses 26 , 36 , 16 respectively. Find the MGF.

324
6.1. MOMENT-GENERATING AND CHARACTERISTIC FUNCTIONS

Solution. The moment-generating function is


2 3 1
MX (s) = E[esX ] = es0 · + es1 · + es2 ·
6 6 6
1 es e2s
= + + .
3 2 6

Practice Exercise 6.1. Find the MGF for a Poisson random variable.

Solution. The MGF of Poisson random variable can be found as


1
X x X1 x
e ( es ) es
MX (s) = E[esX ] = esx = e =e e .
x=0
x! x=0
x!

Practice Exercise 6.2. Find the MGF for an exponential random variable.

Solution. The MGF of an exponential random variable can be found as


Z 1 Z 1
sX sx x
MX (s) = E[e ] = e e dx = e(s )x dx = , if > s.
0 0 s

Why are moment-generating functions so called? The following theorem reveals the
reason.

Theorem 6.1. The MGF has the properties that

MX (0) = 1,
d2
d
ds MX (s)|s=0 = E[X], ds2 MX (s)|s=0 = E[X 2 ],
dk
dsk
MX (s)|s=0 = E[X k ], for any positive integer k.

Proof. The first property can be proved by noting that

MX (0) = E[e0X ] = E[1] = 1.

The third property holds because


Z 1 k Z 1
dk d sx
M X (s) = e f X (x) dx = xk esx fX (x) dx.
dsk 1 ds
k
1

Setting s = 0 yields
Z 1
dk
MX (s)|s=0 = xk fX (x) dx = E[X k ].
dsk 1

The second property is a special case of the third property.


325
CHAPTER 6. SAMPLE STATISTICS

The theorem tells us that if we take the derivative of the MGF and set s = 0, we will
obtain the moment. The order of the moment depends on the order of the derivative. As a
result, the MGF can “generate moments” by taking derivatives. This happens because of
d sx
the exponential function esx . Since ds e = xesx , the variable x appears whenever we take
the derivative.

Practice Exercise 6.3. Let X be a Bernoulli random variable with parameter p.


Find the first two moments using MGF.

Solution. The MGF of a Bernoulli random variable is

MX (s) = E[esX ]
= es0 pX (0) + es1 pX (1)
= (1)(1 p) + (es )(p)
=1 p + pes .

The first and the second moment, using the derivative approach, are
✓ ◆
d d
E[X] = MX (s) = 1 p + pes = pes = p,
ds s=0 ds s=0 s=0
✓ ◆
d2 d2
E[X 2 ] = 2 MX (s) = 2 1 p + pes = pes = p.
ds s=0 ds s=0 s=0

To facilitate our discussions of MGF, we summarize a few MGFs in the table below.

Distribution PMF / PDF E[X] Var[X] MX (s)

Bernoulli pX (1) = p and pX (0) = 1 p p p(1 p) 1 p + pes


n
Binomial pX (k) = k pk (1 p)n k
np np(1 p) (1 p + pes )n
1 1 p pes
Geometric pX (k) = p(1 p)k 1
p p2 1 (1 p)es
k
e (es 1)
Poisson pX (k) = e
k! ⇢ ⇢
1 (x µ)2 2
2 2
s
Gaussian fX (x) = p exp 2
µ exp µs +
2⇡ 2 2 2
1 1
Exponential fX (x) = exp { x} 2 s
1 a+b (b a)2 esb esa
Uniform fX (x) =
b a 2 12 s(b a)

Table 6.1: Moment-generating functions of common random variables.

326
6.1. MOMENT-GENERATING AND CHARACTERISTIC FUNCTIONS

6.1.2 Sum of independent variables via MGF


MGFs are most useful when analyzing the PDF of a sum of two random variables. The
following theorem highlights the result.

Theorem 6.2. Let X and Y be independent random variables. Let Z = X + Y . Then

MZ (s) = MX (s)MY (s). (6.4)

Proof. By the definition of MGF, we have that


h i (a) ⇥ ⇤ ⇥ ⇤
MZ (s) = E es(X+Y ) = E esX E esY = MX (s)MY (s),

where (a) is valid because X and Y are independent.



PN
Corollary 6.1. Consider independent random variables X1 , . . . , XN . Let Z = n=1 Xn
be the sum of random variables. Then the MGF of Z is
N
Y
MZ (s) = MXn (s). (6.5)
n=1

If these random variables are further assumed to be identically distributed, the MGF is
N
MZ (s) = (MX1 (s)) . (6.6)

Proof. This follows immediately from the previous theorem:


N
Y
s(X1 +···+XN ) sX1 sX2 sXN
MZ (s) = E[e ] = E[e ]E[e ] · · · E[e ]= MXn (s).
n=1

If the random variables X1 , . . . , XN are i.i.d., then the product simplifies to


N
Y N
Y N
MXn (s) = MX1 (s) = (MX1 (s)) .
n=1 n=1

Theorem 6.3 (Sum of Bernoulli = binomial). Let X1 , . . . , XN be a sequence of


i.i.d. Bernoulli random variables with parameter p. Let Z = X1 + · · · + XN be the sum.
Then Z is a binomial random variable with parameters (N, p).

Proof. Let us consider a sequence of i.i.d. Bernoulli random variables Xn ⇠ Bernoulli(p)


for n = 1, . . . , N . Let Z = X1 + · · · + XN . The moment-generating function of Z is
N
Y
MZ (s) = E[es(X1 +···+XN ) ] = E[esXn ]
n=1
N
Y N
= pes1 + (1 p)es0 = (pes + (1 p)) .
n=1

327
CHAPTER 6. SAMPLE STATISTICS

Now, let us check the moment-generating function of a binomial random variable: If Z ⇠


Binomial(N, p), then
N
X ✓ ◆
sZ sk N k
MZ (s) = E[e ]= e p (1 p)N k

n=0
k
XN ✓ ◆
N N
= (pes )k (1 p)N k
= (pes + (1 p)) ,
n=0
k
PN N
where the last equality holds because n=0 k a k bN k
= (a + b)N . Therefore, the two
moment-generating functions are identical. ⇤

Theorem 6.4 (Sum of binomial = binomial). Let X1 , . . . , XN be a sequence of


i.i.d. binomial random variables with parameters (n, p). Let Z = X1 + · · · + XN be the
sum. Then Z is a binomial random variable with parameters (N n, p).

Proof. The MGF of a binomial random variable is


n
MXi (s) = (pes + (1 p)) .

If we have N of these random variables, then Z = X1 + · · · + XN will have the MGF


N
Y Nn
MZ (s) = MXi (s) = (pes + (1 p)) .
i=1

Note that this is just the MGF of another binomial random variable with parameter (N n, p).

Theorem 6.5 (Sum of Poisson = Poisson). Let X1 , . . . , XN be a sequence of


i.i.d. Poisson random variables with parameter . Let Z = X1 + · · · + XN be the sum.
Then Z is a Poisson random variable with parameters N .

Proof. The MGF of a Poisson random variable is


1
X k
sX
MX (s) = E[e ]= esk e
k!
k=0
1
X ( es ) k
=e
k!
k=0
es (es 1)
=e e =e .

Assume that we have a sum of N i.i.d. Poisson random variables. Then, by the main theorem,
we have that
(es 1)
MZ (s) = [MX (s)]N = eN .

Therefore, the resulting random variable Z is a Poisson with parameter N . ⇤

328
6.1. MOMENT-GENERATING AND CHARACTERISTIC FUNCTIONS

Theorem 6.6 (Sum of Gaussian = Gaussian). Let X1 , . . . , XN be a sequence of


independent Gaussian random variables with parameters (µ1 , 12 ), . . . , (µN , N
2
). Let
Z = X1 + · · · + XN be the sum. Then Z is a Gaussian random variable:
✓X
N N
X ◆
2
Z = Gaussian µn , n . (6.7)
n=1 n=1

Proof. We skip the proof of the MGF of a Gaussian. It can be shown that
⇢ 2 2
s
MX (s) = exp µs + .
2

When we have a sequence of Gaussian random variables, then

MZ (s) = E[es(X1 +···+XN ) ]


= MX1 (s) · · · MXN (s)
✓ ⇢ 2 2
◆ ✓ ⇢ 2 2

s Ns
= exp µ1 s + 1 · · · exp µN s +
2 2
( N ! N
! )
X X s2
2
= exp µn s + n .
n=1 n=1
2

Therefore,
PN the resulting
PN random variable Z is also a Gaussian. The mean and variance of Z
are n=1 µn and n=1 n2 , respectively.

6.1.3 Characteristic functions


Moment-generating functions are the Laplace transforms of the PDFs. However, since the
Laplace transform is defined on the entire right half-plane, not all PDFs can be transformed.
One way to mitigate this problem is to restrict s to the imaginary axis, s = j!. This will
give us the characteristic function.

Definition 6.2 (Usual definition). The characteristic function of a random variable


X is
j!X
X (j!) = E[e ]. (6.8)

However, we note that since ! can take any value in ( 1, 1), it does not matter if we
consider E[e j!X ] or E[ej!X ]. This leads to the following equivalent definition of the char-
acteristic function:

Definition 6.3 (Alternative definition (for this book)). The characteristic function
of a random variable X is
j!X
X (j!) = E[e ]. (6.9)

329
CHAPTER 6. SAMPLE STATISTICS

If we follow this definition, we see that the characteristic function can be written as
Z 1
j!X
X (j!) = E[e ]= e j!x fX (x) dx. (6.10)
1

This is exactly the Fourier transform of the PDF. The reason for introducing this alternative
characteristic function is that E[e j!X ] is the Fourier transform of fX (x) but E[ej!X ] is the
inverse Fourier transform of fX (x). The former is more convenient (in terms of notation)
for students who have taken a course in signals and systems. However, we should stress that
the usual way of defining the characteristic function is E[ej!X ].
A list of common Fourier transforms is shown in the table below. Additional identities
can be found in standard signals and systems textbooks.

Fourier Transforms
f (t) ! F (!) f (t) ! F (!)

1. e at
u(t) ! 1
a+j! , a>0 10. sinc2 ( W2 t ) ! 2⇡
W
!
( 2W )
1 !0
2. eat u( t) ! a j! , a>0 11. e at
sin(!0 t)u(t) ! (a+j!)2 +!02
a|t| 2a at a+j!
3. e ! a2 +! 2 , a>0 12. e cos(!0 t)u(t) ! (a+j!) 2 +! 2
0

a2 a|!|
t2 p 2 !2
4. a2 +t2 ! ⇡ae ,a>0 13. e 2 2
! 2⇡ e 2
at 1
5. te u(t) ! (a+j!)2 , a>0 14. (t) !1
n!
6. tn e at
u(t) ! (a+j!)n+1 , a>0 15. 1 ! 2⇡ (!)

7. rect( ⌧t ) ! ⌧ sinc( !⌧
2 ) 16. (t t0 ) !e j!t0

⇡ w
8. sinc(W t) ! W rect( 2W ) 17. ej!0 t ! 2⇡ (! !0 )
9. ( ⌧t ) ! ⌧2 sinc2 ( !⌧
4 ) 18. f (t)ej!0 t ! F (! !0 )

Table 6.2: Fourier transform pairs of commonly used functions.

x
Example 6.2. Let X be a random variable with PDF fX (x) = e for x 0. Find
the characteristic function.

Solution. The Fourier transform pair is



1
e x ! ·F e x
= · .
+ j!

Therefore, the characteristic function is X (j!) = +j! .

330
6.1. MOMENT-GENERATING AND CHARACTERISTIC FUNCTIONS

Example 6.3. Let X and Y be independent, and let


( (
e x, x 0, e y
, y 0,
fX (x) = fY (y) =
0, x < 0, 0, y < 0.

Find the PDF of Z = X + Y .

Solution. The characteristic function of X and Y can be found from the Fourier table:

X (j!) = and Y (j!) = .


+ j! + j!
Therefore, the characteristic function of Z is
2
Z (j!) = X (j!) Y (j!) = .
( + j!)2

By inverse Fourier transform, we have that


⇢ 2
fZ (z) = F 1 = 2
ze z
, z 0.
( + j!)2

Why X (j!) but not MX (s)? As we said, the function is not always defined. Recall
that the expectation E[X] exists only when fX (x) is absolutely integrable, or E[|X|] < 1.
For a characteristic function, the expectation is valid because E[|ej!X |] = E[1] = 1. However,
for a function, E[|esX |] could be unbounded. To see a counterexample, we consider the
Cauchy distribution.

Theorem 6.7. Consider the Cauchy distribution with PDF


1
fX (x) = . (6.11)
⇡(x2 + 1)

The MGF of X is undefined but the characteristic function is well defined.

Proof. The MGF is


Z 1 Z 1
sx 1 1
MX (s) = e dx esx dx
1 ⇡(x2 + 1) 1 ⇡(x2 + 1)
Z 1
(sx)3 sx (sx)3
dx, because e
1 6⇡(x2 + 1) 6
Z 1 Z 1
(sx)3 s3
dx = x dx = 1.
1 6⇡(2x2 ) 12⇡ 1
Therefore, the MGF is undefined. On the other hand, by the Fourier table we know that

1
X (j!) = F 2
= e |!| .
⇡(x + 1)

331
CHAPTER 6. SAMPLE STATISTICS

Example 6.4. Let X0 , X1 , . . . be a sequence of independent random variables with


PDF
ak 1
fXk (x) = , ak = k+1 for k = 0, 1, . . . .
⇡(a2k + x2 ) 2
P1
Find the PDF of Y , where Y = k=0 Xk .

Solution. From the Fourier transform table, we know that

ak 1 a2k F 1 ak |!| ak |!|


= · ! · ⇡ak e =e .
⇡(a2k + x2 ) ak ⇡ (a2k + x2 ) ak ⇡

The characteristic function of Y is


1
( 1
)
Y X
Y (j!) = Xk (j!) = exp |!| ak .
k=0 k=0
P1 P1 1
Since k=0 ak = k=0 2k+1 = 12 + 14 + · · · = 1, the characteristic function becomes
|!|
Y (j!) = e . The inverse Fourier transform gives us

|!| 1 |!| F 1 1
e = · ⇡e ! · .
⇡ ⇡ 1 + x2
Therefore the PDF of Y is
1
fY (y) = .
⇡(1 + y 2 )

Example 6.5. Two random variables X and Y have the PDFs


( (
e x, x 0, e y, y 0,
fX (x) = and fY (y) =
0, x < 0, 0, y < 0.

Find the PDF of Z = max(X, Y ) min(X, Y ).

Solution. We first show that

Z = max(X, Y ) min(X, Y ) = |X Y |.

Suppose X > Y , then max(X, Y ) = X and min(X, Y ) = Y . So Z = X Y . If X < Y ,


then max(X, Y ) = Y and min(X, Y ) = X. So Z = Y X. Combining the two cases
gives us Z = |X Y |. Now, consider the Fourier transform of the PDFs:

x F 1
e ! .
1 + j!

332
6.2. PROBABILITY INEQUALITIES

Let U = X Y , and let Z = |U |. The characteristic function is

U (j!) = E[e j!(X Y ) ] = E[e j!X ]E[ej!Y ]


1 1 1 F 1 |u|
= · = 2
! fU (u) = e .
1 + j! 1 j! 1+! 2
With the PDF of U , we can find the CDF of Z:

FZ (z) = P[Z  z] = P[|U |  z]


Z z
= fU (u) du
z
Z z
1 |u|
= e du
z 2
Z z
1 u z
=2 e du = 1 e .
0 2

Hence, the PDF is


d z
fZ (z) = FZ (z) = e .
dz

Closing remark. Moment-generating functions and characteristic functions are useful


mathematical tools. In this section, we have confined our discussion to using them to com-
pute the sum of two random variables. Later sections and chapters will explain further uses
for these functions. For example, we use the MGFs when proving Cherno↵’s bound and
proving the Central Limit Theorem.

6.2 Probability Inequalities

Moment-generating functions and characteristic functions are powerful tools for handling the
sum of random variables. We now introduce another set of tools, known as the probability
inequalities, that allow us to do approximations. We will highlight a few basic probability
inequalities in this section.

6.2.1 Union bound


The first inequality is the union bound we had introduced when we discussed the axioms of
probabilities. The union bound states the following:

Theorem 6.8 (Union Bound). Let A1 , . . . , AN be a collection of sets. Then


"N # N
[ X
P An  P[An ]. (6.12)
n=1 n=1

333
CHAPTER 6. SAMPLE STATISTICS

Proof. We can prove this by induction. First, if N = 2,

P[A1 [ A2 ] = P[A1 ] + P[A2 ] P[A1 \ A2 ]  P[A1 ] + P[A2 ],

because P[A1 \ A2 ] is a probability and so it must be non-negative. Thus we have proved


the base case. Assume that the statement is true for N = K. We need to prove that the
statement is also true for N = K + 1. To this end, we note that
"K+1 # " K ! #
[ [
P An = P An [ AK+1
n=1 n=1
" K
# " K
! #
[ [
=P An + P[AK+1 ] P An \ AK+1
n=1 n=1
" K
#
[
P An + P[AK+1 ].
n=1

Then, according to our hypothesis for N = K, it follows that


"K # K
[ X
P An  P[An ].
n=1 n=1

Putting these together,


"K+1 # K K+1
[ X X
P An  P[An ] + P[AK+1 ] = P[An ].
n=1 n=1 n=1

Therefore, by the principle of induction, we have proved the statement.



Remark. The tightness of the union bound depends on the amount of overlapping between
the events A1 , . . . , An , as illustrated in Figure 6.4. If the events are disjoint, the union bound
is tight. If the events are overlapping significantly, the union is loose. The idea of the union
bound is the principle of divide and conquer. We decompose the system into smaller events
for a system of n variables and use the union bound to upper-limit the overall probability. If
the probability of each event is small, the union bound tells us that the overall probability
of the system will also be small.

Figure 6.4: Conditions under which the union bound is loose or tight. [Left] The union bound is loose
when the sets are overlapping. [Right] The union bound is tight when the sets are (nearly) disjoint.

334
6.2. PROBABILITY INEQUALITIES

Example 6.6. Let X1 , . . . , XN be a sequence of i.i.d. random variables with CDF


FXn (x) and let Z = min(X1 , . . . , XN ). Find an upper bound on the CDF.

Solution. Note that Z = min(X1 , . . . , XN )  z is equivalent to at least one of the


Xn ’s being less than z. Thus, we have that

Z = min(X1 , . . . , XN )  z , X1  z [ · · · [ XN  z.

Substituting this result into the CDF,

FZ (z) = P[Z  z]
= P[min(X1 , . . . , XN )  z]
= P[X1  z [ · · · [ XN  z]
 P[X1  z] + · · · + P[XN  z]
= N · FX (z).

6.2.2 The Cauchy-Schwarz inequality


The second inequality we study here is the Cauchy-Schwarz inequality, which we previously
mentioned in Chapter 5. We review it for the sake of completeness.

Theorem 6.9 (Cauchy-Schwarz inequality). Let X and Y be two random variables.


Then
E[XY ]2  E[X 2 ]E[Y 2 ]. (6.13)

Proof. Let f (s) = E[(sX + Y )2 ] for any real s. Then

f (s) = E[(sX + Y )2 ]
= E[s2 X 2 + 2sXY + Y 2 ]
= E[X 2 ]s2 + 2E[XY ]s + E[Y 2 ].

This is a quadratic equation, and f (s) 0 for all s because E[(sX + Y )2 ] 0.


Recall that for a quadratic equation (x) = ax2 + bx + c, the function (x) 0 if and
only if b2 4ac  0. Substituting this result into our problem, we show that

(2E[XY ])2 4E[X 2 ]E[Y 2 ]  0.

This implies that


E[XY ]2  E[X 2 ]E[Y 2 ],
which completes the proof.

Remark. As shown in Chapter 5, the Cauchy-Schwarz inequality is useful in analyzing
E[XY ]. For example, we can use the Cauchy-Schwarz inequality to prove that the correlation
coefficient ⇢ is bounded between 1 and 1.

335
CHAPTER 6. SAMPLE STATISTICS

6.2.3 Jensen’s inequality


Our next inequality is Jensen’s inequality. To motivate the inequality, we recall that

Var[X] = E[X 2 ] E[X]2 .

Since Var[X] 0 for any X, it follows that

E[X 2 ] E[X]2 . (6.14)


| {z } | {z }
=E[g(X)] =g(E[X])

Jensen’s inequality is a generalization of the above result by recognizing that the inequality
does not only hold for the function g(X) = X 2 but also for any convex function g. The
theorem is stated as follows:

Theorem 6.10 (Jensen’s inequality). Let X be a random variable, and let g : R ! R


be a convex function. Then
E[g(X)] g(E[X]). (6.15)

If the function g is concave, then the inequality sign is flipped: E[g(X)]  g(E[X]). The
way to remember this result is to remember that E[X 2 ] E[X]2 = Var[X] 0.
Now, what is a convex function? Informally, a function g is convex if, when we pick any
two points on the function and connect them with a straight line, the line will be above the
function for that segment. This definition is illustrated in Figure 6.5. Consider an interval
[x, y], and the line segment connecting g(x) and g(y). If the function g(·) is convex, then
the entire line segment should be above the curve.

Figure 6.5: Illustration of a convex function, a concave function, and a function that is neither convex
nor concave.

The definition of a convex function essentially follows the above picture:

Definition 6.4. A function g is convex if

g( x + (1 )y)  g(x) + (1 )g(y), (6.16)

for any 0   1.

Here represents a “sweeping” constant that goes from x to y. When = 1 then x+(1 )y
simplifies to x, and when = 0 then x + (1 )y simplifies to y.

336
6.2. PROBABILITY INEQUALITIES

The definition is easy to understand. The left-hand side g( x + (1 )y) is the function
evaluated at any points in the interval [x, y]. The right-hand side is the red straight line we
plotted in Figure 6.5. It connects the two points g(x) and g(y). Convexity means that the
red line is entirely above the curve.
For twice-di↵erentiable 1D functions, convexity can be described by the curvature of
the function. A function is convex if

g 00 (x) 0. (6.17)

This is self-explanatory because if the curvature is non-negative for all x, then the slope of
g has to keep increasing.

Example 6.7. The following functions are convex or concave:


1 1
g(x) = log x is concave, because g 0 (x) = x and g 00 (x) = x2  0 for all x.
2 0 00
g(x) = x is convex, because g (x) = 2x and g (x) = 2 is positive.
g(x) = e x
is convex, because g 0 (x) = e x
and g 00 (x) = e x
0.

Why is Jensen inequality valid for a convex function? Consider the illustration in
Figure 6.6. Suppose we have a random variable X taking some PDF fX (x). There is a
convex function g(·) that maps the random variable X to g(X). Since g(·) is convex, a PDF
like the one we see in Figure 6.6 will become skewed. (You can map the left tail to the new
left tail, the peak to the new peak, and the right tail to the new right tail.) As you can see
from the figure, the new random variable g(X) has a mean E[g(X)] that is greater than the
mapped old mean g(E[X]). Jensen’s inequality captures this phenomenon by stating that
E[g(X)] g(E[X]) for any convex function g(·).

Figure 6.6: Jensen’s inequality states that if there is a convex function g(·) that maps a random variable
X to a new random variable g(X), the new mean E[g(X)] will be greater than the mapped old mean
g(E[X]).

Proving Jensen’s inequality is straightforward for a two-state discrete random variable.


Define a random variable X with states x and y. The probabilities for these two states are
P[X = x] = and P[X = y] = 1 . Then
X
E[X] = x0 pX (x0 ) = x + (1 )y.
x0 2{x,y}

337
CHAPTER 6. SAMPLE STATISTICS

Now, let g(·) be a convex function. We know from the expectation that
X
E[g(X)] = g(x0 )pX (x0 ) = g(x) + (1 )g(y).
x0 2{x,y}

By convexity of the function g(·), it follows that

g( x + (1 )y)  f (x) + (1 )g(y),


| {z } | {z }
=g(E[X]) =E[g(X)]

where in the underbrace we substitute the definitions using the expectation. Therefore,
for any two-state discrete random variables, the proof of Jensen’s inequality follows directly
from the convexity. If the discrete random variable takes more than two states, we can prove
the theorem by induction. For continuous random variables, we can prove the theorem using
the following approach.

You may skip the proof of Jensen’s inequality if this is your first time reading the book.

Here we present an alternative proof of Jensen’s inequality that does not require proof
by induction. The idea is to recognize that if the function g is convex we can find a tangent
line L(X) = aX + b at the point E[X] that is uniformly lower than g(X), i.e., g(X) L(X)
for all X. Then we can prove the result with a simple geometric argument. Figure 6.7
illustrates this idea.

Figure 6.7: Geometric illustration of the proof of Jensen’s inequality. Suppose g(·) is a convex function.
For any point X on g(·), we can find a tangent line L(X) = aX + b. Since the black curve is always
above the tangent, it follows that E[g(X)] E[L(X)] for any X. Also, note that at a particular point
E[X], the black curve and the red line touch, and so we have L(E[X]) = g(E[X]).

Proof of Jensen’s inequality. Consider L(X) as defined above. Since g is convex, g(X)
L(X) for all X. Therefore,

E[g(X)] E[L(X)]
= E[aX + b]
= aE[X] + b
= L(E[X]) = g(E[X]),

where the last equality holds because L is a tangent line to g where they meet at E[X].

338
6.2. PROBABILITY INEQUALITIES

What are (a, b) in the proof? By Taylor expansion,


g(X) ⇡ g(E[X]) + g 0 (E[X])(X E[X])
def
= L(X).
Therefore, if we want to be precise, then a = g 0 (E[X]) and b = g(E[X]) g 0 (E[X])E[X].

The end of the proof.

Example 6.8. By Jensen’s inequality, we have that

(a) E[X 2 ] E[X]2 , because g(x) = x2 is convex.


⇥ ⇤
(b) E X1 1
E[X] , because g(x) = 1
x is convex.
(c) E[log X]  log E[X], because g(x) = log x is concave.

6.2.4 Markov’s inequality


Our next inequality, Markov’s inequality, is an elementary inequality that links probability
and expectation.

Theorem 6.11 (Markov’s inequality). Let X 0 be a non-negative random variable.


Then, for any " > 0, we have

E[X]
P[X "]  . (6.18)
"

Markov’s inequality concerns the tail of the random variable. As illustrated in Figure 6.8,
P[X "] measures the probability that the random variable takes a value greater than ".
Markov’s inequality asserts that this probability P[X "] is upper-bounded by the ratio
E[X]/". This result is useful because it relates the probability and the expectation. In many
problems the probability P[X "] could be difficult to evaluate if the PDF is complicated.
The expectation, on the other hand, is usually easier to evaluate.
Proof. Consider "P[X "]. It follows that
Z 1 Z 1
"P[X "] = " fX (x) dx  xfX (x) dx,
" "

where the inequality is valid because for any x " the integrand (which is non-negative)
will always increase (or at least not decrease). It then follows that
Z 1 Z 1
xfX (x) dx  xfX (x) dx = E[X]. ⇤
" 0

A pictorial interpretation of Markov’s


R1 inequality is shown in Figure 6.9. For X > 0, it
is not difficult to show that E[X] = 0 1 FX (x) dx. Then, in the CDF plot, we see that
" · P[X "] is a rectangle covering the top left corner. This area is clearly smaller than the
area covered by the function 1 FX (x).

339
CHAPTER 6. SAMPLE STATISTICS

Figure 6.8: Markov’s inequality provides an upper bound to the tail of a random variable. The inequality
states that the probability P[X "] is upper bounded by the ratio E[X]/".

Figure 6.9: The proof of Markov’s inequality follows from the fact that " · P[X "] occupies the
top left Rcorner marked by the yellow rectangle. The expectation is the area above the CDF so that
1
E[X] = 0 1 FX (x) dx. Since the yellow rectangle is smaller than the orange shaded area, it follows
that " · P[X "]  E[X], which is Markov’s inequality.

R1
Practice Exercise 6.4. Prove that if X > 0, then E[X] = 0
1 FX (x) dx.

Solution. We start from the right-hand side:


Z 1 Z 1
1 FX (x) dx = 1 P[X  x] dx
0 0
Z 1
= P[X x] dx
Z0 1 Z 1
= fX (t) dt dx
0 x
Z 1Z t
= fX (t) dx dt
Z0 1 0
= tfX (t) dt = E[X].
0

The change in the integration order is illustrated below.

340
6.2. PROBABILITY INEQUALITIES

How tight is Markov’s inequality? It is possible to create a random variable such that
the equality is met (see Exercise 6.14). However, in general, the estimate provided by the
upper bound is not tight. Here is an example.

Practice Exercise 6.5. Let X ⇠ Uniform(0, 4). Verify Markov’s inequality for P[X
2], P[X 3] and P[X 4].

Solution. First, we observe that E[X] = 2. Then

E[X]
P[X 2] = 0.5, = 1,
2
E[X]
P[X 3] = 0.25, = 0.67,
3
E[X]
P[X 4] = 0, = 0.5.
4
Therefore, although the upper bounds are all valid, they are very loose.

If Markov’s inequality is not tight, why is it useful? It turns out that while Markov’s
inequality is not tight, its variations can be powerful. We will come back to this point when
we discuss Cherno↵’s bound.

6.2.5 Chebyshev’s inequality


The next inequality is a simple extension of Markov’s inequality. The result is known as
Chebyshev’s inequality.

Theorem 6.12 (Chebyshev’s inequality). Let X be a random variable with mean µ.


Then for any " > 0 we have

Var[X]
P[|X µ| "]  . (6.19)
"2

The tail measured by Chebyshev’s inequality is illustrated in Figure 6.10. Since the
event |X µ| " involves an absolute value, the probability measures the two-sided tail.
Chebyshev’s inequality states that this tail probability is upper-bounded by Var[X]/"2 .

341
CHAPTER 6. SAMPLE STATISTICS

Figure 6.10: Chebyshev’s inequality states that the two-sided tail probability P[|X µ| "] is upper-
bounded by Var[X]/"2

Proof. We apply Markov’s inequality to show that

P[|X µ| "] = P[(X µ)2 "2 ]


E[(X µ)2 ] Var[X]
 = .
"2 "2

An alternative form of Chebyshev’s inequality is obtained by letting " = k . In this
case, we have
2
1
P[|X µ| k ]  2 2 = 2 .
k k
Therefore, if a random variable is k times the standard deviation away from the mean, then
the probability bound drops to 1/k 2 .

Practice Exercise 6.6. Let X ⇠ Uniform(0, 4). Find the bound of Chebyshev’s
inequality for the probability P[|X µ| 1].

Solution. Note that E[X] = 2 and 2


= 42 /12 = 4/3. Therefore, we have
2
4
P[|X µ| 1]  = ,
"2 3
which is a valid upper bound, but quite conservative.

Practice Exercise 6.7. Let X ⇠ Exponential(1). Find the bound of Chebyshev’s


inequality for the probability P[X "].

Solution. Note that E[X] = 1 and 2


= 1. Thus we have

P[X "] = P[X µ " µ]  P[|X µ| " µ]


2
1
 = .
(" µ)2 (" 1)2

342
6.2. PROBABILITY INEQUALITIES

We can compare this with the exact probability, which is


"
P[X "] = 1 FX (") = e .

Again, the estimate given by Chebyshev’s inequality is acceptable but too conservative.

Corollary 6.2. Let X1 , . . . , XN be i.i.d. random variables with mean E[Xn ] = µ and
PN
variance Var[Xn ] = 2 . Let X N = N1 n=1 Xn be the sample mean. Then
 2
P XN µ >✏  . (6.20)
N ✏2

Proof. We can first show that E[X N ] = µ and Var[X N ] satisfies


N
1 X 2
Var[X N ] = 2
Var[Xn ] = .
N n=1 N

Then by Chebyshev’s inequality,


 2
Var[X N ]
P XN µ >✏  2
= .
✏ N ✏2


The consequence of this corollary is that the upper bound 2 N/✏2 will converge to zero
as N ! 1. Therefore, the probability of getting the event { X N µ > ✏} is vanishing.
It means that the sample average X N is converging to the true population mean µ, in the
sense that the probability of failing is shrinking.

6.2.6 Cherno↵’s bound


We now introduce a powerful inequality or a set of general procedures that gives us some
highly useful inequalities. The idea is named for Herman Cherno↵, although it was actually
due to his colleague Herman Rubin.

Theorem 6.13 (Cherno↵’s bound). Let X be a random variable. Then, for any
" 0, we have that
P[X "]  e '(") , (6.21)
wherea ⇢
'(") = max s" log MX (s) , (6.22)
s>0

and MX (s) is the moment-generating function.


a '(") is called the Fenchel-Legendre dual function of log MX . See references [6-14].

343
CHAPTER 6. SAMPLE STATISTICS

Proof. There are two tricks in the proof of Cherno↵’s bound. The first trick is a nonlinear
transformation. Since esx is an increasing function for any s > 0 and x, we have that

P[X "] = P[esX es" ]


(a) E[esX ]

es"
(b) s"
=e MX (s)
s"+log MX (s)
=e ,

where the inequality (a) is due to Markov’s inequality. Step (b) just uses the definition of
MGF that E[esX ] = MX (s).
Now for the second trick. Note that the above result holds for all s. That means it
must also hold for the s that minimizes e s"+log MX (s) . This implies that
n o
P[X "]  min e s"+log MX (s) .
s>0

Again, since ex is increasing, the minimizer of the above probability is also the maximizer
of this function: ⇢
'(") = max s" log MX (s) .
s>0

Thus, we conclude that P[X "]  e '(")


.

6.2.7 Comparing Cherno↵ and Chebyshev


Let’s consider an example of how Cherno↵’s bound can be useful.
Suppose that we have a random variable X ⇠ Gaussian(0, 2 /N ). The number N can
be regarded as the number of samples. For example, if Y1 , . . . , YN P
are N Gaussian random
N
variables with mean 0 and variance 2 , then the average X = N1 n=1 Yn will have mean
2
0 and variance /N . Therefore, as N grows, the variance of X will become smaller and
smaller.
First, since the random variable is Gaussian, we can show the following:

2
Lemma 6.1. Let X ⇠ Gaussian(0, N ) be a Gaussian random variable. Then, for any
" > 0, !
p
N"
P[X "] = 1 , (6.23)

where is the standard Gaussian’s CDF.

Note that this is the exact result: If you tell me ", N , and , then the probability P[X "]
is exactly the one shown on the right-hand side. No approximation, no randomness.

344
6.2. PROBABILITY INEQUALITIES

Proof. Since X is Gaussian, the probability is


Z 1 ⇢
1 x2
P[X "] = p exp dx
" 2⇡( 2 /N ) 2( 2 /N )
Z " ⇢
1 x2
=1 p exp dx
1 2⇡( 2 /N ) 2( 2 /N )
Z p" ⇢ 2
2 /N 1 x
=1 p exp dx
1 2⇡ 2
! p !
" N"
=1 p =1 .
2 /N


Let us compute the bound given by Chebyshev’s inequality.

2
Lemma 6.2. Let X ⇠ Gaussian(0, N ) be a Gaussian random variable. Then, for any
" > 0, Chebyshev’s inequality implies that
2
P[X "]  . (6.24)
N "2

Proof. We apply Chebyshev’s inequality by assuming that µ = 0:


P[X "] = P[X µ " µ]  P[|X µ| " µ]
E[(X µ)2 ] 2
 2
= .
(" µ) N "2

We now compute Cherno↵’s bound.

2
Theorem 6.14. Let X ⇠ Gaussian(0, N ) be a Gaussian random variable. Then, for
any " > 0, Cherno↵ ’s bound implies that
⇢ 2
" N
P [X "]  exp . (6.25)
2 2

2
Proof.
n 2The o MGF of a zero-mean Gaussian random variable with variance /N is MX (s) =
s2
exp 2N . Therefore, the function ' can be written as

'(") = max s" log MX (s)
s>0
⇢ 2 2
s
= max s" .
s>0 2N
To maximize the function we take the derivative and set it to zero. This yields
⇢ 2 2
d s N"
s" = 0 ) s⇤ = 2 .
ds 2N

345
CHAPTER 6. SAMPLE STATISTICS

2 2
s
Note that this s⇤ is a maximizer because s" 2N is a concave function.

Substituting s into '("),
⇢ 2 2
s" s
'(") = max
s>0 2N
2 ⇤ 2
✓ ◆ 2
✓ ◆2
(s ) N" N" "2 N
= s⇤ " = 2
" 2
= ,
2N 2N 2 2
and hence

'(") "2 N
P[X "]  e = exp .
2 2

Figure 6.11 shows the comparison between the exact probability, the bound provided
by Chebyshev’s inequality, and Cherno↵’s bound:
⇣p ⌘
Exact: P[X "] = 1 N"
.
2
Chebyshev: P[X "]  N "2 ,
n o
"2 N
Cherno↵: P [X "]  exp 2 2 .

In this numerical experiment, we set " = 0.1, and = 1. We vary the number N . As we can
see from the figure, the bound provided by Chebyshev is valid but very loose. It does not
even capture the tail as N grows. On the other hand, Cherno↵’s bound is reasonably tight.
However, one should note that the tightness of Cherno↵ is only valid for large N . When N
is small, it is possible to construct random variables such that Chebyshev is tighter.
The MATLAB code used to generate this plot is illustrated below.

% MATLAB code to compare the probability bounds


epsilon = 0.1;
sigma = 1;
N = logspace(1,3.9,50);
p_exact = 1-normcdf(sqrt(N)*epsilon/sigma);
p_cheby = sigma^2./(epsilon^2*N);
p_chern = exp(-epsilon^2*N/(2*sigma^2));

loglog(N, p_exact, ’-o’, ’Color’, [1 0.5 0], ’LineWidth’, 2); hold on;
loglog(N, p_cheby, ’-’, ’Color’, [0.2 0.7 0.1], ’LineWidth’, 2);
loglog(N, p_chern, ’-’, ’Color’, [0.2 0.0 0.8], ’LineWidth’, 2);

What could go wrong if we insist on using Chebyshev’s inequality? Consider the fol-
lowing example.

Example 6.9. Let X ⇠ Gaussian(0, 2 /N ). Suppose that we want the probability to


be no greater than a confidence level of ↵:

P[X "]  ↵.

346
6.2. PROBABILITY INEQUALITIES

Probability 100

10-5

10-10
Exact
Chebyshev
Chernoff
10-15
1 2 3
10 10 10
N
Figure 6.11: Comparison between Cherno↵’s bound and Chebyshev’s bound. The random variable we
use is X ⇠ Gaussian(0, 2 /N ). As N grows, we show the probability bounds predicted by the two
methods.

Let ↵ = 0.05, " = 0.1, and = 1. Find the N using (i) Chebyshev’s inequality and (ii)
Cherno↵’s inequality.

Solution: (i) Chebyshev’s inequality implies that


2
P[X "]   ↵,
N "2
which means that
2
N .
↵"2
If we plug in ↵ = 0.05, " = 0.1, and = 1, then N 2000.

(ii) For Cherno↵’s inequality, it holds that


⇢ 2
" N
P[X "]  exp  ↵,
2 2

which means that


2 2
Nlog ↵
"2
Plugging in ↵ = 0.05, " = 0.1, and = 1, we have that N 600. This is more than 3
times smaller than the one predicted by Chebyshev’s inequality. Which one is correct?
Both are correct but Chebyshev’s inequality is overly conservative. If N 600 can
make P[X "]  ↵, then certainly N 2000 will work too. However, N 2000 is too
loose.

347
CHAPTER 6. SAMPLE STATISTICS

6.2.8 Hoe↵ding’s inequality


Cherno↵’s bound can be used to derive many powerful inequalities. Here we present an
inequality for bounded random variables. This result is known as Hoe↵ding’s inequality.

Theorem 6.15 (Hoe↵ding’s inequality). Let X1 , . . . , XN be i.i.d. random variables


with 0  Xn  1, and E[Xn ] = µ. Then

2
P X N µ > ✏  2e 2✏ N , (6.26)

1
PN
where X N = N n=1 Xn .

You may skip the proof of Hoe↵ding’s inequality if this is your first time reading the book.

Proof. (Hoe↵ding’s inequality) First, we show that


" N
# "N #
⇥ ⇤ 1 X X
P XN µ > ✏ = P Xn µ > ✏ = P (Xn µ) > N ✏
N n=1 n=1
h PN i
= P es n=1 (Xn µ) es✏N
PN ✓ ◆N
E[es n=1 (Xn µ) ] E[es(Xn µ) ]
 = .
es✏N es✏
Let Zn = Xn µ. Then µ  Zn  1 µ. At this point we use Hoe↵ding Lemma (see
s2
below) that E[esZn ]  e 8 because b a = (1 µ) ( µ) = 1. Thus,
✓ ◆N s2
!N
⇥ ⇤ E[esZn ] e8 s2 N
s✏N
P XN µ>✏   =e 8 , 8s.
es✏ es✏
This result holds for all s, and thus it holds for the s that minimizes the right-hand side.
This implies that
⇢ ⇢ 2
⇥ ⇤ s N
P X N µ > ✏  min exp s✏N .
s 8
n 2 o
d s N
Minimizing the exponent gives ds 8 s✏N = sN 4 ✏N = 0. Thus we have s = 4✏.
Hence,

⇥ ⇤ (4✏)2 N 2
P X N µ > ✏  exp (4✏)✏N = e 2✏ N .
8
⇥ ⇤ 2
By symmetry, P X N µ < ✏  e 2✏ N . Then by union bound we show that
⇥ ⇤ ⇥ ⇤ ⇥ ⇤
P |X N µ| > ✏ = P X N µ > ✏ + P X N µ < ✏
2✏2 N 2✏2 N
e +e
2✏2 N
= 2e . ⇤

348
6.2. PROBABILITY INEQUALITIES

Lemma 6.3 (Hoe↵ding’s lemma). Let a  X  b be a random variable with


E[X] = 0. Then ⇢ 2
def ⇥ sX ⇤ s (b a)2
MX (s) = E e  exp . (6.27)
8

Proof. Since a  X  b, we can write X as a linear combination of a and b:

X = b + (1 )a,

where = Xb aa . Since exp(·) is a convex function, it follows that e b+(1 )a  eb +(1 )ea .
(Recall that h is convex if h( x + (1 )y)  h(x) + (1 )h(y).) Therefore, we have

esX  esb + (1 )esa


X a sb b X sa
= e + e .
b a b a
Taking expectations on both sides of the equation,
a sb b sa
E[esX ]  e + e ,
b a b a
because E[X] = 0. Now, if we let ✓ = a
b a, then

a sb b sa
e + e = ✓esb + (1 ✓)esa
b a b a
⇣ ⌘ ⇣ ⌘
= esa 1 ✓ + ✓es(b a)
= 1 ✓ + ✓es(b a)
e s✓(b a)

✓u+log(1 ✓+✓eu )
= (1 ✓ + ✓eu ) e ✓u
=e ,

where we let u = s(b a). This can be simplified as E[esX ]  E[e (u)
] by defining

(u) = ✓u + log(1 ✓ + ✓eu ).

The final step is to approximate (u). To this end, we use Taylor approximation:

u2
(u) = (0) + u 0 (0) + 00
(⇠),
2
0 00 1
for some ⇠ 2 [a, b]. Since (0) = 0, (0) = 0, and (u)  4 for all u, it follows that

u2 u2 s2 (b a)2
(u) = 00
(⇠)  = . ⇤
2 8 8

End of the proof.

349
CHAPTER 6. SAMPLE STATISTICS

What is so special about the Hoe↵ding’s inequality?


Since Hoe↵ding’s inequality is derived from Cherno↵’s bound, it inherits the
tightness. Hoe↵ding’s inequality is much stronger than Chebyshev’s inequality
in bounding the tail distributions.
Hoe↵ding’s inequality is one of the few inequalities that do not require E[X] and
Var[X] on the right-hand side.
A downside of the inequality is that boundedness is not always easy to satisfy.
For example, if Xn is a Gaussian random variable, Hoe↵ding does not apply.
There are more advanced inequalities for situations like these.

Interpreting Hoe↵ding’s inequality. One way to interpret Hoe↵ding’s inequality is to


write the equation as
⇥ ⇤ 2✏2 N
P X N µ > ✏  2e | {z },

which is equivalent to ⇥ ⇤
P XN µ ✏ 1 .
This means that with a probability at least 1 , we have

XN ✏  µ  X N + ✏.
2✏2 N
If we let = 2e , this becomes
r r
1 2 1 2
XN log  µ  X N + log . (6.28)
2N 2N
This inequality is a confidence interval (see Chapter 9). It says that with probability at
least 1 , the interval [X N ✏, X N + ✏] includes the true population mean µ.
There are two questions one can ask about the confidence interval:
Given N and , what is the confidence interval? Equation (6.28) tells us that if we
know N , to achieve a probability of at least 1 the confidence
qinterval will follow
1 2
Equation (6.28). For example, if N = 10,000 and = 0.01, 2N log = 0.016.
Therefore, with a probability at least 99%, the true population mean µ will be included
in the interval
X N 0.16  µ  X N + 0.16.

If we want to achieve a certain confidence interval, what is the N we need? If we are


given ✏ and , the N we need is

2✏2 N log 2
 2e ) N .
2✏2
For example, if = 0.01 and ✏ = 0.01, the N we need is N 26, 500.

When is Hoe↵ding’s inequality used? Hoe↵ding’s inequality is fundamental in modern


machine learning theory. In this field, one often wants to quantify how well a learning

350
6.3. LAW OF LARGE NUMBERS

algorithm performs with respect to the complexity of the model and the number of training
samples. For example, if we choose a complex model, we should expect to use more training
samples or overfit otherwise. Hoe↵ding’s inequality provides an asymptotic description of
the training error, testing error, and the number of training samples. The inequality is
often used to compare the theoretical performance limit of one model versus another model.
Therefore, although we do not need to use Hoe↵ding’s inequality in this book, we hope you
appreciate its tightness.

Closing Remark. We close this section by providing the historic context of Cherno↵’s
inequality. Herman Cherno↵, the discoverer of Cherno↵’s inequality, wrote the following
many years after the publication of the original paper in 1952.
“In working on an artificial example, I discovered that I was using the Central Limit
Theorem for large deviations where it did not apply. This led me to derive the asymptotic
upper and lower bounds that were needed for the tail probabilities. [Herman] Rubin claimed
he could get these bounds with much less work, and I challenged him. He produced a rather
simple argument, using Markov’s inequality, for the upper bound. Since that seemed to be
a minor lemma in the ensuing paper I published (Cherno↵, 1952), I neglected to give him
credit. I now consider it a serious error in judgment, especially because his result is stronger
for the upper bound than the asymptotic result I had derived.” — Herman Cherno↵, “A
career in statistics,” in Lin et al., Past, Present, and Future of Statistical Science (2014),
p. 35.

6.3 Law of Large Numbers

In this section, we present our first main result: the law of large numbers. We will discuss
two versions of the law: the weak law and the strong law. We will also introduce two forms
of convergence: convergence in probability and almost sure convergence.

6.3.1 Sample average


The law of large numbers is a probabilistic statement about the sample average. Suppose
that we have a collection of i.i.d. random variables X1 , . . . , XN . The sample average of these
N random variables is defined as follows:

Definition 6.5. The sample average of a sequence of random variables X1 , . . . , XN


is
N
1 X
XN = Xn . (6.29)
N n=1

If the random variables X1 , . . . , XN are i.i.d. so that they have the same population
mean E[Xn ] = µ (for n = 1, . . . , N ), then by the linearity of the expectation,
N
⇥ ⇤ 1 X
E XN = E[Xn ] = µ.
N n=1

351
CHAPTER 6. SAMPLE STATISTICS

Therefore, the mean of X N is the population mean µ.


The sample average, X N , plays an important role in statistics. For example, by sur-
veying 10,000 Americans, we can find a sample average of their ages. Since we never have
access to the true population mean, the sample average is an estimate, and since X N is only
an estimate, we need to ask how good the estimate is.
One reason we ask this question is that X N is a finite-sample “approximation” of µ.
More importantly, the root of the problem is that X N itself is a random variable because
X1 , . . . , XN are all random variables. Since X N is a random variable, there is a PDF of
X N ; there is a CDF of X N ; there is E[X N ]; and there is Var[X N ]. Since X N is a random
variable, it has uncertainty. To say that we are confident about X N , we need to ensure that
the uncertainty is within some tolerable range.
How do we control the uncertainty? We can compute the variance. If X1 , . . . , XN are
i.i.d. random variables with the same variance Var[Xn ] = 2 (for n = 1, . . . , N ), then
N N
⇥ ⇤ 1 X 1 X 2
2
Var X N = 2 Var[Xn ] = 2 = .
N n=1 N n=1 N

Therefore, the variance will shrink to 0 as N grows. In other words, the more samples we
use to construct the sample average, the less deviation the random variable X N will have.

Visualizing the sample average

To help you visualize the randomness of X N , we consider an experiment of drawing N


Bernoulli random variables X1 , . . . , XN with parameter p = 1/2. Since Xn is Bernoulli, it
follows that
E[Xn ] = p and Var[Xn ] = p(1 p).
1
PN
We construct a sample average X N = N n=1 Xn . Since Xn is a Bernoulli random variable,
we know everything about X N . First, X N is a binomial random variable, since X N is the
sum of Bernoulli random variables. Second, the mean and variance of X N are respectively
N
def 1 X
µX N = E[X N ] = E[Xn ] = p,
N n=1
N
2 def 1 X p(1 p)
XN
= Var[X N ] = 2
Var[Xn ] = .
N n=1 N

In Figure 6.12, we plot the random variables X N (the black crosses) for every N . You
can see that at each N , e.g., N = 100, there are many possible observations for X N because
X N itself is a random variable. As N increases, we see that the deviation of the random
variables becomes smaller. In the same plot, we show the bounds µ ± 3 X N , which are three
standard deviations from the mean. We can see clearly that the bounds provide a very good
envelope covering the random variables. As N goes to infinity, we can see that the standard
deviation goes to zero, and so X N approaches the true mean.
For your reference, the MATLAB code and the Python code we used to generate the
plot are shown below.

% MATLAB code to illustrate the weak law of large numbers


Nset = round(logspace(2,5,100));

352
6.3. LAW OF LARGE NUMBERS

0.7

0.6
sample average

0.5

0.4

0.3
102 103 104 105
N
Figure 6.12: The weak law of large numbers. In this plot, we assume that X1 , . . . , XN are i.i.d. Bernoulli
random variables
PN with a parameter p. The black crosses in the plot are the sample averages
X N = N1 n=1 Xn . The red curves are the ideal bounds µX N ± 3 X N , where µX N = p and
p
XN = p(1 p)/N . As N grows, we observe that the variance shrinks to zero. Therefore, the
sample average is converging to the true population mean.

for i=1:length(Nset)
N = Nset(i);
p = 0.5;
x(:,i) = binornd(N, p, 1000,1)/N;
end
y = x(1:10:end,:)’;
semilogx(Nset, y, ’kx’); hold on;
semilogx(Nset, p+3*sqrt(p*(1-p)./Nset), ’r’, ’LineWidth’, 4);
semilogx(Nset, p-3*sqrt(p*(1-p)./Nset), ’r’, ’LineWidth’, 4);

# Python code to illustrate the weak law of large numbers


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
import numpy.matlib
p = 0.5
Nset = np.round(np.logspace(2,5,100)).astype(int)
x = np.zeros((1000,Nset.size))
for i in range(Nset.size):
N = Nset[i]
x[:,i] = stats.binom.rvs(N, p, size=1000)/N
Nset_grid = np.matlib.repmat(Nset, 1000, 1)

plt.semilogx(Nset_grid, x,’ko’);
plt.semilogx(Nset, p + 3*np.sqrt((p*(1-p))/Nset), ’r’, linewidth=6)
plt.semilogx(Nset, p - 3*np.sqrt((p*(1-p))/Nset), ’r’, linewidth=6)

353
CHAPTER 6. SAMPLE STATISTICS

Note the outliers for each N in Figure 6.12. For example, at N = 102 we see a point
located near 0.7 on the y-axis. This point is outside three standard deviations. Is it normal?
Yes. Being outside three standard deviations only says that the probability of having this
outlier is small. It does not say that the outlier is impossible. Having a small probability does
not exclude the possibility. By contrast, if you say that something will surely not happen you
mean that there is not even a small probability. The former is a weaker statement than the
latter. Therefore, even though we establish a three standard deviation envelope, there are
points falling outside the envelope. As N grows, the chance of having a bad outlier becomes
smaller. Therefore, the greater the N , the smaller the chance we will get an outlier.
If the random variables Xn are i.i.d., the above phenomenon is universal. Below is an
example of the Poisson case.

Practice Exercise 6.8. Let Xn ⇠ Poisson( ). Define the sample average as X N =


1
PN
N n=1 Xn . Find the mean and variance of X N .

Solution. Since Xn is Poisson, we know that E[Xn ] = and Var[Xn ] = . So


N N
1 X 1 X
E[X N ] = E[Xn ] = = ,
N n=1 N n=1
N N
1 X 1 X
Var[X N ] = Var[X n ] = = .
N 2 n=1 N 2 n=1 N

Therefore, as N ! 1, the variance Var[X N ] ! 0.

6.3.2 Weak law of large numbers (WLLN)


The analysis of Figure 6.12 shows us something important, namely that the convergence
in a probabilistic way is di↵erent from that in a deterministic way. We now describe one
fundamental result related to probabilistic convergence, known as the weak law of large
numbers.

Theorem 6.16 (Weak law of large numbers). Let X1 , . . . , XN be a set of i.i.d. ran-
PN
dom variables with mean µ and variance 2 . Assume E[X 2 ] < 1. Let X N = N1 n=1 Xn .
Then for any " > 0, 
lim P |X N µ| > " = 0. (6.30)
N !1

Proof. By Chebyshev’s inequality,


⇥ ⇤ Var[X N ] Var[Xn ]
P |X N µ| > "  = .
"2 N "2
Therefore, setting N ! 1 we have
⇥ ⇤ Var[Xn ]
lim P |X N µ| > " = lim = 0.
N !1 N !1 N "2

354
6.3. LAW OF LARGE NUMBERS

Example 6.10. Consider a set of i.i.d. random variables X1 , . . . , XN where


2
Xn ⇠ Gaussian(µ, ).
1
PN
Verify that the sample average X N = N n=1 Xn follows the weak law of large num-
bers.

Solution: Since Xn is a Gaussian, the sample average X N is also a Gaussian:


✓ 2

X N ⇠ Gaussian µ, .
N
⇥ ⇤
Consider the probability P |X N µ| > " for each N :

def
N = P |X N µ| > "
 
= P XN µ > " + P XN µ < "
p ! p !
" N " N
=1 +
p !
" N
=2 .

If we set = 1 and " = 0.1, then


✓ ◆ p !
0.1 · 1 0.1 · 5
1 =2 = 0.9203, 5 =2 = 0.8231,
1 1
p ! p !
0.1 · 10 0.1 · 100
10 =2 = 0.7518, 100 = 2 = 0.3173,
1 1
p !
0.1 · 1000
1000 =2 = 0.0016.
1

As you can see, the the sequence 1 , 2 , . . . , N , . . . rapidly converges to 0 as N grows.


In fact, since (z) is a increasing function for z < 0 with ( 1) = 0, it follows that
 p !
" N
lim P |X N µ| > " = lim 2 = 0.
N !1 N !1

The weak law of large numbers is portrayed graphically in Figure 6.13. In this figure
we draw several PDFs of the sample average X N . The shapes of the PDFs are getting
narrower as the variance of the random variable shrinks. Since the PDFs become narrower,
the probability P[|X N µ| > "] becomes more unlikely. At the limit when N ! 1, the
probability vanishes. The weak law of large numbers asserts that this happens for any set of
def
i.i.d. random variables. It says that the sequence of probability values N = P[|X N µ| > "]

355
CHAPTER 6. SAMPLE STATISTICS

will converge to zero.

Figure 6.13: The weak law of large numbers states that as N increases, the variance of the sample
average X N shrinks. As a result, the probability P[|X N µ| > "] decreases and eventually vanishes.
Note that the convergence here is that of the sequence of probabilities P[|X N µ| > "], which is just
a sequence of numbers.

What is the weak law of large numbers?

Let X N be the sample average of i.i.d. random variables X1 , . . . , XN .



lim P |X N µ| > " = 0. (6.31)
N !1

For details, see Theorem 6.16.


The WLLN concerns the sequence of probability values N = P[|X N µ| > "].
The probabilities converge to zero as N grows.
It is weak because having a small probability does not exclude the possibility of
happening.

6.3.3 Convergence in probability


The example above tells us that in order to show convergence, we need to first compute the
probability n of each event and then take the limit of the sequence, e.g., the one shown in
the table below:

1 5 10 100 1000 10000


23
0.9203 0.8231 0.7518 0.3173 0.0016 1.5240⇥10

Therefore, the convergence is the convergence of the probability. Since { 1 , 2 , . . .} is a


sequence of real numbers (between 0 and 1), any convergence results for real numbers apply
here.
Note that the convergence controls only the probabilities. Probability means chance.
Therefore, having the limit converging to zero only means that the chance of happening is
becoming smaller and smaller. However, at any N , there is still a chance that some bad
event can happen.

356
6.3. LAW OF LARGE NUMBERS

What doP we mean by a bad event? Assume that Xn are fair coins. The sample average
N
X N = (1/N ) n=1 Xn is more or less equal to 1/2 as N grows. However, even if N is a
large number, say N = 1000, we are still not certain that the sample average is exactly 1/2.
It is possible, though very unlikely, that we obtain 1000 heads or 1000 tails (so that the
sample average is “1” or “0”). The bottom line is: Having a probability converging to zero
only means that for any tolerance level we can always find an N large enough so that the
probability is smaller than that tolerance.
The type of convergence described by the weak law of large numbers is known as the
convergence in probability.

Definition 6.6. A sequence of random variables A1 , . . . , AN converges in probability


to a deterministic number ↵ if for every " > 0,

lim P [|AN ↵| > "] = 0. (6.32)


N !1

p
We write AN ! ↵ to denote convergence in probability.

The following two examples illustrate how to prove convergence in probability.

Example 6.11. Let X1 , . . . , XN be i.i.d. random variables with Xn ⇠ Uniform(0, 1).


Define AN = min(X1 , . . . , XN ). Show that AN converges in probability to zero.

Solution. (Without determining the PDF of AN , we notice that as N increases, the


value of AN will likely decrease. Therefore, we should expect AN to converge to zero.)
Pick an " > 0. It follows that

P[|AN 0| "] = P[min(X1 , . . . , XN ) "], because Xn 0


= P[X1 " and · · · and XN "]
= P X1 " · · · P XN " = (1 ")N .

Setting the limit of N ! 1, we conclude that

lim P[|AN 0| "] = lim (1 ")N = 0.


N !1 N !1

Therefore, AN converges to zero in probability.

Practice Exercise 6.9. Let X ⇠ Exponential(1). By evaluating the CDF, we know


that P[X x] = e x . Let AN = X/N . Prove that AN converges to zero in probability.

Solution. For any " > 0,

P[|AN 0| "] = P[AN "]


= P[X N "]
N"
=e .

357
CHAPTER 6. SAMPLE STATISTICS

Putting N ! 1 on both sides of the equation gives us


N"
lim P[|AN 0| "] = lim e = 0.
N !1 N !1

Thus, AN converges to zero in probability.

Example 6.12. Construct an example such that AN converges in probability to some-


thing, but E[AN ] does not converge to the same thing.

Solution. Consider a sequence of random variables AN such that


8
> 1
<1 N , ↵ = 0,
P[AN = ↵] = N , 1
↵ = N 2,
>
:
0, otherwise.

The PDF of the random variable AN is shown in Figure 6.14.

Figure 6.14: Probability density function of the random variable AN .

We first show that AN converges in probability


p to zero. Let " > 0 be a fixed
constant. Since " > 0, P[AN "] = N1 for any N > ". Therefore, we have that

lim P[|AN 0| "] = lim P[AN "]


N !1 N !1
1
= lim = 0.
N !1 N
Hence, AN converges to 0 in probability.
However, E[AN ] does not converge to zero, because
✓ ◆
1 1
E[AN ] = 0 · 1 + N2 · = N.
N N

So E[AN ] goes to infinity as N grows.

6.3.4 Can we prove WLLN using Cherno↵’s bound?

The following discussion of using Cherno↵’s bound to prove WLLN can be skipped if this
is your first time reading the book.

358
6.3. LAW OF LARGE NUMBERS

In proving WLLN we use Chebyshev’s inequality. Can we use Cherno↵’s inequality (or
Hoe↵ding’s) to prove the result? Yes, we can use them. However, notice that the task here is
to prove convergence, not to find the best convergence. Finding the best convergence means
finding the fastest decay rate of the probability sequence. Cherno↵’s bound (and Hoe↵ding’s
inequality) o↵ers a better decay rate. However, Cherno↵’s bound needs to be customized for
individual random variables. For example, Cherno↵’s bound for Gaussian is di↵erent from
Cherno↵’s bound for exponential. This result makes Chebyshev the most convenient bound
because it only requires the variance to be bounded.
What if we insist on using Cherno↵’s bound in proving the WLLN? We can do that for
specific random variables. Let’s consider two examples. The first example is the Gaussian
random variable where Xn ⇠ N (0, 2 ). We know that X N ⇠ N (0, 2 /N ). Cherno↵’s bound
shows that ⇢ 2
⇥ ⇤ " N
P |X N µ| > "  2 exp ,
2 2
Taking the limit on both sides, we have

⇥ ⇤ "2 N
lim P |X N µ| > " = lim 2 exp = 0.
N !1 N !1 2 2

Note that the rate of convergence here is exponential. The rate of convergence o↵ered by
Chebyshev is only linear. Of course, you may argue that since Xn is Gaussian we have
closed-form expressions about the probability, so we do not need Cherno↵’s bound. This is
a legitimate point, and so here is an example where we do not have a closed-form expression
for the probability.
Consider a sequence of arbitrary i.i.d. random variables X1 , . . . , XN with 0  Xn  1.
Then Hoe↵ding’s inequality tells us that
⇥ ⇤
P |X N µ| > "  2 exp 2"2 N .

Taking the limit on both sides, we have


⇥ ⇤
lim P |X N µ| > " = lim 2 exp 2"2 N = 0.
N !1 N !1

Again, we obtain a WLLN result, this time for i.i.d. random variables X1 , . . . , XN with
0  Xn  1.
As you can see from these two examples, WLLN can be proved in multiple ways
depending on how general the random variables need to be.

End of the discussions.

6.3.5 Does the weak law of large numbers always hold?

The following discussion of the failure of the weak law of large numbers can be skipped if
this is your first time reading the book.

359
CHAPTER 6. SAMPLE STATISTICS

The weak law of large numbers does not always hold. Recall that when we prove the
weak law of large numbers using Chebyshev’s inequality, we implicitly require that the
variance Var[X N ] is finite. (Look at the condition that E[X 2 ] < 1.) Thus for distributions
whose variance is unbounded, Chebyshev’s inequality does not hold. One example is the
Cauchy distribution. The PDF of a Cauchy distribution is

fX (x) = 2
,
⇡( + x2 )
where is a parameter. Letting = 1,
Z 1 Z
x2 1 1 1
E[X 2 ] = 2)
dx = 1 dx
1 ⇡(1 + x ⇡ 1 1 + x2
Z Z  1
1 1 1 1 1 1 1
= dx 2
dx = x tan (x) = 1.
⇡ 1 ⇡ 1 1+x ⇡ x= 1

Since the second moment is unbounded, the variance of X will also be unbounded.
A perceptive reader may observe that even if E[X 2 ] is unbounded, it does not mean
that the tail probability is unbounded. This is correct. However, for Cauchy distributions,
we can show that the sample average X N does not converge to the mean when N ! 1
(and so the WLLN fails). To see this, we note that the characteristic function of a Cauchy
random variable X is
1
$ e |!| .
⇡(1 + x2 )
1
PN
So for the sample average X N = N n=1 Xn , the characteristic function is

j! PN N
Y j!
h |!|
iN
j!X N Xn N Xn |!|
E[e ] = E[e N n=1 ]= E[e ]= e N =e ,
n=1

which remains a Cauchy distribution with = 1. Therefore, we have that


Z "
1
P[|X N |  "] = dx
1 ⇡(1 + x2 )
Z 0 Z "
1 1 1 1 1
= 2
dx + 2
dx = + tan (").
1 ⇡(1 + x ) 0 ⇡(1 + x ) 2 ⇡

Thus no matter how many samples we have, P[|X N |  "] will never converge to 1 (so
P[|X N | > "] will never converge to 0). Therefore, WLLN does not hold.

End of the discussion.

6.3.6 Strong law of large numbers


Since there is a “weak” law of large numbers, you will not be surprised to learn that there
is a strong law of large numbers. The strong law is more restrictive than the weak law. Any
sequence satisfying the strong law will satisfy the weak law, but not vice versa. Since the
strong law is “stronger”, the proof is more involved.

360
6.3. LAW OF LARGE NUMBERS

Theorem 6.17 (Strong law of large numbers). Let X1 , . . . , XN be a sequence of


i.i.d. random variables with common mean µ and variance 2 . Assume E[X 4 ] < 1.
PN
Let X N = N1 n=1 Xn be the sample average. Then
h i
P lim X N = µ = 1. (6.33)
N !1

The strong law flips the order of limit and probability. As you can see, the di↵erence
between the strong law and the weak law is the order of the limit and the probability. In the
weak law, the limit is outside the probability, whereas, in the strong law, the limit is inside
the probability. This switch in order makes the interpretation of the result fundamentally
di↵erent. In the final analysis, the weak law concerns the limit of a sequence of probabilities
(which are just real numbers between 0 and 1). However, the strong law concerns the limit
of a sequence of random variables. The strong law answers the question, what is the limiting
object of the sample average as N grows?
The strong law concerns the limiting object, not a sequence of numbers. What
is the “limiting object”? If we denote X N as the sample average using N samples, then
we know that X 1 is a random variable, X 2 is a random variable, and all X n ’s are random
variables. So we have a sequence of random variables. As N goes to infinity, we can ask about
the limiting object limN !1 X N . However, even without any deep analysis, you should be
able to see that limN !1 X N is another random variable. The strong law says that this
limiting object will “successfully” become a deterministic number µ, after a finite number
of “failures”.
The strong law asserts that there are a finite number of failures. Let us explain
“success” and “failure”. X N is a random variable, so it fluctuates. However, as N goes to
infinity, the strong law says that the number of times where X N 6= µ will be zero. That
is, there is a finite number of times where X N 6= µ (i.e., fail), and afterward, you will be
perfectly fine (i.e., success). Yes, perfectly fine means 100%. The weak law only guarantees
99.99%.
A good example for di↵erentiating the weak law and the strong law is an electronic
dictionary that improves itself every time you use it. The weak law says that if you use
the dictionary for a long period, the probability of making an error will become small. You
will still get an error once in a while, but the probability is very small. This is a 99.99%
guarantee, and it is the weak law. The strong law says that the number of failures is finite.
After you have gone through this finite number of failures, you will be completely free of
error. This is a 100% guarantee by the strong law. When will you hit this magical number?
The strong law does not say when; it only asserts the existence of this number. However, this
existence is already good enough in many ways. It gives a certificate of assurance, whereas
the weak law still has uncertainty.
Strong law 6= deterministic. If the strong law o↵ers a 100% guarantee, does it mean
that it is a deterministic guarantee? No, the strong law is still a probabilistic statement
because we are still using P[·] to measure an event. The event can include measure-zero
subsets, and the measure-zero subsets can be huge. For example, the set of rational numbers
on the real line is a measure-zero set when measuring the probability using an integration.
The strong law does not handle those measure-zero subsets.

361
CHAPTER 6. SAMPLE STATISTICS

6.3.7 Almost sure convergence

The discussion below can be skipped if this is your first time reading the book.

The type of convergence used by the strong law of large numbers is the almost sure
convergence. It is defined formally as follows.

Definition 6.7. A sequence of random variables A1 , . . . , AN converges almost surely


to ↵ if h i
P lim AN = ↵ = 1. (6.34)
N !1
a.s.
We write AN ! ↵ to denote almost sure convergence.

To prove almost sure convergence, one needs to show that the sequence AN will demonstrate
AN 6= ↵ for a finite number of times. Afterward, AN needs to demonstrate AN = ↵.

Example 6.13.a Construct a sequence of events that converges almost surely.


Solution. Let X1 , . . . , XN be i.i.d. random variables such that Xn ⇠ Uniform(0, 1).
Define AN = min(X1 , . . . , XN ). Since AN is nonincreasing and is bounded below by
zero, it must have a limit. Let us call this limit
def
A = lim AN .
N !1

Then we can show that

P[A ✏] = P[min(X1 , X2 , . . .) ✏]
(a)
 P[min(X1 , X2 , . . . , XN ) ✏]
(b)
= P[X1 ✏ and X2 ✏ and · · · and XN ✏]
N
= (1 ✏) ,

where (a) holds because there are more elements in (X1 , X2 , . . .) than in
(X1 , X2 , . . . , XN ). Therefore, the minimum value of the former is less than the mini-
mum value of the latter. (b) holds because if min(X1 , X2 , . . . , XN ) ✏, then Xn ✏
for all n.
Since P[A ✏]  (1 ✏)N for any N , the statement still holds as N ! 1. Thus,

P[A ✏]  lim (1 ✏)N = 0.


N !1

This shows P[A ✏] = 0 for any positive ✏. So P[A > ✏] = 0, and hence P[A = 0] = 1.
Since A is the limit of AN , we conclude that
h i
P lim AN = 0 = P [A = 0] = 1.
N !1

362
6.3. LAW OF LARGE NUMBERS

So AN converges to 0 almost surely.


a This example is modified from Bertsekas and Tsitsiklis, Introduction to Probability, Chapter 5.5.

Example 6.14.a Construct an example where a sequence of events converges in prob-


ability but does not converge almost surely.

Solution. Consider a discrete time arrival process. The set of times is partitioned into
consecutive intervals of the form

I1 = {2, 3},
I2 = {4, 5, 6, 7},
I3 = {8, 9, 10, . . . , 15},
..
.
Ik = {2k , 2k + 1, . . . , 2k+1 1}.

Therefore, the length of each interval is |I1 | = 2, |I2 | = 4, . . . , |Ik | = 2k .


During each interval, there is exactly one arrival. Define Yn as a binary random
variable such that for every n 2 Ik ,
(
1, with probability |I1k | ,
Yn =
0, with probability 1 |I1k | .

For example, if n 2 {2, 3}, then P[Yn = 1] = 12 . If n 2 {4, 5, 6, 7}, then P[Yn = 1] = 14 .
In general, we have that
1 1
lim P[Yn = 1] = lim = lim = 0,
n!1 n!1 |Ik | n!1 2k

and hence
1
lim P[Yn = 0] = lim 1 = 1.
n!1 n!1 2k
Therefore, Yn converges to 0 in probability.
However, when we carry out the experiment, there is exactly one arrival per
interval according to the problem conditions. Since we have an infinite number of
intervals I1 , I2 , . . ., we will have an infinite number of arrivals in total. As a result,
Yn = 1 for infinitely many times. We do not know which Yn will equal 1 and which
Yn will equal to 0. However, we know that there are infinitely many Yn that are equal
to 1. Therefore, in the sequence Y1 , Y2 , . . . , Yn , . . ., we must have that the tail of the
sequence is 1. (If Yn stops being 1 after some n, then we will not have an infinite
number of arrivals in total.)
Since Yn = 1 when n is large enough, it follows that
h i
P lim Yn = 1 = 1.
n!1

363
CHAPTER 6. SAMPLE STATISTICS

Equivalently, we can say that the sequence Yn will never take the value 0 when n is
large enough. Thus,
h i
P lim Yn = 0 = 0.
n!1

Therefore, Yn does not converge to 0 almost surely.


a This example is modified from Bertsekas and Tsitsiklis, Introduction to Probability, Chapter 5.5.

End of the discussions.

6.3.8 Proof of the strong law of large numbers


The strong law of large numbers can be proved in several ways. We present a proof based on
Bertsekas and Tsitsiklis, Introduction to Probability, Problems 5.16 and 5.17, which require
a finite fourth moment E[Xn4 ] < 1. An alternative proof that requires only E[Xn ] < 1 is
from Billingsley, Probability and Measure, Theorem 22.1.

The proof of the strong law of large numbers is beyond the scope of this book. This
section is optional.

Lemma 6.4. Consider non-negative random variables X1 , . . . , XN . Assume that


"1 #
X
E Xn < 1. (6.35)
n=1

a.s.
Then Xn ! 0.
PN
Proof. Let S = n=1 Xn . Note that S is a random variable, and our assumption is that
E[S] < 1. Thus, we argue that S < 1 with probability 1. If not, then S will have a positive
probability of being 1. But if this happens, we will have E[S] = 1 because (by the law of
total expectation):
E[S] = E[S | S = infinite]P[S = infinite] + E[S | S = finite]P[S = finite].
| {z }
=1

Now, since S is finite, the sequence {X1 , . . . , XN , . . .} must converge to zero. Otherwise,
if Xn is converging to some constants c > 0, then summing the tail of the sequence (which
contains infinitely many terms) gives infinity:
S = X1 + · · · + XN + · · · + .
| {z } | {z }
=finite =infinite

Since the probability of S being finite is 1, it follows that {X1 , . . . , XN } is converging


to zero with probability 1.

364
6.3. LAW OF LARGE NUMBERS

Theorem 6.18 (Strong law of large numbers). Let X1 , . . . , XN be a sequence of


i.i.d. random variables with common mean µ and variance 2 . Assume E[Xn4 ] < 1.
PN
Let X N = N1 n=1 Xn be the sample average. Then
h i
P lim X N = µ = 1. (6.36)
N !1

Proof. We first prove the case where E[Xn ] = 0. To establish that X N ! 0 with probabil-
ity 1, we use the lemma to show that
" 1 #
X
E |X N | < 1.
N =1
P1 P1
But to show E[ N =1 |X N |] < 1, we note that |x|  1 + x4 . Therefore, E[ N =1 |X N |] 
P1 4
1 + E[ N =1 X N ], and hence we just need to show that
" 1 #
X 4
E X N < 1.
N =1

4
Let us expand the term E[X N ] as follows:
N N N N
4 1 X X X X
E[X N ] = E[Xn1 Xn2 Xn3 Xn4 ].
N 4 n =1 n =1 n =1 n =1
1 2 3 4

There are five possibilities for E[Xn1 Xn2 Xn3 Xn4 ]:

All indices are di↵erent. Then

E[Xn1 Xn2 Xn3 Xn4 ] = E[Xn1 ]E[Xn2 ]E[Xn3 ]E[Xn4 ] = 0 · 0 · 0 · 0 = 0.

One index is di↵erent from other three indices. For example, if n1 is di↵erent from
n2 , n3 , n4 , then

E[Xn1 Xn2 Xn3 Xn4 ] = E[Xn1 ]E[Xn2 Xn3 Xn4 ] = 0 · E[Xn2 Xn3 Xn4 ] = 0.

Two indices are identical. For example, if n1 = n3 , and n2 = n4 , then

E[Xn1 Xn2 Xn3 Xn4 ] = E[Xn1 Xn3 ]E[Xn2 Xn4 ] = E[Xn21 Xn22 ].

There are altogether 3N (N 1) of these cases: N (N 1) comes from choosing N


followed by choosing N 1, and 3 accounts for n1 = n2 6= n3 = n4 , n1 = n3 6= n2 = n4 ,
and n1 = n4 6= n2 = n3 .
Two indices are identical, and two indices are di↵erent. For example, if n1 = n3 but
n2 and n4 are di↵erent. Then

E[Xn1 Xn2 Xn3 Xn4 ] = E[Xn1 Xn3 ]E[Xn2 ]E[Xn4 ] = E[Xn21 ] · 0 · 0 = 0.

365
CHAPTER 6. SAMPLE STATISTICS

All indices are identical. If n1 = n2 = n3 = n4 , then


E[Xn1 Xn2 Xn3 Xn4 ] = E[Xn41 ].
There are altogether N cases of this.
Therefore, it follows that
4 N E[X14 ] + 3N (N 1)E[X12 X22 ]
E[X N ] = .
N4
Since xy  (x2 + y 2 )/2, it follows that
E[X12 X22 ]  E[(X12 )2 + (X22 )2 ]/2 = E[X14 + X24 ]/2 = E[X14 ].
Substituting into the previous result,
4 N E[X14 ] + 3N (N 1)E[X14 ] 3N 2 3
E[X N ]   E[X14 ] = 2 E[X14 ].
N4 N 4 N
Now, let us complete the proof.
" 1 # " 1 #
X 4 X 3
4
E XN  E E[X1 ] < 1,
N2
N =1 N =1
P1 2
P1 2 2
because N =1 (1/N ) is the Basselh problem with
i a solution that N =1 (1/N ) = ⇡ /6.
P1 4 ⇥P1 ⇤
Consequently, we have shown that E N =1 X N < 1, which implies E N =1 |X N | < 1.
Then, by the lemma, we have X N converging to 0 with probability 1, which proves the result.
If E[Xn ] = µ, then just replace Xn with Yn = Xn µ in the above arguments. Then we
can show that Y N converges to 0 with probability 1, which is equivalent to X N converging
to µ with probability 1.

End of the proof of strong law of large numbers.

6.4 Central Limit Theorem

PN
The law of large numbers tells us the mean of the sample average X N = (1/N ) n=1 Xn .
However, if you recall our experiment of throwing N dice and inspecting the PDF of the
sum of the numbers, you may remember that the convolution of an infinite number of
uniform distributions gives us a Gaussian distribution. For example, we show a sequence
of experiments in Figure 6.15. In each experiment, we throw N dice and count the sum.
Therefore, if each face of the die is denoted as Xn , then the sum is X1 + · · · + XN . We plot
the PDF of the sum. As you can see in the figure, X1 + · · · + XN converges to a Gaussian.
This phenomenon is explained by the Central Limit Theorem (CLT).
What⇣does the ⌘ Central Limit Theorem say? Let X N be the sample average, and let
p XN µ
ZN = N be the normalized variable. The Central Limit Theorem is as follows:

366
6.4. CENTRAL LIMIT THEOREM

Figure 6.15: Pictorial illustration of the Central Limit Theorem. Suppose we throw a die and record the
face. [Left] If we only have one die, then the distribution of the face is uniform. [Middle] If we throw
two dice, the distribution is the convolution of two uniform distributions. This will give us a triangle
distribution. [Right] If we throw five dice, the distribution is becoming similar to a Gaussian. The Central
Limit Theorem says that as N goes to infinity, the distribution of the sum will converge to a Gaussian.

Central Limit Theorem:


The CDF of ZN is converging pointwise to the CDF of Gaussian(0,1).

Note that we are very careful here. We are not saying that the PDF of ZN is converging to
the PDF of a Gaussian, nor are we saying that the random variable ZN is converging to a
Gaussian random variable. We are only saying that the values of the CDF are converging
pointwise. The di↵erence is subtle but important.
To understand the difficulty and the core ideas, we first present the concept of conver-
gence in distribution.

6.4.1 Convergence in distribution

Definition 6.8. Let Z1 , . . . , ZN be random variables with CDFs FZ1 , . . . , FZN respec-
tively. We say that a sequence of Z1 , . . . , ZN converges in distribution to a random
variable Z with CDF FZ if

lim FZN (z) = FZ (z), (6.37)


N !1

d
for every continuous point z of FZ . We write ZN ! Z to denote convergence in
distribution.

This definition involves many concepts, which we will discuss one by one. However, the
definition can be summarized in a nutshell as follows.

Convergence in distribution = values of the CDF converge.

Example 1. (Bernoulli) Consider flipping a fair coin N times. Denote each coin flip as a
Bernoulli random variable Xn ⇠ Bernoulli(p), where n = 1, 2, . . . , N . Define ZN as the sum

367
CHAPTER 6. SAMPLE STATISTICS

of N Bernoulli random variables, so that


N
X
ZN = Xn .
n=1

We know that the resulting random variable ZN is a binomial random variable with mean
N p and variance N p(1 p). Let us plot the PDF fZN (z) as shown in Figure 6.16.

Figure 6.16: Convergence in distribution. The convergence in distribution concerns the convergence of
the values of the CDF (not the PDF). In this figure, we let ZN = X1 + · · · + XN , where XN is a
Bernoulli random variable with parameter p. Since a sum of Bernoulli random variables is a binomial,
ZN is a binomial random variable with parameters (N, p). We plot the PDF of ZN , which is a train of
delta functions, and compare it with the Gaussian PDF. Observe that the error, maxz |fZN (z) fZ (z)|,
does not converge to 0. The PDF of ZN is a binomial. A binomial is always a binomial. It will not turn
into a Gaussian.

The first thing we notice in the figure is that as N increases, the PDF of the binomial
has an envelope that is “very Gaussian”. So one temptation is to say that the random
variable ZN is converging to another random variable Z. In addition, we would think that
the PDFs converge in the sense that for all z,
✓ ◆ ⇢
N z 1 (z µ)2
fZN (z) = p (1 p)N z ! fZ (z) = p exp ,
z 2⇡ 2 2 2

where µ = N p and 2 = N p(1 p).


Unfortunately this argument does not work, because fZ (z) is continuous but fZN (z)
is discrete. The sample space of ZN and the sample space of Z are completely di↵erent. In
fact, if we write fZN as an impulse train, we observe that
N ✓ ◆
X N
fZN (z) = pi (1 p)N i
(z i).
i=0
i

Clearly, no matter how big the N is, the di↵erence |fZN (z) fZ (z)| will never go to zero
for non-integer values of z. Mathematically, we can show that

max |fZN (z) fZ (z)| 6 ! 0,


z

as N ! 1. ZN is a binomial random variable regardless of N . It will not become a Gaussian.

368
6.4. CENTRAL LIMIT THEOREM

If fZN (z) is not converging to a Gaussian PDF, how do we explain the convergence?
The answer is to look at the CDF. For discrete PDFs such as a binomial random variable,
the CDF is a staircase function. What we can show is that
X z ✓ ◆ Z z ⇢
N i 1 (t µ)2
FZN (z) = p (1 p)N i ! FZ (z) = p exp dt.
i=0
i 1 2⇡ 2 2 2

The di↵erence between the PDF convergence and the CDF convergence is that the PDF
does not allow a meaningful “distance” between a discrete function and continuous function.
For CDF, the distance is well defined by taking the di↵erence between the staircase function
and the continuous function. For example, we can compute

|FZN (z) FZ (z)|, for all continuous points z of FZ ,

and show that


max |FZN (z) FZ (z)| ! 0.
z

Figure 6.17: Convergence in distribution. This is the same as Figure 6.16, but this time we plot the
CDF of ZN . The CDF is a staircase function. We compare it with the Gaussian CDF. Observe that the
error, maxz |FZN (z) FZ (z)|, converges to zero as N grows. Convergence in distribution says that the
sequence of CDFs FZN (z) will converge to the limiting CDF FZ (z), at all continuous points of FZ (z).

We need to pay attention to the set of z’s. We do not evaluate all z’s but only the z’s
that are continuous points of FZ . If FZ is Gaussian, this does not matter because all z’s
are continuous. However, for CDFs containing discontinuous points, our definition of con-
vergence in distribution will ignore these discontinuous points because they have a measure
zero.

Example 2. (Poisson) Consider Xn ⇠ Poisson( ), and consider X1 , . . . , XN . Define ZN =


PN PN PN
n=1 Xn . It follows that E[ZN ] = n=1 E[Xn ] = N and Var[ZN ] = n=1 Var[Xn ] = N .
Moreover, we know that the sum of Poissons remains a Poisson. Therefore, the PDF of ZN
is
X1 ⇢
(N )k N 1 (z µ)2
fZN (z) = e (z k) and fZ (z) = p exp ,
k! 2⇡ 2 2 2
k=0

369
CHAPTER 6. SAMPLE STATISTICS

0.2 0.15 0.06


Poisson Poisson Poisson
Gaussian Gaussian Gaussian
0.15
0.1 0.04

0.1

0.05 0.02
0.05

0 0 0
0 2 4 6 8 0 5 10 15 20 0 20 40 60 80 100
1 1 1

0.8 0.8 0.8

0.6 0.6 0.6

0.4 0.4 0.4

0.2 Poisson 0.2 Poisson 0.2 Poisson


Gaussian Gaussian Gaussian
0 0 0
0 2 4 6 8 0 5 10 15 20 0 20 40 60 80 100

(a) N = 4 (b) N = 10 (c) N = 50

Figure 6.18: Convergence in distribution for a sum of Poisson random


P variables. Here we assume that
X1 , . . . , XN are i.i.d. Poisson with a parameter . We let ZN = Nn=1 Xn be the sum, and compute the
corresponding PDF (top row) and CDFs (bottom row). Just as with the binomial example, the PDFs of
the Poisson do not converge but the CDFs of the Poisson converge to the CDF of a Gaussian.

where µ = N and 2 = N . Again, fZN does not converge to fZ . However, if we compare


the CDF, we can see from Figure 6.18 that the CDF of the Poisson is becoming better
approximated by the Gaussian.

Interpreting “convergence in distribution”. After seeing two examples, you should


now have some idea of what “convergence in distribution” means. This concept applies to
the CDFs. When we write
lim FZN (z) = FZ (z), (6.38)
N !1

we mean that FZN (z) is converging to the value FZ (z), and this relationship holds for all
the continuous z’s of FZ . It does not say that the random variable ZN is becoming another
random variable Z.

d
ZN ! Z is equivalent to limN !1 FZN (z) = FZ (z).

Example 3. (Exponential) So far, we have studied the sum of discrete random variables.
Now, let’s take a look at continuous random variables. Consider Xn ⇠ Exponential( ), and
PN PN
let X1 , . . . , XN be i.i.d. copies. Define ZN = n=1 Xn . Then E[ZN ] = n=1 E[Xn ] = N/
and Var[ZN ] = N2 . How about the PDF of ZN ? Using the characteristic functions, we know
that

x F
fXn (x) = e ! Xn (j!) = .
+ j!

370
6.4. CENTRAL LIMIT THEOREM

Therefore, the product is


N
Y N N
(N 1)!
ZN (j!) = Xn (j!) = = ⇥
n=1
( + j!)N ( + j!)N (N 1)!
N N
(N 1)! F
= · ! zN 1
e z
= fZN (z).
(N 1)! ( + j!)N (N 1)!
N
N 1 z
This resulting PDF fZN (z) = (N 1)! z e is known as the Erlang distribution. The
CDF of the Erlang distribution is
Z z
FZN (z) = fZN (t) dt
1
Z z N
= tN 1 e t dt
(N 1)!
0
= Gamma function(z, N ),

where the last integral is known as the incomplete gamma function, evaluated at z.
Given all these, we can now compare the PDF and the CDF of ZN versus Z. Figure 6.19
shows the PDFs and the CDFs of ZN for various N values. In this experiment we set = 1.
As we can see from the experiment, the Erlang distribution’s PDF and CDF converge to
a Gaussian. In fact, for continuous random variables such as exponential random variables,
we indeed have the random variable ZN converging to the random variable Z. This is quite
di↵erent from discrete random variables, where ZN does not converge to Z but only FZN
converges to FZ .
0.25 0.15 0.06

0.2
0.1 0.04
0.15

0.1
0.05 0.02
0.05 Sum of Exponential Sum of Exponential Sum of Exponential
Gaussian Gaussian Gaussian
0 0 0
0 2 4 6 8 0 5 10 15 20 0 20 40 60 80 100
1 1 1

0.8 0.8 0.8

0.6 0.6 0.6

0.4 0.4 0.4

0.2 Sum of Exponential 0.2 Sum of Exponential 0.2 Sum of Exponential


Gaussian Gaussian Gaussian
0 0 0
0 2 4 6 8 0 5 10 15 20 0 20 40 60 80 100

(a) N = 4 (b) N = 10 (c) N = 50

Figure 6.19: Convergence in distribution for a sum of exponential random variables.


P Here we assume
that X1 , . . . , XN are i.i.d. exponentials with a parameter . We define ZN = Nn=1 Xn be the sum.
It is known that the sum of exponentials is an Erlang. We compute the corresponding PDF (top row)
and CDFs (bottom row). Unlike the previous two examples, in this example we see that both PDFs and
CDFs of the Erlang distribution are converging to a Gaussian.

371
CHAPTER 6. SAMPLE STATISTICS

d p
Is ! stronger than !? Convergence in distribution is actually weaker than con-
vergence in probability. Consider a continuous random variable X with a symmetric PDF
fX (x) such that fX (x) = fX ( x). It holds that the PDF of X has the same PDF. If
we define the sequence ZN = X if N is odd and ZN = X if N is even, and let Z = X,
then FZN (z) = FZ (z) for every z because the PDF of X and X are identical. There-
d p
fore, ZN ! Z. However, ZN !
6 Z because ZN oscillates between the random variables X
and X. These two random variables are di↵erent (although they have the same CDF)
because P[X = X] = P[{! : X(!) = X(!)}] = P[{! : X(!) = 0}] = 0.

6.4.2 Central Limit Theorem

Theorem 6.19 (Central Limit Theorem). Let X1 , . . . , XN be i.i.d. random variables


of mean E[Xn ] = µ and variance Var[Xn ] = 2 . Also, assume that E[|X 3 |] < 1. Let
PN p ⇣ X µ ⌘n
X N = (1/N ) n=1 Xn be the sample average, and let ZN = N N
. Then

lim FZ N (z) = FZ (z), (6.39)


N !1

where Z = Gaussian(0, 1).

In plain words, the Central Limit Theorem says that the sample average (which is
a random variable) has a CDF converging to the CDF of a Gaussian. Therefore, if we
want to evaluate probabilities associated with the sample average, we can approximate the
probability by the probability of a Gaussian.
As we discussed above, the Central Limit Theorem does not mean that the random
variable ZN is converging to a Gaussian random variable, nor does it mean that the PDF
of ZN is converging to the PDF of a Gaussian. It only means that the CDF of ZN is
converging to the CDF of a Gaussian. Many people think that the Central Limit Theorem
means “sample average converges to Gaussian”. This is incorrect for the above reasons.
However, it is not completely wrong. For continuous random variables where both PDF
and CDF are continuous, we will not run into situations where the PDF is a train of delta
functions. In this case, convergence in CDF can be translated to convergence in PDF.
The power of the Central Limit Theorem is that the result holds for any distribution
of X1 , . . . , XN . That is, regardless of the distribution of X1 , . . . , XN , the CDF of X N is
approaching a Gaussian.

Summary of the Central Limit Theorem


X1 , . . . , XN are i.i.d. random variables, with mean µ and variance 2 . They are
not necessarily Gaussians.
PN p ⇣ ⌘
Define the sample average as X N = (1/N ) n=1 Xn , and let ZN = N X µ .
d
The Central Limit Theorem says ZN ! Gaussian(0, 1). Equivalently, the the-
d 2
orem says that N X N ! Gaussian(µ, ).
So if we want to evaluate the probability of X N 2 A for some set A, we can

372
6.4. CENTRAL LIMIT THEOREM

approximate the probability by evaluating the Gaussian:


Z ⇢
1 (y µ)2
P[X N 2 A] ⇡ p exp dy.
A
2
2⇡( /N ) 2( 2 /N )

CLT does not say that the PDF of X N is becoming a Gaussian PDF.
CLT only says that the CDF of X N is becoming a Gaussian CDF.

If the set A is an interval, we can use the standard Gaussian CDF to compute the
probability.

Corollary 6.3. Let X1 , . . . , XN be i.i.d. random variables


PN with mean µ and vari-
ance 2 . Define the sample average as X N = (1/N ) n=1 Xn . Then
✓ ◆ ✓ ◆
p b µ p a µ
P[a  X N  b] ⇡ N N , (6.40)

Rz x2
where (z) = p1 e 2 dx is the CDF of the standard Gaussian.
1 2⇡

d 2
Proof. By the Central Limit Theorem, we know that X N ! Gaussian(µ, N ). Therefore,
Z b ⇢
1 (y µ)2
P[a  X N  b] ⇡ p exp 2 /N )
dy
a 2⇡( 2 /N ) 2(
Z p ✓ ◆ ✓ ◆
Nb µ
p p
1 y2 b µ a µ
= p p e 2 dy = N N .
Na µ 2⇡

P Limit Theorem says that if we want to evaluate the probability P[a  X N  b],
Figure 6.20: The Central
where X N = (1/N ) N n=1 Xn is the sample average of i.i.d. random variables X1 , . . . , XN , we can
approximate the probability by integrating the Gaussian PDF.

A graphical illustration of the CLT is shown in Figure 6.20, where we use a binomial
random variable (which is the sum of i.i.d. Bernoulli) as an example. The CLT does not say

373
CHAPTER 6. SAMPLE STATISTICS

that the binomial random variable is becoming a Gaussian. It only says that the probability
covered by the binomial can be approximated by the Gaussian.

The following proof of the Central Limit Theorem can be skipped if this is your first time
reading the book.

Proof of the Central Limit Theorem. We now give a “proof” of the Central Limit
Theorem. Technically speaking, this proof does not prove the convergence of the CDF as the
theorem claims; it only proves that the moment-generating function converges. The actual
proof of the CDF convergence is based on the Berry-Esseen Theorem, which is beyond the
scope of this book. However, what we prove below is still useful because it gives us some
intuition about why Gaussian is the limiting random variable we should consider in the first
place.
p ⇣ ⌘
Let ZN = N X N µ . It follows that E[ZN ] = 0 and Var[ZN ] = 1. Therefore, if we
can show that ZN is converging to a standard Gaussian random variable Z ⇠ Gaussian(0, 1),
then by the linear transformation property of Gaussian, Y = pN Z+µ will be Gaussian(µ, 2 /N ).
Our proof is based on analyzing the moment-generating function of ZN . In particular,
 p ⇣X µ
⌘ N
Y h i
def s N N s
sZN p (Xn µ)
MZN (s) = E[e ]=E e = E e N .
n=1

Expanding the exponential term using the Taylor expansion (Chapter 1.2),
N
Y h s
i
p (Xn µ)
E e N

n=1
N
Y  ✓ ◆
s s2 (Xn µ)3
= E 1+ p (Xn µ) + (Xn µ)2 + O p
n=1
N 2 2N 3N N

N 
Y ✓ ◆N
s s2 ⇥ 2
⇤ s2
= 1+ p E[Xn µ] + E (Xn µ) = 1+ .
n=1
N 2 2N 2N
⇣ ⌘N
s2 2
It remains to show that 1 + 2N ! es /2
. If we can show that, we have shown that the
MGF of ZN is also the MGF of Gaussian(0, 1). To this end, we consider log(1 + x). By the
Taylor approximation, we have that
✓ ◆ ✓ 2 ◆ 2
d d x
log(1 + x) ⇡ log(1) + log x|x=1 x + 2
log x|x=1 + O(x3 ).
dx dx 2
⇣ ⌘
s2 s2 s4
Therefore, we have log 1 + 2N ⇡ 2N 4N 2 . As N ! 1, the limit becomes
✓ ◆
s2 s4 s2 s2
lim N log 1 + = , ⇡ lim
N !1 2N N !1 4N 2 2
⇣ ⌘N s2
s2
and so taking the exponential on both sides yields limN !1 1 + 2N = e 2 . Therefore,
s2
we conclude that limN !1 MZN (s) = e 2 , and so ZN is converging to a Gaussian.

374
6.4. CENTRAL LIMIT THEOREM


Limitation of our proof. The limitation of our proof lies in the issue of whether the
integration and the limit are interchangeable:
⇢Z
lim MZN (s) = lim fZN (z)esz dz
N !1 N !1
Z ⇣ ⌘
?
= lim fZN (z) esz dz.
N !1

If they were, then proving limN !1 MZN (s) = MZ (s) is sufficient to claim fZN (z) ! fZ (z).
However, we know that the latter is not true in general. For example, if fZN (z) is a train of
delta functions, then the limit and the integration are not interchangeable.
Berry-Esseen Theorem. The formal way of proving the Central Limit Theorem is to
prove the Berry-Esseen Theorem. The theorem states that

sup FZN (z) FZ (z)  C p ,


z2R 3 N
where and C are universal constants. Here, you can more or less treat the supremum
operator as the maximum. The left-hand side represents the worst-case error of the CDF
FZN compared to the limiting CDF FZ . The right-hand side involves several constants C,
, and , but they are fixed.
As N goes to infinity, the right-hand side will converge to zero. Therefore, if we can
prove this result, then we have proved the actual Central Limit Theorem. In addition,
we have found the rate p of convergence since the right-hand side tells us that the error
drops at the rate of 1/ N , which is not particularly fast but is sufficient for our purpose.
Unfortunately, proving the Berry-Esseen theorem is not easy. One of the difficulties, for
example, is that one needs to deal with the infinite convolutions in the time domain or the
frequency domain.
Interpreting our proof. If our proof is not completely valid, why do we mention it?
For one thing, it provides us with some useful intuition. For most of the (well-behaving)
random variables whose moments are finite, the exponential term in the moment-generating
function can be truncated to the second-order polynomial. Since a second-order polynomial
is a Gaussian, it naturally concludes that as long as we can perform such truncation the
truncated random variable will be Gaussian.
To convince you that the Gaussian MGF is the second-order approximation to other
MGFs, we use Bernoulli as an example. Let X1 , . . . , XN be i.i.d.
PN Bernoulli with a parame-
ter p. Then the moment-generating function of X N = (1/N ) n=1 Xn would be:

PN N
Y
1 s
MX N (s) = E[esX ] = E[es N n=1 Xn
]= E[e N Xn ]
n=1
✓ ✓ ◆◆N
s
N s s2
= (1 p + pe )
N ⇡ 1 p+p 1+ +
N 2N 2
✓ ◆N
sp s2 p
= 1+ + .
N 2N 2

375
CHAPTER 6. SAMPLE STATISTICS

Using the logarithmic approximation, it follows that


✓ ◆
sp s2 p
log MX N (s) = N log 1 + +
N 2N 2
✓ ◆ ✓ ◆2
sp s2 p N sp s2 p
⇡N + +
N 2N 2 2 N 2N 2
2
s p(1 p) def
⇡ sp + = log MY (s).
2N
Taking the exponential on both sides, we have that

s2 p(1 p)
MY (s) = exp sp + ,
2N
⇣ ⌘
which is the MGF of a Gaussian random variable Y ⇠ Gaussian p, p(1N p) .
Figure 6.21 shows several MGFs. In each of the subfigures we plot the exact MGF
s
MX N (s) = (1 p+pe N )N as a function of s. (The parameter p in this example is p = 0.5.) We
vary the number N , and we inspect how the shape of MX N (s) changes. On top of the exact
n 2
o
MGFs, we plot the Gaussian approximations MY (s) = exp sp + s p(1 2N
p)
. According to
our calculation, this Gaussian approximation is the second-order approximation to the exact
MGF. The figures show the e↵ect of the second-order approximation. For example, in (a)
when N = 2 the Gaussian is a quadratic approximation of the exact MGF. For (b) and (c),
as N increases, the approximation improves.

105 105 105


Binomial MGF Binomial MGF Binomial MGF
104 104 104
Gaussian MGF Gaussian MGF Gaussian MGF
103 103 103
102 102 102
101 101 101
100 100 100
10-1 10-1 10-1
10-2 10-2 10-2
-10 -5 0 5 10 -10 -5 0 5 10 -10 -5 0 5 10
(a) N = 2 (b) N = 4 (c) N = 10

Figure 6.21: Explanation of the Central Limit Theorem


P using the function. In this set of plots, we show
the MGF of the random variable X N = (1/N ) N n=1 Xn , where X1 , . . . , XN are i.i.d. Bernoulli random
variables. The exact MGF of X N is the binomial, whereas the approximated MGF is the Gaussian. We
observe that as N increases, the Gaussian approximation to the exact MGF improves.
The reason why the second-order approximation works for Gaussian is that when N
increases, the higher order moments of X N vanish and only the
n leading firstotwo moments
s2 p(1 p)
survive. The MGFs are becoming flat because MY (s) = exp sp + 2N converges to
exp{sp} when N ! 1. Taking the inverse Laplace transform, MY (s) = exp{sp} corresponds
to a delta function. This makes sense because as N grows, the variance of the X shrinks.

End of the discussion.

376
6.4. CENTRAL LIMIT THEOREM

6.4.3 Examples

Example 6.15. Prove the equivalence of a few statements.


p ⇣X µ⌘ d
N N
! Gaussian(0, 1)
p d
N (X N µ) ! Gaussian(0, 2 )
p d
N X N ! Gaussian(µ, 2 )

Solution. The proof is based on the linear transformation property of Gaussian ran-
dom variables. For example, if the first statement is true, then the second statement
is also true because
p
lim FpN (X N µ) (z) = lim P[ N (X N µ)  z]
N !1 N !1
 ✓ ◆
p XN µ z
= lim P N 
N !1
Z z/
1 t2
= p e 2 dt
1 2⇡
Z z
1 t2
= p e 2 2 dt.
1 2⇡ 2
The other results can be proved similarly.

Example 6.16. Suppose Xn ⇠ Poisson(10) for n = 1, . . . , N , and let X N be the


sample average. Use the Central Limit Theorem to approximate P[9  X N  11] for
N = 20.

Solution. We first show that


" N
# N
1 X 1 X
E[X N ] = E Xn = E [Xn ] = 10,
N n=1 N n=1
N
1 X 1 10 1
Var[X N ] = 2 Var [Xn ] = Var[Xn ] = = .
N n=1 N 20 2

d
Therefore, the Central Limit Theorem implies that X N ! Gaussian 10, 12 . The
probability is
! !
11 10 9 10
P[9  X N  11] ⇡ p p
1/2 1/2
✓ ◆ ✓ ◆
1 1
= p p = 0.9214 0.0786 = 0.8427.
0.5 0.5

377
CHAPTER 6. SAMPLE STATISTICS

PN We can also do anSexact calculation to verify our approximation. Let SN =


X
n=1 n so that X N = N
N . Since a sum of Poisson remains a Poisson, it follows that

SN ⇠ Poisson(10N ) = Poisson(200).

Consequently,

P[9  X N  11] = P[180  SN  220]


220
X 180
X
200` e 200
200` e 200
= = 0.9247 0.0822 = 0.8425.
`! `!
`=0 `=0

Note that this is an exact calculation subject to numerical errors when evaluating the
finite sums. The proximity to the Gaussian approximation shows the convenience of
the Central Limit Theorem.

Example 6.17. Suppose you have collected N = 100 data points from an unknown
distribution. The only thing you know is that the true population mean is µ = 500
and the standard deviation is = 80. (Note that this distribution is not necessarily a
Gaussian.)

(a) Find the probability that the sample mean will be inside the interval (490, 510).
(b) Find an interval such that 95% of the sample average is covered.

✓ ⇣ ⌘2 ◆
d
Solution. To solve (a), we note that X N ! Gaussian 500, p80
100
. Therefore,

! !
510 500 490 500
P[490  X N  510] =
p80 p80
100 100
= (1.25) ( 1.25) = 0.7888.

To solve (b), we know that (x) = 0.025 implies that x = 1.96, and (x) = 0.975
implies that x = +1.96. So
y 500
= ±1.96 ) y = 484.32 or y = 515.68.
p80
100

Therefore, P[484.32  X N  515.68] = 0.95.

6.4.4 Limitation of the Central Limit Theorem


If we recall the statement of the Central Limit Theorem (Berry-Esseen), we observe that
the theorem states only that
 ✓ ◆
p XN µ
lim P N  " = lim FZN (") = FZ (") = (").
N !1 N !1

378
6.4. CENTRAL LIMIT THEOREM

Rearranging the terms, 


"
lim P X N  µ + p = (").
N !1 N
This implies that the approximation is good only when the deviation " is small.
Let us consider an example to illustrate this idea. Consider a set of i.i.d. exponential
random variables X1 , . . . , XN , where Xn ⇠ Exponential( ). Let SN = X1 + · · · + XN be
the sum, and let X = SN /N be the sample average. Then, according to Chapter 6.4.1, SN
is an Erlang distribution SN ⇠ Erlang(N, ) with a PDF
N
fSN (x) = xN 1
e x
.
(N 1)!

Practice Exercise 6.10. Let SN ⇠ Erlang(N, ) with a PDF fSN (x). Show that if
YN = aSN + b for any constants a and b, then
✓ ◆
1 y b
fYN (y) = fSN .
a a

Solution: This is a simple transformation of random variables:


 Z y b
y b a
FYN (y) = P[Y  y] = P[aSN + b  y] = P SN  = fSN (x) dx.
a 1

Hence, using the fundamental theorem of calculus,


Z y b ✓ ◆
d a 1 y b
fYN (y) = fSN (x) dx = fSN .
dy 1 a a

We are interested in knowing the statistics of X N and comparing it with a Gaussian.


To this end, we construct a normalized variable

XN µ
ZN = p ,
/ N

where µ = E[Xn ] = 1
and 2
= Var[Xn ] = 1
2 . Then

SN /N µ SN N µ p
ZN = p = p = p SN N
/ N N N
p
Using the result of the practice exercise, by mapping a = p
N
and b = N , it follows that
p p !
N z+ N
fZN (z) = f SN .
p
N

Now we compare ZN with the standard Gaussian Z ⇠ Gaussian(0, 1). According to the
Central Limit Theorem, the standard Gaussian is a good approximation to the normalized

379
CHAPTER 6. SAMPLE STATISTICS

sample average ZN . To compare the two results, we conduct a numerical experiment. We


let = 1 and we vary N . We plot the PDF fZN (z) as a function of z, for di↵erent N ’s, in
Figure 6.22. In addition, we plot the PDF fZ (z), which is the standard Gaussian.
The plot in Figure 6.22 shows that while the Central Limit Theorem provides a good
approximation, the approximation is only good for values that are close to the mean. For
the tails, the Gaussian approximation is not as good.

100

10-2

N=1
-4 N = 10
10
N = 100
N = 1000
Gaussian
10-6
-1 0 1 2 3 4 5

Figure 6.22: CLT fails at the tails. We note that X1 , . . . , XN are i.i.d. exponential with a parameter
= 1. We plot the PDFs of the normalized sample average ZN = X/NpNµ by varying N . We plot the PDF
of the standard Gaussian Z ⇠ Gaussian(0, 1) on the same grid. Note that the Gaussian approximation
is good for values that are close to the mean. For the tails, the Gaussian approximation is not very
accurate.

The limitation of the Central Limit Theorem is attributable to the fact that Gaussian
is a second-order approximation. If a random variable has a very large third moment, the
second-order approximation may not be sufficient. In this case, we need a much larger N to
drive the third moment to a small value and make the Gaussian approximation valid.

When will the Central Limit Theorem fail?


The Central Limit Theorem fails when N is small.
The Central Limit Theorem fails if the third moment is large. As an extreme
case, a Cauchy random variable does not have a finite third moment. The Central
Limit Theorem is not valid for this case.
The Central Limit Theorem can only approximate the probability for input val-
ues near the mean. It does not approximate the tails, for which we need to use
Cherno↵’s bound.

6.5 Summary

Why do we need to study the sample average? Because it is the summary of the dataset. In
machine learning, one of the most frequently asked questions is about the number of training

380
6.6. REFERENCES

samples required to train a model. The answer can be found by analyzing the average number
of successes and failures as the number of training samples grows. For example, if we define
f as the classifier that takes a data point xn and predicts a label f (xn ), we hope that it
will match with the true label yn . If we define an error
(
1, f (xn ) = yn correct classification,
En =
0, f (xn ) 6= yn incorrect classification,
PN
then En is a Bernoulli random variable, and the total loss E = N1 n=1 En will be the
P N
training loss. But what is N1 n=1 En ? It is exactly the sample average of En . Therefore, by
analyzing the sample average E we will learn something about the generalization capability
of our model.

How should we study the sample average? By understanding the law of large numbers
and the Central Limit Theorem, as we have seen in this chapter.

Law of large numbers: X converges to the true mean µ as N grows.


Central Limit Theorem: The CDF of X can be approximated by the CDF of a
Gaussian, as N grows.

Performance guarantee? The other topic we discussed in this chapter is the concept
of convergence type. There are essentially four types of convergence, ranked in the order of
restrictions.

Deterministic convergence: A sequence of deterministic numbers converges to


another deterministic number. For example, the sequence 1, 12 , 13 , 14 , . . . converges
to 0 deterministically. There is nothing random about it.
Almost sure convergence: Randomness exists, and there is a probabilistic con-
vergence. Almost sure convergence means that there is zero probability of failure
after a finite number of failures.
Convergence in probability: The sequence of probability values converges, i.e.,
the chance of failure is going to zero. However, you can still fail even if your N
is large.
Convergence in distribution: The probability values can be approximated by
the CDF of a Gaussian.

6.6 References

Moment-Generating and Characteristic Functions


6-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 4.4.

381
CHAPTER 6. SAMPLE STATISTICS

6-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapters 4.5 and 4.7.
6-3 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapters 5.5 and 7.2.

6-4 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001. Chapters 4.5 and 4.7.
6-5 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
7.7.
6-6 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapter 4.3.

Basic probability inequality


6-7 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 5.1.
6-8 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapters 6 and 8.
6-9 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 7.4.

6-10 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
8.2.
6-11 Larry Wasserman, All of Statistics, Springer 2003. Chapter 4.

Concentration inequalities
6-12 Larry Wasserman, All of Statistics, Springer 2003. Chapter 4.
6-13 Martin Wainwright, High-Dimensional Statistics, Cambridge University Press, 2019.
Chapter 2.1.

6-14 Stephane Boucheron, Gabor Lugosi and Pascal Massart, Concentration Inequalities,
Oxford University Press, 2013. Chapters 2.1 and 2.2.

Law of large numbers


6-15 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapters 5.2, 5.3, 5.5.
6-16 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapters 7.1, 7.2, 7.4

6-17 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 7.4.

382
6.7. PROBLEMS

6-18 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
8.2, 8.4.
6-19 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 3.3, 14.1, 14.3.

6-20 Larry Wasserman, All of Statistics, Springer 2003. Chapter 5.1 - 5.3.
6-21 Patrick Billingsley, Probability and Measure, Wiley 1995. Section 22.

Central Limit Theorem


6-22 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 5.4.
6-23 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 7.3.

6-24 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 7.4.
6-25 Sheldon Ross, A First Course in Probability, Prentice Hall, 8th Edition, 2010. Chapter
8.3.
6-26 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, 2006. Chapters 5.6, 14.2.
6-27 Larry Wasserman, All of Statistics, Springer 2003. Chapter 5.4.
6-28 Patrick Billingsley, Probability and Measure, Wiley 1995. Section 27.

6.7 Problems

Exercise 1. (Video Solution)


Let X, Y , Z be three independent random variables:

X ⇠ Bernoulli(p), Y ⇠ Exponential(↵), Z ⇠ Poisson( )

Find the function for the following random variables.

(a) U = Y + Z
(b) U = 2Z + 3
(c) U = XY

(d) U = 2XY + (1 X)Z

383
CHAPTER 6. SAMPLE STATISTICS

Exercise 2. (Video Solution)


Two random variables X and Y have the joint PMF
n+m m
1 2 ( 1+ 2)
P(X = n, Y = m) = e , m = 0, 1, 2, . . . , n m.
(n + m)!m!
Let Z = X + Y . Find the function MZ (s) and the PMF of Z.

Exercise 3. (Video Solution)


Let X0 , X1 , . . . be a sequence of independent random variables with PDF
ak 1
fXk (x) = , ak = ,
⇡(a2k + x2 ) 2k+1
for k = 0, 1, . . .. Find the PDF of Y , where
1
X
Y = Xk .
k=0

Hint: You may find the characteristic function useful.

Exercise 4.
The random variables X and Y are independent and have PDFs
( (
e x, x 0, 0, y > 0,
fX (x) = and fY (y) =
0, x < 0, et , y  0.

Find the PDF of Z = X + Y . (Hint: Use the characteristic function and the moment-
generating function.)

Exercise 5.
A discrete random variable X has a PMF
1
pX (k) = k , k = 1, 2, . . . .
2
Find the characteristic function X (j!).

Exercise 6.
Let T1 , T2 , . . . be i.i.d. random variables with PDF
(
e t, t 0,
fTk (t) =
0, t < 0,
Pn
for k = 1, 2, 3, . . .. Let Sn = k=1 Tk . Find the PDF of Sn .

Exercise 7. (Video Solution)


2
In this exercise we will prove a variant of Chebyshev when the variance is unknown but
X is bounded between a  X  b.

384
6.7. PROBLEMS

(a) Let 2 R. Find a that minimizes E[(X )2 ]. Hence, show that E[(X )2 ] Var[X]
for any .
(b) Let = (a + b)/2. Show that

(b a)2
E[(X )2 ] = E[(X a)(X b)] + .
4

(b a)2
(c) From (a) and (b), show that Var[X]  4 .

(d) Show that for any " > 0,


(b a)2
P[|X µ| > "]  .
4"2

Exercise 8.
The random variables X and Y are independent with PDFs
1 1
fX (x) = and fY (y) = ,
⇡(1 + x2 ) ⇡(1 + y 2 )

respectively. Find the PDF of Z = X Y . (Hint: Use the characteristic function.)

Exercise 9.
A random variable X has the characteristic function
j!/(1 j!)
X (j!) =e .

Find the mean and variance of X.

Exercise 10.
Show that for any random variables X and Y ,
1
P[|X Y | > ✏]  E[(X Y )2 ].
✏2

Exercise 11.
Let X be an exponential random variable with a parameter . Let µ = E[X] and 2 =
Var[X]. Compute P[|X µ| k ] for any k > 1. Compare this to the bound obtained by
Chebyshev’s inequality.

Exercise 12.
Let X1 , . . . , XN be i.i.d. Bernoulli with a parameter p. Let ↵ > 0 and define
s ✓ ◆
1 2
✏= log .
2N ↵

385
CHAPTER 6. SAMPLE STATISTICS

1
PN
Let X N = N n=1 Xn . Define an interval
⇥ ⇤
I = XN ✏, X N + ✏ .

Use Hoe↵ding’s inequality to show that

P[I contains p] 1 ↵.

Exercise 13.
Let Z ⇠ Gaussian(0, 1). Prove that for any ✏ > 0,
r ✏2
2e 2
P[|Z| > ✏]  .
⇡ ✏
Hint: Note that ✏P[|Z| > ✏] = 2✏P[Z > ✏], and then follow the procedure we used to prove
Markov’s inequality.

Exercise 14.
(a) Give a non-negative random variable X 0 such that Markov’s inequality is met with
equality. Hint: Consider a discrete random variable.
(b) Give a random variable X such that Chebyshev’s inequality is met with equality.

Exercise 15.
Consider a random variable X such that
s2 2
E[esX ]  e 2 .

(a) Show that for any t, ⇢


t2
P[X t]  exp .
2 2
Hint: Use Cherno↵’s bound.
(b) Show that
E[X 2 ]  4 2
.
R1
Hint: First prove that E[X ] = 2
0
P[X 2
t] dt. Then use part (a) above.

Exercise 16.
Let X1 , . . . , XN be i.i.d. uniform random variables distributed over [0, 1]. Suppose Y1 , . . . , YN
are defined as follows.
(a) Yn = Xn /n
(b) Yn = (Xn )n
(c) Yn = max(X1 , . . . , Xn )

386
6.7. PROBLEMS

(d) Yn = min(X1 , . . . , Xn )
For (a), (b), (c), and (d), show that Yn converges in probability to some limit. Identify the
limit in each case.

Exercise 17.
Let n = n1 for n = 1, 2, . . .. Let Xn ⇠ Poisson( n ). Show that Xn converges in probability
to 0.

Exercise 18.
Let Y1 , Y2 , . . . be a sequence of random variables such that
(
1
0, with probability 1 n,
Yn = n
2 , with probability n1 .

Does Yn converge in probability to 0?

Exercise 19. (Video Solution)


A Laplace random variable has a PDF

|x|
fX (x) = e , > 0,
2
2
and the variance is Var[X] = 2 . Let X1 , . . . , X500 be a sequence of i.i.d. Laplace random
variables. Let
X1 + · · · + X500
M500 = .
500
(a) Find E[X]. Express your answer in terms of .
(b) Let = 10. Using Chebyshev’s inequality, find a lower bound of

P[ 0.1  M500  0.1].

(c) Let = 10. Using the Central Limit Theorem, find the probability

P [ 0.1  M500  0.1] .

You may leave your answer in terms of the (·) function.

Exercise 20. (Video Solution)


Let X1 , . . . , Xn be a sequence of i.i.d. random variables such that Xi = ±1 with equal
probability. Let
n
1 X
Yn = p Xi .
n i=1
Prove the Central Limit Theorem for this particular sequence of random variables by showing
that

387
CHAPTER 6. SAMPLE STATISTICS

(a) E[Yn ] = 0, Var[Yn ] = 1.


s2
(b) The function of Yn is MYn (s) ! e 2 as n ! 1.

Exercise 21. (Video Solution)


Let X1 , . . . , XN be a sequence of i.i.d. random variables with mean and variance
2
E[Xn ] = µ and Var[Xn ] = , n = 1, . . . , N.

The distribution of Xn is, unknown. Let


N
1 X
MN = Xn .
N n=1

Use the Central Limit Theorem to estimate the probability P[MN > 2µ].

388
Chapter 7

Regression

Starting with this chapter, we will discuss several combat skills — techniques that we use
to do the actual data analysis. The theme of this topic is learning and inference, which are
both at the core of modern data science. The word “learning” can be broadly interpreted
as seeking the best model to explain the data, and the word “inference” refers to prediction
and recovery. Here, prediction means that we use the observed data to forecast or generalize
to unseen situations, whereas recovery means that we try to restore the missing data in our
current observations. In this chapter we will learn regression, one of the most widely used
learning and inference techniques.
Regression is a process for finding the relationship between the inputs and the outputs.
In a regression problem, we consider a set of input data {x1 , . . . , xN } and a set of output
def
data {y1 , . . . , yN }. We call the set of these input-output pairs D = {(x1 , y1 ), . . . , (xN , yN )}
the training data. The true relationship between an xn and a yn is unknown. We do not
know, you do not know, only God knows. We denote this unknown relationship as a mapping
f (·) that takes xn and maps it to yn ,
yn = f (xn ),
as illustrated in Figure 7.1.

Figure 7.1: A regression problem is about finding the best approximation to the input-output relationship
of the data.

Since we do not know f (·), finding it from a set of finite number of data points D =
{(x1 , y1 ), . . . , (xN , yN )} is infeasible — there are infinitely many ways we can make yn =
f (xn ) for every n = 1, . . . , N . The idea of regression is to add a structure to the problem.
Instead of looking for f (·), we find a proxy g✓ (·). This proxy g✓ (·) takes a certain parametric
form. For example, we can postulate that (xn , yn ) has a linear relationship, and so
g✓ (xn ) = ✓1 xn + ✓0 , n = 1, . . . , N.
|{z} |{z}
parameter parameter

389
CHAPTER 7. REGRESSION

This equation is a straight line with a slope ✓1 and a y-intercept ✓0 . We call ✓ = [✓1 , ✓0 ]
the parameter of the model f (·). To emphasize that the function we are using here is
parameterized by ✓, we denote the function by g✓ (·).
Of course, any model we choose is our guess. It will never be the true model. There is
always a di↵erence between what our model tells us and what we have observed. We denote
this “di↵erence” or “error” by en and define it as:

e n = yn g✓ (xn ), n = 1, . . . , N.

The purpose of regression is to find the best ✓ such that the error is minimized. For example,
consider a minimization of the sum-square error:
N
X
✓b = argmin
2
(yn g✓ (xn )) .
✓2Rd n=1
| {z }
training loss Etrain (✓)

The sum of the squared error is just one of the many possible ways we can define the training
loss Etrain (✓). We will discuss di↵erent ways to define the training loss in this chapter, but the
point should be evident. For a given dataset D = {(x1 , y1 ), . . . , (xN , yN )}, regression tries
to find a function g✓ (·) such that the training loss is minimized. The optimization variable
is the parameter ✓. If the function g✓ (·) is a linear function in ✓, we call the regression a
linear regression.

Figure 7.2: A regression problem involves several steps: picking a model g✓ , defining the training loss
Etrain (✓), and solving the optimization to update ✓.

A summary of the regression process is shown in Figure 7.2. Given the training data
D = {(x1 , y1 ), . . . , (xN , yN )}, the user picks a model g✓ (·) to make a prediction. We com-
pare the predicted value g✓ (xn ) with the observed value yn , and compute the training loss
Etrain (✓). The training loss Etrain (✓) is a function of the model parameter ✓. Di↵erent model
parameters ✓ give di↵erent training loss. We solve an optimization problem to find the best
model parameter. In practice, we often iterate the process for a few times until the training
loss is settled down.

390
What is regression?
Given the data points (x1 , y1 ), . . . , (xN , yN ), regression is the process of finding
the parameter ✓ of a function g✓ (·) such that the training loss is minimized:
N
X
✓b = argmin L (yn , g✓ (xn )), (7.1)
✓2Rd n=1
| {z }
training loss Etrain (✓)

where L(·, ·) is the loss between a pair of true observation yn and the prediction g✓ (xn ).
One common choice of L(·, ·) is L(g✓ (xn ), yn ) = (g✓ (xn ) yn )2 .

Example 1. Fitting the data


Suppose we have a set of data points (x1 , y1 ), (x2 , y2 ), . . . , (xN , yN ), where xn ’s are the
inputs and yn ’s are the outputs. These pairs of data points can be plotted in a scatter plot,
as shown in Figure 7.3. We want to find the curve that best fits the data.
To solve this problem, we first need to choose a model, for example
g✓ (xn ) = ✓0 + ✓1 xn + ✓2 x2n + ✓3 x3n + ✓4 x4n .
We call the coefficients ✓ = [✓0 , ✓1 , ✓2 , ✓3 , ✓4 ] the regression coefficients. They can be found
by solving the optimization problem
XN ✓ ◆2
minimize yn (✓0 + ✓1 xn + ✓2 x2n + ✓3 x3n + ✓4 x4n ) .
✓0 ,✓1 ,✓2 ,✓3 ,✓4
n=1

-1

-2 data
fitted curve
-3
-1 -0.5 0 0.5 1

Figure 7.3: Regression canPbe used to fit the dataset using curves. In this example, we use a fourth-th
order polynomial g✓ (x) = 4p=0 ✓p xpn to fit a 50-point dataset.

This optimization asks for the best ✓ = [✓0 , . . . , ✓4 ]T such that the training loss is
minimized. Solving the minimization problem would require some e↵ort, P4but if we imagine
that we have solved it we can find the best curve, which is g✓ (x) = p=0 ✓p xpn with the
optimal ✓ plugged in. The red curve in Figure 7.3 shows an example in which we have used
a fourth-order polynomial to fit a dataset comprising 50 data points. We will learn how to
solve the problem in this chapter.

391
CHAPTER 7. REGRESSION

Example 2. Predicting the stock market


Imagine that you have bought some shares in the stock market. You have looked at the past
data, and you want to predict the price of the shares over the next few days. How would
you do it besides just eyeballing the data?
First, you would plot the data points on a graph. Mathematically, we can denote these
data points as {x1 , x2 , . . . , xN }, where the indices n = 1, 2, . . . , N can be treated as time
stamps. We assume a simple model to describe the relationship between the xn ’s, say

xn ⇡ axn 1 + bxn 2,

for some parameters ✓ = (a, b).1 This model assumes that the current value xn can be
approximated by a linear combination of two previous values xn 1 and xn 2 . Therefore, if
we have x1 and x2 we should be able to predict x3 , and if we have x2 and x3 we should be
able to predict x4 , etc. The magic of this prediction comes from the parameters a and b. If
we know a and b, the prediction can be done by simply plugging in the numbers.
The regression problem here is to estimate the parameters a and b from the data. Since
we are given a set of training data {x1 , x2 , . . . , xN }, we can check whether our predicted
b3 is close to the true x3 , and whether our predicted value x
value x b4 is close to the true x4 ,
etc. This leads to the optimization
N ✓
X ◆2
a, bb) = argmin
(b xn (axn 1 + bxn 2 ) ,
a,b n=1
| {z }
=prediction

where we use initial conditions that x0 = x 1 = 0. The optimization problem requires us


to minimize the disparity between xn and the predicted value axn 1 + bxn 2 , for all n.
By finding the (a, b) that minimizes this objective function, we will accomplish our goal of
estimating the best (a, b).
Figure 7.4 shows an example of predicting a random process using the above model.
If the parameters a and b are properly determined, we will obtain a reasonably well-fitted
curve to the data. A simple extrapolation to the future timestamp would suffice for the
forecast task.

Plan for this chapter

What are the key ingredients of regression?


Learning: Formulate the regression problem as an optimization problem, and
solve it by finding the best parameters.
Inference: Use the estimated parameters and models to predict the unseen data
points.

Regression is too broad a topic to be covered adequately in a single chapter. Accord-


ingly, we will present a few principles and a few practical algorithmic techniques that are
broadly applicable to many (definitely not all) regression tasks. These include the following.
1 Caution: If you lose money in the stock market by following this naive model, please do not cry. This

model is greatly oversimplified and probably wrong.

392
1.5

0.5

-0.5 data
best fit
candidate
-1
0 0.2 0.4 0.6 0.8 1

Figure 7.4: An autoregression model aims at learning the model parameters based on the previous
samples. This example illustrates fitting the data using the model xn = axn 1 +bxn 2 , for n = 1, . . . , N .

The principle of regression (Section 7.1). We explain the formulation of a regression


problem via optimization. There are a few steps involved in developing this concept.
First, we will exclusively focus on linear models because these models are easier to
analyze than nonlinear models but are still rich enough for many practical problems.
We will discuss how to solve the linear regression problem and some applications of
the solutions. We then address the issue of outliers using a concept called the robust
linear regression.
Overfitting (Section 7.2). The biggest practical challenge of regression is overfitting.
Overfitting occurs when a model fits too closely to the training samples so that it
fails to generalize. We will delve deeply into the roots of overfitting and show that
overfitting depends on three factors: the number of training samples N , the model
complexity d, and the magnitude of noise 2 .
Bias-variance trade-o↵ (Section 7.3). We will present one of the most fundamental
results in learning theory, known as the bias-variance trade-o↵. It applies to all regres-
sion problems, not just to linear models. Understanding this trade-o↵ will help you
understand the fundamental limits of your problem so that you know what to expect
from the model.
Regularization (Section 7.4). In this section we discuss a technique for combatting
overfitting known as regularization. Regularization is carried out by adding an extra
term to the regression objective function. By solving the modified optimization, the
regression solution is improved in two ways: (i) regularization makes the regression
solution less sensitive to noise perturbations, and (ii) it alleviates the fitting difficulty
when we have only a few training samples. We will discuss two regularization strategies:
the ridge regression and the LASSO regression.
Much of this chapter deals with optimization. If this is your first time reading this
book, we encourage you to have a reference book on linear algebra at hand.

393
CHAPTER 7. REGRESSION

7.1 Principles of Regression

We start by recalling our discussion in the introduction. The purpose of regression can be
summarized in a simple statement:

Given the data points (x1 , y1 ), . . . , (xN , yN ), find the parameter ✓ of a function g✓ (·)
such that the training loss is minimized:
N
X
✓b = argmin L (yn , g✓ (xn )), (7.2)
✓2Rd n=1
| {z }
training loss Etrain (✓)

where L(·, ·) is the loss between a pair of true observation yn and the prediction g✓ (xn ).

When the context makes it clear, we will drop the subscript ✓ in g✓ (·) with the understanding
that the function g(·) is parameterized by ✓.
As you can see, regression finds a function g(·) that best approximates the input-output
relationship between xn and yn . There are two choices we need to make when formulating
a regression problem:
Function g(·): What is the family of functions we want to use? This could be a line, a
polynomial, or a set of basis functions. If it is a polynomial, what is its order? We need
to make all these decisions before running the regression. A poor choice of function
family can lead to a poor regression result.
Loss “L(·, ·)”: How do we measure the closeness between yn and g(xn )? Are we measur-
ing in terms of the squared error (yn g(xn ))2 , or the absolute di↵erence |yn g(xn )|,
or something else? Again, a poor choice of distance function can create a false sense
of closeness because you might be optimizing for a wrong objective.
Before we delve into the details, we need to discuss briefly the connection between
regression and probability. A regression problem can be solved without knowing probability,
so why is regression discussed in a book on probability?
This question is related to how much we know about the statistical model and what
kind of optimality we are seeking. A full answer requires some understanding of maximum
likelihood estimation and maximum a posteriori estimation, which will be explained in
Chapter 8. As a quick preview of our results, we summarize the key ideas below:

How is regression related to probability?


If you know the statistical relationship between xn and yn , then we can construct
a regression problem that maximizes the likelihood of the underlying distribu-
tion. Such regression solution is optimal with respect to the likelihood.
We can construct a regression problem that can minimize the expectation of the

394
7.1. PRINCIPLES OF REGRESSION

squared error. This regression solution is mean-squared optimal.


If you are a Bayesian and you know the prior distribution of xn , then we can
construct a regression problem that maximizes the posterior distribution. The
solution to this regression problem is Bayesian optimal.
If you know nothing about the statistics of xn and yn , you can still run the
regression and get something, and this “something” can be very useful. However,
you cannot claim statistical optimality of this “something”.
See Chapter 8 for additional discussion.

It is important to understand that a regression problem is at the intersection of op-


timization and statistics. The need for optimization is clear because we need to minimize
the error. The statistical need is to generalize to unknown data. If there is no statistical
relationship between xn and yn (for all n), whatever model we obtain from the regression
will only work for the N training samples. The model will not generalize because knowing
xn will not help us know yn . In other words, if there is no statistical relationship between
xn and yn , you can fit perfectly to the training data but you will fail miserably to fit the
testing data.

7.1.1 Intuition: How to fit a straight line?


In this subsection we want to give you the basic idea of how regression is formulated. To
keep things simple, we will discuss how to fit data using a straight line.
Consider a collection of data points D = {(x1 , y1 ), . . . , (xN , yN )}, where xn ’s are the
inputs and yn ’s are the observations, for example, in the table below.

n xn yn
1 0.6700 3.0237
2 0.3474 2.3937
3 0.6695 3.5548
.. .. ..
. . .
N 1 0.2953 2.6396
N 0.6804 3.2536

Let us consider the linear regression problem. The goal of linear regression is to find
the straight line that best fits the datasets. All straight lines on a 2D graph are plots of the
equation
g(x) = ax + b,
where a is the slope of the line and b is the y-intercept of the line. We denote this line
by g(·). Note that this function g is characterized by two parameters (a, b) because once
(a, b) are known the line is determined. If we change (a, b), the line will change as well.
Therefore, by finding the best line we are essentially searching for the best (a, b) such that
the training error is minimized.
The pictorial meaning of linear regression can easily be seen in Figure 7.5, which
shows N = 50 data points according to some latent distributions. Given these 50 data
points, we construct several possible candidates for the regression model. These candidates

395
CHAPTER 7. REGRESSION

are characterized by the parameters (a, b). For example, the parameters (a, b) = (1, 2) and
(a, b) = ( 2, 3) represent two di↵erent straight lines in the candidate pool. The goal of the
regression is to find the best line from these candidates. Note that since we limit ourselves
to straight lines, the candidate set will not include polynomials or trigonometric functions.
These functions are outside the family we are considering.
4.5

3.5

2.5

data
2 best fit
candidate
1.5
0 0.2 0.4 0.6 0.8 1

Figure 7.5: The objective of least squares fitting (or linear regression) is to find a line that best fits the
dataset.

Given these candidate functions, we need to measure the the training loss. This can
be defined in multiple ways, such as
PN
Sum-squared loss Etrain (✓) = n=1 (yn g(xn ))2 .
PN
Sum-absolute loss Etrain (✓) = n=1 |yn g(xn )|.
PN
Cross-entropy loss Etrain (✓) = n=1 (yn log g(xn ) + (1 yn ) log(1 g(xn ))).
PN
Perceptual loss Etrain (✓) = n=1 max( yn g(xn ), 0), when yn and g(xn ) are binary
taking values ±1. This is a reasonable training error because if yn matches with g(xn ),
then yn g(xn ) = 1 and so max( yn g(xn ), 0) = 0. But if yn does not match with g(xn ),
then yn g(xn ) = 1 and hence max( yn g(xn ), 0) = 1. Thus, the loss captures the sum
of all the mismatched pairs.
Choosing the loss function is problem-specific. It is also where probability enters the picture
because, without any knowledge about the distributions of xn and yn , there is no way to
choose the best training loss. You can still pick one, as we will do, but it will not be granted
any probabilistic guarantees.
Among these possible choices of the training error, we are going to focus on the sum-
squared loss because it is convex and di↵erentiable. This makes the computation easy,
since we can run any textbook optimization algorithm. The regression problem under the
sum-squared loss is:
⇣ ⌘ XN ✓ ◆2
a, bb = argmin
b yn (axn + b) . (7.3)
(a,b) n=1
| {z }
=g(xn )

In this equation, the symbol “argmin” means “argument minimize”, which returns the ar-
gument that minimizes the cost function on the right. The interpretation of the equation is

396
7.1. PRINCIPLES OF REGRESSION

PN
that we seek the (a, b) that minimize the sum n=1 (yn (axn + b))2 . Since we are mini-
mizing the squared error, this linear regression problem is also known as the least squares
fitting problem. The idea is summarized in the following box.

What is linear least squares fitting?


Find a line g(x) = ax + b that best fits the training data {(xn , yn )}N
n=1 .
The optimality criterion is to minimize the squared error
N ✓
X ◆2
Etrain (✓) = yn g(xn ) , (7.4)
n=1

where ✓ = (a, b) is the model parameter.


There exist other optimality criteria. Squared error is convex and di↵erentiable.

7.1.2 Solving the linear regression problem


Let’s consider how to solve the linear regression problem given by Equation (7.3). The
problem is the following: ⇣ ⌘
a, bb = argmin Etrain (a, b).
b (7.5)
(a,b)

a, bb) should
As with any two-dimensional optimization problem, the optimal point (b
have a zero gradient, meaning that
@ @
Etrain (a, b) = 0 and Etrain (a, b) = 0.
@a @b
This should be familiar to you, even if you have only learned basic calculus. This pair of
equations says that, at a minimum point, the directional slopes should be zero no matter
which direction you are looking at.
The derivative with respect to a is
@
Etrain (a, b)
@a
⇢ N ✓ ◆2
@ X
= yn (axn + b)
@a n=1
⇢✓ ◆2 ✓ ◆2 ✓ ◆2
@
= y1 (ax1 + b) + y2 (ax2 + b) + · · · + yN (axN + b)
@a
✓ ◆ ✓ ◆
= 2 y1 (ax1 + b) ( x1 ) + · · · + 2 yN (axN + b) ( xN )
N N N
!
X X X
2
=2 x n yn + a xn + b xn .
n=1 n=1 n=1

397
CHAPTER 7. REGRESSION

Similarly, the derivative with respect to b is


⇢ N ✓ ◆2
@ @ X
Etrain (a, b) = yn (axn + b)
@b @b n=1
✓ ◆ ✓ ◆
= 2 y1 (ax1 + b) ( 1) + · · · + 2 yN (axN + b) ( 1)
N N N
!
X X X
=2 yn + a xn + b 1 .
n=1 n=1 n=1

Setting these two equations to zero, we have that


N N N
!
X X X
2 yn x n + a x2n +b xn = 0,
n=1 n=1 n=1
N N N
!
X X X
2 yn + a xn + b 1 = 0.
n=1 n=1 n=1

Rearranging the terms, the pair can be equivalently written as


2N 3 2N 3
P 2 P N P
x x  x y
6n=1 n n=1 n 7 a 6n=1 n n 7
6 7 6 7.
4P N 5 b =4 P N 5
xn N yn
n=1 n=1

Therefore, if we can solve this system of linear equations, we will have the linear regression
solution.
Remark. It is easy to see that the solution achieves the minimum instead of the maximum,
since the second-order derivatives are positive:

XN XN
@2 @2
E train (a, b) = x2n 0 and E train (a, b) = 1 > 0.
@a2 n=1
@b2 n=1

The following theorem summarizes this intermediate result.

Theorem 7.1. The solution of the problem Equation (7.5)

⇣ ⌘ N ✓
X ◆2
b b
a, b = argmin yn (axn + b)
(a,b) n=1

satisfies the equation


2 3 2N 3
P
N P
N P
x2n xn 7  x n yn 7
6 6
6n=1 n=1 7 b a
= 6n=1 7. (7.6)
4PN 5 bb 4 PN 5
xn N yn
n=1 n=1

398
7.1. PRINCIPLES OF REGRESSION

Matrix-vector form of linear regression


Solving this linear regression requires some basic linear algebra. The regression can be
written as 2 3 2 3 2 3
y1 x1 1  e1
6 .. 7 6 .. . 7 a 6 7
4 . 5 = 4 . .. 5 + 4 ... 5 .
b
yN xN 1 | {z } eN
| {z } | {z } ✓ | {z }
y X e

With X, y, ✓ and e, we can write the linear regression problem compactly as

y = X✓ + e.

Therefore, the training loss Etrain (✓) can be defined as

Etrain (✓) = ky X✓k2


2 3 2 3 2
y1 x1 1  N ✓ ◆2
6 .. 7 6 .. .. 7 a X
= 4 . 5 4 . .5 b = yn (axn + b) .
n=1
yN xN 1

Now, taking the gradient with respect to ✓ yields2



r✓ Etrain (✓) = r✓ ky X✓k2

= 2X T (y X✓).

Equating this to zero, we obtain

X T (y X✓) = 0 () X T X✓ = X T y. (7.7)

Equation (7.7) is called the normal equation.


The normal equation is a convenient way of constructing the system of linear equations.
Using the 2-by-2 system shown in Equation (7.6) as an example, we note that
2 3 2P N PN
3
 x1 1 x 2
x
.. 7 = 6 n n7
x · · · xN 6 . 6n=1 7,
XT X = 1 4 .. . 5 4
n=1
5
1 ··· 1 P
N
xN 1 xn N
n=1
2 3 2 3
y1 P
N
 x n yn 7
x1 ··· xN 6 .. 7 6
XT y =
1 ··· 1 4 . 5=6 n=1
4 P N
7.
5
yN yn
n=1

Therefore, as long as you can construct the X matrix, forming the 2-by-2 system in Equa-
tion (7.6) is straightforward: start with y = X✓ and then multiply the matrix transpose
X T to both sides. The resulting system is what you need. There is nothing to memorize.
2 This is a basic vector calculus result. For details, you may consult standard texts such as the University

of Waterloo’s matrix cookbook. https://www.math.uwaterloo.ca/~hwolkowi/matrixcookbook.pdf

399
CHAPTER 7. REGRESSION

Running linear regression on a computer


On a computer, solving the linear regression for a line is straightforward. Let us look at the
MATLAB code first.
% MATLAB code to fit data points using a straight line
N = 50;
x = rand(N,1)*1;
a = 2.5; % true parameter
b = 1.3; % true parameter
y = a*x + b + 0.2*rand(size(x)); % Synthesize training data

X = [x(:) ones(N,1)]; % construct the X matrix


theta = X\y(:); % solve y = X theta

t = linspace(0, 1, 200); % interpolate and plot


yhat = theta(1)*t + theta(2);
plot(x,y,’o’,’LineWidth’,2); hold on;
plot(t,yhat,’r’,’LineWidth’,4);

In this piece of MATLAB code, we need to define the data matrix X. Here, x(:) is the
column vector that stores all the values (x1 , . . . , xN ). The all-one vector ones(N,1) is the
second column in our X matrix. The command X\y(:) is equivalent to solving the normal
equation
X T X✓ = X T y.
The last few lines are used to plot the predicted curve. Note that theta(1) and theta(2)
are the entries of the solution ✓. The result of this program is exactly the plot shown in
Figure 7.5 above.
In Python, the program is quite similar. The command we use to solve the inversion
is np.linalg.lstsq.

# Python code to fit data points using a straight line


import numpy as np
import matplotlib.pyplot as plt

N = 50
x = np.random.rand(N)
a = 2.5 # true parameter
b = 1.3 # true parameter
y = a*x + b + 0.2*np.random.randn(N) # Synthesize training data

X = np.column_stack((x, np.ones(N))) # construct the X matrix


theta = np.linalg.lstsq(X, y, rcond=None)[0] # solve y = X theta

t = np.linspace(0,1,200) # interpolate and plot


yhat = theta[0]*t + theta[1]
plt.plot(x,y,’o’)
plt.plot(t,yhat,’r’,linewidth=4)

400
7.1. PRINCIPLES OF REGRESSION

7.1.3 Extension: Beyond a straight line


Regression is a powerful technique. Although we have discussed its usefulness for fitting
straight lines, the same concept can fit other curves.
To generalize the regression formulation, we consider a d-dimensional regression coef-
ficient vector ✓ = [✓0 , . . . , ✓d 1 ]T 2 Rd and a general linear model
d 1
X
g✓ (xn ) = ✓p p (xn ).
p=0

Here, the mappings { p (·)}dp=01 can be considered as a nonlinear transformation that takes
the input xn and maps it to another value. For example, p (·) = (·)p will map an input x
to a pth power xp .
We can now write the system of linear equations as
2 3 2 32 3 2 3
y1 0 (x1 ) 1 (x1 ) ··· d 1 (x1 ) ✓0 e1
6 y2 7 6 0 (x2 ) 1 (x2 ) ··· 76 7 6 e2 7
d 1 (x2 ) 76 ✓1 7
6 7 6 6 7
6 .. 7 = 6 .. .. .. 76 .. 7 + 6 .. 7. (7.8)
4 . 5 4 . ··· . . 54 . 5 4 . 5
yN 0 (xN ) 1 (xN ) ··· d 1 (xN ) ✓d 1 eN
| {z } | {z }| {z } | {z }
y X ✓ e

Let us look at some examples.

Example 7.1. (Quadratic fitting) Consider the linear regression problem using a
quadratic equation:

yn = ax2n + bxn + c, n = 1, . . . , N.

Express this equation in matrix-vector form.

Solution. The matrix-vector expression is


2 3 2 2 3 2 3
y1 x1 x1 1 2 3 e1
6 y2 7 6 x22 x2 17 a 6 e2 7
6 7 6 7 6 7
6 .. 7 = 6 .. .. .. 7 4 b 5 + 6 .. 7 .
4 . 5 4 . . . 5 c 4 . 5
yN x2N xN 1 eN

This is again in the form of y = X✓ + e.

The MATLAB and Python programs for Example 7.1 are shown below. A numerical
example is illustrated in Figure 7.6.
% MATLAB code to fit data using a quadratic equation
N = 50;
x = rand(N,1)*1;
a = -2.5;
b = 1.3;
c = 1.2;

401
CHAPTER 7. REGRESSION

2.5

1.5

0.5
data
fitted curve
0
0 0.2 0.4 0.6 0.8 1

Figure 7.6: Example: Our goal is to fit the dataset of 50 data points shown above. The model we use
is g✓ (xn ) = ax2n + bxn + c, for n = 1, . . . , N .

y = a*x.^2 + b*x + c + 1*rand(size(x));

N = length(x);
X = [ones(N,1) x(:) x(:).^2];
beta = X\y(:);
t = linspace(0, 1, 200);
yhat = theta(3)*t.^2 + theta(2)*t + theta(1);
plot(x,y, ’o’,’LineWidth’,2); hold on;
plot(t,yhat,’r’,’LineWidth’,6);

# Python code to fit data using a quadratic equation


import numpy as np
import matplotlib.pyplot as plt

N = 50
x = np.random.rand(N)
a = -2.5
b = 1.3
c = 1.2
y = a*x**2 + b*x + c + 0.2*np.random.randn(N)

X = np.column_stack((np.ones(N), x, x**2))
theta = np.linalg.lstsq(X, y, rcond=None)[0]
t = np.linspace(0,1,200)
yhat = theta[0] + theta[1]*t + theta[2]*t**2
plt.plot(x,y,’o’)
plt.plot(t,yhat,’r’,linewidth=4)

The generalization to polynomials of arbitrary order is to replace the model with


d 1
X
g✓ (xn ) = ✓p xp ,
p=0

402
7.1. PRINCIPLES OF REGRESSION

where p = 0, 1, . . . , d 1 represent the orders of the polynomials and ✓0 , . . . , ✓d 1 are the


regression coefficients. In this case, the matrix system is
2 3 2 32 3 2 3
y1 1 x1 · · · xd1 1 ✓0 e1
6 y2 7 6 1 x 2 · · · x d 1 7 6 ✓ 1 7 6 e 2 7
6 7 6 2 76 7 6 7
6 .. 7 = 6 . .. .. 7 6 .. 7 + 6 .. 7 ,
4 . 5 4 .. · · · . . 5 4 . 5 4 . 5
yN 1 xN ··· xdN 1 ✓d 1 eN
which again is in the form of y = X✓ + e.

Example 7.2. (Legendre polynomial fitting) Let {Lp (·)}dp=01 be a set of Legendre
polynomials (see discussions below), and consider the linear regression problem using
d 1
X
yn = ✓p Lp (x), n = 1, . . . , N.
p=0

Express this equation in matrix-vector form.

Solution. The matrix-vector expression is


2 3 2 32 3 2 3
y1 L0 (x1 ) L1 (x1 ) · · · Ld 1 (x1 ) ✓0 e1
6 y2 7 6 L0 (x2 ) L1 (x2 ) · · · Ld 76
1 (x2 ) 7 6 ✓1 7 6 e2 7
6 7 6 7 6 7
6 .. 7 = 6 .. .. .. 76 .. 7 + 6 .. 7 .
4 . 5 4 . ··· . . 54 . 5 4 . 5
yN L0 (xN ) L1 (xN ) · · · Ld 1 (xN ) ✓d 1 eN

Legendre polynomials are orthogonal polynomials. In conventional polynomials, the


functions {x, x2 , x3 , . . . , xp } are not orthogonal. As we increase p, the set of functions
{x, x2 , x3 , . . . , xp } will have redundancy, which will eventually result in the matrix X being
noninvertible.
The pth-order Legendre polynomial is denoted by Lp (x). Using the Legendre polyno-
mials as the building block of the regression problem, the model is expressed as
d 1
X
def
g✓ (x) = ✓p Lp (x)
p=0

= ✓0 L0 (x) + ✓1 L1 (x) + ✓2 L2 (x) + · · · + ✓d 1 Ld 1 (x),


| {z } | {z }
=x = 12 (3x2 1)

where L0 (·), L1 (·) and L2 (·) are the Legendre polynomials of order 0, 1 and 2, respectively.
As an example, the first few leading Legendre polynomials are
L0 (x) = 1,
L1 (x) = x,
1
L2 (x) = (3x2 1),
2
1
L3 (x) = (5x3 3x).
2

403
CHAPTER 7. REGRESSION

The order of the Legendre polynomials is always the same as that of the ordinary polyno-
mials. The shapes of these polynomials are shown in Figure 7.7(a).
4
1
data
3 Legendre basis
Polynomial basis
0.5
2

0 1
L 0 (x)
L 1 (x) 0
L 2 (x)
-0.5
L 3 (x) -1
L 4 (x)
-1 -2
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) (b)

Figure 7.7: (a) The first 5 leading Legendre polynomials plotted in the range of 1  x  1. (b) Fitting
the data using an ordinary polynomial and a Legendre polynomial.

Figure 7.7(b) demonstrates a fitting problem using the Legendre polynomials. You
can see that the fitting is just as good as that of the ordinary polynomials (which should
be the case). However, if we compare the coefficients, we observe that the magnitude of
the Legendre coefficients is smaller (see Table 7.1). In general, as the order of polynomials
increases and the noise grows, the ordinary polynomials will become increasingly difficult to
fit the data.

✓4 ✓3 ✓2 ✓1 ✓0
Ordinary polynomials 5.3061 3.3519 3.6285 1.8729 0.1540
Legendre polynomials 1.2128 1.3408 0.6131 0.1382 0.0057

Table 7.1: The regression coefficients of an ordinary polynomial and a Legendre polynomial. Note that
while both polynomials can fit the data, the Legendre polynomial coefficients have smaller magnitudes.

Calling Legendre polynomials for regression is not difficult in MATLAB and Python.
Specifically, one can call legendreP in MATLAB and scipy.special.eval_legendre in
Python.

% MATLAB code to fit data using Legendre polynomials


N = 50;
x = 1*(rand(N,1)*2-1);
a = [-0.001 0.01 +0.55 1.5 1.2];
y = a(1)*legendreP(0,x) + a(2)*legendreP(1,x) + ...
+ a(3)*legendreP(2,x) + a(4)*legendreP(3,x) + ...
+ a(5)*legendreP(4,x) + 0.5*randn(N,1);

X = [legendreP(0,x(:)) legendreP(1,x(:)) ...


legendreP(2,x(:)) legendreP(3,x(:)) ...

404
7.1. PRINCIPLES OF REGRESSION

legendreP(4,x(:))];
beta = X\y(:);

t = linspace(-1, 1, 200);
yhat = beta(1)*legendreP(0,t) + beta(2)*legendreP(1,t) + ...
+ beta(3)*legendreP(2,t) + beta(4)*legendreP(3,t) + ...
+ beta(5)*legendreP(4,t);
plot(x,y,’ko’,’LineWidth’,2,’MarkerSize’,10); hold on;
plot(t,yhat,’LineWidth’,6,’Color’,[0.9 0 0]);

import numpy as np
import matplotlib.pyplot as plt
from scipy.special import eval_legendre

N = 50
x = np.linspace(-1,1,N)
a = np.array([-0.001, 0.01, 0.55, 1.5, 1.2])
y = a[0]*eval_legendre(0,x) + a[1]*eval_legendre(1,x) + \
a[2]*eval_legendre(2,x) + a[3]*eval_legendre(3,x) + \
a[4]*eval_legendre(4,x) + 0.2*np.random.randn(N)

X = np.column_stack((eval_legendre(0,x), eval_legendre(1,x), \
eval_legendre(2,x), eval_legendre(3,x), \
eval_legendre(4,x)))
theta = np.linalg.lstsq(X, y, rcond=None)[0]
t = np.linspace(-1, 1, 50);
yhat = theta[0]*eval_legendre(0,t) + theta[1]*eval_legendre(1,t) + \
theta[2]*eval_legendre(2,t) + theta[3]*eval_legendre(3,t) + \
theta[4]*eval_legendre(4,t)
plt.plot(x,y,’o’,markersize=12)
plt.plot(t,yhat, linewidth=8)
plt.show()

The idea of fitting a set of data using the Legendre polynomials belongs to the larger
family of basis functions. In general, we can use a set of basis functions to model the data:
d 1
X
def
g✓ (x) = ✓p p (x),
p=0

where { p (x)}dp=01 are the basis functions and {✓p }dp=01 are the regression coefficients. The
constant ✓0 is often called the bias of the regression.
Choice of the p (x) can be extremely broad. One can choose the ordinary polynomials
p (x) = xp or the Legendre polynomial p (x) = Lp (x). Other choices are also available:

Fourier basis: p (x) = ej!p x , where !p is the pth carrier frequency.


Sinusoid basis: p (x) = sin(!p x), which is same as the Fourier basis but taking the
imaginary part.

405
CHAPTER 7. REGRESSION

n o
(x µp )2
Gaussian basis: p (x) = p1 2
exp 2 p2 , where (µp , p) are the model param-
2⇡ p
eters.

Evidently, by choosing di↵erent basis functions we have di↵erent ways to fit the data. There
is no definitive answer as to which functions are better. Statistical techniques such as model
selections are available, but experience will tell you to align with one and not the other. It
is frequently more useful to have some domain knowledge rather than resorting to various
computational techniques.

How to fit data using basis functions


Construct this equation:
2 3 2 32 3 2 3
y1 0 (x1 ) 1 (x1 ) ··· d 1 (x1 ) ✓0 e1
6 y2 7 6 0 (x2 ) 1 (x2 ) ··· 76
d 1 (x2 ) 76 ✓1 7 6 e2 7
6 7 6 7 6 7
6 .. 7 = 6 .. .. .. 76 .. 7 + 6 .. 7, (7.9)
4 . 5 4 . ··· . . 54 . 5 4 . 5
yN 0 (xN ) 1 (xN ) · · · d (x
1 N ) ✓d 1 eN
| {z } | {z }| {z } | {z }
y X ✓ e

The functions p (x) are the basis functions, e.g., p (x) = xp for ordinary poly-
nomials.
You can replace the polynomials with the Legendre polynomials.
You can also replace the polynomials with other basis functions.
Solve for ✓ by
✓b = argmin ky X✓k2 .

Example 7.3. (Autoregressive model) Consider a two-tap autoregressive model:

yn = ayn 1 + byn 2, n = 1, 2, . . . , N

where we assume y0 = y 1 = 0. Express this equation in the matrix-vector form.

Solution. The matrix-vector form of the equation is


2 3 2 3 2 3
y1 y0 y 1 e1
6 y2 7 6 y1 y0 7  6 e2 7
6 7 6 7 a 6 7
6 .. 7 = 6 .. .. 7 b + 6 .. 7 .
4 . 5 4 . . 5|{z} 4 . 5
yN yN 1 yN 2 =✓ eN
| {z } | {z }
=y =X

In general, we can append more previous samples to predict the future. The general

406
7.1. PRINCIPLES OF REGRESSION

expression is
L
X
yn = ✓ ` yn `, n = 1, 2, . . . , N,
`=1

where ` = 1, 2, . . . , L denote the previous L samples of the data and {✓1 , . . . , ✓L } are the
regression coefficients. If we do this we see that the matrix expression is
2 3 2 y y 1 y 2 · · · y1 L
3 2 3
y1 0
2 3 e1
6 y2 7 6 y1 6 y0 7
y 1 · · · y2 L 7 ✓ 1 6 e2 7
6 7 6 y y1 y0 · · · y3 L 7 6 7
6 y3 7 6 2 76 ✓2 7 6 e3 7
6 7 6 y y2 y1 · · · y4 L 7 6 7 6 7
6 y4 7 = 6 3 76 .. 7 + 6 e4 7 .
6 7 6 . .. .. .. .. 74 . 5 6 . 76
6 .. 7 6 . 7
4 . 5 4 . . . . . 7
5 ✓L 4 .. 5
yN .. | {z } eN
| {z } | yN 1 yN 2 y{z N 3 . yN L =✓
}
=y
=X

Observe the pattern associated with this matrix X. Each column is a one-entry shifted
version of the previous column. This matrix is called a Toeplitz matrix.
The MATLAB (and Python) code for calling and using the Toeplitz matrix is shown
below.

% MATLAB code for auto-regressive model


N = 500;
y = cumsum(0.2*randn(N,1)) + 0.05*randn(N,1); % generate data

L = 100; % use previous 100 samples


c = [0; y(1:400-1)];
r = zeros(1,L);
X = toeplitz(c,r); % Toeplitz matrix
theta = X\y(1:400); % solve y = X theta
yhat = X*theta; % prediction
plot(y(1:400), ’ko’,’LineWidth’,2);hold on;
plot(yhat(1:400),’r’,’LineWidth’,4);

# Python code for auto-regressive model


import numpy as np
import matplotlib.pyplot as plt
from scipy.linalg import toeplitz

N = 500
y = np.cumsum(0.2*np.random.randn(N)) + 0.05*np.random.randn(N)

L = 100
c = np.hstack((0, y[0:400-1]))
r = np.zeros(L)
X = toeplitz(c,r)
theta = np.linalg.lstsq(X, y[0:400], rcond=None)[0]
yhat = np.dot(X, theta)

407
CHAPTER 7. REGRESSION

plt.plot(y[0:400], ’o’)
plt.plot(yhat[0:400],linewidth=4)

The plots generated by the above programs are shown in Figure 7.8(a). Note that we
are doing an interpolation, because we are predicting the values within the training dataset.

2 2

0 0

-2 -2

-4 -4

-6 -6
0 100 200 300 400 500 0 100 200 300 400 500
(a) (b)

Figure 7.8: Autoregressive model on a simulated dataset, using L = 100 coefficients. (a) Training data.
Note that the model trains very well on this dataset. (b) Testing data. When tested on future data, the
autoregressive model can still predict for a few samples but loses track when the time elapsed grows.

We now consider extrapolation. Given the training data, we can find the regression
coefficients by solving the above linear equation. This gives us ✓. To predict the future
samples we need to return to the equation
L
X
ybn = ✓` ybn ` , n = 1, 2, . . . , N,
| {z }
`=1
=previous estimate

where ybn ` are the previous estimates. For example, if we are given 100 days of stock prices,
then predicting the 101st day’s price should be based on the L days before the 101st. A
simple for-loop suffices for such a calculation.
Figure 7.8(b) shows a numerical example of extrapolating data using the autoregressive
model. In this experiment we use N = 400 samples to train an autoregressive model of order
L = 100. We then predict the data for another 100 data points. As you can see from the
figure, the first few samples still look reasonable. However, as time increases, the model
starts to lose track of the real trend.
Is there any way we can improve the autoregressive model? A simple way is to increase
the memory L so that we can use a long history to predict the future. This boils down to
the long-term running average of the curve, which works well in many cases. However, if
the testing data does not follow the same distribution as the training data (which is often
the case in the real stock market because unexpected news can change the stock price),
then even the long-term average will not be a good forecast. That is why data scientists on
Wall Street make so much money: they have advanced mathematical tools for modeling the
stock market. Nevertheless, we hope that the autoregressive model provides you with a new
perspective for analyzing data.
The summary below highlights the main ideas of the autoregressive model.

408
7.1. PRINCIPLES OF REGRESSION

What is the autoregressive model?


It solves this problem
2 3 2 y y 1 y 2 ··· y1
3 2 3
y1 0 L 2 3 e1
6 y2 7 6 y 1 y0 y 1 ··· y2 7
L7
✓ 1 6 e2 7
6 7 6 6 ✓2 7 6 7
6 y3 7 6 y y1 y0 ··· y3 L7
76 7 6 7
.. 7 + 6 e3 7.
2
6 7=6 .. 76 (7.10)
6 .. 7 6 .. .. .. .. 4 .5 6 . 7
4 . 5 6 4 . . . . . 7
5 4 .. 5
.. ✓L
yN yN L | {z } | e{z
| {z } | yN 1 yN yN .
2 3 N
{z } =✓ }
=y =e
=X

The number of taps in the past history would a↵ect the memory and hence the
long-term forecast.
Solve for ✓ by
✓b = argmin ky X✓k2 . (7.11)
✓2Rd

7.1.4 Overdetermined and underdetermined systems

The sub-section requires knowledge of some concepts in linear algebra that can be found
in standard references.a
a Carl Meyer, Matrix Analysis and Applied Linear Algebra, SIAM, 2000.

Let us now consider the theoretical properties of the least squares linear regression
problem, which is an optimization:

✓b = argmin ky X✓k2 . (P1)


✓2Rd

We observe that the objective value of this optimization problem can go to zero if and only
if the minimizer ✓b is the solution of the system of linear equations

Find ✓ such that y = X✓. (P2)

We emphasize that Problem (P1) and Problem (P2) are two di↵erent problems. Even if we
cannot solve Problem (P2), Problem (P1) is still well defined, but the objective value will
not go to zero. This subsection aims to draw the connection between the two problems and
discuss the respective solutions. We will start with Problem (P2) by considering two shapes
of the matrix X.

Overdetermined system
Problem (P2) is called overdetermined if X 2 RN ⇥d is tall and skinny, i.e., N > d. This hap-
pens when you have more rows than columns, or equivalently when you have more equations
than unknowns. When N > d, Problem (P2) has a unique solution ✓b = (X T X) 1 X T y if

409
CHAPTER 7. REGRESSION

and only if X T X is invertible, or equivalently if and only if the columns of X are linearly in-
dependent. A technical description of this is that X has a full rank, denoted by rank(X) = d.
When rank(X) = d, Problem (P1) has a unique global minimizer ✓b = (X T X) 1 X T y, which
is the same as the unique solution of Problem (P2).

Figure 7.9: Hierarchy of the solutions of an overdetermined system. An overdetermined system uses
a tall and skinny matrix X. The rank of a matrix X is defined as the largest number of independent
columns we can find in X. If rank(X) = d, the matrix X T X is invertible, and Problem (P2) will have
a unique solution. If rank(X) < d, then the solution depends on whether the particular observation y
lives in the range space of X. If yes, Problem (P2) will have infinitely many solutions because there is
a nontrivial null space. If no, Problem (P2) will have no solution because the system is incompatible.

If the columns of X are linearly dependent so that X T X is not invertible, we say


that X is rank-deficient (denoted as rank(X) < d). In this case, Problem (P2) may not
have a solution. We say that it may not have a solution because it is still possible to have a
solution. It all depends on whether y can be written as a linear combination of the linearly
independent columns of X.
If yes, we say that y lives in the range space of X. The range space of X is defined
as the set of vectors {z | z = X↵, for some ↵}. If rank(X) = d, all y will live in the range
space of X. But if rank(X) < d, only some of the y will live in the range space of X.
When this happens, the matrix X must have a nontrivial null space. The null space of X
is defined as the set of vectors {z | Xz = 0}. A nontrivial null space will give us infinitely
many solutions to Problem (P2). This is because if ↵ is the solution found in the range
space so that y = X↵, then we can pick any z from the null space such that Xz = 0.
This will lead to another solution ↵ + z such that X(↵ + z) = X↵ + 0 = y. Since we have
infinitely many choices of such z’s, there will be infinitely many solutions to Problem (P2).
Although there are infinitely many solutions to Problem (P2), all of them are the global
minimizers of Problem (P1). They can make the objective value equal to zero because the
equality y = X✓ holds. However, the solutions to Problem (P2) are not unique since the
objective function is convex but not strictly convex.
If y does not live in the range space of X, we say that Problem (P2) is incompatible.
If a system of linear equations is incompatible, there is no solution. However, even when
this happens, we can still solve the optimization Problem (P1), but the objective value will
not reach 0. The minimizer is a global minimizer because the objective function is convex,

410
7.1. PRINCIPLES OF REGRESSION

but the minimizer is not unique.

Underdetermined system
Problem (P2) is called underdetermined if X is fat and short, i.e., N < d. This happens
when you have more columns than rows, or equivalently when you have more unknowns than
equations. In this case, X T X is not invertible, and so we cannot use ✓b = (X T X) 1 X T y
as the solution. However, if rank(X) = N , then any y will live in the range space of X. But
because X is fat and short, there exists a nontrivial null space. Therefore, Problem (P2)
will have infinitely many solutions, attributed to the vectors generated by the null space.
For this set of infinitely many solutions, the corresponding Problem (P1) will have a global
minimizer, and the objective value will be zero. However, the minimizer is not unique. This
is the first case in Figure 7.10.

Figure 7.10: Hierarchy of the solutions of an underdetermined system. An underdetermined system uses
a fat and short matrix X. The rank of a matrix X is defined as the largest number of independent
columns we can find in X. If rank(X) = N , we will have infinitely many solutions. If rank(X) < N ,
then the solutions depends on whether the particular observation y lives in the range space of X. If yes,
Problem (P2) will have infinitely many solutions because there is a nontrivial null space. If no, Problem
(P2) will have no solution because the system is incompatible.

There are two other cases in Figure 7.10, which occur when rank(X) < N :
(i) If y is in the range space of X, Problem (P2) will have infinitely many solutions.
Since Problem (P2) remains feasible, the objective function of Problem (P1) will go
to zero.
(ii) If y is not in the range space of X, the system in Problem (P2) is incompatible
and there will be no solution. The objective value of Problem (P1) will not go to zero.
If an underdetermined system has infinitely many solutions, we need to pick and choose.
One of the possible approaches is to consider the optimization

✓b = argmin k✓k2 subject to X✓ = y. (P3)


✓2Rd

This optimization is di↵erent from Problem (P1), which is an unconstrained optimization.


Our goal is to minimize the deviation between X✓ and y. Problem (P3) is constrained. Since

411
CHAPTER 7. REGRESSION

we assume that Problem (P2) has infinitely many solutions, the constraint set y = X✓
is feasible. Among all the feasible choices, we pick the one that minimizes the squared
norm. Therefore, the solution to Problem (P3) is called the minimum-norm least squares.
Theorem 7.2 below summarizes the solution. If y does not live in the range space of X,
then Problem (P2) does not have a solution. Therefore, the constraint in P3 is infeasible,
and hence the optimization problem does not have a minimizer.

Theorem 7.2. Consider the underdetermined linear regression problem where N < d:

✓b = argmin k✓k2 subject to y = X✓,


✓2Rd

where X 2 RN ⇥d , ✓ 2 Rd , and y 2 RN . If rank(X) = N , then the linear regression


problem will have a unique global minimum

✓b = X T (XX T ) 1
y. (7.12)

This solution is called the minimum-norm least-squares solution.

Proof. The proof of the theorem requires some knowledge of constrained optimization.
Consider the Lagrangian of the problem:
T
L(✓, ) = k✓k2 + (X✓ y),

where is called the Lagrange multiplier. The solution of the constrained optimization is
the stationary point of the Lagrangian. To find the stationary point, we take the derivatives
with respect to ✓ and . This yields

r✓ L = 2✓ + X T = 0,
r L = X✓ y = 0.

The first equation gives us ✓ = X T /2. Substituting it into the second equation, and
assuming that rank(X) = N so that X T X is invertible, we have
⇣ ⌘
X X T /2 y = 0,

which implies that = 2(XX T ) 1


y. Therefore, ✓ = X T (XX T ) 1
y. ⇤

The end of this subsection. Please join us again.

7.1.5 Robust linear regression

This subsection is optional for a first reading of the book.

The linear regression we have discussed so far is based on an important criterion,


namely the squared error criterion. We chose the squared error as the training loss because

412
7.1. PRINCIPLES OF REGRESSION

it is di↵erentiable and convex. Di↵erentiability allows us to take the derivative and locate
the minimum point. Convexity allows us to claim a global minimizer (also unique if the
objective function is strictly convex). However, such a nice criterion su↵ers from a serious
drawback: the issue of outliers.
Consider Figure 7.11. In Figure 7.11(a), we show a regression problem for N = 50
data points. Our basis functions are the ordinary polynomials in the fourth order. Everything
looks fine in the figure. We intervene in the data by randomly altering a few of them so that
their values are o↵. There are only a handful of these outliers. We run the same regression
analysis again, but we observe (see Figure 7.11(b)) that our fitted curve has been distorted
quite significantly.
4 5

3 4

3
2
2
1
1
0
0

-1 data -1 data
fitted curve fitted curve
-2 -2
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) (·)2 without outlier (b) (·)2 with outlier

Figure 7.11: Linear regression using the squared error as the training loss su↵ers from outliers. (a) The
regression performs well when there is no outlier. (b) By adding only a few outliers, the regression curve
has already been distorted.

This occurs because of the squared error. By the definition of a squared error, our
training loss is
N ✓
X ◆2
Etrain (✓) = yn g✓ (xn ) .
n=1

Without loss of generality, let us assume that one of these error terms is large because of an
outlier. Then the training loss becomes
✓ ◆2 ✓ ◆2 ✓ ◆2 ✓ ◆2
Etrain (✓) = y1 g✓ (x1 ) + y2 g✓ (x2 ) + y3 g✓ (x3 ) + · · · + yN g✓ (xN ) .
| {z } | {z } | {z } | {z }
small small large small

Here is the daunting fact: If one or a few of these individual error terms are large, the
square operation will amplify them. As a result, the error you see is not just large but large2 .
Moreover, since we put the squares to the small errors as well, we have small2 instead of
small. When you try to weigh the relative significance between the outliers and the normal
data points, the outliers suddenly have a very large contribution to the error. Since the goal
of linear regression is to minimize the total loss, the presence of the outliers will drive the
optimization solution to compensate for the large error.

413
CHAPTER 7. REGRESSION

One possible solution is to replace the squared error by the absolute error, such that
N
X
Etrain (✓) = yn g✓ (xn ) .
n=1

This is a simple modification, but it is very e↵ective. The reason is that the absolute error
keeps the small just as small, and keeps the large just as large. There is no amplification.
Therefore, while the outliers still contribute to the overall loss, their contributions are less
prominent. (If you have a lot of strong outliers, even the absolute error will fail. If this
happens, you should go back to your data collection process and find out what has gone
wrong.)
When we use the absolute error as the training loss, the resulting regression problem is
the least absolute deviation regression (or simply the robust regression). The tricky thing
about the least absolute deviation is that the training loss is not di↵erentiable. In other
words, we cannot take the derivative and find the optimal solution. The good news is that
there exists an alternative approach for solving this problem: using linear programming
(implemented via the simplex method).

Solving the robust regression problem


Let us focus on the linear model
g✓ (xn ) = xTn ✓,
where xn = [ 0 (xn ), . . . , d 1 (xn )]T 2 Rd is the nth input vector for some basis functions
{ p }dp=01 , and ✓ = [✓0 , . . . , ✓d 1 ]T 2 Rd is the parameter. Substituting this into the training
loss, the optimization problem is
N
X
minimize yn xTn ✓ .
✓2Rd
n=1

Here is an important trick. The idea is to express the problem as an equivalent problem
N
X
minimize un
✓2Rd ,u2RN
n=1
subject to un = |yn xTn ✓|, n = 1, . . . , N.
There is a small but important di↵erence between this problem and the previous one. In the
first problem, there is only one optimization variable ✓. In the new problem, we introduce an
additional variable u = [u1 , . . . , uN ]T and add a constraint un = |yn xTn ✓| for n = 1, . . . , N .
We introduce u so that we can have some additional degrees of freedom. At the optimal
solution, un must equal to |yn xTn ✓|, and so the corresponding ✓ is the solution of the
original problem.
Now we note that x = |a| is equivalent to x a and x a. Therefore, the constraint
can be equivalently written as
N
X
minimize un , (7.13)
✓2Rd ,u2RN
n=1
subject to un (yn xTn ✓), n = 1, . . . , N
un (yn xTn ✓), n = 1, . . . , N.

414
7.1. PRINCIPLES OF REGRESSION

In other words, we have rewritten the equality constraint as a pair of inequality constraints
by removing the absolute signs.
The optimization in Equation (7.13) is in the form of a standard linear programming
problem. A linear programming problem takes the form of
minimize cT x (7.14)
x2Rk
subject to Ax  b,
for some vectors c 2 Rk , b 2 Rm , and matrix A 2 Rm⇥k . Linear programming is a stan-
dard optimization problem that you can find in most optimization textbooks. On a com-
puter, if we know c, b and A, solving the linear programming problem can be done using
built-in commands. For MATLAB, the command is linprog. For Python, the command is
scipy.optimize.linprog. We will discuss a concrete example shortly.
% MATLAB command for linear programming
x = linprog(c, A, b);

# Python command for linear programming


linprog(c, A, b, bounds=(None,None), method="revised simplex")

Given Equation (7.13), the question becomes how to convert it into the standard linear
programming format. This requires two steps. The first step uses the objective function:
N
X d 1
X N
X
un = (0)(✓p ) + (1)(un )
n=1 p=0 n=1

⇥ ⇤ ✓
= 0 0 ··· 0 1 1 ··· 1 .
| {z } u
=cT

Therefore, the vector c has d 0’s followed by N 1’s.


The second step concerns the constraint. It can be shown that un (yn xTn ✓) is
equivalent to xTn ✓ un  yn . Written in the matrix form, we have
2 T 32 3 2 3
x1 1 0 ··· 0 ✓ y1
6 xT2 0 1 · · · 0 7 6 u 1 7 6 y2 7
6 76 7 6 7
6 .. .. .. .. 7 6 .. 7  6 .. 7 ,
4 . . . ··· . 54 . 5 4 . 5
T
xN 0 0 ··· 1 uN yN
which is equivalent to 
⇥ ⇤ ✓
X I  y, (7.15)
u
where I 2 RN ⇥N is the identity matrix.
Similarly, the other constraint un (yn xTn ✓) is equivalent to xTn ✓ un  yn .
Written in the matrix form, we have
2 32 3 2 3
xT1 1 0 ··· 0 ✓ y1
6 xT2 0 1 ··· 0 7 6 u1 7 6 y2 7
6 76 7 6 7
6 .. .. .. .. 7 6 .. 7  6 .. 7 ,
4 . . . ··· . 54 . 5 4 . 5
xTN 0 0 ··· 1 uN yN

415
CHAPTER 7. REGRESSION

which is equivalent to 
⇥ ⇤ ✓
X I  y
u
Putting everything together, we have finally arrived at the linear programming problem

⇥ ⇤ ✓
minimize 0d 1N
✓2Rd ,u2RN u
  
X I ✓ y
subject to  ,
X I u y

where 0d 2 Rd is an all-zero vector, and 1N 2 RN is an all-one vector. It is this problem


that solves the robust linear regression.
Let us look at how to implement linear programming to solve the robust regression
optimization. As an example, we continue with the polynomial fitting problem in which
there are outliers. We choose the ordinary polynomials as the basis functions. To construct
the linear programming problem, we need to define the matrix A and the vectors c and
b according to the linear programming form. This is done using the following MATLAB
program.
% MATLAB code to demonstrate robust regression
N = 50;
x = linspace(-1,1,N)’;
a = [-0.001 0.01 0.55 1.5 1.2];
y = a(1)*legendreP(0,x) + a(2)*legendreP(1,x) + ...
a(3)*legendreP(2,x) + a(4)*legendreP(3,x) + ...
a(5)*legendreP(4,x) + 0.2*randn(N,1);
idx = [10, 16, 23, 37, 45];
y(idx) = 5;

X = [x(:).^0 x(:).^1 x(:).^2 x(:).^3 x(:).^4];


A = [X -eye(N); -X -eye(N)];
b = [y(:); -y(:)];
c = [zeros(1,5) ones(1,N)]’;
theta = linprog(c, A, b);

t = linspace(-1,1,200)’;
yhat = theta(1) + theta(2)*t(:) + ...
theta(3)*t(:).^2 + theta(4)*t(:).^3 + ...
theta(5)*t(:).^4;
plot(x,y, ’ko’,’LineWidth’,2); hold on;
plot(t,yhat,’r’,’LineWidth’,4);

In this set of commands, the basis vectors are defined as xTn = [ 4 (xn ), . . . , 0 (xn )]T , for
n = 1, . . . , N . The matrix I is constructed by using the command eye(N), which constructs
the identity matrix of size N ⇥ N . The rest of the commands are self-explanatory. Note that
the solution to the linear programming problem consists of both ✓ and u. To squeeze ✓ we
need to locate the first d entries. The remainder is u.
Commands for Python are similar, although we need to call np.hstack and np.vstack
to construct the matrices and vectors. The main routine is linprog in the scipy.optimize

416
7.1. PRINCIPLES OF REGRESSION

library. Note that for this particular example, the bounds are bounds=(None,None), or
otherwise Python will search in the positive quadrant.
# Python code to demonstrate robust regression
import numpy as np
import matplotlib.pyplot as plt
from scipy.special import eval_legendre
from scipy.optimize import linprog

N =
50
x =
np.linspace(-1,1,N)
a =
np.array([-0.001, 0.01, 0.55, 1.5, 1.2])
y =
a[0]*eval_legendre(0,x) + a[1]*eval_legendre(1,x) + \
a[2]*eval_legendre(2,x) + a[3]*eval_legendre(3,x) + \
a[4]*eval_legendre(4,x) + 0.2*np.random.randn(N)
idx = [10,16,23,37,45]
y[idx] = 5
X = np.column_stack((np.ones(N), x, x**2, x**3, x**4))
A = np.vstack((np.hstack((X, -np.eye(N))), np.hstack((-X, -np.eye(N)))))
b = np.hstack((y,-y))
c = np.hstack((np.zeros(5), np.ones(N)))
res = linprog(c, A, b, bounds=(None,None), method="revised simplex")
theta = res.x
t = np.linspace(-1,1,200)
yhat = theta[0]*np.ones(200) + theta[1]*t + theta[2]*t**2 + \
theta[3]*t**3 + theta[4]*t**4
plt.plot(x,y,’o’,markersize=12)
plt.plot(t,yhat, linewidth=8)
plt.show()

The result of this experiment is shown in Figure 7.12. It is remarkable to see that the
robust regression result is almost as good as the result would be without outliers.
If robust linear regression performs so well, why don’t we use it all the time? Why
is least squares regression still more popular? The answer has a lot to do with the com-
putational complexity and the uniqueness of the solution. Linear programming requires an
algorithm for a solution. While we have very fast linear programming solvers today, the com-
putational cost of solving a linear program is still much higher than solving a least-squares
problem (which is essentially a matrix inversion).
The other issue with robust linear regression is the uniqueness of the solution. Lin-
ear programming is known to have degenerate solutions when the constraint set (a high-
dimensional polygon) touches the objective function (which is a line) at one of its edges.
The least-squares fitting does not have this problem because the optimization surface is a
parabola. Unless the matrix X T X is noninvertible, the solution is guaranteed to be the
unique global minimum. Linear programming does not have this convenient property. We
can have multiple solutions ✓ that give the same objective value. If you try to interpret your
result by inspecting the magnitude of the ✓’s, the nonuniqueness of the solution would cause
problems because your interpretation can be swiped immediately if the linear programming
gives you a nonunique solution.

417
CHAPTER 7. REGRESSION

5 5

4 4

3 3

2 2

1 1

0 0

-1 -1

-2 -2
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) Ordinary (·)2 regression with outliers (b) Robust | · | regression with outliers

Figure 7.12: (a) Ordinary linear regression using (·)2 as the training loss. In the absence of any outlier,
the regression performs well. (b) Robust linear regression using | · | as the training loss. Note that even
in the presence of outliers, the robustness regression perform reasonably well.

End of this subsection. Please join us again.

Closing remark. The principle of linear regression is primarily to set up a function to fit
the data. This, in turn, is about finding a set of good basis functions and minimizing the
appropriate training loss. Selecting the basis is usually done in several ways:

The problem forces you to choose certain basis functions. For example, suppose you
are working on a disease dataset. The variates are height, weight, and BMI. You do
not have any choice here because your goal is to see which factor contributes the most
to the cause of the disease.
There are known basis functions that work. For example, suppose you are working on
a speech dataset. Physics tells us that Fourier bases are excellent representations of
these sinusoidal functions. So it would make more sense to use the Fourier basis than
the polynomials.
Sometimes the basis can be learned from the data. For example, you can run principal-
component analysis (PCA) to extract the basis. Then you can run the linear regression
to compute the coefficients. This is a data-driven approach and could apply to some
problems.

7.2 Overfitting

The regression principle we have discussed in the previous section is a powerful technique
for data analysis. However, there are many ways in which things can fall apart. We have
seen the problem of outliers, where perturbations of one or a few data points would result
in a big change in the regression result, and we discussed some techniques to overcome the

418
7.2. OVERFITTING

outlier problem, e.g., using robust regression. In addition to outliers, there are other causes
of the failure of the regression.
In this section, we examine the relationship between the number of training samples
and the complexity of the model. For example, if we decide to use polynomials as the basis
functions and we have only N = 20 data points, what should be the order of the polynomials?
Shall we use the 5th-order polynomial, or shall we use the 20th-order? Our goal in this section
is to acquire an understanding of the general problem known as overfitting. Then we will
discuss methods for mitigating overfitting in Section 7.4.

7.2.1 Overview of overfitting


Imagine that we have a dataset containing N = 20 training samples. We know that the data
are generated from a fourth-order polynomial with Legendre polynomials as the basis. On
top of these samples, we also know that a small amount of noise corrupts each sample, for
example, Gaussian noise of standard deviation = 0.1.
We have two options here for fitting the data:
P4
Option 1: h(x) = p=0 ✓p Lp (x), which is a 4th-order polynomial.
P50
Option 2: g(x) = p=0 ✓p Lp (x), which is a 50th-order polynomial.
Model 2 is more expressive because it has more degrees of freedom. Let us fit the data using
these two models. Figure 7.13 shows the results. However, what is going on with the 50th-
order polynomial? It has gone completely wild. How can the regression ever choose such a
terrible model?
3 3

2 2

1 1

0 0

-1 -1

-2 data -2 data
fitted curve fitted curve
-3 -3
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) 4th-order polynomial (b) 50th-order polynomial

Figure 7.13: Fitting data using a 4th-order polynomial and a 50th-order polynomial.

Here is an even bigger surprise: If we compute the training loss, we get


N ✓ ◆2
1 X
Etrain (h) = yn h(xn ) = 0.0063,
N n=1
N ✓ ◆2
1 X 24
Etrain (g) = yn g(xn ) = 5.7811 ⇥ 10 .
N n=1

419
CHAPTER 7. REGRESSION

Thus, while Model 2 looks wild in the figure, it has a much lower training loss than Model 1.
So according to the training loss, Model 2 fits better.
Any sensible person at this point will object, since Model 2 cannot possibly be better,
for the following reason. It is not because it “looks bad”, but because if you test the model
with an unseen sample it is almost certain that the testing error will explode. For example,
in Figure 7.13(a) if we look at x = 0, we would expect the predicted value to be close
to y = 0. However, Figure 7.13(b) suggests that the predicted value is going to negative
infinity. It would be hard to believe that the negative infinity is a better prediction than the
other one. We refer to this general phenomenon of fitting very well to the training data but
generalizing poorly to the testing data as overfitting.

What is overfitting?
Overfitting means that a model fits too closely to the training samples so that it
fails to generalize.

Overfitting occurs as a consequence of an imbalance between the following three factors:


Number of training samples N . If you have many training samples, you should learn
very well, even if the model is complex. Conversely, if the model is complex but does
not have enough training samples, you will overfit it. The most serious problem in
regression is often insufficient training data.
Model order d. This refers to the complexity of the model. For example, if your model
uses a polynomial, d refers to the order of the polynomial. If your training set is too
small, you need to use a less complex model. The general rule of thumb is: “less is
more”.
Noise variance 2 . This refers to the variance of the error en you add to the data.
The model we assumed in the previous numerical experiment is that

yn = g(xn ) + en , n = 1, . . . , N.

where en ⇠ Gaussian(0, 2 ). If increases, it is inevitable that the fitting will be-


come more difficult. Hence it would require more training samples, and perhaps a less
complex model would work better.

7.2.2 Analysis of the linear case


Let us spell out the details of these factors one by one. To make our discussion concrete, we
will use linear regression as a case study. The general analysis will be presented in the next
section.

Notations
Ground Truth Model. To start with, we assume that we have a population set D
containing infinitely many samples (x, y) drawn according to some latent distributions.
The relationship between x and y is defined through an unknown target function

y = f (x) + e,

420
7.2. OVERFITTING

2
where e ⇠ Gaussian(0, ) is the noise. For our analysis, we assume that f (·) is linear,
so that
f (x) = xT ✓ ⇤ ,
where ✓ ⇤ 2 Rd is the ground truth model parameter. Notice that f (·) is deterministic,
but e is random. Therefore, any randomness we see in y is due to e.
Training and Testing Set. From D, we construct two datasets: the training data set
Dtrain that contains training samples {(x1 , y1 ), . . . , (xN , yN )} and the testing dataset
Dtest that contains {(x1 , y1 ), . . . , (xM , yM )}. Both Dtrain and Dtest are subsets of D.
Predictive Model. We consider a predictive model g✓ (·). For simplicity, we assume
that g✓ (·) is also linear:
g✓ (x) = xT ✓.
Given the training dataset D = {(x1 , y1 ), . . . , (xN , yN )}, we construct a linear regres-
sion problem:
✓b = argmin kX✓ yk2 .
✓2Rd

Throughout our analysis, we assume that N d so that we have more training data
than the number of unknowns. We further assume that X T X is invertible, and so
there is a unique global minimizer

✓b = (X T X) 1
X T y.

b we define the in-sample


Training Error. Given the estimated model parameter ✓,
prediction as
b
ybtrain = X train ✓,
where X train = X is the training data matrix. The in-sample prediction is the pre-
dicted value using the trained model for the training data. The corresponding error
with respect to the ground truth is called the training error:

b 1
Etrain (✓) = Ee kb
y yk2 ,
N train

where N is the number of training samples in the training dataset. Note that the
expectation is taken with respect to the noise vector e, which follows the distribution
Gaussian(0, 2 I).
Testing Error. During testing, we construct a testing matrix X test . This gives us the
estimated values ybtest :
b
ybtest = X test ✓.
The out-sample prediction is the predicted value using the trained model for the testing
data. The corresponding error with respect to the ground truth is called the testing
error: 
b = Ee 1 kb
Etest (✓) y yk2 ,
M test
where M is the number of testing samples in the testing dataset.

421
CHAPTER 7. REGRESSION

Analysis of the training error


We first analyze the training error, which we defined as

1 2 def
Etrain = Ee kb
y yk = MSE(yb, y). (7.16)
N

For this particular choice of the training error, we call it the mean squared error (MSE). It
measures the di↵erence between yb and y.

Theorem 7.3. Let ✓ ⇤ 2 Rd be the ground truth linear model parameter, and X 2
RN ⇥d be a matrix such that N d and X T X is invertible. Assume that the data

follows the linear model y = X✓ + e where e ⇠ Gaussian(0, 2 I). Consider the linear
regression problem ✓b = argmin kX✓ yk2 , and the predicted value yb = X ✓. b The
✓2Rd
mean squared training error of this linear model is
 ✓ ◆
def 1 2 2 d
Etrain = MSE(yb, y) = Ee kb
y yk = 1 . (7.17)
N N

The proof below depends on some results from linear algebra that may be difficult for
first-time readers. We recommend you read the proof later.

Proof. Recall that the least squares linear regression solution is ✓b = (X T X) 1


X T y. Since
y = X✓ ⇤ + e, we can substitute this into the predicted value yb to show that

yb = X ✓b = X(X T X) 1
X T y = X(X T X) 1
X T (X✓ ⇤ + e) = X✓ ⇤ + He.
| {z }
=H

Therefore, substituting yb = X✓ ⇤ + He into the MSE,


 
def 1 2 1 2
MSE(yb, y) = Ee y yk = Ee
kb kX✓ ⇤ + He X✓ ⇤ ek
N N

1 2
= Ee k(H I)ek .
N

At this point we need to use a tool from linear algebra. One useful identity3 is that for any
v 2 RN ,

kvk2 = Tr(vv T ).
3 The reason for this identity is that
82 2 39
> v1 v1 v 2 ··· v 1 vN >
>
> 6 v 2 v1 >
XN < v22 ··· v 2 vN 7>= n o
2 6 7 T
v= vn = Tr 6 . .. .. .. 7 = Tr vv .
>
> 4 .. . . . 5>>
n=1 >
: >
;
vN v 1 v N v2 ··· vN 2

422
7.2. OVERFITTING

Using this identity, we have that


  ⇢
1 2 1
Ee k(H I)ek = Ee Tr (H I)eeT (H I)T
N N

1 ⇥ ⇤
= Tr (H I)Ee eeT (H I)T
N
2

= Tr (H I)(H I)T ,
N

where we used the fact that E[eeT ] = 2 I. The special structure of H tells us that H T = H
and H T H = H. Thus, we have (H I)T (H I) = I H. In addition, using the cyclic
property of trace Tr(AB) = Tr(BA), we have that

Tr(H) = Tr(X(X T X) 1
XT )
= Tr((X T X) 1
X T X) = Tr(I) = d.

Consequently,
2
⇢ 2

T
Tr (H I)(H I) = Tr I H
N N
✓ ◆
2 d
= 1 .
N

This completes the proof.


The end of the proof. Please join us again.

Practice Exercise 1. In the theorem above, we proved the MSE of the prediction y.
In this example, we would like to prove the MSE for the parameter. Prove that
 ⇢
2
b ✓ ⇤ ) def
MSE(✓, = Ee ✓b ✓ ⇤ = 2 Tr (X T X) 1 .

Solution. Let us start with the definition:



2
b ⇤
MSE(✓, ✓ ) = Ee (X T X) 1
XT y ✓⇤

2
= Ee (X T X) 1
X T (X✓ ⇤ + e) ✓⇤
 
2 2
⇤ T T ⇤
= Ee ✓ + (X X) 1
X e ✓ = Ee (X T X) 1
XT e .

423
CHAPTER 7. REGRESSION

Continuing the calculation,


  ⇢
2
Ee (X T X) 1 X T e = Ee Tr (X T X) 1
X T e eT X(X T X) 1

⇢ 
= Tr (X T X) 1 X T Ee eeT X(X T X) 1

= Tr (X T X) 1 X T · 2 I · X(X T X) 1
⇢ ⇢
= Tr (X T X) 1 X T · X(X T X) 1 =
2 2
Tr (X T X) 1
.

Analysis of the testing error


Similarly to the training error, we can analyze the testing error. The testing error is defined
as 
0 def 1 2
Etest = MSE(by , y ) = Ee,e0 y y0 k ,
kb (7.18)
M
where yb = [b y1 , . . . , ybM ]T is a vector of M predicted values and y 0 = [y10 , . . . , yM
0 T
] is a vector
4
of M true values in the testing data.
We would like to derive something concrete. To make our analysis simple, we consider
a special case in which the testing set contains (x1 , y10 ), . . . , (xN , yN 0
). That is, the inputs
x1 , . . . , xN are identical for both training and testing (for example, suppose that you measure
the temperature on two di↵erent days but at the same time stamps.) In this case, we have
M = N , and we have X test = X train = X. However, the noise added to the testing data is
still di↵erent from the noise added to the training data.
With these simplifications, we can derive the testing error as follows.

Theorem 7.4. Let ✓ ⇤ 2 Rd be the ground truth linear model parameter, and X 2
RN ⇥d be a matrix such that N d and X T X is invertible. Assume that the training
data follows the linear model y = X✓ ⇤ + e, where e ⇠ Gaussian(0, 2 I). Consider
the linear regression problem ✓b = (X T X) 1 X T y, and let yb = X ✓.
b Let X test = X

be the testing input data matrix, and define y = X test ✓ + e 2 RN , with e0 ⇠
0 0

Gaussian(0, 2 I), be the testing output. Then, the mean squared testing error of this
linear model is
 ✓ ◆
def 1 2 d
Etest = MSE(yb, y 0 ) = Ee,e0 y y0 k = 2 1 +
kb . (7.19)
N N

In this definition, the expectation is taken with respect to a joint distribution of (e, e0 ).
This is because, in testing, the trained model is based on y of which the randomness is e.
However, the testing data is based on y 0 , where the randomness comes from e0 . We assume
that e and e0 are independent i.i.d. Gaussian vectors.
4 In practice, the number of testing samples M can be much larger than the number of training samples N .

This probably does not agree with your experience, in which the testing dataset is often much smaller than
the training dataset. The reason for this paradox is that the practical testing data set is only a finite subset
of all the possible testing samples available. So the “testing error” we compute in practice approximates the
true testing error. If you want to compute the true testing error, you need a very large testing dataset.

424
7.2. OVERFITTING

As with the previous proof, we recommend you study this proof later.

Proof. The MSE can be derived from the definition:



0 1 2
MSE(yb, y ) = Ee,e0 y y0 k
kb
N

1 2
= Ee,e0 kX✓ ⇤ + He X✓ ⇤ e0 k
N

1 2
= Ee,e0 kHe e0 k .
N
Since each noise term en and e0n is an i.i.d. copy of the same Gaussian random variable, by
using the fact that
Tr(H) = Tr(X(X T X) 1
XT )
= Tr((X T X) 1
X T X) = Tr(I) = d,
we have that
h i ⇥ ⇤ h i ⇥ ⇤
2
Ee,e0 kHe e0 k = Ee kHek2 Ee,e0 2eT H T e0 + Ee0 ke0 k2
| {z }
=0
h n oi ⇥ ⇤
= Ee Tr HeeT H T + Ee0 Tr e0 e0T
n ⇥ ⇤ o ⇥ ⇤
= Tr HEe eeT H T + Tr{Ee0 e0 e0T }
n o
= Tr H · 2 I N ⇥N · H T + Tr 2 I N ⇥N
n o
= 2 Tr HH T + Tr 2 I N ⇥N
2 2 2
= Tr(I d⇥d ) + Tr {I N ⇥N } = (d + N ).
Combining all the terms,
 ✓ ◆
1 2 d
MSE(yb, y 0 ) = Ee,e0 kb
y y0 k = 2
1+ ,
N N
which completes the proof.

The end of the proof.

7.2.3 Interpreting the linear analysis results


Let us summarize the two main theorems. They state that, for N d,
 ✓ ◆
def 1 2 2 d
Etrain = MSE(yb, y) = Ee kb
y yk = 1 , (7.20)
N N
 ✓ ◆
def 0 1 0 2 2 d
Etest = MSE(yb, y ) = Ee,e0 kb
y yk = 1+ . (7.21)
N N
This pair of equations tells us everything about the overfitting issue.

425
CHAPTER 7. REGRESSION

2
How do Etrain and Etest change w.r.t. ?
2
Etrain " as ". Thus noisier data are harder to fit.
2
Etest " as ". Thus a noiser model is more difficult to generalize.

The reasons for these results should be clear from the following equations:
✓ ◆
d
Etrain = 2 1 ,
N
✓ ◆
d
Etest = 2 1 + .
N

As 2 increases, the training error Etrain grows linearly w.r.t. 2 . Since the training error
measures how good your model is compared with the training data, a larger Etrain means it
is more difficult to fit. For the testing case, Etest also grows linearly w.r.t. 2 . This implies
that the model would be more difficult to generalize if the model were trained using noisier
data.

How do Etrain and Etest change w.r.t. N ?


Etrain " as N ". Thus more training samples make fitting harder.
Etest # as N ". Thus more training samples improve generalization.

The reason for this should also be clear from the following equations:
✓ ◆
d
Etrain = 2 1 ,
N
✓ ◆
d
Etest = 2 1 + .
N
As N increases, the model sees more training samples. The goal of the model is to minimize
the error with all the training samples. Thus the more training samples we have, the harder
it will be to make everyone happy, so the training error grows as N grows. For testing, if the
model is trained with more samples it is more resilient to noise. Hence the generalization
improves.

How do Etrain and Etest change w.r.t. d?


Etrain # as d ". Thus a more complex model makes fitting easier.
Etest " as d ". Thus a more complex model makes generalization harder.

These results are perhaps less obvious than the others. The following equations tell us that
✓ ◆
d
Etrain = 2 1 ,
N
✓ ◆
d
Etest = 2 1+ . (7.22)
N

426
7.2. OVERFITTING

For this linear regression model to work, d has to be less than N ; otherwise, the matrix
inversion (X T X) 1 is invalid. However, as d grows while N remains fixed, we ask the
linear regression to fit a larger and larger model while not providing any additional training
samples. Equation (7.22) says that Etrain will drop as d increases but Etest will increase as d
increases. Therefore, a larger model will not generalize as well if N is fixed.
If d > N , then the optimization

✓b = argmin kX✓ yk2


✓2Rd

will have many global minimizers (see Figure 7.10), implying that the training error can go
to zero. Our analysis of Etrain and Etest does not cover this case because our proofs require
(X T X) 1 to exist. However, we can still extrapolate what will happen. When the training
error is zero, it only means that we fit perfectly into the training data. Since the testing
error grows as d grows (though not in the particular form shown in Equation (7.22)), we
should expect the testing error to become worse.

Learning curve
The results we derived above can be summarized in the learning curve shown in Figure 7.14.
In this figure we consider a simple problem where

yn = ✓ 0 + ✓ 1 x n + e n ,

for en ⇠ Gaussian(0, 1). Therefore, according to our theoretical derivations, we have = 1


and d = 2. For every N , we compute the average training error Etrain and the average testing
error Etest , and then mark them on the figure. These are our empirical training and testing
errors. On the same figure, we calculate the theoretical training and testing error according
to Equation (7.22).
The MATLAB and Python codes used to generate this learning curve are shown below.

Nset = round(logspace(1,3,20));
E_train = zeros(1,length(Nset));
E_test = zeros(1,length(Nset));
a = [1.3, 2.5];
for j = 1:length(Nset)
N = Nset(j);
x = linspace(-1,1,N)’;
E_train_temp = zeros(1,1000);
E_test_temp = zeros(1,1000);
X = [ones(N,1), x(:)];
for i = 1:1000
y = a(1) + a(2)*x + randn(size(x));
y1 = a(1) + a(2)*x + randn(size(x));
theta = X\y(:);
yhat = theta(1) + theta(2)*x;
E_train_temp(i) = mean((yhat(:)-y(:)).^2);
E_test_temp(i) = mean((yhat(:)-y1(:)).^2);
end
E_train(j) = mean(E_train_temp);

427
CHAPTER 7. REGRESSION

E_test(j) = mean(E_test_temp);
end
semilogx(Nset, E_train, ’kx’, ’LineWidth’, 2, ’MarkerSize’, 16); hold on;
semilogx(Nset, E_test, ’ro’, ’LineWidth’, 2, ’MarkerSize’, 8);
semilogx(Nset, 1-2./Nset, ’k’, ’LineWidth’, 4);
semilogx(Nset, 1+2./Nset, ’r’, ’LineWidth’, 4);

import numpy as np
import matplotlib.pyplot as plt

Nset = np.logspace(1,3,20)
Nset = Nset.astype(int)
E_train = np.zeros(len(Nset))
E_test = np.zeros(len(Nset))
for j in range(len(Nset)):
N = Nset[j]
x = np.linspace(-1,1,N)
a = np.array([1, 2])
E_train_tmp = np.zeros(1000)
E_test_tmp = np.zeros(1000)
for i in range(1000):
y = a[0] + a[1]*x + np.random.randn(N)
X = np.column_stack((np.ones(N), x))
theta = np.linalg.lstsq(X, y, rcond=None)[0]
yhat = theta[0] + theta[1]*x
E_train_tmp[i] = np.mean((yhat-y)**2)
y1 = a[0] + a[1]*x + np.random.randn(N)
E_test_tmp[i] = np.mean((yhat-y1)**2)
E_train[j] = np.mean(E_train_tmp)
E_test[j] = np.mean(E_test_tmp)
plt.semilogx(Nset, E_train, ’kx’)
plt.semilogx(Nset, E_test, ’ro’)
plt.semilogx(Nset, (1-2/Nset), linewidth=4, c=’k’)
plt.semilogx(Nset, (1+2/Nset), linewidth=4, c=’r’)

The training error curve and the testing error curve behave in opposite ways as N
increases. The training error Etrain increases as N increases, because when we have more
training samples it becomes harder for the model to fit all the data. By contrast, the testing
error Etest decreases as N increases, because when we have more training samples the model
becomes more robust to noise and unseen data. Therefore, the testing error improves.
As N goes to infinity, both the training error and the testing error converge. This is
due to the law of large numbers, which says that the empirical training and testing errors
should converge to their respective expected values. If the training error and the testing error
converge to the same value, the training can generalize to testing. If they do not converge to
the same value, there is a mismatch between the training samples and the testing samples.
It is important to pay attention to the gap between the converged values. We often
assume that the training samples and the testing samples are drawn from the same distri-
bution, and therefore the training samples are good representatives of the testing samples.

428
7.3. BIAS AND VARIANCE TRADE-OFF

1.2
Training Error
1.15 Testing Error

1.1

1.05
Error

0.95

0.9

0.85

0.8
101 102 103
Number of training samples, N

Figure 7.14: The learning curve is a pair of functions representing the training error and the testing
error. As N increases we expect the training error to increase and the testing error to decrease. The two
functions will converge to the same value as N goes to infinity. If they do not converge to the same
value, there is an intrinsic mismatch between the training samples and the testing samples, e.g., the
training samples are not representative enough for the dataset.

If the assumption is not true, there will be a gap between the converged training error and
the testing error. Thus, what you claim in training cannot be transferred to the testing.
Consequently, the learning curve provides you with a useful debugging tool to check how
well your training compares with your testing.
Closing remark. In this section we have studied a very important concept in regression,
overfitting. We emphasize that overfitting is not only caused by the complexity of the model
but a combination of the three factors 2 , N , and d. We close this section by summarizing
the causes of overfitting:

What is the source of overfitting?


2
Overfitting occurs because you have an imbalance between , N and d.
Selecting the correct complexity for your model is the key to avoid overfitting.

7.3 Bias and Variance Trade-O↵

Our linear analysis has provided you with a rough understanding of what we experience in
overfitting. However, for general regression problems where the models are not necessarily
linear, we need to go deeper. The goal of this section is to explain the trade-o↵ between
bias and variance. This analysis requires some patience as it involves many equations. We
recommend skipping this section on a first reading and then returning to it later.

429
CHAPTER 7. REGRESSION

If it is your first time reading it, we recommend you go through it slowly.

7.3.1 Decomposing the testing error


Notations
As we did at the beginning of Section 7.2, we consider a ground truth model that relates
an input x and an output y:
y = f (x) + e,
where e ⇠ Gaussian(0, 2 ) is the noise. For example, if we use a linear model, then f could
be f (x) = ✓ T x, for some regression coefficients ✓.
During training, we pick a prediction model g✓ (·) and try to predict the output when
given a training sample x:
yb = g✓ (x).
For example, we may choose g✓ (x) = ✓ T x, which is also a linear model. We may also choose
a linear model in another basis, e.g., g✓ (x) = ✓ T (x) for some transformations (·). In any
case, the goal of training is to minimize the training error:
N
1 X
✓b = argmin
2
(g✓ (xn ) yn ) ,
✓ N n=1

where the sum is taken over the training samples Dtrain = {(x1 , y1 ), . . . , (xN , yN )}. Because
the model parameter ✓b is learned from the training dataset Dtrain , the prediction model
depends on Dtrain . To emphasize this dependency, we write

g (Dtrain ) = the model trained from (x1 , y1 ), . . . , (xN , yN ) .

During testing, we consider a testing dataset Dtest = {(x01 , y10 ), . . . , (x0M , yM


0
)}. We put
these testing samples into the trained model to predict an output:
0
ybm = g (Dtrain ) (x0m ), m = 1, . . . , M. (predicted value)

Since the goal of regression is to make g (Dtrain ) as close to f as possible, it is natural to


0 0
expect ybm to be close to ym .

Testing error decomposition (noise-free)


So we can now compute the testing error — the error that we ultimately care about. In the
noise-free condition, i.e., e = 0, the testing error is defined as
h i
(D ) 2
Etesttrain = Ex0 g (Dtrain ) (x0 ) f (x0 ) (7.23)
M ✓ ◆2
1 X
⇡ g (Dtraing ) (x0m ) f (x0m ) .
M m=1

There are several components in this equation. First, x0 is a testing sample drawn from a
certain distribution. You can think of Dtest as a finite subset drawn from this distribution.

430
7.3. BIAS AND VARIANCE TRADE-OFF

2
Second, the error g (Dtrain ) (x0 ) f (x0 ) measures the deviation between our predicted value
and the true value. Note that this error term is specific to one testing sample x0 . Therefore,
we take expectation Ex0 to find the average of the error for the distribution of x0 .
(D )
The testing error Etesttrain is a function that is dependent on the training set Dtrain ,
because the model g (Dtrain ) is trained from Dtrain . Therefore, as we change the training
set, we will have a di↵erent model g and hence a di↵erent testing error. To eliminate the
randomness of the training set, we define the overall testing error as

(D )
Etest = EDtrain Etesttrain
 h i
2
= EDtrain Ex0 g (Dtrain ) (x0 ) f (x0 ) . (7.24)

Note that this definition of the testing error is consistent with the special case in Equa-
tion (7.18), in which the testing error involves a joint expectation over e and e0 . The ex-
pectation over e accounts for the training samples, and the expectation over e0 accounts for
the testing samples.
Let us try to extract some meaning from the testing error. Our method will be to
decompose the testing error into bias and variance.

Theorem 7.5. Assume a noise-free condition. The testing error of a regression prob-
lem is given by

Etest = Ex0 (g(x0 ) f (x0 ))2 + EDtrain [(g (Dtrain ) (x0 ) g(x0 ))2 ] , (7.25)
| {z } | {z }
=bias(x0 ) =var(x0 )

def
where g(x0 ) = EDtrain [g (Dtrain ) (x0 )].

Proof. To simplify our notation, we will drop the subscript “train” in Dtrain when the
context is clear. We have that
h h ii
Etest = ED Ex0 (g (D) (x0 ) f (x0 ))2
h h ii
= Ex0 ED (g (D) (x0 ) f (x0 ))2 .

Continuing the calculation,


h h ii
Etest = Ex0 ED (g (D) (x0 ) g(x0 ) + g(x0 ) f (x0 ))2
 h i h i
= Ex0 ED (g (D) (x0 ) g(x0 ))2 + 2ED (g (D) (x0 ) g(x0 ))(g(x0 ) f (x0 ))
h i
+ ED (g(x0 ) f (x0 ))2 .

def
Since g(x0 ) = ED [g (D) (x0 )], it follows that
h i
2ED (g (D) (x0 ) g(x0 ))(g(x0 ) f (x0 )) = 0

431
CHAPTER 7. REGRESSION

because g(x0 ) f (x0 ) is independent of D, and


h i
ED (g(x0 ) f (x0 ))2 = (g(x0 ) f (x0 ))2 .

Therefore,
 h i h i
Etest = E x0 ED (g (D) (x0 ) g(x0 ))2 + (g(x0 ) f (x0 ))2 .

Thus, by defining two following terms we have proved the theorem.


def
bias(x0 ) = (g(x0 ) f (x0 ))2 ,
def
var(x0 ) = ED [(g (D) (x0 ) g(x0 ))2 ].


Let’s consider what this theorem implies. This result is a decomposition of the testing
error into bias and variance. It is a universal result that applies to all regression models,
not only linear cases. To summarize the meanings of bias and variance:

What are bias and variance?


Bias = how far your average is from the truth.
Variance = how much fluctuation you have around the average.

Figure 7.15 gives a pictorial representation of bias and variance. In this figure, we
construct four scenarios of bias and variance. Each cross represents the predictor g (Dtrain ) ,
with the true predictor f at the origin. Figure 7.15(a) shows the case with a low bias and
a low variance. All these predictors g (Dtrain ) are very close to the ground truth, and they
have small fluctuations around their average. Figure 7.15(b) shows the case of a high bias
and a low variance. It has a high bias because the entire group of g (Dtrain ) is shifted to the
corner. The bias, which is the distance from the truth to the average, is therefore large. The
variance remains small because the fluctuation around the average is small. Figure 7.15(c)
shows the case of a low bias but high variance. In this case, the fluctuation around the
average is large. Figure 7.15 shows the case of high bias and high variance. We want to
avoid this case.

Bias low Bias high Bias low Bias high


Var low Var low Var high Var high
(a) (b) (c) (d)

Figure 7.15: Imagine that you are throwing a dart with a target at the center. The four subfigures show
the levels of bias and variance.

432
7.3. BIAS AND VARIANCE TRADE-OFF

Testing error decomposition (noisy case)


Let us consider a situation when there is noise. In the presence of noise, the training and
testing samples will follow the relationship
y = f (x) + e,
where e ⇠ Gaussian(0, 2 ). We assume that the noise is Gaussian to make the proof easier.
We can consider other types of noise in theory, but the theoretical results will need to be
modified.
In the presence of noise, the testing error is
⇣ ⌘2
0 def
Etest (x ) = EDtrain ,e g (Dtrain ) (x0 ) f (x0 ) + e
⇣ ⌘2
= EDtrain ,e g (Dtrain ) (x0 ) g(x0 ) + g(x0 ) f (x0 ) + e ,

where we take the joint expectation over the training dataset Dtrain and the error e. Con-
tinuing the calculation, and using the fact that Dtrain and e are independent (and E[e] = 0),
it follows that
⇣ ⌘2
Etest (x ) = EDtrain ,e g (Dtrain ) (x0 ) g(x0 ) + g(x0 ) f (x0 ) + e
0

⇣ ⌘2 ⇣ ⌘2
= EDtrain ,e g (D) (x0 ) g(x0 ) + g(x0 ) f (x0 ) + e2
⇣ ⌘2 ⇣ ⌘2 h i
= EDtrain g (Dtrain ) (x0 ) g(x0 ) + g(x0 ) f (x0 ) + Ee e2 .
| {z } | {z
0
} | {z }
=bias(x ) =noise
=var(x0 )

Taking the expectation of x0 over the entire testing distribution gives us


Etest = Ex0 [Etest (x0 )] = Ex0 [var(x0 )] + Ex0 [bias(x0 )] + 2
.
| {z } | {z }
var bias

The theorem below summarizes the results:

Theorem 7.6. Assume a noisy condition where y = f (x) + e for some i.i.d. Gaussian
noise e ⇠ Gaussian(0, 2 ). The testing error of a regression problem is given by
 
Etest = Ex0 (g(x ) f (x )) + Ex0 EDtrain [(g (Dtrain ) (x0 ) g(x0 ))2 ] + 2 ,
0 0 2
(7.26)
| {z } | {z }
=bias(x0 ) =var(x0 )

def
where g(x0 ) = EDtrain [g (Dtrain ) (x0 )].

7.3.2 Analysis of the bias


Let us examine the bias and variance in more detail. To discuss bias we must first understand
the quantity
def
g(x0 ) = EDtrain [g (Dtrain ) (x0 )], (7.27)

433
CHAPTER 7. REGRESSION

which is known as the average predictor. The average predictor, as the equation suggests, is
the expectation of the predictor g (Dtrain ) . Remember that g (Dtrain ) is a predictor constructed
from a specific training set Dtrain . If tomorrow our training set Dtrain contains other data
(that come from the same underlying distribution), g (Dtrain ) will be di↵erent. The average
predictor g is the average across these random fluctuations of the dataset Dtrain . Here is an
example:
Suppose we use a linear model with the ordinary polynomials as the bases. The data
points are generated according to
d 1
X
yn = ✓p xpn + en . (7.28)
p=0
| {z }
def
= f (xn )=✓ T xn

If we use a particular training set Dtrain and run the regression, we will be able to obtain
one of the regression lines, as shown in Figure 7.16. Let us call this line g (1) . We repeat the
experiment by drawing another dataset, and call it g (2) . We continue and eventually we will
find a set of regression lines g (1) , g (2) , . . . , g (K) , where K denotes the number of training sets
you are using to generate all the gray curves. The average predictor g is defined as
K
0 (Dtrain ) 1 X (k) 0
g(x ) = EDtrain [g ]⇡ g (x ).
K
k=1

Thus if we take the average of all these gray curves we will obtain the average predictor,
which is the red curve shown in Figure 7.16.

-1
-1 -0.5 0 0.5 1

Figure 7.16: We run linear regression many times for di↵erent training datasets. Each one consists of
di↵erent random realizations of noise. The gray curves are the regression lines returned by each of the
training datasets. We then take the average of these gray curves to obtain the red curve, which is the
average predictor.

If you are curious about how this plot was generated, the MATLAB and Python codes
are given below.
% MATLAB code to visualize the average predictor
N = 20;

434
7.3. BIAS AND VARIANCE TRADE-OFF

a = [5.7, 3.7, -3.6, -2.3, 0.05];


x = linspace(-1,1,N);
yhat = zeros(100,50);
for i=1:100
X = [x(:).^0, x(:).^1, x(:).^2, x(:).^3, x(:).^4];
y = X*a(:) + 0.5*randn(N,1);
theta = X\y(:);
t = linspace(-1, 1, 50);
yhat(i,:) = theta(1) + theta(2)*t(:) + theta(3)*t(:).^2 ...
+ theta(4)*t(:)^3 + theta(5)*t(:).^4;
end
figure;
plot(t, yhat, ’color’, [0.6 0.6 0.6]); hold on;
plot(t, mean(yhat), ’LineWidth’, 4, ’color’, [0.8 0 0]);
axis([-1 1 -2 2]);

import numpy as np
import matplotlib.pyplot as plt
from scipy.special import eval_legendre
np.set_printoptions(precision=2, suppress=True)

N = 20
x = np.linspace(-1,1,N)
a = np.array([0.5, -2, -3, 4, 6])
yhat = np.zeros((50,100))
for i in range(100):
y = a[0] + a[1]*x + a[2]*x**2 + \
a[3]*x**3 + a[4]*x**4 + 0.5*np.random.randn(N)
X = np.column_stack((np.ones(N), x, x**2, x**3, x**4))

theta = np.linalg.lstsq(X, y, rcond=None)[0]


t = np.linspace(-1,1,50)
Xhat = np.column_stack((np.ones(50), t, t**2, t**3, t**4))
yhat[:,i] = np.dot(Xhat, theta)
plt.plot(t, yhat[:,i], c=’gray’)
plt.plot(t, np.mean(yhat, axis=1), c=’r’, linewidth=4)

We now show an analytic calculation to verify Figure 7.16.

Example 7.4. Consider a linear model such that

y = xT ✓ + e. (7.29)

What is the predictor g (Dtrain ) (x0 )? What is the average predictor g(x0 )?

Solution. First, consider a training dataset Dtrain = {(x1 , y1 ), . . . , (xN , yN )}. We


assume that the xn ’s are deterministic and fixed. Therefore, the source of randomness
in the training set is caused by the noise e ⇠ Gaussian(0, 2 ) and hence by the noisy

435
CHAPTER 7. REGRESSION

observation y.
The training set gives us the equation y = X✓ + e, where X is the matrix
constructed from xn ’s. The regression solution to this dataset is

✓b = (X T X) 1
X T y,
(Dtrain )
which should actually be ✓b because y is a dataset-dependent vector.
Consequently,
T
g (Dtrain ) (x0 ) = ✓b x0 = (x0 )T (X T X) 1
XT y
= (x0 )T (X T X) 1
X T (X✓ + e)
= (x0 )T ✓ + (x0 )T (X T X) 1
X T e.

Since the randomness of Dtrain is caused by the noise, it follows that

g(x0 ) = EDtrain [g (Dtrain ) (x0 )] = Ee [(x0 )T ✓ + (x0 )T (X T X) 1


X T e]
= (x0 )T ✓ + (x0 )T (X T X) 1
X T Ee [e]
= (x0 )T ✓ + 0 = f (x0 ).

So the average predictor will return the ground truth. However, note that not all
predictors will return the ground truth.

In the above example, we obtained an interesting result, namely that g(x0 ) = f (x0 ).
That is, the average predictor equals the true predictor. However, in general, g(x0 ) does
not necessarily equal f (x0 ). If this occurs, we have a deviation (g(x0 ) f (x0 ))2 > 0. This
deviation is called the bias. Bias is independent of the number of training samples because
we have taken the average of the predictors. Therefore, bias is more of an intrinsic (or
systematic) error due to the choice of the model.

What is bias?
Bias is defined as bias = Ex0 [(g(x0 ) f (x0 ))2 ], where x0 is a testing sample.
It is the deviation from the average predictor to the true predictor.
Bias is not necessarily a bad thing. A good predictor can have some bias as long
as it helps to reduce the variance.

7.3.3 Variance
The other quantity in the game is the variance. Variance at a testing sample x0 is defined
as
def
var(x0 ) = EDtrain [(g (Dtrain ) (x0 ) g(x0 ))2 ]. (7.30)
As the equation suggests, the variance measures the fluctuation between the predictor
g (Dtrain ) and the average predictor g. Figure 7.17 illustrates the polynomial-fitting prob-
lem we discussed above. In this figure we consider two levels of variance by varying the

436
7.3. BIAS AND VARIANCE TRADE-OFF

noise strength of en . The figure shows that as the observation becomes noisier, the predictor
g (Dtrain ) will have a larger fluctuation for the average predictor.
2 2

1 1

0 0

-1 -1

-2 -2
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) small variance (b) large variance

Figure 7.17: Variance measures the magnitude of fluctuation between the particular predictor g (Dtrain )
and the average predictor g.

Example 7.5. Continuing with Example 7.4, we ask: What is the variance?

Solution. We first determine the predictor and its average:

g (Dtrain ) = (X T X) 1
X T y = ✓ + (X T X) 1
XT e
g = E[g (Dtrain ) ] = Ee [✓ + (X T X) 1
X T e] = ✓,

so the prediction at a testing sample x0 is

g (Dtrain ) (x0 ) = (x0 )T ✓ + (x0 )T (X T X) 1


XT e
g(x0 ) = (x0 )T ✓,

Consequently, the variance is


⇣ ⌘2 ⇣ ⌘2
EDtrain g (Dtrain ) 0 0
(x ) g(x ) = Ee (x0 )T ✓ + (x0 )T (X T X) 1 X T e (x0 )T ✓
⇣ ⌘2
= Ee (x0 )T (X T X) 1 X T e .

Continuing the calculation,


⇣ ⌘2
EDtrain g (Dtrain ) (x0 ) g(x0 ) = (x0 )T (X T X) 1
X T Ee [eeT ]X(X T X) 1
x0

= (x0 )T (X T X) 1
XT 2
IX(X T X) 1
x0
= (x0 )T (X T X) 1 x0
2
n o
= 2 Tr (X T X) 1 (x0 )(x0 )T .

437
CHAPTER 7. REGRESSION

What will happen if we use more samples so that N grows? As N grows, the matrix X will
have more rows. Assuming that the magnitude of the entries remains unchanged, more rows
in X will increase the magnitude of X T X because we are summing more terms. Consider
a 2 ⇥ 2 ordinary polynomial system where
2PN PN 3
2
n=1 xn n=1 xn
X T X = 4P 5.
N
n=1 xn N
T 1
As N grows, all the entries in the matrix
n grow. As a result, (X
o X) will shrink in mag-
2 T 1 0 0 T
nitude and thus drive the variance Tr (X X) (x )(x ) to zero.

What is variance?
Variance is the deviation between the predictor g (Dtrain ) and its average g.
It can be reduced by using more training samples.

7.3.4 Bias and variance on the learning curve


The decomposition of the testing error into bias and variance is portrayed visually by the
learning curve shown in Figure 7.18. This figure shows the testing error and the training
error as functions of the number of training samples. As N increases, we observe that both
testing and training errors converge to the same value. At any fixed N , the testing error is
composed of bias and variance:
The bias is the distance from the ground to the steady-state level. This value is fixed
and is a constant w.r.t. N . In other words, regardless of how many training samples
you have, the bias is always there. It is the best outcome you can achieve.
The variance is the fluctuation from the steady-state level to the instantaneous state.
It drops as N increases.

Figure 7.18: The learning curve can be decomposed into the sum of the bias and the variance. The bias
is the testing error when N = 1. For finite N , the di↵erence between the testing error and the bias is
the variance.

438
7.3. BIAS AND VARIANCE TRADE-OFF

Figure 7.19 compares the learning curve of two models. The first case requires us to
fit the data using a simple model (marked in purple). The training error and the testing
error have small fluctuations around the steady-state because, for simple models, you need
only a small number of samples to make the model happy. The second case requires us to
fit the data using a complex model (marked in green). This set of curves has a much wider
fluctuation because it is harder to train and harder to generalize. However, when we have
enough training samples, the training error and the testing error will converge to a lower
steady-state value. Therefore, you need to pay the price of using a complex model, but if
you do, you will enjoy a lower testing error.

2.5
Simple Model - Training Error
Simple Model - Testing Error
2 Complex Model - Training Error
Complex Model - Testing Error
1.5
Error

0.5

0
101 102 103
Number of training samples, N

Figure 7.19: The generalization capability of a model is summarized by the training and testing errors
of the model. If we use a simple model we will have an easier time with the training but the steady-state
testing error will be high. In contrast, if we use a complex model we need to have a sufficient number
of training samples to train the model well. However, when the complex model is well trained, the
steady-state error will be lower.

The implication of all this is that you should choose the model by considering the
number of data points. Never buy an expensive toy when you do not have the money! If
you insist on using a complex model while you do not have enough training data, you will
su↵er from a poor testing error even if you feel good about it.

Closing remark. We close this section by revisiting the bias-variance trade-o↵:


 
Etest = Ex0 (g(x ) f (x )) + Ex0 EDtrain [(g (Dtrain ) (x0 ) g(x0 ))2 ] + 2 .
0 0 2
(7.31)
| {z } | {z }
=bias(x0 ) =var(x0 )

The relationship among the three terms is summarized below:

What is the trade-o↵ o↵ered by the bias-variance analysis?


Overfitting improves if N ": Variance drops as N grows. Bias is unchanged.
Overfitting worsens if 2 ". If training noise grows, g (Dtrain ) will have more fluc-
tuations, so variance will grow. If testing noise grows, e2 grows.

439
CHAPTER 7. REGRESSION

Overfitting worsens if the target function f is too complicated to be approximated


by g.

End of the section. Please join us again.

7.4 Regularization

Having discussed the source of the overfitting problem, we now discuss methods to allevi-
ate overfitting. The method we focus on here is regularization. Regularization means that
instead of seeking the model parameters by minimizing the training loss alone, we add a
penalty term to force the parameters to“behave better”. As a preview of the technique, we
change the original training loss
N ✓
X d 1
X ◆2
Etrain (✓) = yn ✓p p (xn ) , (7.32)
n=1 p=0
| {z }
data fidelity

which consists of only the data fidelity term, to a modified training loss
N ✓
X d 1
X ◆2 d 1
X
Etrain (✓) = yn ✓p p (xn ) + · ✓p2 . (7.33)
n=1 p=0 p=0
| {z } | {z }
F (✓), data fidelity ·R(✓), regularization

Putting this into the matrix form, we define the data fidelity term as
F (✓) = kX✓ yk2 . (7.34)
The newly added term R(✓) is called the regularization function or the penalty function.
It can take a variety of forms, e.g.,
Pd 1
Ridge regression: R(✓) = p=0 ✓p2 = k✓k2 .
Pd 1
LASSO regression: R(✓) = p=0 |✓p | = k✓k1 .
In this section we aim to understand the role of the regularization functions by studying
these two examples of R(✓).

7.4.1 Ridge regularization


To explain the meaning of Equation (7.33) we write it in terms of matrices and vectors:
minimize kX✓ yk2 + k✓k2 , (7.35)
✓2Rd

where is called the regularization parameter.It needs to be tuned by the user. We refer
to Equation (7.35) as the ridge regression.5
5 In signal processing and optimization, Equation (7.35) is called the Tikhonov regularization. We follow

the statistics community in calling it the ridge regression.

440
7.4. REGULARIZATION

How can the regularization function help to mitigate the overfitting problem? First
let’s find the solution to this problem.

Practice Exercise 1. Prove that the solution to Equation (7.35) is

✓b = (X T X + I) 1
X T y. (7.36)

Solution. Take the derivative with respect to ✓.a This yields



r✓ kX✓ yk2 + k✓k2 = 2X T (X✓ y) + 2 ✓ = 0.

Rearranging the terms gives

(X T X + I)✓ = X T y.

Taking the inverse of the matrix on both sides yields the solution.
a The solution here requires some basic matrix calculus. You may refer to the University of Water-

loo’s Matrix Cookbook https://www.math.uwaterloo.ca/~hwolkowi/matrixcookbook.pdf.

Let us compare the ridge regression solution with the vanilla regression solutions:
✓bvanilla = (X T X) 1
X T y,
✓bridge ( ) = (X T X + I) 1
X T y.
Clearly, the only di↵erence is the presence of the parameter :
If ! 0, then ✓bridge (0) = ✓bvanilla . This is because
Etrain (✓) = kX✓ yk2 + k✓k2 .
| {z }
=0

Hence, when ! 0, the regression problem goes back to the vanilla version, and so
does the solution.
! 1, then ✓bridge (1) = 0. This happens because
1
Etrain (✓) = kX✓ yk2 + k✓k2 .
| {z }
=0
2
Since we are now minimizing k✓k , the solution will be ✓ = 0 because zero is the
smallest value a squared function can achieve.
For any 0 < < 1, the net e↵ect of (X T X + I) is the constant added to all the
eigenvalues of X T X. By taking the eigendecomposition of X T X,
[U , S] = eig(X T X),
we have that
X T X + I = U SU T + I
= U SU T + U U T = U (S + I)U T .

441
CHAPTER 7. REGRESSION

Therefore, if the eigenvalue matrix S has a zero eigenvalue it will be o↵set by :


2 3 2 3
| |+
6 ~ 7 6 ~+ 7
S=6 4
7
5 ! S+ I=6 4
7
5
 +
0

As a result, even if X T X is not invertible (or close to not invertible), the new matrix
X T X + I is guaranteed to be invertible.

Practice Exercise 2. You may be wondering what happens if X T X has a negative


eigenvalue so that when we add a positive , the resulting matrix may have a zero
eigenvalue. Prove that X T X will never have a negative eigenvalue, and X T X + I
always has positive eigenvalues.

Solution. Eigenvalues of a matrix A are nonnegative if and only if v T Av 0 for


any v. Thus we need to check whether v T X T Xv 0 for all v. However, this is easy:

v T X T Xv = kXvk2 ,

which must be nonnegative for any v. Matrices satisfying this property are called
positive semidefinite. Therefore, X T X is positive semidefinite.

Implementation
Solving the ridge regression is easy. First, we observe that the regularization function R(✓) =
k✓k2 is a quadratic function. Therefore, it can be combined with the data fidelity term as
✓b = argmin kX✓ yk2 + k✓k2
✓2Rd
p
= argmin kX✓ yk2 + k I✓ 0k2
✓2Rd
  2
= argmin pX ✓ y
.
✓2Rd I 0
Therefore,
p all we need to do is to concatenate the matrix X with a d ⇥ d identity operator
I, and concatenate y with a d ⇥ 1 all-zero vector.
In MATLAB and Python, the implementation of the ridge regression is done by defining
a new matrix A and a new vector b, as shown below:
% MATLAB command for ridge regression
A = [X; sqrt(lambda)*eye(d)];
b = [y(:); zeros(d,1)];
theta = A\b;

% MATLAB command for ridge regression


A = np.vstack((X, np.sqrt(lambd)*np.eye(d)))
b = np.hstack((y, np.zeros(d)))
theta = np.linalg.lstsq(A, b, rcond=None)[0]

442
7.4. REGULARIZATION

Example 7.6. Consider a dataset of N = 20 data points. These data points are
constructed from the model

yn = 0.5 2xn 3x2n + 4x3n + 6x4N + en , n = 1, . . . , N,

where en ⇠ Gaussian(0, 0.252 ) is the noise. Fit the data using


(a) Vanilla linear regression with a 4th-order polynomial.
(b) Vanilla linear regression with a 20th-order polynomial.
(c) Ridge regression with a 20th-order polynomial, by considering three choices of :
= 10 6 , = 10 3 , and = 10.
Solution.
(a) We first fit the data using a 4th-order polynomial. This fitting is relatively
straightforward. In the MATLAB / Python programs below, set d = 4 and
= 0. The result is shown in Figure 7.20(a).
4 4

3 3

2 2

1 1

0 0
data data
fitted curve fitted curve
-1 -1
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1

(a) Vanilla, 4th-order polynomial (b) Vanilla, 20th-order polynomial

Figure 7.20: Overfitting occurs when the model is too complex for the number of training samples.
When using a vanilla regression with a 20th-order polynomial, the curve overfits the data and
causes a catastrophic fitting error.
P20
(b) Suppose we use a 20th-order polynomial g(x) = p=0 ✓p xp to fit the data. We
plot the result in Figure 7.20(b). Since the order of the polynomial is very high
relative to the number of training samples, it comes as no surprise that the fitting
is poor. This is overfitting, and we know the reason.
(c) Next, we consider a ridge regression using three choices of . The result is shown
in Figure 7.21. If is too small, we observe that some overfitting still occurs. If
is too large, then the curve underfits the data. For an appropriately chosen ,
it can be seen that the fitting is reasonably good.

443
CHAPTER 7. REGRESSION

4 4 4

3 3 3

2 2 2

1 1 1

0 0 0
data data data
fitted curve fitted curve fitted curve
-1 -1 -1
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1

6 3
(a) Ridge, = 10 (b) Ridge, = 10 (c) Ridge, = 10

Figure 7.21: Ridge regression addresses the overfitting problem by adding a regularization term
to the training loss. Depending on the strength of the parameter , the fitted curve can vary from
overfitting to underfitting.

The MATLAB and Python codes used to generate the above plots are shown below.

% MATLAB code to demonstrate a ridge regression example


% Generate data
N = 20;
x = linspace(-1,1,N);
a = [0.5, -2, -3, 4, 6];
y = a(1)+a(2)*x(:)+a(3)*x(:).^2+a(4)*x(:).^3+a(5)*x(:).^4+0.25*randn(N,1);

% Ridge regression
lambda = 0.1;
d = 20;
X = zeros(N, d);
for p=0:d-1
X(:,p+1) = x(:).^p;
end
A = [X; sqrt(lambda)*eye(d)];
b = [y(:); zeros(d,1)];
theta = A\b;

% Interpolate and display results


t = linspace(-1, 1, 500);
Xhat = zeros(length(t), d);
for p=0:d-1
Xhat(:,p+1) = t(:).^p;
end
yhat = Xhat*theta;
plot(x,y, ’ko’,’LineWidth’,2, ’MarkerSize’, 10); hold on;
plot(t,yhat,’LineWidth’,4,’Color’,[0.2 0.2 0.9]);

# Python code to demonstrate a ridge regression example


import numpy as np
import matplotlib.pyplot as plt
from scipy.special import eval_legendre
np.set_printoptions(precision=2, suppress=True)

444
7.4. REGULARIZATION

N =
20
x =
np.linspace(-1,1,N)
a =
np.array([0.5, -2, -3, 4, 6])
y =
a[0] + a[1]*x + a[2]*x**2 + \
a[3]*x**3 + a[4]*x**4 + 0.25*np.random.randn(N)
d = 20
X = np.zeros((N, d))
for p in range(d):
X[:,p] = x**p

lambd = 0.1
A = np.vstack((X, np.sqrt(lambd)*np.eye(d)))
b = np.hstack((y, np.zeros(d)))
theta = np.linalg.lstsq(A, b, rcond=None)[0]

t = np.linspace(-1, 1, 500)
Xhat = np.zeros((500,d))
for p in range(d):
Xhat[:,p] = t**p
yhat = np.dot(Xhat, theta)

plt.plot(x,y,’o’,markersize=12)
plt.plot(t,yhat, linewidth=4)
plt.show()

Why does ridge regression work?


The penalty term k✓k2 in

✓bridge = argmin kX✓ yk2 + k✓k2


✓2Rd

does not allow solutions with very k✓k2 .


The penalty term adds a positive o↵set to the eigenvalues of X T X.
Since the denominator in (X T X + I) 1 X T y becomes larger than that of
(X T X) 1 X T y, noise in y is less amplified.

Choosing the parameter


How should we choose the parameter ? The honest answer is that there is no answer
because the optimal can only be found if we have access to the testing samples. If we do,
we can plot the MSE (the testing error) with respect to , as shown in Figure 7.22(a).
Of course in reality we do not have access to the testing data. However, we can reserve
a small portion of the training samples and treat them as validation samples. Then we
run the ridge regression for di↵erent choices of . The that minimizes the error on these
validation samples is the one that you should deploy. If the training set is small, we can

445
CHAPTER 7. REGRESSION

10-1
0.3

0.25

0.2
10-2
0.15

0.1

0.05

10-3 0
10-10 10-5 100 100 105

(a) Testing error vs (b) F (✓b ) vs R(✓b )

Figure 7.22: (a) Determining the optimal requires knowledge of the testing samples. In practice, we
can replace the testing samples with the validation samples, which are subsets of the training data. Then
by plotting the validation error as a function of we can determine the optimal . (b) The alternative
is to plot F (✓b ) versus R(✓b ). The optimal can be found by locating the elbow point.

shu✏e the validation samples randomly and compute the average. This scheme is known as
cross-validation.
For some problems, there are “tactics” you may be able to employ for determining
the optimal . The first approach is to ask yourself what would be the reasonable range
of k✓k2 or kX✓ yk2 ? Are you expecting them to be large or small? Approximately in
what order of magnitude? If you have some clues about this, then you can plot the function
F (✓b ) = kX ✓b yk2 as a function of R(✓b ) = k✓b k2 , where ✓b is a shorthand notation
for ✓bridge ( ), which is the estimated parameter using a specific value of . Figure 7.22(b)
shows an example of such a plot. As you can see, by varying we have di↵erent values of
F (✓b ) and R(✓b ).
If you have some ideas about what k✓k2 should be, say you want k✓k2  ⌧ , you can go
to the F (✓b ) versus R(✓b ) curve and find a point such that R(✓b )  ⌧ . On the other hand,
if you want kX✓ yk2  ✏, you can also go to the F (✓b ) versus R(✓b ) curve and find a
point such that kX✓ yk2  ✏. In either case, you have the freedom to shift the difficulty
of finding to that of finding ⌧ or ✏. Note that ⌧ and ✏ have better physical interpretations.
The quantity ✏ tells us the upper bound of the prediction error, and ⌧ tells us the upper
bound of the parameter magnitude. If you have been working on your dataset long enough,
the historical data (and your experience) will help you determine these values.
Another feasible option suggested in the literature is finding the anchor point of the
F (✓b ) and R(✓b ). The idea is that if the curve has a sharp elbow, the turning point would
indicate a rapid increase/decrease in F (✓b ) (or R(✓b )).

How to determine
Cross-validation: Reserve a few training samples as validation samples. Check
the prediction error w.r.t. these validation samples. The that minimizes the
validation error is the one you deploy.
k✓k2  ⌧ : Plot the F (✓b ) and R(✓b ). Then go along the R-axis to find the

446
7.4. REGULARIZATION

position where R(✓b )  ⌧ .


kX✓ yk2  ⌧ : Plot the F (✓b ) and R(✓b ). Then go along the F -axis to find
the position where F (✓b )  ✏.
Find the elbow point of F (✓b ) and R(✓b ).

Bias and variance trade-o↵ for ridge regression


We now discuss the bias and variance trade-o↵ of the ridge regression.

Theorem 7.7. Let y = X✓ + e be the training data, where e is zero-mean and has a
covariance 2 I. Consider the ridge regression

✓b = argmin kX✓ yk2 + k✓k2 . (7.37)


✓2Rd

Then the estimate has the properties that

✓b = (X T X + I) 1 X T X✓ + (X T X + I) 1 X T e,
E[✓b ] = (X T X + I) 1 X T X✓ = W ✓,
Cov[✓b ] = 2 (X T X + I) 1 X T X(X T X + I) 1 ,

MSE(✓b , ✓) = 2 Tr W (X T X) 1 W T + ✓ T (W I)T (W I)✓,

where W = (X T X + I) 1
X T X.

Proof. The proof of this theorem involves some tedious matrix operations that will be
omitted here. If you are interested in the proof you can consult van Wieringen’s “Lecture
notes on ridge regression”, https://arxiv.org/pdf/1509.09169.pdf.

The results of this theorem provide a way to assess the bias and variance. Specifically,
from the MSE we know that
h i
MSE(✓b , ✓) = Ee k✓b ✓k2
n o
= kEe [✓b ] ✓k2 + Tr Cov[✓b ]

= ✓ T (W I)T (W I)✓ + 2 Tr W (X T X) 1 W T .
| {z }
bias | {z }
variance

The bias and variance are defined respectively as


Bias(✓b , ✓) = ✓ T (W I)T (W I)✓,

Var(✓b , ✓) = 2 Tr W (X T X) 1
WT .

We can then plot the bias and variance as a function of . An example is shown in Fig-
ure 7.23.

447
CHAPTER 7. REGRESSION

103

102

101

100 MSE
Bias
Variance
10-1
10-4 10-3 10-2 10-1

Figure 7.23: The bias and variance of the ridge regression behave in opposite ways as increases. The
MSE is the sum of bias and variance.

The result in Figure 7.23 can be summarized in three points:


Bias " as ". This is because a large pushes the solution towards ✓ = 0. Therefore,
the bias with respect to the ground truth ✓ will increase.
Variance # as ". Since variance is caused by noise, increasing forces the solution
✓ to be small. Hence, it becomes less sensitive to noise.
MSE reaches a minimum point somewhere in the middle. The MSE is the sum of bias
and variance. Therefore, it drops to the minimum and then rises again as increases.
With appropriate choice of , we can show that the ridge regression can have a
lower mean squared error than the vanilla regression. The following result is due to C. M.
Theobald:6

2
Theorem 7.8. For <2 k✓k 2 ,
⇣ ⌘ ⇣ ⌘
MSE ✓bridge ( ), ✓ < MSE ✓bvanilla , ✓ . (7.38)

This theorem says that as long as is small enough, the ridge regression will have a lower
MSE than the vanilla regression. Thus ridge regression is almost always helpful. Of course,
the optimal is not provided by the theorem, which only tells us where to search for a
good .

Why does ridge regression reduce the testing error?


The regularization reduces the variance (see Figure 7.23 when > 0)
It pays the price of increasing the bias.

6 Theobald, C. M. (1974). Generalizations of mean square error applied to ridge regression. Journal of

the Royal Statistical Society. Series B (Methodological), 36(1), 103-106.

448
7.4. REGULARIZATION

Usually, the drop in variance outweighs the increase in bias. So the overall MSE
drops.
Bias is not always a bad thing.

7.4.2 LASSO regularization


The ridge regression we discussed in the previous subsection is just one of the many possible
ways of doing regularization. One alternative is to replace k✓k2 by k✓k1 , where
d 1
X
k✓k1 = |✓p |. (7.39)
p=0

This change from the sum-squares to sum-absolute-values has been main driving force in
data science, machine learning, and signal processing for at least the past two decades. The
optimization associated with k✓k1 is

minimize kX✓ yk2 + k✓k1 , (7.40)


✓2Rd

or
N ✓
X d 1
X ◆2 d 1
X
Etrain (✓) = yn ✓p p (xn ) + · |✓p | . (7.41)
n=1 p=0 p=0
| {z } | {z }
F (✓), data fidelity ·R(✓), regularization

Seeking a sparse solution


To understand the choice of k · k1 , we need to introduce the concept of sparsity.

Definition 7.1. A vector ✓ is called sparse if it has only a few non-zero elements.

As illustrated in Figure 7.24, a sparse ✓ ensures that only a very few columns of the data
matrix X are active. This is an attractive property because, in some of the regression
problems, it is indeed possible to have just a few dominant factors. The LASSO regression
says that if our problem possesses this sparse solution, then the k · k1 can help us find the
sparse solution.

Figure 7.24: A vector ✓ is sparse if it only contains a few non-zero elements. If ✓ is sparse, then the
observation y is determined by a few active components.

449
CHAPTER 7. REGRESSION

How can k✓k1 promote sparsity? If we consider the sets

⌦1 = {✓ | k✓k1  ⌧ } = {(✓1 , ✓2 ) | |✓1 | + |✓2 |  ⌧ },


⌦2 = {✓ | k✓k2  ⌧ } = {(✓1 , ✓2 ) | ✓12 + ✓22  ⌧ },

we note that ⌦1 has a diamond shape whereas ⌦2 has a circular shape. Since the data
fidelity term kX✓ yk2 is an ellipsoid, seeking the optimal value in the presence of the
regularization term can be viewed as moving the ellipsoid until it touches the set defined
by the regularization. As illustrated in Figure 7.25, since {✓ | k✓k2  ⌧ } is a circle, the
solution will be somewhere in the middle. On the other hand, since {✓ | k✓k1  ⌧ } is a
diamond, the solution will be one of the vertices. The di↵erence between “somewhere in
the middle” and “a vertex” is that the vertex is a sparse solution, since by the definition of
a vertex one coordinate must be zero and the other coordinate must be non-zero. We can
easily extrapolate this idea to the higher-dimensional spaces. In this case, we will see that
the solution for the k · k1 problem has only a few non-zero entries.

Figure 7.25: A vector ✓ is sparse if it contains only a few non-zero elements. If ✓ is sparse, then the
observation y is determined by a few active components.

The optimization formulated in Equation (7.41) is known as the least absolute shrink-
age and selection operator (LASSO). LASSO problems are difficult, but over the past two
decades we have increased our understanding of the problem. The most significant break-
through is that we now have algorithms to solve the LASSO problem efficiently. This is
important because, unlike the ridge regression, where we have a (very simple) closed-form
solution, the LASSO problem can only be solved using iterative algorithms.

What is so special about LASSO?


LASSO regularization promotes a sparse solution.
If the underlying model has a sparse solution, e.g., you choose a 50th-order
polynomial, but the underlying model is a third-order polynomial, then there
should only be three non-zero regression coefficients in your 50th-order polyno-
mial. LASSO will help in this case.

450
7.4. REGULARIZATION

If the underlying model has a dense solution, then LASSO is of limited value. A
ridge regression could be better.
While k✓k1 is not di↵erentiable (at 0), there exist polynomial-time convex algo-
rithms to solve the problem, e.g., interior-point methods.

Solving the LASSO problem


Today, there are many open-source packages to solve the LASSO problem. They are mostly
developed in the convex optimization literature. One of the most user-friendly packages is
the CVX package developed by S. Boyd and colleagues at Stanford University.7 Once you
have downloaded and installed the package, solving the optimization can be done literally
by typing in the data fidelity term and the regularization term. An example is given below.
cvx_begin
variable theta(d)
minimize(sum_square(X*theta-y) + lambda*norm(theta,1))
cvx_end

As you can see, the program is extremely simple. You start by calling cvx_begin
and end it with cvx_end. Inside the box we create a variable beta(d), where d denotes
the dimension of the vector theta. The main command is minimize. However, this line is
almost self-explanatory. As long as you follow the syntax given by the user guidelines, you
will be able to set it up properly.
In Python, we can call the cvxpy library.
import cvxpy as cvx
theta = cvx.Variable(d)
objective = cvx.Minimize( cvx.sum_squares(X*theta-y) \
+ lambd*cvx.norm1(theta) )
prob = cvx.Problem(objective)
prob.solve()

To see a concrete example, we use the crime rate data obtained from https://web.
stanford.edu/~hastie/StatLearnSparsity/data.html. A snapshot of the data is shown
in the table below. In this dataset, the vector y is the crime rate, which is the last column
of the table. The feature/basis vectors are funding, hs, not-hs, college.

city crime rate funding hs no-hs college


1 478 40 74 11 31
2 494 32 72 11 43
3 643 57 71 18 16
4 341 31 71 11 25
.. .. .. .. .. ..
. . . . . .
50 940 66 67 26 18

7 The MATLAB version is here: http://cvxr.com/cvx/. The Python version is here: https://cvxopt.

org/. Follow the instructions to install the package.

451
CHAPTER 7. REGRESSION

We consider two optimizations:

b1 ( ) = argmin E1 (✓) def


✓ = kX✓ yk2 + k✓k1 ,

b2 ( ) = argmin E2 (✓) def
✓ = kX✓ yk2 + k✓k2 .

As we have discussed, the first optimization uses the k · k1 regularized least squares, which is
the LASSO problem. The second optimization is the standard k·k2 regularized least squares.
Since both solutions depend on the parameter , we parameterize the solutions in terms of
. Note that the optimal for ✓ b1 is not necessarily the optimal for ✓ b2 .
One thing we would like to demonstrate in this example is visualizing the linear re-
b1 ( ) and ✓
gression coefficients ✓ b2 ( ) as changes. To solve the optimization, we use CVX
with the MATLAB and Python implementation is shown below.
data = load(’./dataset/data_crime.txt’);
y = data(:,1); % The observed crime rate
X = data(:,3:end); % Feature vectors
[N,d]= size(X);

lambdaset = logspace(-1,8,50);
theta_store = zeros(d,50);
for i=1:length(lambdaset)
lambda = lambdaset(i);
cvx_begin
variable theta(d)
minimize( sum_square(X*theta-y) + lambda*norm(theta,1) )
% minimize( sum_square(X*theta-y) + lambda*sum_square(theta) )
cvx_end
theta_store(:,i) = theta(:);
end

figure(1);
semilogx(lambdaset, theta_store, ’LineWidth’, 4);
legend(’funding’,’% high’, ’% no high’, ’% college’, ...
’% graduate’, ’Location’,’NW’);
xlabel(’lambda’);
ylabel(’feature attribute’);

import cvxpy as cvx


import numpy as np
import matplotlib.pyplot as plt

data = np.loadtxt("/content/data_crime.txt")
y = data[:,0]
X = data[:,2:7]
N,d = X.shape

lambd_set = np.logspace(-1,8,50)

452
7.4. REGULARIZATION

theta_store = np.zeros((d,50))
for i in range(50):
lambd = lambd_set[i]
theta = cvx.Variable(d)
objective = cvx.Minimize( cvx.sum_squares(X*theta-y) \
+ lambd*cvx.norm1(theta) )
# objective = cvx.Minimize( cvx.sum_squares(X*theta-y) \
+ lambd*cvx.sum_squares(theta) )
prob = cvx.Problem(objective)
prob.solve()
theta_store[:,i] = theta.value

for i in range(d):
plt.semilogx(lambd_set, theta_store[i,:])

14 14
funding funding
12 % high 12 % high
% no high % no high
10 % college 10 % college
feature attribute

feature attribute

% graduate % graduate
8 8

6 6

4 4

2 2

0 0

-2 -2
10-2 100 102 104 106 108 10-2 100 102 104 106 108
lambda lambda

(a) LASSO (b) Ridge

Figure 7.26: Ridge and LASSO regression on the crime-rate dataset. (a) The LASSO regression suggests
that there are only a few active components as we change . (b) The ridge regression returns a set of
dense solutions for all choices of .

Figure 7.26 shows some interesting di↵erences between the two regression models.

Trajectory. For the k · k2 estimate ✓b2 ( ), the trajectory of the regression coefficients
is smooth. This is attributable to the fact that the training loss E2 (✓) is continuously
di↵erentiable in ✓, and so the solution trajectory is smooth. By contrast, the k · k1
estimate ✓b1 ( ) has a more disruptive trajectory.
Active members. For the LASSO problem, ✓b1 ( ) switches the active member as
changes. For example, the feature high-school is the first one being activated when
#. This implies that if we limit ourselves to only one feature, then high-school is
the feature we should select. The ridge regression does not have this feature-selection
property. How about when = 106 ? In this case, the LASSO has two active members:
funding and high-school. This suggests that if there are two contributing factors,
funding and high-school are the two. As = 104 , we see that in LASSO, the green
curve goes to zero but then the red curve rises. This means a correlation between

453
CHAPTER 7. REGRESSION

high school and no high school, which should not be a surprise because they are
complementary to each other.
Magnitude of solutions. The magnitude of the solutions does not necessarily convey
a clear conclusion because the feature vectors (e.g., high school) and the observable
crime rate have di↵erent units.
Limiting solutions. As ! 0, both ✓b1 ( ) and ✓b2 ( ) reach the same solution, because
the training losses are identical when = 0.

LASSO for overfitting


Does LASSO help to mitigate the overfitting problem? Not always, but it often does. In
Figure 7.27 we consider fitting a dataset of N = 20 data points. The ground truth model
we use is

yn = L0 (xn ) + 0.5L1 (xn ) + 0.5L2 (xn ) + 1.5L3 (xn ) + L4 (xn ) + en ,

where en ⇠ Gaussian(0, 2 ) for = 0.25. When fitting the data, we purposely choose a
20th-order Legendre polynomial as the regression model. With only N = 20 data points, we
can be almost certain that there is overfitting.
The MATLAB and Python codes for solving this LASSO problem are shown below.

% MATLAB code to demonstrate overfitting and LASSO


% Generate data
N = 20;
x = linspace(-1,1,N)’;
a = [1, 0.5, 0.5, 1.5, 1];
y = a(1)*legendreP(0,x)+a(2)*legendreP(1,x)+a(3)*legendreP(2,x)+ ...
a(4)*legendreP(3,x)+a(5)*legendreP(4,x)+0.25*randn(N,1);

% Solve LASSO using CVX


d = 20;
X = zeros(N, d);
for p=0:d-1
X(:,p+1) = reshape(legendreP(p,x),N,1);
end
lambda = 2;
cvx_begin
variable theta(d)
minimize( sum_square( X*theta - y ) + lambda * norm(theta , 1) )
cvx_end

% Plot results
t = linspace(-1, 1, 200);
Xhat = zeros(length(t), d);
for p=0:d-1
Xhat(:,p+1) = reshape(legendreP(p,t),200,1);
end
yhat = Xhat*theta;

454
7.4. REGULARIZATION

plot(x,y, ’ko’,’LineWidth’,2, ’MarkerSize’, 10); hold on;


plot(t,yhat,’LineWidth’,6,’Color’,[0.2 0.5 0.2]);

# Python code to demonstrate overfitting and LASSO


import cvxpy as cvx
import numpy as np
import matplotlib.pyplot as plt

# Setup the problem


N = 20
x = np.linspace(-1,1,N)
a = np.array([1, 0.5, 0.5, 1.5, 1])
y = a[0]*eval_legendre(0,x) + a[1]*eval_legendre(1,x) + \
a[2]*eval_legendre(2,x) + a[3]*eval_legendre(3,x) + \
a[4]*eval_legendre(4,x) + 0.25*np.random.randn(N)

# Solve LASSO using CVX


d = 20
lambd = 1
X = np.zeros((N, d))
for p in range(d):
X[:,p] = eval_legendre(p,x)
theta = cvx.Variable(d)
objective = cvx.Minimize( cvx.sum_squares(X*theta-y) \
+ lambd*cvx.norm1(theta) )
prob = cvx.Problem(objective)
prob.solve()
thetahat = theta.value

# Plot the curves


t = np.linspace(-1, 1, 500)
Xhat = np.zeros((500,d))
for p in range(P):
Xhat[:,p] = eval_legendre(p,t)
yhat = np.dot(Xhat, thetahat)
plt.plot(x, y, ’o’)
plt.plot(t, yhat, linewidth=4)

Let us compare the various regression results. Figure 7.27(b) shows the vanilla regres-
sion, which as you can see fits the N = 20 data points very well. However, no one would
believe that such a fitting curve can generalize to unseen data. Figure 7.27(c) shows the
ridge regression result. When performing the analysis, we sweep a range of and pick the
value = 0.5 so that the fitted curve is neither too “wild” nor too “flat”. We can see that
the fitting is improved. However, since the ridge regression only penalizes large-magnitude
coefficients, the fitting is still not ideal. Figure 7.27(d) shows the LASSO regression result.
Since the true model is a 4th-order polynomial and we use a 20th-order polynomial, the true
solution is sparse. Therefore, LASSO is helpful, and hence we can pick a sparse solution.
The significance of LASSO is often not about the fitting of the data points but the

455
CHAPTER 7. REGRESSION

4 4

3 3

2 2

1 1

0 0
data data
fitted curve fitted curve
-1 -1
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(a) Ground truth model (b) Vanilla regression
4 4

3 3

2 2

1 1

0 0
data data
fitted curve fitted curve
-1 -1
-1 -0.5 0 0.5 1 -1 -0.5 0 0.5 1
(c) Ridge (d) LASSO

Figure 7.27: We fit a dataset of N = 20 data points. (a) The ground truth model that generates
the data. The model is a 4th-order ordinary polynomial. (b) Vanilla regression result, without any
regularization. Note that there is severe overfitting because the model complexity is too high. (c) Ridge
regression result, by setting = 0.5. (d) LASSO regression result, by setting = 2.

number of active coefficients. In Figure 7.28 we show a comparison between the ground
truth coefficients, the vanilla regression coefficients, the ridge regression coefficients, and the
LASSO regression coefficients. It is evident that the LASSO solution contains a much smaller
number of non-zeros compared to the ridge regression. Most of the high-order coefficients
are zero. By contrast, the vanilla regression coefficients are wild. The ridge regression is
better, but there are many non-zero high-order coefficients.

Closing remark. In this section, we discussed two regularization techniques: ridge regres-
sion and LASSO regression. Both techniques are about adding a penalty term to the training
loss to constrain the regression coefficients. In the optimization literature, writings on ridge
and LASSO regression are abundant, covering both algorithms and theoretical properties.
An example of a theoretical question addressed in the literature is: Under what conditions
is LASSO guaranteed to recover the correct support of the solution, i.e., locating the correct
positions of the non-zeros? Problems like these are beyond the scope of this book.

456
7.5. SUMMARY

2 15

10
1
5

0 0

-5
-1
-10

-2 -15
5 10 15 20 5 10 15 20
(a) Ground truth model (b) Vanilla regression
2 2

1 1

0 0

-1 -1

-2 -2
5 10 15 20 5 10 15 20
(c) Ridge (d) LASSO

Figure 7.28: Coefficients of the regression models. (a) The ground truth model, which is a 4th-order
polynomial. There are only 5 non-zero coefficients. (b) The vanilla regression coefficients. Note that
the values are wild and large, although the curve fits the training data points very well. (c) The ridge
regression coefficients. While the overall magnitudes are significantly improved from the vanilla, some
high-order coefficients are still non-zero. (d) The LASSO regression coefficients. There are very few
non-zeros, and the non-zeros match well with the ground truth.

7.5 Summary

Regression is one of the most widely used techniques in data science. The formulation of the
regression problem is as simple as setting up a system of linear equations:

minimize kX✓ yk2 , (7.42)


✓2Rd

which has a closed-form solution. The biggest problems in practice are outliers, lack of
training samples, and poor choice of the regression model.
Outliers: We always recommend plotting the data whenever possible to check if there
are obvious outliers. There are also statistical tests in which you can evaluate the
validity of your samples. One simple way to debug outliers is to run the regression

457
CHAPTER 7. REGRESSION

and check the prediction error against each training sample. If you have an outlier,
and if your model is of reasonably low complexity, then a sample with an excessively
large prediction error is an outlier. For example, if most of the training samples are
within one standard deviation from your prediction but a few are substantially o↵,
you will know which ones are the outliers. Robust linear regression is one technique for
countering outliers, but an experienced data scientist can often reject outliers before
running any regression algorithms. Domain knowledge is of great value for this purpose.
Lack of training samples: As we have discussed in the overfitting section, it is ex-
tremely important to ensure that your model complexity is appropriate for the number
of training samples. If the training set is small, do not use a complex model. Regu-
larization techniques are valuable tools to mitigate overfitting. However, choosing a
good regularization requires domain knowledge. For example, if you know that some
features are not important, you need to scale them properly so as not to over-influence
the regression solution.
Wrong model: We have mentioned several times that regression can always return you
a result because regression is an optimization problem. However, whether that result
is meaningful depends on how meaningful your regression problem is. For example, if
the noise is i.i.d. Gaussian, a data fidelity term with k · k2 would be a good choice;
however, if the noise is i.i.d. Poisson, k · k2 would become a very bad model. We need
a tighter connection with the statistics of the underlying data-generation model for
problems like these. This is the subject of our next chapter, on parameter estimation.

7.6 References

Linear regression
Treatment of standard linear regression is abundant. In the context of machine learning and
data science, the following references are useful.
7-1 Gareth James, Daniela Witten, Trevor Hastie, and Robert Tibshirani, An Introduction
to Statistical Learning with Applications in R, Springer 2013, Chapter 3.
7-2 Stephen Boyd and Lieven Vandenberghe, Convex Optimization, Cambridge University
Press, 2004. Chapter 6.
7-3 Trevor Hastie, Robert Tibshirani, and Jerome Friedman, The Elements of Statistical
Learning, Springer, 2001. Chapter 3.
7-4 Christopher Bishop, Pattern Recognition and Machine Learning, Springer 2006. Chap-
ter 3.1.
7-5 Yaser Abu-Mostafa, Malik Magdon-Ismail and Hsuan-Tien Lin, Learning from Data,
AML Book, 2012. Chapter 3.2

Overfitting and Bias/Variance


The theory of overfitting and the trade-o↵ between bias and variance can be found in multiple
references. The following are basic treatments of the subject.

458
7.7. PROBLEMS

7-6 Yaser Abu-Mostafa, Malik Magdon-Ismail and Hsuan-Tien Lin, Learning from Data,
AML Book, 2012. Chapter 4.
7-7 Christopher Bishop, Pattern Recognition and Machine Learning, Springer 2006. Chap-
ter 3.2.

Ridge and LASSO regression


Ridge and LASSO regression are important tools in statistical learning today. The following
two textbooks cover some of the perspectives of the statistical community and the signal
processing community.
7-8 Trevor Hastie, Robert Tibshirani, and Martin Wainwright, Statistical Learning with
Sparsity: The LASSO and Generalizations, CRC Press, 2015.
7-9 Michael Elad, Sparse and Redundant Representations, Springer, 2010. Chapters 1
and 3.

7.7 Problems

Exercise 1.
(a) Construct a dataset with N = 20 samples, following the model
d 1
X
yn = ✓p Lp (xn ) + en , (7.43)
p=0

where ✓0 = 1, ✓1 = 0.5, ✓2 = 0.5, ✓3 = 1.5, ✓4 = 1, for 1 < x < 1. Here, Lp (x) is the
Legendre polynomial of the pth order. The N = 20 samples are random uniformly sam-
pled from the interval [ 1, 1]. The noise samples en are i.i.d. Gaussian with variance
2
= 0.252 . Plot the dataset using the MATLAB or Python command scatter.
(b) Run the regression using the same model where d = 5, without any regularization.
Plot the predicted curve and overlay with the training samples.
(c) Repeat (b) by running the regression with d = 20. Explain your observations.
(d) Increase the number of training samples N to N = 50, N = 500, and N = 5000, and
repeat (c). Explain your observations.
(e) Construct a testing dataset with M = 1000 testing samples. For each of the regression
models trained in (b)-(d), compute the testing error.

Exercise 2.
Consider a data generation model
N
X1
j 2⇡kn
xn = ck e N , n = 0, . . . , N 1.
k=0

459
CHAPTER 7. REGRESSION

(a) Write the above equation in matrix-vector form

x = W c.

What are the vectors c and x, and what is the matrix W ?

(b) Show that W is orthogonal, i.e.,, W H W = I, where W H is the conjugate transpose


of W .
(c) Using (b), derive the least squares regression solution.

Exercise 3.
Consider a simplified LASSO regression problem:

✓b = argmin ky ✓k2 + k✓k1 . (7.44)


✓2Rd

Show that the solution is given by

✓b = sign(y) · max (|y| , 0) , (7.45)

where · is the elementwise multiplication.

Exercise 4.
A one-dimensional signal is corrupted by blur and noise:
L
X1
yn = h` x n ` + en .
`=0

(a) Formulate the least squares regression problem in matrix-vector form y = Hx + e.


Find x, y and H.
(b) Consider a regularization function
N
X
2
R(x) = (xn xn 1) .
n=2

Show that this regularization is equivalent to R(x) = kDxk2 for some D. Find D.
(c) Using the regularization in (b), derive the regularized least squares regression result:

minimize ky Hxk2 + kDxk2 .


x

Exercise 5.
Let (·) be the sigmoid function
1
(a) = .
1 + ea
We want to use (a) as a basis function.

460
7.7. PROBLEMS

(a) Show that the tanh function and the sigmoid function are related by

tanh(a) = 2 (2a) 1.

(b) Show that a linear combination of sigmoid functions


d 1
X ✓ ◆
xn µj
yn = ✓ 0 + ✓p
p=1
s

is equivalent to a linear combination of tanh functions


d 1
X ✓ ◆
xn µj
yn = ↵ 0 + ↵p tanh .
p=1
2s

(c) Find the relationship between ✓p and ↵p .

Exercise 6. (NHANES Part 1)(Data download)


The National Health and Nutrition Examination Survey (NHANES) is a program to assess
the health and nutritional status of adults and children in the United States8 . The complete
survey result contains over 4,000 samples of health-related data of individuals who partici-
pated in the survey between 2011 and 2014. In the following exercises, we will focus on two
categories of the data for each individual: height (in mm) and body mass index (BMI). The
data is divided into two classes based on gender. Table 1 contains snippets of the data.

index female bmi female stature mm index male bmi male stature mm
0 28.2 1563 0 30 1679
1 22.2 1716 1 25.6 1586
2 27.1 1484 2 24.2 1773
3 28.1 1651 3 27.4 1816

Table 7.2: Male and Female Data Snippets

Use csv.reader to read the training data files for the two data classes.

Important! Before proceeding to the problems,


normalize the number in male_stature_mm and female_stature_mm by dividing them
by 1000, and
normalize that of male_bmi and female_bmi by dividing them by 10.
This will significantly reduce the numerical error.
Consider a linear model:
g✓ = ✓ T x, (7.46)
8 https://www.cdc.gov/nchs/nhanes/index.htm

461
CHAPTER 7. REGRESSION

The regression problem we want to solve is


N
X
✓b = argmin
2
(yn g✓ (xn )) ,
✓2Rd n=1

where D = {(xn , yn )}N


n=1 is the training dataset. Putting the equation into the matrix form,
we know that the optimization is equivalent to

✓b = argmin ky X✓k2 .
✓2Rd | {z }
Etrain (✓)

b State the conditions under which the solution is the unique


(a) Derive the solution ✓.
global minimum in terms of the rank of X. Suggest two techniques that can be used
when X T X is not invertible.
(b) For the NHANES dataset, assign yn = +1 if the nth sample is a male and yn = 1
if the nth sample is a female. Implement your answer in (a) with Python to solve the
problem. Report your answer.
(c) Repeat (b), but this time use CVXPY. Report your answer, and compare with (b).

Exercise 7. (NHANES Part 2)(Data download)


We want to do a classification based on the linear model we found in the previous exercise.
The classifier we will use is

predicted label = sign(g✓ (x)), (7.47)

where x 2 Rd is the a test sample. Here, we label +1 for male and 1 for female. Because
the dataset we consider in this exercise has only two columns, the linear model is

g✓ (x) = ✓0 + ✓1 x1 + ✓2 x2 ,

where x = [1, x1 , x2 ]T is the input data and ✓ = [✓0 , ✓1 , ✓2 ]T is the parameter vector.
(a) First, we want to visualize the classifier.
(i) Plot the training data points of the male and female classes. Mark the male class
with blue circles and the female class with red dots.
(ii) Plot the decision boundary g✓ (·) and overlay it with the data plotted in (a).
Hint: g✓ (·) is a straight line in 2D. You can express x2 in terms of x1 and other
parameters.
(b) (This problem requires knowledge of the content of Chapter 9). Report the classifica-
tion accuracy. To do so, take testing data x and compute the prediction according to
Equation (7.47).
(i) What is the Type 1 error (False Alarm) of classifying males? That is, what is the
percentage of testing samples that should be female but a male was predicted?
(ii) What is the Type 2 error (Miss) of classifying males? That is, what is the per-
centage of testing samples that should be male but a female was predicted?

462
7.7. PROBLEMS

(iii) What is the precision and recall for this classifier? For the definitions of precision
and recall, refer to Chapter 9.5.4.

Exercise 8. (NHANES Part 3)(Data download)


This exercise requires some background in optimization. Please refer to Reference [7.2, Chap-
ter 9 and 10]. Consider the following three optimization problems:

✓b = argmin kX✓ yk22 + k✓k22 , (7.48)


✓2Rd

✓b↵ = argmin kX✓ yk22 subject to k✓k22  ↵, (7.49)


✓2Rd

✓b✏ = argmin k✓k22 subject to kX✓ yk22  ✏. (7.50)


✓2Rd

(a) Set lambd = np.arange(0.1,10,0.1). Plot

kX ✓b yk22 as a function of k✓b k22 .


kX ✓b yk22 as a function of .
k✓b k22 as a function of .
(b) (i) Write down the Lagrangian for each of the three problems. Note that the first
problem does not have any Lagrange multiplier. For the second and third prob-
lems you may use the following notations:
↵ = the Lagrange multiplier of Equation (7.49), and
✏ = the Lagrange multiplier of Equation (7.50).
(ii) State the first-order optimality conditions (the Karush-Kuhn-Tucker or KKT
conditions) for each of the three problems. Express your answers in terms of X,
✓, y, , ↵, ✏, and the two Lagrange multipliers ↵ , ✏ .
(iii) Fix > 0. We can solve Equation (7.48) to obtain ✓b . Find ↵ and the Lagrange
multiplier ↵ in Equation (7.49) such that ✓b would satisfy the KKT conditions
of Equation (7.49).
(iv) Fix > 0. We can solve Equation (7.48) to obtain ✓b . Find ✏ and the Lagrange
multiplier ✏ in Equation (7.50) such that ✓b would satisfy the KKT conditions
of Equation (7.50).
(v) Fix > 0. By using the ↵ and ↵ you found in (iii), you can show that ✓b would
satisfy the KKT conditions of Equation (7.49). Is it enough to claim that ✓b is
the solution of Equation (7.49)? If yes, why? If no, what else do we need to show?
Please elaborate through a proof, if needed.

Exercise 9.
Consider a training dataset Dtrain = {(x1 , y1 ), . . . , (xN , yN )} and a weight w = [w1 , . . . , wN ]T .
Find the regression solution to the following problem and discuss how you would choose the
weight.
XN
2
✓b = argmin wn yn xTn ✓ . (7.51)
✓2Rd n=1

463
CHAPTER 7. REGRESSION

Exercise 10.
Consider a training dataset Dtrain = {(x1 , y1 ), . . . , (xN , yN )}. Suppose that the input data
xn is corrupted by i.i.d. Gaussian noise en ⇠ Gaussian(0, 2 I d ) so that the training set
becomes Dtrain = {(x1 + e1 , y1 ), . . . , (xN + eN , yN )}. Show that the (vanilla) least squares
linear regression by taking the expectation over en ,
N
X h 2
i
✓b = argmin Een yn (xn + en )T ✓ , (7.52)
✓2Rd n=1

is equivalent to a ridge regression.

464
Chapter 8

Estimation

In this chapter, we discuss another set of important combat skills in data science, namely es-
timation. Estimation has a close relationship with regression. Regression primarily takes the
optimization route, while estimation takes the probabilistic route. As we will see, at a cer-
tain point the two will merge. That is, under some specific statistical conditions, estimation
processes will coincide with the regression.
Estimation is summarized pictorially in Figure 8.1. Imagine that we have some random
samples X1 , . . . , XN . These samples are drawn from a distribution fX (x; ✓), where ✓ is a
parameter that characterizes the distribution. The parameter ✓ is not known to us. The
goal of estimation is to solve an inverse problem to recover the parameter based on the
observations X1 , . . . , XN .

Figure 8.1: Estimation is an inverse problem of recovering the unknown parameters that were used by
the distribution. In this figure, the PDF of X using a parameter ✓ is denoted as fX (x; ✓). The forward
data-generation process takes the parameter ✓ and creates the random samples X1 , . . . , XN . Estimation
takes these observed random samples and recovers the underlying model parameter ✓.

What is estimation?
Estimation is an inverse problem with the goal of recovering the underlying pa-
rameter ✓ of a distribution fX (x; ✓) based on the observed samples X1 , . . . , XN .

465
CHAPTER 8. ESTIMATION

What are parameters?


Before we discuss the methods of estimation, let us clarify the meaning of the parameter ✓.
All probability density functions (PDFs) have parameters. For example, a Bernoulli random
variable is characterized by a parameter p that defines the probability of getting a “head”. A
Gaussian random variable is characterized by two parameters: the mean µ and variance 2 .

Example 8.1. (Parameter of a Bernoulli) If Xn is a Bernoulli random variable, then


the PMF has a parameter ✓:

pXn (xn ; ✓) = ✓xn (1 ✓)1 xn


.

Remark. The PMF is expressed in this form because xn is either 1 or 0:


(
✓1 (1 ✓)1 1 = ✓, if xn = 1,
pXn (xn ; ✓) =
✓0 (1 ✓)1 0 = 1 ✓, if xn = 0.

Example 8.2. (Parameter of a Gaussian) If Xn is a Gaussian random variable, the


PDF is ⇢
1 (xn µ)2
✓ )= p
fXn (xn ; |{z} exp ,
2⇡ 2 2 2
=(µ, )

where ✓ = [µ, ] consists of both the mean and the variance. We can also designate
the parameter ✓ to be the mean only. For example, if we know that = 1, then the
PDF is ⇢
1 (xn µ)2
✓ ) = p exp
fXn (xn ; |{z} ,
2⇡ 2

where ✓ is the mean.

Since all probability density functions have parameters, estimating them from the
observed random variables is a well-defined inverse problem. Of course, there are better
estimates and there are worse estimates. Let us look at the following example to develop
our intuitions about estimation.
Figure 8.2 shows a dataset containing 1000 data points generated from a 2D Gaussian
distribution with an unknown mean vector µ and an unknown covariance matrix ⌃. We
duplicate this dataset in the four subfigures. The estimation problem is to recover the
unknown mean vector µ and the covariance matrix ⌃. In the subfigures we propose four
candidates, each with a di↵erent mean vector and a di↵erent covariance matrix. We draw
the contour lines of the corresponding Gaussians. It can be seen that some Gaussians fit the
data better than others. The goal of this chapter is to develop a systematic way of finding
the best fit for the data.

Plan for this chapter


The discussions in this chapter concern the three elementary distributions:

466
5 5 5 5
4 4 4 4
3 3 3 3
2 2 2 2
1 1 1 1
0 0 0 0
-1 -1 -1 -1
-2 -2 -2 -2
-3 -3 -3 -3
-4 -4 -4 -4
-5 -5 -5 -5
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5

Bad estimate
 Bad estimate
 Bad estimate
 Good estimate

2 0 0.5 0
µ= µ= µ= µ=
 0.5  1.5  0.7  0
0.25 0.2 1 0.2 1 0 0.25 0.3
⌃= ⌃= ⌃= ⌃=
0.2 1 0.2 0.1 0 1 0.3 1

Figure 8.2: An estimation problem. Given a set of 1000 data points drawn from a Gaussian distribution
with unknown mean µ and covariance ⌃, we propose several candidate Gaussians and see which one
would be the best fit to the data. Visually, we observe that the right-most Gaussian has the best fit.
The goal of this chapter is to develop a systematic way of solving estimation problems of this type.

Likelihood: fX|⇥ (x|✓), which is the conditional PDF of X given that the parameter
is ⇥.
Prior: f⇥ (✓), which is the PDF of ⇥.
Posterior: f⇥|X (✓|x), which is the conditional PDF of ⇥ given the data X.
Each of these density functions has its respective meaning, and consequently a set of di↵erent
estimation techniques. In Section 8.1 we introduce the concept of maximum-likelihood (ML)
estimation. As the name suggests, the estimate is constructed by maximizing the likelihood
function. We will discuss a few examples of ML estimation and draw connections between
ML estimation and regression. In Section 8.2 we will discuss several basic properties of an
ML estimate. Specifically, we will introduce the ideas of unbiasedness, consistency, and the
invariance principle.
The second topic discussed in this chapter is the maximum-a-posteriori (MAP) esti-
mation, detailed in Section 8.3. In MAP, the parameter ⇥ is a random variable. Since ⇥ is a
random variable, it has its own probability density function f⇥ (✓), which we call the prior.
Given the likelihood and the prior, we can define the posterior. The MAP estimation finds
the peak of the posterior distribution as a way to “explain” the data. Several important
topics will be covered in Section 8.3. For example, we will discuss the choice of the prior
via the concept of conjugate prior. We will also discuss how MAP is related to regularized
regressions such as the ridge and LASSO regressions.
The third topic is the minimum mean-square estimation (MMSE), outlined in Sec-
tion 8.4. The MMSE is a Bayesian approach. An important result that will be demonstrated
is that the MMSE estimate is the conditional expectation of the posterior distribution. In
other words, it is the mean of the posterior. An MMSE estimate has an important di↵erence
compared to a MAP estimate, namely that while an MMSE estimate is the mean of the
posterior, a MAP estimate is the mode of the posterior. We discuss the formulation of the
estimation problem and ways of solving the problem. We also discuss how the MMSE can
be performed for multidimensional Gaussian distributions.

467
CHAPTER 8. ESTIMATION

8.1 Maximum-Likelihood Estimation

Maximum-likelihood (ML) estimation, as the name suggests, is an estimation method that


“maximizes” the “likelihood”. Therefore, to understand the ML estimation, we first need to
understand the meaning of likelihood, and why maximizing the likelihood would be useful.

8.1.1 Likelihood function


Consider a set of N data points D = {x1 , x2 , . . . , xN }. We want to describe these data points
using a probability distribution. What would be the most general way of defining such a
distribution?
Since we have N data points, and we do not know anything about them, the most gen-
eral way to define a distribution is as a high-dimensional probability density function (PDF)
fX (x). This is a PDF of a random vector X = [X1 , . . . , XN ]T . A particular realization of
this random vector is x = [x1 , . . . , xN ]T .
fX (x) is the most general description for the N data points because fX (x) is the
joint PDF of all variables. It provides the complete statistical description of the vector X.
For example, we can compute the mean vector E[X], the covariance matrix Cov(X), the
marginal distributions, the conditional distribution, the conditional expectations, etc. In
short, if we know fX (x), we know everything about X.
The joint PDF fX (x) is always parameterized by a certain parameter ✓. For example, if
we assume that X is drawn from a joint Gaussian distribution, then fX (x) is parameterized
by the mean vector µ and the covariance matrix ⌃. So we say that the parameter ✓ is
✓ = (µ, ⌃). To state the dependency on the parameter explicitly, we write

fX (x; ✓) = PDF of the random vector X with a parameter ✓.

When you express the joint PDF as a function of x and ✓, you have two variables to
play with. The first variable is the observation x, which is given by the measured data. We
usually think about the probability density function fX (x) in terms of x, because the PDF
is evaluated at X = x. In estimation, however, x is something that you cannot control.
When your boss hands a dataset to you, x is already fixed. You can consider the probability
of getting this particular x, but you cannot change x.
The second variable stated in fX (x; ✓) is the parameter ✓. This parameter is what
we want to find out, and it is the subject of interest in an estimation problem. Our goal is
to find the optimal ✓ that can o↵er the “best explanation” to data x, in the sense that it
can maximize fX (x; ✓).
The likelihood function is the PDF that shifts the emphasis to ✓:

Definition 8.1. Let X = [X1 , . . . , XN ]T be a random vector drawn from a joint PDF
fX (x; ✓), and let x = [x1 , . . . , xN ]T be the realizations. The likelihood function is a

468
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

function of the parameter ✓ given the realizations x:


def
L(✓ | x) = fX (x; ✓). (8.1)

A word of caution: L(✓ | x) is not a conditional PDF because ✓ is not a random variable.
The correct way to interpret L(✓ | x) is to view it as a function of ✓. This function changes
its shape according the observed data x. We will return to this point shortly.

Independent observations
While fX (x) provides us with a complete picture of the random vector X, using fX (x) is
tedious. We need to describe how each Xn is generated and describe how Xn is related to
Xm for all pairs of n and m. If the vector X contains N entries, then there are N 2 /2 pairs
of correlations we need to compute. When N is large, finding fX (x) would be very difficult
if not impossible.
In practice, fX (x) may sometimes be overkill. For example, if we measure the inter-
arrival time of a bus for several days, it is quite likely that the measurements will not be
correlated. In this case, instead of using the full fX (x), we can make assumptions about
the data points. The assumption we will make is that all the data points are independent
and that they are drawn from an identical distribution fX (x). The assumption that the
data points are independently and identically distributed (i.i.d.) significantly simplifies the
problem so that the joint PDF fX can be written as a product of single PDFs fXn :
N
Y
fX (x) = fX1 ,...,XN (x1 , . . . , xN ) = fXn (xn ).
n=1

If you prefer a visualization, we can take a look at the covariance matrix, which goes
from a full covariance matrix to a diagonal matrix and then to an identity matrix:
2 3 2 3
Var[X1 ] Cov(X1 , X2 ) ··· Cov(X1 , XN ) Var[X1 ] 0 ··· 0
··· ···
6 Cov[X2 , X1 ] Var[X2 ] Cov(X2 , XN )
7 6 0 Var[X2 ] 0
7
4 .
.
.
. .. .
. 5 =) 4 .
.
.
. .. .
. 5
. . . . independent . . . .
Cov(XN , X1 ) Cov(XN , X2 ) ··· Var[XN ] 0 0 ··· Var[XN ]
2 2 3
0 ··· 0
2
0 ··· 0
6 7
=) 4 .
.
.
. .. .
. 5.
identical . . . .
2
0 0 ···

The assumption of i.i.d. is strong. Not all data can be modeled as i.i.d. (For example,
photons passing through a scattering medium have correlated statistics.) However, if the
i.i.d. assumption is valid, we can simplify the model significantly.
If the data points are i.i.d., then we can write the joint PDF as
N
Y
fX (x; ✓) = fXn (xn ; ✓).
n=1

This gives us a simplified form of the likelihood function, written as a product of the indi-
vidual PDFs.

469
CHAPTER 8. ESTIMATION

Definition 8.2. Given i.i.d. random variables X1 , . . . , XN that all have the same PDF
fXn (xn ), the likelihood function is
N
Y
def
L(✓ | x) = fXn (xn ; ✓). (8.2)
n=1

In computation we often take the log of the likelihood function. We call the resulting function
the log-likelihood.

Definition 8.3. Given a set of i.i.d. random variables X1 , . . . , XN with PDF fXn (x; ; ✓),
the log-likelihood is defined as
N
X
log L(✓ | x) = log fX (x; ✓) = log fXn (xn ; ✓). (8.3)
n=1

Example 8.3. Find the log-likelihood of a sequence of i.i.d. Gaussian random variables
X1 , . . . , XN with mean µ and variance 2 .
Solution. Since the random variables X1 , . . . , XN are i.i.d. Gaussian, the PDF is
N ⇢
Y
2 1 (xn µ)2
fX (x; µ, )= p e 2 2 . (8.4)
2⇡ 2
n=1

Taking the log on both sides yields the log-likelihood function:


2
log L(µ, | x) = log fX (x; µ, 2 )
(N ⇢ )
Y 1 (xn µ)2
= log p e 2 2

n=1 2⇡ 2
XN ⇢
1 (xn µ)2
= log p e 2 2
2⇡ 2
n=1
XN ⇢
1 (xn µ)2
= log(2⇡ 2 )
n=1
2 2 2
N
N 2 1 X
= log(2⇡ ) 2
(xn µ)2 .
2 2 n=1

Practice Exercise 8.1. Find the log-likelihood of a sequence of i.i.d. Bernoulli random
variables X1 , . . . , XN with parameter ✓.

470
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

Solution. If X1 , . . . , XN are i.i.d. Bernoulli random variables, we have


N ⇢
Y
fX (x; ✓) = ✓xn (1 ✓)1 xn
.
n=1

Taking the log on both sides of the equation yields the log-likelihood function:
(N ⇢ )
Y
xn 1 xn
log L(✓ | x) = log ✓ (1 ✓)
n=1
N
X ⇢
= log ✓xn (1 ✓)1 xn

n=1
N
X
= xn log ✓ + (1 xn ) log(1 ✓)
n=1
N
! N
!
X X
= xn · log ✓ + N xn · log(1 ✓).
n=1 n=1

Visualizing the likelihood function


The likelihood function L(✓ | x) is a function of ✓, but its value also depends on the under-
lying measurements x. It is extremely important to keep in mind the presence of both.
To help you visualize the e↵ect of ✓ and x, we consider a set of i.i.d. Bernoulli random
variables. As we have just shown in the practice exercise, the likelihood function of these
i.i.d. random variables is
N
! N
!
X X
log L(✓ | x) = xn · log ✓ + N xn · log(1 ✓), (8.5)
n=1 n=1
| {z } | {z }
S N S

PN
where we define S = n=1 xn as the sum of the (binary) measurements.
To make the dependency on S and ✓ explicit, we write L(✓ |x) as

log L(✓ | S) = S log ✓ + (N S) log(1 ✓), (8.6)

which emphasizes the role of S in defining the log-likelihood function. We plot the surface
of L(✓ | S) as a function of S and ✓, assuming that N = 50. As shown on the left-hand side
of Figure 8.3, the surface L(✓|S) has a saddle shape. Along one direction the function goes
up, whereas along another direction the function goes down. In the middle of Figure 8.3,
we show a bird’s-eye view of the surface, with the color-coding matched with the surface
plot. As you can see, when plotted as a function of ✓ and x (in our case, we use a summary
PN
statistic S = n=1 xn ), the two-dimensional plot tells us how the log-likelihood function
changes when S changes. On the right-hand side of Figure 8.3, we show two particular
cross sections of the two-dimensional plot. One cross section is taken from S = 25 and the
other cross section is taken from S = 12. Since the total number of heads in this numerical
experiment is assumed to be N = 50, the first cross section at S = 25 is obtained when

471
CHAPTER 8. ESTIMATION

P
Figure 8.3: We plot the log-likelihood function as a function of S = N n=1 xn and ✓. [Left] We show
the surface plot of L(✓|S) = S log ✓ + (N S) log(1 ✓). Note that the surface has a saddle shape.
[Middle] By taking a bird’s-eye view of the surface plot, we obtain a 2-dimensional contour plot of the
surface, where the color code matches the height of the log-likelihood function. [Right] We take two
cross sections along S = 25 and S = 12. Observe how the shape changes.

half of the Bernoulli measurements are “1”, whereas the second cross section at S = 12 is
obtained when a quarter of the Bernoulli measurements are “1”.
The cross sections tell us the log-likelihood function log L(✓|S) is a function defined
specifically for a given measurement x. As you can see from Figure 8.3, the log-likelihood
function changes when S changes. Therefore, if our goal is to “find a ✓ that maximizes the
log-likelihood function”, then for a di↵erent x we will have a di↵erent answer. For example,
according to Figure 8.3, the maximum for log L(✓|S = 25) occurs when ✓ ⇡ 0.5, and the
maximum for log L(✓|S = 12) occurs when ✓ ⇡ 0.24. These are the maximum-likelihood
estimates for the respective measurements.
We use the following MATLAB code to generate the surface plot:

% MATLAB code to generate the surface plot


N = 50;
S = 1:N;
theta = linspace(0.1,0.9,100);
[S_grid, theta_grid] = meshgrid(S, theta);
L = S_grid.*log(theta_grid) + (N-S_grid).*log(1-theta_grid);
s = surf(S,theta,L);
s.LineStyle = ’-’;
colormap jet
view(65,15)

For the bird’s-eye view plot, we replace surf with imagesc(S,theta,L). For the cross
section plots, we call the commands plot(theta, L(:,12)) and plot(theta, L(:,25)).

8.1.2 Maximum-likelihood estimate


The likelihood is the PDF of X but viewed as a function of ✓. The optimization problem
of maximizing L(✓ | x) is called the maximum-likelihood (ML) estimation:

472
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

Definition 8.4. Let L(✓) be the likelihood function of the parameter ✓ given the
measurements x = [x1 , . . . , xN ]T . The maximum-likelihood estimate of the parameter
✓ is a parameter that maximizes the likelihood:
def
✓bML = argmax L(✓ | x). (8.7)

Example 8.4. Find the ML estimate for a set of i.i.d. Bernoulli random variables
{X1 , . . . , XN } with Xn ⇠ Bernoulli(✓) for n = 1, . . . , N .
Solution. We know that the log-likelihood function of a set of i.i.d. Bernoulli random
variables is given by
N
! N
!
X X
log L(✓ | x) = xn · log ✓ + N xn · log(1 ✓). (8.8)
n=1 n=1

Thus, to find the ML estimate, we need to solve the optimization problem


( N ! N
! )
X X
b
✓ML = argmax xn · log ✓ + N xn · log(1 ✓) .
✓ n=1 n=1

Taking the derivative with respect to ✓ and setting it to zero, we obtain


( N ! N
! )
d X X
xn · log ✓ + N xn · log(1 ✓) = 0.
d✓ n=1 n=1

This gives us
⇣P ⌘
N
xn PN
n=1 N n=1 xn
= 0.
✓ 1 ✓
Rearranging the terms yields
N
1 X
✓bML = xn .
N n=1

Let’s do a sanity check to see if this result makes sense. The solution to this problem
says that ✓bML is the empirical average of the measurements. Assume that N = 50. Let us
consider two particular scenarios as illustrated in Figure 8.4.
def PN
Scenario 1: x is a vector of measurements such that S = n=1 xn = 25. Since
N = 50, the formula tells us that ✓bML = 2550 = 0.5. This is the best guess based on the
50 measurements where 25 are heads. If you look at Figure 8.3 and Figure 8.4, when
S = 25, we are looking at a particular cross section in the 2D plot. The likelihood
function we are inspecting is L(✓|S = 25). For this likelihood function, the maximum
occurs at ✓ = 0.5.

473
CHAPTER 8. ESTIMATION

Figure 8.4: Illustration of how the maximum-likelihood estimate of a set of i.i.d. Bernoulli random
variables is determined. The subfigures above show two particular scenarios at S = 25 and S = 12,
assuming that N = 50. When S = 25, the likelihood function has a quadratic shape centered at
✓ = 0.5. This point is also the peak of the likelihood function when S = 25. Therefore, the ML estimate
is ✓bML = 0.5. The second case is when S = 12. The quadratic likelihood is shifted toward the left. The
ML estimate is ✓bML = 0.24.

def PN
Scenario 2: x is a vector of measurements such that S = n=1 xn = 12. The formula
tells us that ✓bML = 12
50 = 0.24. This is again the best guess based on the 50 measure-
ments where 12 are heads. Referring to Figure 8.3 and Figure 8.4, we can see that
the likelihood function corresponds to another cross section L(✓|S = 12) where the
maximum occurs at ✓ = 0.24.

At this point, you may wonder why the shape of the likelihood function L(✓ | x) changes
so radically as x changes? The answer can be found in Figure 8.5. Imagine that we have
N = 50 measurements of which S = 40 give us heads. If these i.i.d. Bernoulli random
variables have a parameter ✓ = 0.5, it is quite unlikely that we will get 40 out of 50
measurements to be heads. (If it were ✓ = 0.5, we should get more or less 25 out of 50
heads.) When S = 40, and without any additional information about the experiment, the
most logical guess is that the Bernoulli random variables have a parameter ✓ = 0.8. Since
the measurement S can be as extreme as 0 out of 50 or 50 out of 50, the likelihood function
L(✓ | x) has to reflect these extreme cases. Therefore, as we change x, we observe a big
change in the shape of the likelihood function.
As you can see from Figure 8.5, S = 40 corresponds to the marked vertical cross
section. As we determine the maximum-likelihood estimate, we search among all the possi-
bilities, such as ✓ = 0.2, ✓ = 0.5, ✓ = 0.8, etc. These possibilities correspond to the horizontal
lines we drew in the figure. Among those horizontal lines, it is clear that the best estimate
occurs when ✓ = 0.8, which is also the ML estimate.

474
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

Figure 8.5: Suppose that we have a set of measurements such that S = 40. To determine the ML
estimate, we look at the vertical cross section at S = 40. Among the di↵erent candidate parameters,
e.g., ✓ = 0.2, ✓ = 0.5 and ✓ = 0.8, we pick the one that has the maximum response to the likelihood
function. For S = 40, it is more likely that the underlying parameter is ✓ = 0.8 than ✓ = 0.2 or ✓ = 0.5.

Visualizing ML estimation as N grows


Maximum-likelihood estimation can also be understood directly from the PDF instead of
the likelihood function. To explain this perspective, let’s do a quick exercise.

Practice Exercise 8.2. Suppose that Xn is a Gaussian random variable. Assume


that = 1 is known but the mean ✓ is unknown. Find the ML estimate of the mean.

Solution. The ML estimate ✓bML is

✓bML = argmax log L(✓ | x)



(N ⇢ )
Y 1 (xn ✓)2
= argmax log p exp
✓ n=1
2⇡ 2
N
N 1X
= argmax log(2⇡) (xn ✓)2 .
✓ 2 2 n=1

Taking the derivative with respect to ✓, we obtain


( N
)
d N 1X
log(2⇡) (xn ✓)2 = 0.
d✓ 2 2 n=1
PN
This gives us n=1 (xn ✓) = 0. Therefore, the ML estimate is
N
1 X
✓bML = xn .
N n=1

Now we will draw the PDF and compare it with the measured data points. Our focus

475
CHAPTER 8. ESTIMATION

is to analyze how the ML estimate changes as N grows.

When N = 1. There is only one observation x1 . The best Gaussian that fits this sample
must be the one that is centered at x1 . In fact, the optimization is1
⇢ ⇢
1 (x1 ✓)2
✓bML = argmax log L(✓ | x1 ) = argmax log p exp
✓ ✓ 2⇡ 2 2 2
= argmax (x1 ✓)2 = x1 .

Therefore, the ML estimate is ✓bML = x1 . Figure 8.6 illustrates this case. As we conduct the
ML estimation, we imagine that there are a few candidate PDFs. The ML estimation says
that among all these candidate PDFs we need to find one that can maximize the probability
of obtaining the observation x1 . Since we only have one observation, we have no choice but
to pick a Gaussian centered at x1 . Certainly the sample X1 = x1 could be bad, and we may
find a wrong Gaussian. However, with only one sample there is no way for us to make better
decisions.
0.5
0.45 Data Point
0.4 Candidate PDF
0.35 Estimated PDF
0.3
0.25
0.2
0.15
0.1
0.05
0
-5 -4 -3 -2 -1 0 1 2 3 4 5
x
Figure 8.6: N = 1. Suppose that we are given one observed data point located around x = 2.1. To
conduct the ML estimation we propose a few candidate PDFs, each being a Gaussian with unit variance
but a di↵erent mean ✓. The ML estimate is a parameter ✓ such that the corresponding PDF matches
the best with the observed data. In this example the best match happens when the estimated Gaussian
PDF is centered at x1 .

When N = 2. In this case we need to find a Gaussian that fits both x1 and x2 . The
probability of simultaneously observing x1 and x2 is determined by the joint distribution.
By independence we then have
(✓ ◆2 ⇢ )
b 1 (x1 ✓)2 + (x2 ✓)2 )
✓ML = argmax log p exp
✓ 2⇡ 2 2 2

(x1 ✓)2 + (x2 ✓)2 x1 + x2
= argmax 2
= ,
✓ 2 2
1 We skip the step of checking whether the stationary point is a maximum or a minimum, which can be

done by evaluating the second-order derivative. In fact, since the function (x1 ✓)2 is concave in ✓, a
stationary point must be a maximum.

476
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

where the last step is obtained by taking the derivative:


d
(x1 ✓)2 + (x2 ✓)2 = 2(x1 ✓) + 2(x2 ✓).
d✓
Equating this with zero yields the solution ✓ = x1 +x
2
2
. Therefore, the best Gaussian that
x1 +x2 2
fits the observations is Gaussian( 2 , ).

0.5
0.45 Data Point
0.4 Candidate PDF
0.35 Estimated PDF
0.3
0.25
0.2
0.15
0.1
0.05
0
-5 -4 -3 -2 -1 0 1 2 3 4 5
x
Figure 8.7: N = 2. Suppose that we are given two observed data points located around x1 = 0.98
and x2 = 1.15. To conduct the ML estimation we propose a few candidate PDFs, each being a
Gaussian with unit variance but a di↵erent mean ✓. The ML estimate is a parameter ✓ such that the
corresponding PDF best matches the observed data. In this example the best match happens when the
estimated Gaussian PDF is centered at (x1 + x2 )/2 ⇡ 1.07.

Does this result make sense? When you have two data points x1 and x2 , the ML
estimation is trying to find a Gaussian that can best fit both of these two data points.
Your best bet here is ✓bML = (x1 + x2 )/2, because there are no other choices. If you choose
✓bML = x1 or ✓bML = x2 , it cannot be a good estimate because you are not using both data
points. As shown in Figure 8.7, for these two observed data points x1 and x2 , the PDF
marked in red (which is a Gaussian centered at (x1 + x2 )/2) is indeed the best fit.

When N = 10 and N = 100. We can continue the above calculation for N = 10 and
N = 100. In this case the MLE is
(✓ ◆N ⇢ )
2 2
1 (x 1 ✓) + · · · + (x N ✓)
✓bML = argmax log p exp
✓ 2⇡ 2 2 2
XN N
(xn ✓)2 1 X
= argmax = xn .
✓ n=1
2 2 N n=1
where the optimization is solved by taking the derivative:
N N
d X X
(xn ✓)2 = 2 (xn ✓)
d✓ n=1 n=1
PN
Equating this with zero yields the solution ✓ = N1 n=1 xn .
The result suggests that for an arbitrary number of training samples the ML estimate
is the sample average. These cases are illustrated in Figure 8.8. As you can see, the red
curves (the estimated PDF) are always trying to fit as many data points as possible.
The above experiment tells us something about the ML estimation:

477
CHAPTER 8. ESTIMATION

0.5 0.5
0.45 Data Point 0.45 Data Point
0.4 Candidate PDF 0.4 Candidate PDF
0.35 Estimated PDF 0.35 Estimated PDF
0.3 0.3
0.25 0.25
0.2 0.2
0.15 0.15
0.1 0.1
0.05 0.05
0 0
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
(c) N = 10 (d) N = 100

Figure 8.8: When N = 10 and N = 100, the ML estimation continues to evaluate the di↵erent
candidate PDFs. For a given set of data points, the ML estimation picks the best PDF to fitPthe data
points. In this Gaussian example it was shown that the optimal parameter is ✓bML = (1/N ) N n=1 xn ,
which is the sample average.

How does ML estimation work, intuitively?


The likelihood function L(✓|x) measures how “likely” it is that we will get x if
the underlying parameter is ✓.
In the case of a Gaussian with an unknown mean, you move around the Gaussian
until you find a good fit.

8.1.3 Application 1: Social network analysis


ML estimation has extremely broad applicability. In this subsection and the next we discuss
two real examples. We start with an example in social network analysis.
In Chapter 3, when we discussed the Bernoulli random variables, we introduced the
Erdős-Rényi graph — one of the simplest models for social networks. The Erdős-Rényi graph
is a single-membership network that assumes that all users belong to the same cluster. Thus
the connectivity between users is specified by a single parameter, which is also the probability
of the Bernoulli random variable.
In our discussions in Chapter 3 we defined an adjacency matrix to represent a graph.
The adjacency matrix is a binary matrix, with the (i, j)th entry indicating an edge connect-
ing nodes i and j. Since the presence and absence of an edge is binary and random, we may
model each element of the adjacency matrix as a Bernoulli random variable

Xij ⇠ Bernoulli(p).

In other words, the edge Xij linking user i and user j in the network is either Xij = 1 with
probability p, or Xij = 0 with probability 1 p. In terms of notation, we define the matrix
X 2 RN ⇥N as the adjacency matrix, with the (i, j)th element being Xij .
A few examples of a single-membership Erdős-Rényi graph are shown in Figure 8.9. As
the figure shows, the network connectivity increases as the Bernoulli parameter p increases.
This happens because p defines the “density” of the edges. If p is large, we have a greater
chance of getting Xij = 1, and so there is a higher probability that an edge is present
between node i and node j. If p is small, the probability is lower.

478
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

p = 0.3 p = 0.5 p = 0.7 p = 0.9


4
2 35 33 3 4 3 12 14 28 5
7 24 38
23 7 31
29 6 33 20 36 28
27 3 2019 2 3 2 15
21 1 39 1 13
1 34 40 15 27 26 10 2 29
10 18 1231 38 8
6 20 10
36 39 1 35 9 25 32
1 11 17 2 16
14 3
1 13 39 9 2
17 32 4 17 33 7 35 18
0 28 11 16 30 7
40 22 0 36 30 0 35
23 4 20 22 33 4 27
30 2 19 28 37 18 0 24 34
14 18 17
34 26 24 5 32
5 8 25
6 -1 1
27 -1 40 34 32 19 21
8
-1 9 37 26 24 21 38 36 40
15 13 10 3 19
16 31 25 29 31
25 148 -2 22 -2 16 26 39 30
29 15 22 -2
11 5 9 37
-2 2 37 6
23 12
38 -3 -3
21 12 23 13 11

-3 -4 -4 -4
-2 0 2 -2 0 2 -4 -2 0 2 4 -4 -2 0 2 4

(a) Graph representations of Erdős-Rényi graphs at di↵erent p.

(b) Adjacent matrices of the corresponding graphs.


Figure 8.9: A single-membership Erdős-Rényi graph is a graph structure in which the edge between
node i and node j is defined as a Bernoulli random variable with parameter p. As p increases, the graph
has a higher probability of having more edges. The adjacent matrices shown in the bottom row are the
mathematical representations of the graphs.

Suppose that we are given one snapshot of the network, i.e., one realization x 2 RN ⇥N
of the adjacency matrix X 2 RN ⇥N . The problem of recovering the latent parameter p can
be formulated as an ML estimation.

Example 8.5. Write down the log-likelihood function of the single-membership Erdős-
Rényi graph ML estimation problem.
Solution. Based on the definition of the graph model, we know that

Xij ⇠ Bernoulli(p).

Therefore, the probability mass function of Xij is

P[Xij = 1] = p and P[Xij = 0] = 1 p.

This can be compactly expressed as


N Y
Y N
fX (x; p) = pxij (1 p)1 xij
.
i=1 j=1

Hence, the log-likelihood is


N X
X N
log L(p | x) = {xij log p + (1 xij ) log(1 p)} .
i=1 j=1

479
CHAPTER 8. ESTIMATION

Now that we have the log-likelihood function, we can proceed to estimate the param-
eter p. The solution to this is the ML estimate.

Practice Exercise 8.3. Solve the ML estimation problem:

pbML = argmax log L(p | x).


p

Solution. Using the log-likelihood we just derived, we have that


N X
X N
pbML = {xij log p + (1 xij ) log(1 p)} .
i=1 j=1

Taking the derivative and setting it to zero,


8 9
d <X X =
N N
d
log L(p | x) = {xij log p + (1 xij ) log(1 p)}
dp dp : i=1 j=1
;
N ⇢
N X
X xij 1 xij
= = 0.
i=1 j=1
p 1 p

PN PN
Let S = i=1 j=1 xij . The equation above then becomes

S N2 S
= 0.
p 1 p

Rearranging the terms yields (1 p)S = p(N 2 S), which gives us


N N
S 1 XX
pbML = = xij . (8.9)
N2 N 2 i=1 j=1

On computers, visualizing the graphs and computing the ML estimates are reasonably
straightforward. In MATLAB, you can call the command graph to build a graph from the
adjacency matrix A. This will allow you to plot the graph. The computation, however, is done
directly by the adjacency matrix. In the code below, you can see that we call rand to generate
the Bernoulli random variables. The command triu extracts the upper triangular matrix
from the matrix A. This ensures that we do not pick the diagonals. The symmetrization of
A+A’ ensures that the graph is indirectional, meaning that i to j is the same as j to i.
% MATLAB code to visualize a graph
n = 40; # Number of nodes
p = 0.3 # probability
A = rand(n,n)<p;
A = triu(A,1);
A = A+A’; # Adj matrix
G = graph(A); # Graph

480
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

plot(G); # Drawing
p_ML = mean(A(:)); # ML estimate

In Python, the computation is done similarly with the help of the networkx library.
2
The number of edges m is defined as m = p n2 . This is because for a graph with n nodes, there
2
are at most n2 unique pairs of indirected edges. Multiplying this number by the probability
p will give us the number of edges m.
# Python code to visualize a graph
import networkx as nx
import numpy as np
n = 40 # Number of nodes
p = 0.3 # probability
m = np.round(((n ** 2)/2)*p) # Number of edges
G = nx.gnm_random_graph(n,m) # Graph
A = nx.adjacency_matrix(G) # Adj matrix
nx.draw(G) # Drawing
p_ML = np.mean(A) # ML estimate

As you can see in both the MATLAB and the Python code, the ML estimate pbML is de-
termined by taking
PN P the sample average. Thus the ML estimate, according to our calculation,
N
is pbML = N12 i=1 j=1 xij .

8.1.4 Application 2: Reconstructing images


Being able to see in the dark is the holy grail of imaging. Many advanced sensing technologies
have been developed over the past decade. In this example, we consider a single-photon image
sensor. This is a counting device that counts the number of photons arriving at the sensor.
Physicists have shown that a Poisson process can model the arrival of the photons. For
simplicity we assume a homogeneous pattern of N pixels. The underlying intensity of the
homogeneous pattern is a constant .
Suppose that we have a sensor with N pixels X1 , . . . , XN . According to the Poisson
statistics, the probability of observing a pixel value is determined by the Poisson probability:
Xn ⇠ Poisson( ), n = 1, . . . , N,
or more explicitly,
xn
P[Xn = xn ] = e ,
xn !
where xn is the nth observed pixel value, and is an integer.
A single-photon image sensor is slightly more complicated in the sense that it does
not report Xn but instead reports a truncated version of Xn . Depending on the number of
incoming photons, the sensor reports
(
1, Xn 1,
Yn = (8.10)
0, Xn = 0.
We call this type of sensors a one-bit single-photon image sensor (see Figure 8.10). Our
question is: If we are given the measurements X1 , . . . , XN , can we estimate the underlying
parameter ?

481
CHAPTER 8. ESTIMATION

Figure 8.10: A one-bit single-photon image sensor captures an image with binary bits: It reports a “1”
when the number of photons exceeds certain threshold, and “0” otherwise. The recovery problem here
is to estimate the underlying image from the measurements.

Example 8.6. Derive the log-likelihood function of the estimation problem for the
single-photon image sensors.
Solution. Since Yn is a binary random variable, its probability is completely specified
by the two states it takes:

P[Yn = 0] = P[Xn = 0] = e
P[Yn = 1] = P[Xn 6= 0] = 1 e .

Thus, Yn is a Bernoulli random variable with probability 1 e of getting a value


of 1, and probability e of getting a value of 0. By defining yn as a binary number
taking values of either 0 or 1, it follows that the log-likelihood is
⇢Y
N
yn 1 yn
log L( | y) = log 1 e e
n=1
N ⇢
X
= yn log(1 e ) (1 yn ) .
n=1

Practice Exercise 8.4. Solve the ML estimation problem


bML = argmax log L( | y). (8.11)

PN
Solution. First, we define S = n=1 yn . This simplifies the log-likelihood function to
N ⇢
X
log L( | y) = yn log(1 e ) (1 yn )
n=1
= S log(1 e ) (N S).

482
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

The ML estimation is
bML = argmax S log(1 e ) (N S).

Taking the derivative w.r.t. yields



d S
S log(1 e ) (N S) = e (N S).
d 1 e

Moving around the terms, it follows that


✓ ◆
S S
e (N S) = 0 =) = log 1 .
1 e N

Therefore, the ML estimate is


N
!
bML = 1 X
log 1 yn . (8.12)
N n=1

For real images, you can extrapolate the idea from yn to yi,j,t , which denotes the (i, j)th
pixel located at time t. Defining y t 2 RN ⇥N as the tth frame of the observed data, we can
use T frames to recover one image b ML 2 RN ⇥N . It follows from the above derivation that
the ML estimate is !
XT
b ML = log 1 1
y . (8.13)
T t=1 t
Figure 8.11 shows a pair of input-output images of a 256 ⇥ 256 image.

(a) Observed data (1-frame) (b) ML estimate (using 100 frames)

Figure 8.11: ML estimation for a single-photon image sensor problem. The observed data consists of
100 frames of binary
P measurements y 1 , . . . , y T , where T = 100. The ML estimate is constructed by
= log(1 T1 Tt=1 y t ).

On a computer the ML estimation can be done in a few lines of MATLAB code. The
code in Python requires more work, as it needs to read images using the openCV library.

483
CHAPTER 8. ESTIMATION

% MATLAB code to recover an image from binary measurements


lambda = im2double(imread(’cameraman.tif’));
T = 100; % 100 frames
x = poissrnd( repmat(lambda, [1,1,T]) ); % generate Poisson r.v.
y = (x>=1); % binary truncation
lambdahat = -log(1-mean(y,3)); % ML estimation
figure(1); imshow(x(:,:,1));
figure(2); imshow(lambdahat);

# Python code to recover an image from binary measurements


import cv2
import numpy as np
import scipy.stats as stats
import matplotlib.pyplot as plt
lambd = cv2.imread(’./cameraman.tif’) # read image
lambd = cv2.cvtColor(lambd, cv2.COLOR_BGR2GRAY)/255 # gray scale
T = 100
lambdT = np.repeat(lambd[:, :, np.newaxis], T, axis=2) # repeat image
x = stats.poisson.rvs(lambdT) # Poisson statistics
y = (x>=1).astype(float) # binary truncation
lambdhat = -np.log(1-np.mean(y,axis=2)) # ML estimation
plt.imshow(lambdhat,cmap=’gray’)

8.1.5 More examples of ML estimation


By now you should be familiar with the procedure for solving the ML estimation problem.
We summarize the two steps as follows.

How to solve an ML estimation problem


Write down the likelihood L(✓ | x).
bML = argmax log L(✓ | x).
Maximize the likelihood by solving ✓

Practice Exercise 8.5 (Gaussian). Suppose that we are given a set of i.i.d. Gaus-
sian random variables X1 , . . . , XN , where both the mean µ and the variance 2 are
unknown. Let ✓ = [µ, 2 ]T be the parameter. Find the ML estimate of ✓.

Solution. We first write down the likelihood. The likelihood of these i.i.d. Gaussian
random variables is
✓ ◆N ( N
)
1 1 X 2
L(✓|x) = p exp (xn µ) .
2⇡ 2 2 2 n=1

484
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

To solve the ML estimation problem, we maximize the log-likelihood:


def
✓bML = argmax L(✓ | x)

( N
)
N 2 1 X 2
= argmax log(2⇡ ) 2
(xn µ) .
µ, 2 2 2 n=1

Since we have two parameters, we need to take the derivatives for both.
( N
)
d N 1 X
log(2⇡ 2 ) (xn µ)2 = 0,
dµ 2 2 2 n=1
( N
)
d N 2 1 X 2
log(2⇡ ) (xn µ) = 0.
d 2 2 2 2 n=1

2
(Note that the derivative of the second equation is taken w.r.t. to and not .) This
pair of equations gives us
N N
1 X N 1 1 X
2
(xn µ) = 0, and · 2
· (2⇡) + 4
(xn µ)2 = 0.
n=1
2 2⇡ 2 n=1

Rearranging the equations, we find that


N N
1 X 2 1 X
bML =
µ xn and bML = (xn bML )2 .
µ (8.14)
N n=1 N n=1

Practice Exercise 8.6. (Poisson) Given a set of i.i.d. Poisson random variables
X1 , . . . , XN with an unknown parameter , find the ML estimate of .

Solution. For a Poisson random variable, the likelihood function is


N ⇢
Y xn
L( | x) = e . (8.15)
n=1
xn !

To solve the ML estimation problem, we note that


(N )
Y xn
bML = argmax L( | x) = argmax log e
n=1
xn !
⇢ P xn
n
Q N
= argmax log e .
n xn !
Q
Since n xn ! is independent of , its presence or absence will not a↵ect the optimization

485
CHAPTER 8. ESTIMATION

problem. Consequently we can drop the term. It follows that


n P o
bML = argmax log n xn e N

!
X
= argmax xn log N .
n

Taking the derivative and setting it to zero yields


( ! ) P
d X xn
xn log N = n N = 0.
d n

Rearranging the terms yields


XN
bML = 1 xn . (8.16)
N n=1

The idea of ML estimation can also be extended to vector observations.

Example 8.7. (High-dimensional Gaussian) Suppose that we are given a set of i.i.d.
d-dimensional Gaussian random vectors X 1 , . . . , X N such that

X n ⇠ Gaussian(µ, ⌃).

We assume that ⌃ is fixed and known, but µ is unknown. Find the ML estimate of µ.
Solution. The likelihood function is
N
Y
L(µ | {xn }N
n=1 ) = fX n (xn ; µ)
n=1
N
( ⇢ )
Y 1 1 T 1
= p exp (xn µ) ⌃ (xn µ)
n=1 (2⇡)d |⌃| 2
!N ( N
)
1 1X T 1
= p exp (xn µ) ⌃ (xn µ) .
(2⇡)d |⌃| 2 n=1

Thus the log-likelihood function is

XN ⇢
N N 1 1
log L(µ | {xn }N
n=1 ) = log |⌃| + d
log(2⇡) + (xn µ)T ⌃ (xn µ) .
2 2 n=1
2

The ML estimate is found by maximizing this log-likelihood function:

b ML = argmax log L(µ | {xn }N


µ n=1 ).
µ

486
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

Taking the gradient of the function and setting it to zero, we have that
( N ⇢
)
d N N X 1
d T 1
log |⌃| + log(2⇡) + (xn µ) ⌃ (xn µ) = 0.
dµ 2 2 n=1
2

The derivatives of the first two terms are zero because they do not depend on µ). Thus
we have that:
N ⇢
X
1
⌃ (xn µ) = 0.
n=1

1
PN
b ML =
Rearranging the terms yields the ML estimate µ N n=1 xn .

Example 8.8. (High-dimensional Gaussian) Assume the same problem setting as in


Example 8.7, except that this time we assume that both the mean vector µ and the
covariance matrix ⌃ are unknown. Find the ML estimate for ✓ = (µ, ⌃).
Solution. The log-likelihood follows from Example 8.7:

XN ⇢
N N 1 1
log L(µ | {xn }N
n=1 ) = log |⌃| + log(2⇡)d + (xn µ)T ⌃ (xn µ) .
2 2 n=1
2

Finding the ML estimate requires taking the derivative with respect to both µ and ⌃:
( N ⇢
)
d N N X 1
d T 1
log |⌃| + log(2⇡) + (xn µ) ⌃ (xn µ) = 0,
dµ 2 2 n=1
2
( N ⇢
)
d N N X 1
d T 1
log |⌃| + log(2⇡) + (xn µ) ⌃ (xn µ) = 0.
d⌃ 2 2 n=1
2

After some tedious algebraic steps (see Duda et al., Pattern Classification, Problem
3.14), we have that
N
1 X
b ML =
µ xn , (8.17)
N n=1
XN
b ML = 1
⌃ (xn b ML )(xn
µ b ML )T .
µ (8.18)
N n=1

8.1.6 Regression versus ML estimation


ML estimation is closely related to regression. To understand the connection, we consider a
linear model that we studied in Chapter 7. This model describes the relationship between

487
CHAPTER 8. ESTIMATION

the inputs x1 , . . . , xN and the observed outputs y1 , . . . , yN , via the equation


d 1
X
yn = ✓p p (xn ) + en , n = 1, . . . , N. (8.19)
p=0

In this expression, p (·) is a transformation that extracts the “features” of the input vector
x to produce a scalar. The coefficient ✓p defines the relative weight of the feature p (xn ) in
constructing the observed variable P yn . The error en defines the modeling error between the
d 1
observation yn and the prediction p=0 ✓p p (xn ). We call this equation a linear model.
Expressed in matrix form, the linear model is
2 3 2 32 3 2 3
y1 0 (x1 ) 1 (x1 ) ··· d 1 (x1 ) ✓0 e1
6 y2 7 6 0 (x2 ) (x ) · · · (x ) 7 6 ✓ 7 6 7
6 7 6 1 2 d 1 2 76 1 7 6 e2 7
6 .. 7 = 6 .. .. .. 76 .. 7 + 6 .. 7,
4 . 5 4 . ··· . . 54 . 5 4 . 5
yN 0 (xN ) 1 (xN ) · · · d 1 (xN ) ✓d 1 eN
| {z } | {z }| {z } | {z }
=y =X =✓ =e

or more compactly as y = X✓ + e. Rearranging the terms, it is easy to show that

N N d 1
!2
X X X
e2n = yn ✓p p (xn )
n=1 n=1 p=0
N
X 2
= (yn [X✓]n ) = ky X✓k2 .
n=1

Now we make an assumption: that each noise en is an i.i.d. copy of a Gaussian random
variable with zero mean and variance 2 . In other words, the error vector e is distributed
according to e ⇠ Gaussian(0, 2 I). This assumption is not always true because there are
many situations in which the error is not Gaussian. However, this assumption is necessary
for us to make the connection between ML estimation and regression.
With this assumption, we ask, given the observations y1 , . . . , yN , what would be the
ML estimate of the unknown parameter ✓? We answer this question in two steps.

Example 8.9. Find the likelihood function of ✓, given y = [y1 , . . . , yN ]T .


Solution. The PDF of y is given by a Gaussian:
N ⇢
Y ⇢
1 (yn [X✓]n )2
fY (y; ✓) = p exp
n=1 2⇡ 2 2 2
( N
)
1 1 X 2
=p exp 2
(yn [X✓]n )
(2⇡ 2 )N 2 n=1

1 1
=p exp 2
ky X✓k2 . (8.20)
(2⇡ 2 )N 2

488
8.1. MAXIMUM-LIKELIHOOD ESTIMATION

Therefore, the log-likelihood function is


( ⇢ )
1 1 2
log L(✓ | y) = log p exp ky X✓k
(2⇡ 2 )N 2 2
N 1
= log(2⇡ 2 ) ky X✓k2 .
2 2 2

The next step is to solve the ML estimation by maximizing the log-likelihood.

Example 8.10. Solve the ML estimation problem stated in Example 8.9. Assume that
X T X is invertible.
Solution.
bML = argmax log L(✓ | y)



N 2 1
= argmax log(2⇡ ) 2
ky X✓k2 .
✓ 2 2

Taking the derivative w.r.t. ✓ yields



d N 2 1
log(2⇡ ) 2
ky X✓k2 = 0.
d✓ 2 2
d T
Since d✓ ✓ A✓ = A + AT , it follows from the chain rule that
⇢ ⇢
d 1 2 d 1
ky X✓k = (y X✓)T (y X✓)
d✓ 2 2 d✓ 2 2
1
= 2 X T (X✓ y).

Substituting this result into the equation,


1
2
X T (X✓ y) = 0.

Rearranging terms we obtain X T X✓ = X T y, of which the solution is


bML = (X T X)
✓ 1
X T y. (8.21)

Since the ML estimate in Equation (8.21) is the same as the regression solution (see
Chapter 7), we conclude that the regression problem of a linear model is equivalent to solving
an ML estimation problem.
The main di↵erence between a linear regression problem and an ML estimation problem
is the underlying statistical model, as illustrated in Figure 8.12. In linear regression, you
do not care about the statistics of the noise term en . We choose (·)2 as the error because it
is di↵erentiable and convenient. In ML estimation, we choose (·)2 as the error because the
noise is Gaussian. If the noise is not Gaussian, e.g., the noise follows a Laplace distribution,
we need to choose | · | as the error. Therefore, you can always get a result by solving the
linear regression. However, this result will only become meaningful if you provide additional

489
CHAPTER 8. ESTIMATION

Figure 8.12: ML estimation is equivalent to a linear regression when the underlying statistical model
for ML estimation is a Gaussian. Specifically, if the error term e = y X✓ is an independent Gaussian
vector with zero mean and covariance matrix 2 I, then the resulting ML estimation is the same as linear
regression. If the underlying statistical model is not Gaussian, then solving the regression is equivalent
to applying a Gaussian ML estimation to a non-Gaussian problem. This will still give us a result, but
that result will not maximize the likelihood, and thus it will not have any statistical guarantee.

information about the problem. For example, if you know that the noise is Gaussian, then
the regression solution is also the ML solution. This is a statistical guarantee.
In practice, of course, we do not know whether the noise is Gaussian or not. At this
point we have two courses of action: (i) Use your prior knowledge/domain expertise to
determine whether a Gaussian assumption makes sense, or (ii) select an alternative model
and see if the alternative model fits the data better. In practice, we should also question
whether maximizing the likelihood is what we want. We may have some knowledge and
therefore prefer the parameter ✓, e.g., we want a sparse solution so that ✓ only contains a
few non-zeros. In that case, maximizing the likelihood without any constraint may not be
the solution we want.

ML estimation versus regression


ML estimation requires a statistical assumption, whereas regression does not.
Pd 1
Suppose that you use a linear model yn = p=0 ✓p p (xn ) + en where en ⇠
Gaussian(0, 2 ), for n = 1, . . . , N .
Then the likelihood function in the ML estimation is

1 1
L(✓ | y) = p exp 2
ky X✓k2 ,
(2⇡ )2 N 2

The ML estimate ✓ bML is ✓ bML = (X T X) 1 X T y, which is exactly the same as


the regression solution. If the above statistical assumptions do not hold, then the
regression solution will not maximize the likelihood.

490
8.2. PROPERTIES OF ML ESTIMATES

8.2 Properties of ML Estimates

ML estimation is a very special type of estimation. Not all estimations are ML. If an estimate
is ML, are there any theoretical properties we can analyze? For example, will ML estimates
guarantee the recovery of the true parameter? If so, when will this happen? In this section
we investigate these theoretical questions so that you will acquire a better understanding of
the statistical nature of ML estimates.2

8.2.1 Estimators
We know that an ML estimate is defined as

✓bML (x) = argmax L(✓ | x). (8.22)


We write ✓bML (x) to emphasize that ✓bML is a function of x. The dependency of ✓bML (x) on
x should not be a surprise. For example, if the ML estimate is the sample average, we have
that
N
1 X
✓bML (x1 , . . . , xN ) = xn ,
N n=1

where x = [x1 , . . . , xN ]T .
However, in this setting we should always remember that x1 , . . . , xN are realizations
of the i.i.d. random variables X1 , . . . , XN . Therefore, if we want to analzye the randomness
of the variables, it is more reasonable to write ✓bML as a random variable ⇥ b ML . For example,
in the case of sample average, we have that
N
b 1 X
⇥ML (X1 , . . . , XN ) = Xn . (8.23)
N n=1

b ML the ML estimator of the true parameter ✓.


We call ⇥

Estimate versus estimator


N
1 X
An estimate is a number, e.g., ✓bML = xn . It is the random realization of
N n=1
a random variable.
XN
b ML = 1
An estimator is a random variable, e.g., ⇥ Xn . It takes a set of
N n=1
random variables and generates another random variable.

2 For notational simplicity, in this section we will focus on a scalar parameter ✓ instead of a vector

parameter ✓.

491
CHAPTER 8. ESTIMATION

The ML estimators are one type of estimator, namely those that maximize the likeli-
hood functions. If we do not want to maximize the likelihood we can still define an estimator.
An estimator is any function that takes the data points X1 , . . . , XN and maps them to a
number (or a vector of numbers). That is, an estimator is

b 1 , . . . , XN ).
⇥(X

b the estimator of the true parameter ✓.


We call ⇥

Example 8.11. Let X1 , . . . , XN be Gaussian i.i.d. random variables with unknown


mean ✓ and known variance 2 . Construct two possible estimators.
Solution. We define two estimators:
XN
b 1 (X1 , . . . , XN ) = 1
⇥ Xn ,
N n=1
b 2 (X1 , . . . , XN ) = X1 ,

In the first case, the estimator takes all the samples and constructs the sample average.
The second estimator takes all the samples and returns on the first element. Both are
legitimate estimators. However, ⇥ b 1 is the ML estimator, whereas ⇥ b 2 is not.

8.2.2 Unbiased estimators


While you can define estimators in any way you like, certain estimators are good and others
are bad. By “good” we mean that the estimator can provide you with the information about
the true parameter ✓; otherwise, why would you even construct such an estimator? However,
b is a random variable because it is constructed from X1 , . . . , XN .
the difficulty here is that ⇥
Therefore, we need to define di↵erent metrics to quantify the usefulness of the estimators.

b is unbiased if
Definition 8.5. An estimator ⇥
b = ✓.
E[⇥] (8.24)

Unbiasedness means that the average of the random variable ⇥ b matches the true
b
parameter ✓. In other words, while we allow ⇥ to fluctuate, we expect the average to match
the true ✓. If this is not the case, using more measurements will not help us get closer to ✓.

Example 8.12. Let X1 , . . . , XN be i.i.d. Gaussian random variables with a unknown


mean ✓. It has been shown that the ML estimator is
XN
b ML = 1
⇥ Xn . (8.25)
N n=1

b ML unbiased?
Is the ML estimator ⇥

492
8.2. PROPERTIES OF ML ESTIMATES

Solution: To check the unbiasedness, we look at the expectation:


N N
b ML ] = 1 X 1 X
E[⇥ E[Xn ] = ✓ = ✓.
N n=1 N n=1

b ML = 1
PN
Thus, ⇥ N n=1 Xn is an unbiased estimator of ✓.

Example 8.13. Same as the example before, but this time we consider an estimator
b = X1 + X2 + 5.
⇥ (8.26)

Is this estimator unbiased?


Solution: In this case,
b = E[X1 + X2 + 5] = E[X1 ] + E[X2 ] + 5 = 2✓ + 5 6= ✓.
E[⇥]

Therefore, the estimator is biased.

Example 8.14. Let X1 , . . . , XN be i.i.d. Gaussian random variables with unknown


mean µ and unknown variance 2 . We have shown that the ML estimators are
N N
1 X 2 1 X
bML =
µ Xn and bML = (Xn bML )2 .
µ
N n=1 N n=1

It is easy to show that E[b 2


µML ] = µ. How about bML ? Is it an unbiased estimator?
Solution: For simplicity we assume µ = 0 so that E[Xn2 ] = E[(Xn 0)2 ] = 2
.
Note that
N ⇢
2 1 X
E[bML ]= E[Xn2 ] 2E[b µ2ML ]
µML Xn ] + E[b
N n=1
8 2 3 2 !2 39
XN < N
X XN =
1 1 1
= 2
2E 4 Xj Xn 5 + E 4 Xn 5 .
N n=1 : N j=1 N n=1 ;

By independence, we observe that E[Xj Xn ] = E[Xj ]E[Xn ] = 0, for any j 6= n. There-


fore,
2 3
XN 
1 1
E4 Xj Xn 5 = E X1 Xn + · · · + XN Xn
N j=1 N
2
1 2
= (0 + · · · + + · · · + 0) = .
N N

493
CHAPTER 8. ESTIMATION

Similarly, we have that


2 !2 3 8 9
N
X N <
X X =
1 1
E4 Xn 5 = 2 E[Xn2 ] + E[Xj Xn ]
N n=1 N n=1 : ;
j6=n
N n
X o 2
1 2
= +0 = .
N2 n=1
N

Combining everything, we arrive at the result:


8 2 3 2 !2 39
XN < XN XN =
1 1 1
2
E[bML ]= 2
2E 4 Xj Xn 5 + E 4 Xn 5
N n=1 : N j=1 N n=1 ;
N ⇢
1 X 2 2 2 2
= +
N n=1 N N
N 1 2
= ,
N
2 2 2
which is not equal to . Therefore, bML is a biased estimator of .

In the previous example, it is possible to construct an unbiased estimator for the


variance. To do so, we can use
N
X
2 1
bunbias = (Xn bML )2 ,
µ (8.27)
N 1 n=1

so that E[bunbias
2
] = 2 . However, note that bunbias
2
does not maximize the likelihood, so while
you can get unbiasedness, you cannot maximize the likelihood. If you want to maximize the
likelihood, you cannot get unbiasedness.

What is an unbiased estimator?


An estimator ⇥b is unbiased if E[⇥]
b = ✓.
b is the true parameter ✓.
Unbiased means that the statistical average of ⇥
2 b = (1/N ) P N b
If Xn ⇠ Gaussian(✓, ), then ⇥ n=1 Xn is unbiased, but ⇥ = X1 is
biased.

8.2.3 Consistent estimators


By definition, an estimator ⇥(X b 1 , . . . , XN ) is a function of N random variables X1 , . . . , XN .
b
Therefore, ⇥(X1 , . . . , XN ) changes as N grows. In this subsection we analyze how ⇥ b behaves
when N changes. For notational simplicity we use the following notation:
b N = ⇥(X
⇥ b 1 , . . . , XN ). (8.28)
b 1 , . . . , XN ).
Thus, as N increases, we use more random variables in defining ⇥(X

494
8.2. PROPERTIES OF ML ESTIMATES

b N p! ✓, i.e.,
b N is consistent if ⇥
Definition 8.6. An estimator ⇥

lim P ⇥ bN ✓ ✏ = 0. (8.29)
N !1

The definition here follows from our discussions of the law of large numbers in Chapter 6.
The specific type of convergence is known as the convergence in probability. It says that
as N grows, the estimator ⇥ b will be close enough to ✓ so that the probability of getting a
large deviation will diminish, as illustrated in Figure 8.13.

1.2 1.2
1 1
0.8 0.8
0.6 0.6
0.4 0.4
0.2 0.2
0 0
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
(a) N = 1 (b) N = 2
1.2 1.2
1 1
0.8 0.8
0.6 0.6
0.4 0.4
0.2 0.2
0 0
-5 -4 -3 -2 -1 0 1 2 3 4 5 -5 -4 -3 -2 -1 0 1 2 3 4 5
(c) N = 4 (d) N = 8
⇥ ⇤
Figure 8.13: The four subfigures here illustrate the probability of error P |⇥ bN ✓| ✏ , which is
represented by the areas shaded in blue. We assume that the estimator ⇥ b N is a Gaussian random
2
variable following a distribution Gaussian(0, N ), where we set = 1. The threshold we use in this
figure is ✏ = 1. As N grows, we see that the probability of error diminishes. If the probability of error
goes to zero, we say that the estimator is consistent.

The examples in Figure 8.13 are typical situations for an estimator based on the
sample average. For example, if we assume that X1 , . . . , XN are i.i.d. Gaussian copies of
Gaussian(0, 2 ), then the estimator

XN
b 1 , . . . , XN ) = 1
⇥(X Xn
N n=1

2
will follow a Gaussian distribution Gaussian(0, N ). (Please refer to Chapter 6 for the deriva-
tion.) Then, as N grows, the PDF of ⇥ b N becomes narrower and narrower. For a fixed ✏, it
follows that the probability of error will diminish to zero. In fact, we can prove that, for this

495
CHAPTER 8. ESTIMATION

example,
  
P ⇥ bN ✓ bN
✏ =P ⇥ ✓ bN
✏ +P ⇥ ✓ ✏
Z 1 ✓ 2
◆ Z ✓ ✏ ✓ 2

= Gaussian z ✓, dz + Gaussian z ✓, dz
✓+✏ N 1 N
Z 1 (z ✓)2
Z ✓ ✏ (z ✓)2
1 1
= p e 2 2 /N dz + p e 2 2 /N dz
2⇡ 2 /N 2⇡ 2 /N
✓+✏ 1
Z 1 Z ✏
p
1 z2 / N 1 z2
= p e 2 dz + p e 2 dz

p
/ N
2⇡ 1 2⇡
✓ ◆ ✓ ◆
✏ ✏
=1 p + p
/ N / N
✓ ◆

=2 p .
/ N

Therefore, as N ! 1, it holds that p✏ ! 1. Hence,


/ N
 ✓ ◆
bN ✏
lim P ⇥ ✓ ✏ = lim 2 p = 0.
N !1 N !1 / N
This explains why in Figure 8.13 the probability of error diminishes to zero as N grows.
Therefore, we say that ⇥b N is consistent.
In general, there are two ways to check whether an estimator is consistent:
Prove convergence in probability. This is based on the definition of a consistent
estimator. If we can prove that
⇥ ⇤
b N ✓| ✏ = 0,
lim P |⇥ (8.30)
N !1

then we say that the estimator is consistent.


Prove convergence in mean squared error:
bN
lim E[(⇥ ✓)2 ] = 0. (8.31)
N !1

To see why convergence in the mean squared error is sufficient to guarantee consistency,
we recall Chebyshev’s inequality in Chapter 6, which says that

⇥ b N ✓)2 ]
⇤ E[(⇥
bN
P |⇥ ✓| ✏  .
✏2
Thus, if limN !1 E[(⇥b N ✓)2 ] = 0, convergence in probability will also hold. How-
ever, since mean square convergence is stronger than convergence in probability, being
unable to show mean square convergence does not imply that an estimator is incon-
sistent.
Be careful not to confuse a consistent estimator and an unbiased estimator. The two
are di↵erent concepts; one does not imply the other.

496
8.2. PROPERTIES OF ML ESTIMATES

Consistent versus unbiased


b will converge to
Consistent = If you have enough samples, then the estimator ⇥
the true parameter.
Unbiasedness does not imply consistency. For example (Gaussian), if

b = X1 ,

then E[X1 ] = µ. But P[|⇥b µ| > ✏] does not converge to 0 as N grows. So this
estimator is inconsistent. (See Example 8.16 below.)
Consistency does not imply unbiasedness. For example (Gaussian), if

XN
b= 1
⇥ (Xn µ)2
N n=1

is a biased estimate for variance, but it is consistent. (See Example 8.17 below.)

Example 8.15. Let X1 , . . . , XN be i.i.d. Gaussian random variables with an unknown


mean µ and known
PN variance 2 . We know that the ML estimator for the mean is
bML = (1/N ) n=1 Xn . Is µ
µ bML consistent?
Solution. We have shown that the ML estimator is
N
1 X
bML =
µ Xn .
N n=1

2
Since E[b
µML ] = µ, and E[(b
µML µ)2 ] = Var[b
µML ] = N , it follows that

⇥ ⇤ E[(b
µML µ)2 ] 2
P |b
µML µ| ✏  = .
✏2 N ✏2
Thus, when N goes to infinity, the probability converges to zero, and hence the esti-
mator is consistent.

Example 8.16. Let X1 , . . . , XN be i.i.d. Gaussian random variables with an unknown


mean µ and known variance 2 . Define an estimator µ b = X1 . Show that the estimator
is unbiased but inconsistent.
Solution. We know that E[b
µ] = E[X1 ] = µ. So µ
b is an unbiased estimator. However,
we can show that
µ µ)2 ] = E[(X1 µ)2 ] = 2 .
E[(b
Since this variance E[(b
µ µ)2 ] does not shrink as N increases, it follows that no matter

497
CHAPTER 8. ESTIMATION

how many samples we use we cannot make E[(b


µ µ)2 ] go to zero. To be more precise,
 
P |bµ µ| ✏ = P |X1 µ| ✏
 
= P X1  µ ✏ + P X1 µ + ✏
Z µ ✏ Z 1
1 (x µ)2 1 (x µ)2
= p e 2 2 dx + p e 2 2 dx
2⇡ 2 2⇡ 2
1 µ+✏
✓ ◆

=2 ,

which does not converge to zero as N ! 1. So the estimator is inconsistent.

Example 8.17. Let X1 , . . . , XN be i.i.d. Gaussian random variables with an unknown


mean µ and an unknown variance 2 . Is the ML estimate of the variance, i.e., bML 2
,
consistent?
Solution. We know that the ML estimator for the mean is
N
1 X
bML =
µ Xn ,
N n=1

and we have shown that it is an unbiased and consistent estimator of the mean. For
the variance,
N N
2 1 X 2 1 X⇥ 2 ⇤
bML = (Xn bML ) =
µ X 2b b2ML
µML Xn + µ
N n=1 N n=1 n
N N
1 X 2 1 X
= X µML ·
2b b2ML
Xn + µ
N n=1 n N n=1
N
1 X 2
= X b2ML .
µ
N n=1 n
PN
Note that N1 n=1 Xn2 is the sample average of the second moment, and so by the
weak law of large numbers it should converge in probability to E[Xn2 ]. Similarly, µ
bML
will converge in probability to µ. Therefore, we have
N
2 1 X 2 p
bML = X b2ML ! (
µ 2
+ µ2 ) µ2 = 2
.
N n=1 n

Thus, we have shown that the ML estimator of the variance is biased but consistent.

498
8.2. PROPERTIES OF ML ESTIMATES

The following discussions about the consistency of ML estimators can be skipped.

As we have said, there are many estimators. Some estimators are consistent and some
are not. The ML estimators are special. It turns out that under certain regularity conditions
the ML estimators of i.i.d. observations are consistent.
Without proving this result formally, we highlight a few steps to illustrate the idea.
Suppose that we have a set of i.i.d. data points x1 , . . . , xN drawn from some distribution
f (x, | ✓ true ). To formulate the ML estimation, we consider the log-likelihood function (di-
vided by N ):
N
1 1 X
log L(✓ | x) = log f (xn ; ✓). (8.32)
N N n=1
Here, the variable ✓ is unknown. We need to find it by maximizing the log-likelihood.
By the weak law of large numbers, we can show that the log-likelihood based on the
N samples will converge in probability to
N
1 X p
log f (xn ; ✓) ! E[log f (x; ✓)]. (8.33)
N n=1
| {z }
gN (✓)

The expectation can be evaluated by integrating over the true distribution:


Z
E[log f (x; ✓)] = log f (x; ✓) · f (x; ✓ true )dx.
| {z }
g(✓)

where f (x; ✓ true ) denotes the true distribution of the samples xn ’s. From these two results
we define two functions:
XN Z
def 1 def
gN (✓) = log f (xn ; ✓), and g(✓) = log f (x; ✓) · f (x; ✓ true )dx,
N n=1

p
and we know that gN (✓) ! g(✓).
We also know that ✓bML is the ML estimator, and so

✓bML = argmax gN (✓).



Let ✓ be the maximizer of the limiting function, i.e.,

✓ ⇤ = argmax g(✓).

p p
Because gN (✓) ! g(✓), we can (loosely3 ) argue that ✓bML ! ✓ ⇤ . If we can show that
p
✓ ⇤ = ✓ true , then we have shown that ✓bML ! ✓ true , implying that ✓bML is consistent.
3 To rigorously prove this statement we need some kind of regularity conditions on g
N and g. A more
formal proof can be found in H. Vincent Poor, An Introduction Signal Detection and Estimation, Springer,
1998, Section IV.D.

499
CHAPTER 8. ESTIMATION

To show that ✓ ⇤ = ✓ true , we note that


Z Z
d d
log f (x; ✓) · f (x; ✓ true ) dx = log f (x; ✓) · f (x; ✓ true ) dx
d✓ d✓
Z 0
f (x; ✓)
= · f (x; ✓ true ) dx.
f (x; ✓)

We ask whether this is equal to zero. Putting ✓ = ✓ true , we have that


Z 0 Z
f (x; ✓ true )
· f (x; ✓ true ) dx = f 0 (x; ✓ true ) dx.
f (x; ✓ true )

However, this integral can be simplified to


Z Z
0 d
f (x; ✓ true ) dx = f (x; ✓) dx = 0.
d✓ ✓=✓ true
| {z }
=1

Therefore, ✓ true is the maximizer for g(✓), and so ✓ true = ✓ ⇤ .

End of the discussion. Please join us again.

8.2.4 Invariance principle


Another useful property satisfied by the ML estimate is the invariance principle. The in-
variance principle says that a monotonic transformation of the true parameter is preserved
for the ML estimates.

What is the invariance principle?


There is a monotonic function h.
There is an ML estimate ✓bML for ✓.
The monotonic function h maps the true parameter ✓ 7 ! h(✓).
Then the same function will map the ML estimate ✓bML 7 ! h(✓bML ).

The formal statement of the invariance principle is given by the theorem below.

Theorem 8.1. If ✓bML is the ML estimate of ✓, then for any one-to-one function h
of ✓, the ML estimate of h(✓) is h(✓bML ).

Proof. Define the likelihood function L(✓) (we have dropped x to simplify the notation).
Then, for any monotonic function h, we have that
1
L(✓) = L(h (h(✓))).

500
8.2. PROPERTIES OF ML ESTIMATES

Let ✓bML be the ML estimate:

✓bML = argmax L(✓) = argmax L(h 1


(h(✓))).
✓ ✓

By the definition of ML, ✓bML must maximize the likelihood. Therefore, L(h 1 (h(✓))) is
maximized when h 1 (h(✓)) = ✓bML . This implies that h(✓) = h(✓bML ) because h is monotonic.
Since h(✓) is the parameter we try to estimate, the equality h(✓) = h(✓bML ) implies that
h(✓bML ) is the ML estimate of h(✓). ⇤

Example 8.18. Consider the single-photon image sensor example we discussed in


Section 8.1. We consider a set of i.i.d. Bernoulli random variables with PMF
⌘ ⌘
pXn (1) = 1 e and pXn (0) = e . (8.34)

Find the ML estimate through (a) direct calculation and (b) the invariance principle.
Solution. (a) Following the example in Equation (8.12), the ML estimate of ⌘ is
N N
!
Y 1 X
⌘ xn ⌘ 1 xn
⌘bML = argmax (1 e ) (e ) = log 1 xn .

n=1
N n=1

(b) We can obtain the same result using the invariance principle. Since Xn is a
binary random variable, we assume that it is a Bernoulli with parameter ✓. Then the
ML estimate of ✓ is
N
Y
✓bML = argmax ✓xn (1 ✓)1 xn
✓ n=1
N
X
1
= xn .
N n=1

The relationship between ✓ and ⌘ is that ✓ = 1 e ⌘ , or ⌘ = log(1 ✓). So we let


h(✓) = log(1 ✓). The invariance principle says that the ML estimate of h(✓) is

def d (i)
⌘bML = h(✓) b
ML = h(✓ML )
N
!
1 X
= log 1 xn ,
N n=1

where (i) follows from the invariance principle.

The invariance principle can be very convenient, especially when the transformation h is
complicated, so that a direct evaluation of the ML estimate is difficult.
The invariance principle is portrayed in Figure 8.14. We start with the Bernoulli log-
likelihood

log L(✓|S) = S log ✓ + (1 S) log(1 ✓).

501
CHAPTER 8. ESTIMATION

Figure 8.14: The invariance principle is a transformation of the ML estimate. In this example, we
consider a Bernoulli log-likelihood function shown in the lowermost plot. For this log-likelihood, the ML
estimate is ✓bML = 0.4. On the left-hand side we show another log-likelihood, derived for a truncated
Poisson random variable. Note that the ML estimate is ⌘bML = 0.5108. The invariance principle asserts
that, instead of computing these ML estimates directly, we can first derive the relationship between ⌘
and ✓ for any ✓. Since we know that ✓ = 1 e ⌘ , it follows that ⌘ = log(1 ✓). We define this
transformation as ⌘ = h(✓) = log(1 ✓). Then the ML estimate is ⌘bML = h(✓bML ) = h(0.4) = 0.5108.
The invariance principle saves us the trouble of computing the maximization of the more truncated
Poisson likelihood.

In this particular example we let S = 20, where S denotes the sum of the N = 50 Bernoulli
random variables. The other log-likelihood is the truncated Poisson, which is given by
⌘ ⌘
log L(⌘|S) = S log(1 e ) + (1 S) log(e ).

The transformation between the two is the function ⌘ = h(✓) = log(1 ✓). Putting
everything into the figure, we see that the ML estimate (✓ = 0.4) is translated to ⌘ = 0.5108.
The invariance principle asserts that this calculation can be done by ⌘bML = h(✓bML ) =
h(0.4) = 0.5108.

8.3 Maximum A Posteriori Estimation

In ML estimation, the parameter ✓ is treated as a deterministic quantity. There are, however,


many situations where we have some prior knowledge about ✓. For example, we may not
know exactly the speed of a car, but we may know that the speed is roughly 65 mph

502
8.3. MAXIMUM A POSTERIORI ESTIMATION

with a standard deviation of 5 mph. How do we incorporate such prior knowledge into the
estimation problem?
In this section, we introduce the second estimation technique, known as the maximum
a posteriori (MAP) estimation. MAP estimation links the likelihood and the prior. The key
idea is to treat the parameter ✓ as a random variable (vector) ⇥ with a PDF f⇥ (✓).

8.3.1 The trio of likelihood, prior, and posterior


To understand how the MAP estimation works, it is important first to understand the role
of the parameter ✓, which changes from a deterministic quantity to a random quantity.
Recall the likelihood function we defined in the ML estimation; it is

L(✓ | x) = fX (x; ✓),

if we assume that we have a set of i.i.d. observations x = [x1 , . . . , xN ]T . By writing the PDF
of X as fX (x; ✓), we emphasize that ✓ is a deterministic but unknown parameter. There
is nothing random about ✓.
In MAP, we change the nature of ✓ from deterministic to random. We replace ✓ by ⇥
and write
becomes
fX (x; ✓) =) fX|⇥ (x|✓). (8.35)
The di↵erence between the left-hand side and the right-hand side is subtle but important.
On the left-hand side, fX (x; ✓) is the PDF of X. This PDF is parameterized by ✓. On the
right-hand side, fX|⇥ (x|✓) is a conditional PDF of X given ⇥. The values they provide
are exactly the same. However, in fX|⇥ (x|✓), ✓ is a realization of a random variable ⇥.
Because ⇥ is now a random variable (vector), we can define its PDF (yes, the PDF
of ⇥), and denote it by
f⇥ (✓), (8.36)
which is called the prior distribution. The prior distribution of ⇥ is unique in MAP estima-
tion. There is nothing called a prior in ML estimation.
Multiplying fX|⇥ (x|✓) with the prior PDF f⇥ (✓), and using Bayes’ Theorem, we
obtain the posterior distribution:

fX|⇥ (x|✓)f⇥ (✓)


f⇥|X (✓|x) = . (8.37)
fX (x)

The posterior distribution is the PDF of ⇥ given the measurements X.


The likelihood, the prior, and the posterior can be confusing. Let us clarify their mean-
ings.
Likelihood fX|⇥ (x|✓): This is the conditional probability density of X given the pa-
rameter ⇥. Do not confuse the likelihood fX|⇥ (x|✓) defined in the MAP context
and the likelihood fX (x; |✓) defined in the ML context. The former assumes that ⇥
is random whereas the latter assumes that ✓ is deterministic. They have the same
values.
Prior f⇥ (✓): This is the prior distribution of ⇥. It does not come from the data X
but from our prior knowledge. For example, if we see a bike on the road, even before
we take any measurement we will have a rough idea of its speed. This is the prior
distribution.

503
CHAPTER 8. ESTIMATION

Posterior f⇥|X (✓|x): This is the posterior density of ⇥ given that we have observed X.
Do not confuse f⇥|X (✓|x) and L(✓ | x). The posterior distribution f⇥|X (✓|x) is a PDF
of ⇥ given X = x. The likelihood L(✓ | x) is not a PDF. If you integrate f⇥|X (✓|x)
with respect to ✓, you get 1, but if you integrate L(✓ | x) with respect to ✓, you do
not get 1.

What is the di↵erence between ML and MAP?

Likelihood ML fX (x; ✓) The parameter ✓ is deterministic.


MAP fX|⇥ (x | ✓) The parameter ⇥ is random.

Prior ML There is no prior, because ✓ is deterministic.


MAP f⇥ (✓) This is the PDF of ⇥.

Optimization ML Find the peak of the likelihood fX (x; ✓).


MAP Find the peak of the posterior f⇥|X (✓ | x).

Maximum a posteriori (MAP) estimation is a form of Bayesian estimation. Bayesian


methods emphasize our prior knowledge or beliefs about the parameters. As we will see
shortly, the prior has something valuable to o↵er, especially when we have very few data
points.

8.3.2 Understanding the priors


Since the biggest di↵erence between MAP and ML is the addition of the prior f⇥ (✓), we
need to take a closer look at what they mean. In Figure 8.15 below, we show a set of six
di↵erent priors. We ask two questions: (1) What do they mean? (2) Which one should we
use?

Figure 8.15: This figure illustrates six di↵erent examples of the prior distribution f⇥ (✓), when the prior
is a 1D parameter ✓. The prior distribution f⇥ (✓) is the PDF of ⇥. (a) f⇥ (✓) = (✓), which is a delta
function. (b) f⇥ (✓) = b 1 a for a  ✓  b. This is a uniform distribution. (c) This is also a uniform
distribution, but the spread is very wide. (d) f⇥ (✓) = Gaussian(0, 2 ), which is a zero-mean Gaussian.
(e) The same Gaussian, but with a di↵erent mean. (f) A Gaussian with zero mean, but a large variance.

504
8.3. MAXIMUM A POSTERIORI ESTIMATION

What does the shape of a prior tell us?

It tells us your belief as to how the underlying parameter ⇥ should be distributed.

The meaning of this statement can be best understood from the examples shown in Fig-
ure 8.15:
Figure 8.15(a). This is a delta prior f⇥ (✓) = (✓) (or f⇥ (✓) = (✓ ✓0 )). If you use this
prior, you are absolutely sure that the parameter ⇥ takes a specific value. There is no
uncertainty about your belief. Since you are so confident about your prior knowledge,
you will ignore the likelihood that is constructed from the data. No one will use a
delta prior in practice.
Figure 8.15(b). f⇥ (✓) = b 1 a for a  ✓  b, and is zero otherwise. This is a bounded
uniform prior. You do not have any preference for the parameter ⇥, but you do know
from your prior experience that a  ⇥  b.
Figure 8.15(c). This prior is the same as (b) but is short and very wide. If you use
this prior, it means that you know nothing about the parameter. So you give up the
prior and let the likelihood dominate the MAP estimate.
Figure 8.15(d). f⇥ (✓) = Gaussian(0, 2 ). You use this prior when you know something
about the parameter, e.g., that it is centered at certain location and you have some
uncertainty.
Figure 8.15(e). Same as (d), but the parameter is centered at some other location.
Figure 8.15(f). Same as (d), but you have less confidence about the parameter.
As you can see from these examples, the shape of the prior tells us how you want ⇥ to be
distributed. The choice you make will directly influence the MAP optimization, and hence
the MAP estimate.
Since the prior is a subjective quantity in the MAP framework, you as the user have
the freedom to choose whatever you like. For instance, if you have conducted a similar
experiment before, you can use the results of the previous experiments as the current prior.
Another strategy is to go with physics. For instance, we can argue that ✓ should be sparse
so that it contains as few non-zeros as possible. In this case, a sparsity-driven prior, such
as f⇥ (✓) = exp{ k✓k1 }, could be a choice. The third strategy is to choose a prior that is
computationally “friendlier”, e.g., in quadratic form so that the MAP is di↵erentiable. One
such choice is the conjugate prior. We will discuss this later in Section 8.3.6.

Which prior should we choose?


Based on your preference, e.g., you know from historical data that the parameter
should behave in certain ways.
Based on physics, e.g., the parameter has a physical interpretation, so you need
to abide by the physical laws.
Choose a prior that is computationally “friendlier”. This is the topic of the
conjugate prior, which is a prior that does not change the form of the posterior
distribution. (We will discuss this later in Section 8.3.6.)

505
CHAPTER 8. ESTIMATION

8.3.3 MAP formulation and solution


Our next task is to study how to formulate the MAP problem and how to solve it.

Definition 8.7. Let X = [X1 , . . . , XN ]T be i.i.d. observations. Let ⇥ be a random


parameter. The maximum-a-posteriori estimate of ⇥ is

✓bMAP = argmax f⇥|X (✓|x). (8.38)


Philosophically speaking, ML and MAP have two di↵erent goals. ML considers a para-
metric model with a deterministic parameter. Its goal is to find the parameter that maximizes
the likelihood for the data we have observed. MAP also considers a parametric model but
the parameter ⇥ is random. Because ⇥ is random, we are finding one particular state ✓ of
the parameter ⇥ that o↵ers the best explanation conditioned on the data X we observe.
In a sense, the two optimization problems are
✓bML = argmax fX|⇥ (x|✓),

✓bMAP = argmax f⇥|X (✓|x).


This pair of equations is interesting, as the pair tells us that the di↵erence between the ML
estimation and the MAP estimation is the flipped order of X and ⇥.
There are two reasons we care about the posterior. First, in MAP the posterior allows
us to incorporate the prior. ML does not allow a prior. A prior can be useful when the
number of samples is small. Second, maximizing the posterior does have some physical
interpretations. MAP asks for the probability of ⇥ = ✓ after observing N training samples
X = x. ML asks for the probability of observing X = x given a parameter ✓. Both are
correct and legitimate criteria, but sometimes we might prefer one over the other.
To solve the MAP problem, we notice that
✓bMAP = argmax f⇥|X (✓|x)

fX|⇥ (x|✓)f⇥ (✓)
= argmax
✓ fX (x)
= argmax fX|⇥ (x|✓)f⇥ (✓), fX (x) does not contain ✓

= argmax log fX|⇥ (x|✓) + log f⇥ (✓).

Therefore, what MAP adds is the prior log f⇥ (✓). If you use an uninformative prior, e.g., a
prior with extremely wide support, then the MAP estimation will return more or less the
same result as the ML estimation.

When does MAP = ML?


The relation “=” does not make sense here, because ✓ is random in MAP but
deterministic in ML.
Solution of MAP optimization = solution of ML optimization, when f⇥ (✓) is
uniform over the parameter space.

506
8.3. MAXIMUM A POSTERIORI ESTIMATION

In this case, f⇥ (✓) = constant and so it can be dropped from the optimization.

Example 8.19. Let X1 , . . . , XN be i.i.d. random variables with a PDF fXn |⇥ (xn |✓)
for all n, and ⇥ be a random parameter with PDF f⇥ (✓):

1 (xn ✓)2
fXn |⇥ (xn |✓) = p exp ,
2⇡ 2 2 2

1 (✓ µ0 )2
f⇥ (✓) = p exp .
2⇡ 02 2 02

Find the MAP estimate.


Solution. The MAP estimate is
"N ⇢ # " ⇢ #
Y 1 (xn ✓)2 1 (✓ µ0 )2
b
✓MAP = argmax p exp ⇥ p exp
✓ n=1 2⇡ 2 2 2 2⇡ 02 2 02
✓ ◆N ( N
)
1 1 X (xn ✓)2 (✓ µ0 )2
= argmax p ⇥p exp .
✓ 2⇡ 2 2⇡ 02 n=1
2 2 2 02

Since the maximizer is not changed by any monotonic function, we apply logarithm
to the above equations. This yields

N 1
✓bMAP = argmax log 2⇡ 2 log(2⇡ 02 )
✓ 2 2
XN
(xn ✓)2 (✓ µ0 ) 2
2 .
n=1
2 2 2 0

Constants in the maximization do not matter. So by dropping the constant terms we


obtain
( N )
X (xn ✓)2 (✓ µ0 )2
b
✓MAP = argmax . (8.39)
✓ n=1
2 2 2 02

It now remains to solve the maximization. To this end we take the derivative w.r.t. ✓
and show that
( N )
d X (xn ✓)2 (✓ µ0 )2
= 0.
d✓ n=1
2 2 2 02

This yields
N
X (xn ✓) ✓ µ0
2 2 = 0.
n=1 0

507
CHAPTER 8. ESTIMATION

Rearranging the terms gives us the final result:


⇣ P ⌘ 2
2 1 N
0 N n=1 xn + N µ0
✓bMAP = 2 2 . (8.40)
0 + N

Practice Exercise 8.7. Prove that if f⇥ (✓) = (✓ ✓ 0 ), the MAP estimate is ✓bMAP =
✓0 .

Solution. If f⇥ (✓) = (✓ ✓ 0 ), then

✓bMAP = argmax log fX|⇥ (x|✓) + log f⇥ (✓)



= argmax log fX|⇥ (x|✓) + log (✓ ✓0 )

8
<argmax log fX|⇥ (x|✓) 1, ✓ 6= ✓ 0 .

=
:argmax log fX|⇥ (x|✓) + 0, ✓ = ✓0 .

Thus, if ✓bMAP 6= ✓ 0 , the first case says that there is no solution, so we must go with
the second case ✓bMAP = ✓ 0 . But if ✓bMAP = ✓ 0 , there is no optimization because we
have already chosen ✓bMAP = ✓ 0 . This proves the result.

8.3.4 Analyzing the MAP solution


As we said earlier, MAP o↵ers something that ML does not. To see this, we will use the
result of the Gaussian random variables as an example and analyze the MAP solution as
we change the parameters N and 0 . Recall that if X1 , . . . , XN are i.i.d. Gaussian random
variables with unknown mean ✓ and known variance , the ML estimate is
N
1 X
✓bML = xn .
N n=1
2
Assuming that the parameter ⇥ is distributed according to a PDF Gaussian(µ0 , 0 ), we
have shown in the previous subsection that
⇣ P ⌘ 2
2 1 N 2
n=1 xn + N µ0
2b
b
0 N 0 ✓ML + N µ0
✓MAP = 2 2 = 2 2 .
0 + N 0 + N

In what follows, we will take a look at the behavior of the MAP estimate ✓bMAP as N
and 0 change. The results of our discussion are summarized in Figure 8.16.
First, let’s look at the e↵ect of N .

How does N change ✓bMAP ?


As N ! 1, the MAP estimate ✓bMAP ! ✓bML : If we have enough samples, we
trust the data.

508
8.3. MAXIMUM A POSTERIORI ESTIMATION

(a) E↵ect of N (b) E↵ect of 0

Figure 8.16: The MAP estimate ✓bMAP swings between the ML estimate ✓bML and the prior µ0 . (a) When
N increases, the likelihood is more reliable and so we lean towards the ML estimate. If N is small, we
should trust the prior more than the ML estimate. (b) When 0 decreases, we become more confident
about the prior and so we will use it. If 0 is large, we use more information from the ML estimate.

As N ! 0, the MAP estimate ✓bMAP ! ✓0 . If we do not have any samples, we


trust the prior.

These two results can be demonstrated by taking the limits. As N ! 1, the MAP estimate
converges to
2
2b
b 0 ✓ML + N µ0
lim ✓MAP = lim 2 2 = ✓bML . (8.41)
0 + N
N !1 N !1

This result is not surprising. When we have infinitely many samples, we will completely
rely on the data and make our estimate. Thus, the MAP estimate is the same as the ML
estimate.
When N ! 0, the MAP estimate converges to
2
2b
0 ✓ML + N µ0
lim ✓bMAP = lim 2 2 = µ0 . (8.42)
0 + N
N !0 N !0

This means that, when we do not have any samples, the MAP estimate ✓bMAP will completely
use the prior distribution, which has a mean µ0 .
The implication of this result is that MAP o↵ers a natural swing between ✓bML and ✓b0 ,
controlled by N . Where does this N come from? If we recall the derivation of the result, we
note that the N a↵ects the likelihood term through the number of samples:
⇢ XN
(xn ✓)2 (✓ µ0 ) 2
✓bMAP = argmax .
✓ 2 2 2 2
n=1
| {z } | {z0 }
1 term
N terms here

Thus, as N increases, the influence of the data term grows, and so the result will gradually
shift towards ✓bML .
Figure 8.17 illustrates a numerical experiment in which we draw N random samples
x1 , . . . , xN according to a Gaussian distribution Gaussian(✓, 2 ), with = 1. We assume
that the prior distribution is Gaussian(µ0 , 02 ), with µ0 = 0 and 0 = 0.25. The ML estimate
PN
of this problem is ✓bML = N1 n=1 xn , whereas the MAP estimate is given by Equation (8.40).

509
CHAPTER 8. ESTIMATION

The figure shows the resulting PDFs. A helpful analogy is that the prior and the likelihood
are pulling a rope in two opposite directions. As N grows, the force of the likelihood increases
and so the influence becomes stronger.

(a) N = 1 (b) N = 50

Figure 8.17: The subfigures show the prior distribution f⇥ (✓) and the likelihood function fX|⇥ (x|✓),
given the observed data. (a) When N = 1, the estimated posterior distribution f⇥|X (✓|x) is pulled
towards the prior. (b) When N = 50, the posterior is pulled towards the ML estimate. The analogy for
the situation is that each data point is acting as a small force against the big force of the prior. As N
grows, the small forces of the data points accumulate and eventually dominate.

We next look at the e↵ect of 0.

How does 0 change ✓bMAP ?


As 0 ! 1, the MAP estimate ✓bMAP ! ✓bML : If we have doubts about the prior,
we trust the data.
As 0 ! 0, the MAP estimate ✓bMAP ! ✓0 . If we are absolutely sure about the
prior, we ignore the data.

When 0 ! 1, the limit of ✓bMAP is


2
2b
0 ✓ML + N µ0
lim ✓bMAP = lim 2 2 = ✓bML . (8.43)
0 !1 0 !1
0 + N

The reason why this happens is that 0 is the uncertainty level of the prior. If 0 is high,
we are not certain about the prior. In this case, MAP chooses to follow the ML estimate.
When 0 ! 0, the limit of ✓bMAP is
2
2b
0 ✓ML + N µ0
lim ✓bMAP = lim 2 2 = µ0 . (8.44)
0 + N
0 !0 0 !0

Note that when 0 ! 0, we are essentially saying that we are absolutely sure about the
prior. If we are so sure about the prior, there is no need to look at the data. In that case
the MAP estimate is µ0 .

510
8.3. MAXIMUM A POSTERIORI ESTIMATION

The way to understand the influence of 0 is to inspect the equation:


⇢ XN
(xn ✓)2 (✓ µ0 ) 2
✓bMAP = argmax .
✓ 2 2 2 02
n=1
| {z } | {z }
fixed w.r.t. changes with 0
0

Since 0 is purely a preference you decide, you can control how much trust to put onto the
prior.

(a) 0 = 0.1 (b) 0 =1

Figure 8.18: The subfigures show the prior distribution f⇥ (✓) and the likelihood function fX|⇥ (x|✓),
given the observed data. (a) When 0 = 0.1, the estimated posterior distribution f⇥|X (✓|x) is pulled
towards the prior. (b) When 0 = 1, the posterior is pulled towards the ML estimate. An analogy for
the situation is that the strength of the prior depends on the magnitude of 0 . If 0 is small the prior
is strong, and so the influence is large. If 0 is large the prior is weak, and so the ML estimate will
dominate.

Figure 8.18 illustrates a numerical experiment in which we compare 0 = 0.1 and


0 = 1. If 0 is small, the prior distribution f⇥ (✓) becomes similar to a delta function. We
can interpret it as a very confident prior, so confident that we wish to align with the prior.
The situation can be imagined as a game of tug-of-war between a powerful bull and a horse,
which the bull will naturally win. If 0 is large the prior distribution will become flat. It
means that we are not very confident about the prior so that we will trust the data. In this
case the MAP estimate will shift towards the ML estimate.

8.3.5 Analysis of the posterior distribution


When the likelihood is multiplied with the prior to form the posterior, what does the poste-
rior distribution look like? To answer this question we continue our Gaussian example with
a fixed variance and an unknown mean ✓. The posterior distribution is proportional to

fX|⇥ (x|✓)f⇥ (✓)


f⇥|X (✓|x) = / fX|⇥ (x|✓)f⇥ (✓)
fX (x)
"N ⇢ # " ⇢ #
Y 1 (xn ✓)2 1 (✓ µ0 ) 2
= p exp 2
· p exp 2 . (8.45)
n=1 2⇡ 2 2 2⇡ 2
0
2 0

511
CHAPTER 8. ESTIMATION

Performing the multiplication and completing the squares,

XN
(xn ✓)2 (✓ µ0 )2 (✓ ✓bMAP )2
+ = ,
n=1
2 2 2 02 2
2 MAP

where
2
2b
0 ✓ML + N µ0 1 1 N
✓bMAP = 2 , and 2 = 2 + 2. (8.46)
2
0 + N
bMAP 0

In other words, the posterior distribution f⇥|X (✓|x) is also a Gaussian with

f⇥|X (✓|x) = Gaussian(✓bMAP , bMAP


2
).

2
If fX|⇥ (x|✓) = Gaussian(x; ✓, ), and f⇥ (✓) = Gaussian(✓; µ0 , 0 ), what is the
posterior f⇥|X (✓|x)?
The posterior f⇥|X (✓|x) is Gaussian(✓bMAP , bMAP
2
), where
2
2b
0 ✓ML + N µ0 1 1 N
✓bMAP = 2 , and 2 = 2 + 2
. (8.47)
2
0 + N
bMAP 0

The posterior tells us how N and 0 will influence the MAP estimate. As N grows,
the posterior mean and variance becomes

lim ✓bMAP = ✓bML = ✓, and lim bMAP = 0.


N !1 N !1

As a result, the posterior distribution f⇥|X (✓|x) will converge to a delta function centered
at the ML estimate ✓bML . Therefore, as we try to solve the MAP problem by maximizing the
posterior, the MAP estimate has to improve because bMAP ! 0.
We can plot the posterior distribution Gaussian(✓bMAP , bMAP2
) as a function of the
number of samples N . Figure 8.19 illustrates this example using the following configurations.
The likelihood is Gaussian with µ = 1, = 0.25. The prior is Gaussian with µ0 = 0 and
= 0.25. We construct the Gaussian according to Gaussian(✓bMAP , bMAP 2
) by varying N .
The result shown in Figure 8.19 confirms our prediction: As N grows, the posterior becomes
more like a delta function whose mean is the true mean µ. The posterior estimator ✓bMAP ,
for each N , is the peak of the respective Gaussian.

What is the pictorial interpretation of the MAP estimate?


For every N , MAP has a posterior distribution f⇥|X (✓|x).
bML .
As N grows, f⇥|X (✓|x) converges to a delta function centered at ✓
bML .
MAP tries to find the peak of f⇥|X (✓|x). For large N , it returns ✓

512
8.3. MAXIMUM A POSTERIORI ESTIMATION

8
N=0
N=1
6 N=2
N=5
N=8
4
N = 12
N = 20
2

0
-1 -0.5 0 0.5 1 1.5

Figure 8.19: Posterior distribution f⇥|X (✓|x) = Gaussian(✓bMAP , MAP


2
) as N grows. When N is small,
the posterior distribution is dominated by the prior. As N increases, the posterior distribution changes
its mean and its variance.

8.3.6 Conjugate prior


Choosing the prior is an important topic in a MAP estimation. We have elaborated two
“engineering” solutions: Use your prior experience or follow the physics. In this subsection,
we discuss the third option: to choose something computationally friendly. To explain what
we mean by “computationally friendly”, let us consider the following example, thanks to
Avinash Kak.4
Consider a Bernoulli distribution with a PDF
N
Y
fX|⇥ (x|✓) = ✓xn (1 ✓)1 xn
. (8.48)
n=1

To compute the MAP estimate, we assume that we have a prior f⇥ (✓). Therefore, the MAP
estimate is given by
✓bMAP = argmax fX|⇥ (x|✓)f⇥ (✓)

"N #
Y
= argmax ✓xn (1 ✓)1 xn
· f⇥ (✓)
✓ n=1
N
X
= argmax xn log ✓ + (1 xn ) log(1 ✓) + log f⇥ (✓).
✓ n=1

Let us consider three options for the prior. Which one would you use?
n o
1 (✓ µ)2
Candidate 1: f⇥ (✓) = p2⇡ 2
exp 2 2 , a Gaussian prior. If you choose this
prior, the optimization problem will become
XN ⇢
b (✓ µ)2
✓MAP = argmax xn log ✓ + (1 xn ) log(1 ✓) .
✓ n=1
2 2
4 Avinash Kak “ML, MAP, and Bayesian — The Holy Trinity of Parameter Estimation and Data Pre-

diction”, https://engineering.purdue.edu/kak/Tutorials/Trinity.pdf

513
CHAPTER 8. ESTIMATION

We can still take the derivative and set it to zero. This gives
PN PN
n=1 xn N n=1 xn ✓ µ
= 2
.
✓ 1 ✓
PN
Defining S = n=1 xn and moving the terms around, we have
2 2
(1 ✓) S ✓ (N S) = ✓(1 ✓)(✓ µ).
This is a cubic polynomial problem that has a closed-form solution and is also solvable
by a computer. But it’s also tedious, at least to lazy engineers like ourselves.
|✓|
Candidate 2: f⇥ (✓) = 2 e , a Laplace prior. In this case, the optimization problem
becomes
N ⇢
X
✓bMAP = argmax xn log ✓ + (1 xn ) log(1 ✓) |✓|.
✓ n=1

Welcome to convex optimization! There is no closed-form solution. If you want to solve


this problem, you need to call a convex solver.
Candidate 3: f⇥ (✓) = C1 ✓↵ 1 (1 ✓) 1 , a beta prior. This prior looks very compli-
cated, but let’s plug it into our optimization problem:
XN ⇢
✓bMAP = argmax xn log ✓
✓ n=1

+ (1 xn ) log(1 ✓) + (↵ 1) log ✓ + ( 1) log(1 ✓)

= argmax (S + ↵ 1) log ✓ + (N S+ 1) log(1 ✓),



PN
where S = n=1 xn . Taking the derivative and setting it to zero, we have
S+↵ 1 N S+ 1
= .
✓ 1 ✓
Rearranging the terms we obtain the final estimate:
S+↵ 1
✓bMAP = . (8.49)
N + +↵ 2
There are a number of intuitions that we can draw from this beta prior, but most
importantly, we have obtained a very simple solution. That is because the posterior distri-
bution remains in the same form as the prior, after multiplying by the prior. Specifically, if
we use the beta prior, the posterior distribution is
f⇥|X (✓|x) / fX|⇥ (x|✓)f⇥ (✓)
"N #
Y 1 ↵
= ✓xn (1 ✓)1 xn
· ✓ 1
(1 ✓) 1

n=1
C
S+↵ 1
=✓ (1 ✓)N S+ 1
.
This is still in the form of ✓F 1 (1 ✓)⌅ 1 , which is the same as the prior. When this
happens, we call the prior a conjugate prior. In this example, the beta prior is a conjugate
before the Bernoulli likelihood.

514
8.3. MAXIMUM A POSTERIORI ESTIMATION

What is a conjugate prior?


It is a prior such that when multiplied by the likelihood to form the posterior,
the posterior f⇥|X (✓|x) takes the same form as the prior f⇥ (✓).
Every likelihood has its conjugate prior.
Conjugate priors are not necessarily good priors. They are just computationally
friendly. Some of them have good physical interpretations.

We can make a few interpretations of the beta prior, in the context of Bernoulli likeli-
hood. First, the beta distribution takes the form
1
f⇥ (✓) = ✓↵ 1
(1 ✓) 1
, (8.50)
B(↵, )

with B(↵, ) is the beta function5 . The shape of the beta distribution is shown in Fig-
ure 8.20. For di↵erent choices of ↵ and , the distribution has a peak located towards
either side of the interval [0, 1]. For example, if ↵ is large but is small, the distribution
f⇥ (✓) leans towards 1 (the yellow curve).

4
= 2, =8
= 3, =7
= 8, =2
3

0
0 0.2 0.4 0.6 0.8 1

Figure 8.20: Beta distribution f⇥ (✓) for various choices of ↵ and . When (↵, ) = (2, 8), the beta
distribution favors small ✓. When (↵, ) = (8, 2), the beta distribution favors large ✓. By swinging
between the (↵, ) pairs, we obtain a prior that has a preference over ✓.

As a user, you have the freedom to pick f⇥ (✓). Even if you are restricted to the beta
distribution, you still have plenty of degrees of freedom in choosing ↵ and so that your
choice matches your belief. For example, if you know ahead of time that the Bernoulli
experiment is biased towards 1 (e.g., the coin is more likely to come up heads), you can
choose a large ↵ and a small . By contrast, if you believe that the coin is fair, you choose
↵ = . The parameters ↵ and are known as the hyperparameters of the prior distribution.
Hyperparameters are parameters for f⇥ (✓).
5 The (↵) ( )
beta function is defined as B(↵, ) = (↵+ )
, where is the gamma function. For integer n,
(n) = (n 1)!

515
CHAPTER 8. ESTIMATION

Example 8.20. (Prior for Gaussian mean) Consider a Gaussian likelihood for a fixed
variance 2 and unknown mean ✓:
✓ ◆N ( N )
1 X (xn ✓)2
fX|⇥ (x|✓) = p exp .
2⇡ 2 n=1
2 2

Show that the conjugate prior is given by



1 (✓ µ0 ) 2
f⇥ (✓) = p exp 2 . (8.51)
2⇡ 2
0
2 0

Solution. We have shown this result previously. By some (tedious) completing squares,
we show that ⇢
1 (✓ µN )2
f⇥|X (✓|x) = p exp 2 ,
2
2⇡ N 2 N
where
2 2 2 2
N 0 b 2 0
µN = 2 2
µ0 + 2 ✓
2 ML
and N = 2 2.
N 0 + N 0 + +N 0

Since f⇥|X (✓|x) is in the same form as f⇥ (✓), we know that f⇥ (✓) is a conjugate prior.

Example 8.21. (Prior for Gaussian variance) Consider a Gaussian likelihood for a
mean µ and unknown variance 2 :
✓ ◆N ( N )
1 X (xn µ)2
fX| (x| ) = p exp .
2⇡ 2 n=1
2 2

Find the conjugate prior.


1
Solution. We first define the precision ✓ = 2 . The likelihood is
✓ ◆N ( N
)
1 X (xn µ)2
fX|⇥ (x|✓) = p exp
2⇡ 2
n=1
2 2
( N
)
1 ✓X
= ✓N/2 exp (xn µ) 2
.
(2⇡)N/2 2 n=1

We propose to choose the prior f⇥ (✓) as


1 a a 1
f⇥ (✓) = b ✓ exp { b✓} ,
(a)

for some a and b. This f⇥ (✓) is called the Gamma distribution Gamma(✓|a, b). We can
show that E[⇥] = ab and Var[⇥] = ba2 . With some (tedious) completing squares, we

516
8.3. MAXIMUM A POSTERIORI ESTIMATION

show that the posterior is


( N
! )
(a0 +N/2) 1 1X 2
f⇥|X (✓|x) / ✓ exp b0 + (xn µ) ✓ ,
2 n=1

which is in the same form as the prior. So we know that our proposed f⇥ (✓) is a
conjugate prior.

The story of conjugate priors is endless because every likelihood has its conjugate prior.
Table 8.1 summarizes a few commonly used conjugate priors, their likelihoods, and their
posteriors. The list can be expanded further to distributions with multiple parameters. For
example, if a Gaussian has both unknown mean and variance, then there exists a conjugate
prior consisting of a Gaussian multiplied by a Gamma. Conjugate priors also apply to multi-
dimensional distributions. For example, the prior for the mean vector of a high-dimensional
Gaussian is another high-dimensional Gaussian. The prior for the covariance matrix of a
high-dimensional Gaussian is the Wishart prior. The prior for both the mean vector and the
covariance matrix is the normal Wishart.

Table of Conjugate Priors

Likelihood Conjugate Prior Posterior

fX|⇥ (x|✓) f⇥ (✓) f⇥|X (✓|x)

Bernoulli(✓) Beta(↵, ) Beta(↵ + S, + N S)


⇣ ⌘
Poisson(✓) Gamma(↵, ) Gamma ↵ + S, 1+N
⇣ ⌘
Exponential(✓) Gamma(↵, ) Gamma ↵ + N, 1+ S
⇣ ⌘
2 2 µ / 2 +S/ 2
Gaussian(✓, ) Gaussian(µ0 , 0) Gaussian 1/0 20+N/ 2
0
⇣ PN ⌘
Gaussian(µ, ✓2 ) Inv. Gamma(↵, ) Gamma ↵ + N2 , + 12 n=1 (xn µ)2

Table 8.1: Commonly used conjugate priors.

8.3.7 Linking MAP with regression


ML and regression represent the statistics and the optimization aspects of the same problem.
With the parallel argument, MAP is linked to the regularized regression. The reason follows
immediately from the definition of MAP:

✓bMAP = argmax log fX|⇥ (x|✓) + log f⇥ (✓) .


✓ | {z } | {z }
data fidelity regularization

517
CHAPTER 8. ESTIMATION

To make this more explicit, we consider following linear regression problem:


2 3 2 32 3 2 3
y1 0 (x1 ) 1 (x1 ) ··· d 1 (x1 ) ✓0 e1
6 y2 7 6 0 (x2 ) (x ) · · · (x ) 7 6 ✓1 7 6 e 2 7
6 7 6 1 2 d 1 2 76 7 6 7
6 .. 7 = 6 .. .. .. 76 .. 7 + 6 .. 7.
4 . 5 4 . ··· . . 54 . 5 4 . 5
yN 0 (xN ) 1 (xN ) · · · d 1 (xN ) ✓d 1 eN
| {z } | {z }| {z } | {z }
=y =X =✓ =e

2
If we assume that e ⇠ Gaussian(0, I), the likelihood is defined as

1 1
fY |⇥ (y | ✓) = p exp 2
ky X✓k2 . (8.52)
(2⇡ )2 N 2

In the ML setting, the ML estimate is the maximizer of the likelihood:

✓bML = argmax log fY |⇥ (y|✓)



1
= argmax 2
ky X✓k2 .
✓ 2

For MAP, we add a prior term so that the optimization becomes

✓bMAP = argmax log fY |⇥ (y|✓) + log f⇥ (✓)



1
= argmin 2
ky X✓k2 log f⇥ (✓).
✓ 2

Therefore, the regularization of the regression is exactly log f⇥ (✓). We can perform reverse
engineering to find out the corresponding prior for our favorite choices of the regularization.
Ridge regression. Suppose that

k✓k2
f⇥ (✓) = exp .
2 02

Taking the negative log on both sides yields

k✓k2
log f⇥ (✓) = .
2 02

Putting this into the MAP estimate,


1 1
✓bMAP = argmin 2
ky X✓k2 + 2 k✓k
2
✓ 2 2 0
2
= argmin ky X✓k2 + 2 k✓k2 ,
✓ 0
| {z }
=

where is the corresponding ridge regularization parameter. Therefore, the ridge regression
is equivalent to a MAP estimation using a Gaussian prior.

518
8.3. MAXIMUM A POSTERIORI ESTIMATION

How is MAP related to ridge regression?


In MAP, define the prior as a Gaussian:

k✓k2
f⇥ (✓) = exp . (8.53)
2 02

The prior says that the solution ✓ is naturally distributed according to a Gaussian
with mean zero and variance 02 .

LASSO regression. Suppose that



k✓k1
f⇥ (✓) = exp .

Taking the negative log on both sides yields

k✓k1
log f⇥ (✓) = .

Putting this into the MAP estimate we can show that
1 1
✓bMAP = argmin 2
ky X✓k2 + k✓k1
✓ 2 ↵
2
1
= argmin ky X✓k2 + k✓k1 .
✓ 2 ↵ }
| {z
=

To summarize:

How is MAP related to LASSO regression?


LASSO is a MAP using the prior

k✓k1
f⇥ (✓) = exp . (8.54)

At this point, you may be wondering what MAP buys us when regularized regression
can already do the job. The answer is about the interpretation. While regularized regression
can always return us a result, that is just a result. However, if you know that the parameter ✓
is distributed according to some distributions f⇥ (✓), MAP o↵ers a statistical perspective of
the solution in the sense that it returns the peak of the posterior f⇥|X (✓|x). For example, if
we know that the data is generated from a linear model with Gaussian noise, and if we know
that the true regression coefficients are drawn from a Gaussian, then the ridge regression is
guaranteed to be optimal in the posterior sense. Similarly, if we know that there are outliers
and have some ideas about the outlier statistics, perhaps the LASSO regression is a better
choice.
It is also important to note the di↵erent optimalities o↵ered by MAP versus ML versus
regression. The optimality o↵ered by regression is the training loss, which can always give
us a result even if the underlying statistics do not match the optimization formulation,

519
CHAPTER 8. ESTIMATION

e.g., there are outliers, and you use unregularized least-squares minimization. You can get a
result, but the outliers will heavily influence your solution. On the other hand, if you know
the data statistics and choose to follow the ML, then the ML solution is optimal in the sense
of optimizing the likelihood fX|⇥ (x|✓). If you further know the prior statistics, the MAP
solution will be optimal, but this time it is optimal w.r.t. to the posterior f⇥|X (✓|x). Since
each of these is optimizing for a di↵erent goal, they are only good for their chosen objectives.
For example, ✓ bMAP can be a biased estimate if our goal is to maximize the likelihood. The
bML is optimal for the likelihood but can be a bad choice for the posterior. Both ✓
✓ bMAP and
b
✓ ML can possibly achieve a reasonable mean-squared error, but their results may not make
sense (e.g., if ✓ is an image then ✓bMAP may over-smooth the image whereas ✓ bML amplifies
noise). So it’s incorrect to think that ✓bMAP is superior to ✓bML because it is more general.
Here are some rules of thumb for MAP, ML, and regression:

When should I use regression, ML and MAP?


Regression: If you are lazy and you know nothing about the statistics, do the
regression with whatever regularization you prefer. It will give you a result. See
if it makes sense with your data.
MAP: If you know the statistics of the data, and if you have some preference for
the prior distribution, go with MAP. It will o↵er you the optimal solution w.r.t.
finding the peak of the posterior.
ML: If you are interested in some simple-form solution, and you want those nice
properties such as consistency and unbiasedness, then go with ML. It usually
possesses the “friendly” properties so that you can derive the performance limit.

8.4 Minimum Mean-Square Estimation

First-time readers are often tempted to think that the maximum-likelihood estimation or
the maximum a posteriori estimation are the best methods to estimate parameters. In some
sense, this is true because both estimation procedures o↵er some form of optimal explanation
for the observed variables. However, as we said above, being optimal with respect to the
likelihood or the posterior only means optimal under the respective criteria. An ML estimate
is not necessarily optimal for the posterior, whereas a MAP estimate is not necessarily
optimal for the likelihood. Therefore, as we proceed to the third commonly used estimation
strategy, we need to remind ourselves of the specific type of optimality we seek.

8.4.1 Positioning the minimum mean-square estimation


Mean-square error estimation, as it is termed, uses the mean-square error as the optimality
criterion. The corresponding estimation process is known as the minimum mean-square
estimation (MMSE). MMSE is a Bayesian approach, meaning that it uses the prior f⇥ (✓)
as well as the likelihood fX|⇥ (x|✓). As we will show shortly, the MMSE estimate of a set

520
8.4. MINIMUM MEAN-SQUARE ESTIMATION

of i.i.d. observation X = [X1 , . . . , XN ]T is


(a)
✓bMMSE (x) = E⇥|X [⇥|X = x] (a) : We will discuss this.
Z
= ✓ · f⇥|X (✓|x) d✓. (8.55)

You may find this equation very surprising, because it says that the MMSE estimate is
the mean of the posterior distribution f⇥|X (✓|x). Let’s compare this result with the ML
estimate and the MAP estimate:

✓bML = peak of fX|⇥ (x | ✓),


✓bMAP = peak of f⇥X| (✓ | x),
✓bMMSE = average of f⇥|X (✓ | x).

Therefore, an MMSE estimate is not by any means universally superior or inferior to a MAP
estimate or an ML estimate. It is just a di↵erent estimate with a di↵erent goal.
So how exactly are these estimates di↵erent? Figure 8.21 illustrates a typical situation
of asymmetric distribution. Here, we plot both the likelihood function fX|⇥ (x | ✓) and the
posterior function f⇥X| (✓ | x).

Figure 8.21: A typical example of an ML estimate, a MAP estimate and an MMSE estimate.

As shown in the figure, the ML estimate is the peak of the likelihood, whereas the MAP
estimate is the peak of the posterior. The third estimate is the MMSE estimate, which is
the average of the posterior distribution. It is easy to see that if the posterior distribution
is symmetric and has a single peak, the peak is always the mean. Therefore, for single-peak
symmetric distributions, MMSE and MAP estimates are identical.

What is so special about the MMSE estimate?


MMSE is a Bayesian estimation, so it requires a prior.
An MMSE estimate is the mean of the posterior distribution.
MMSE estimate = MAP estimate if the posterior distribution is symmetric and
has a single peak.

521
CHAPTER 8. ESTIMATION

8.4.2 Mean squared error


The MMSE is based on minimizing the mean squared error (MSE). In this subsection we
discuss the mean squared error in the Bayesian setting. In the deterministic setting, given
an estimate ✓b and a ground truth ✓, the MSE is defined as
MSE( ✓ }
| {z ✓b } ) = (✓
, | {z b 2.
✓) (8.56)
ground truth estimate

In any estimation problem, the estimate ✓b is always a function of the observed variables.
Thus, we have
b
✓(X) = g(X), where X = [X1 , . . . , XN ]T ,
for some function g(·). Substituting this into the definition of MSE, and recognizing that X
is drawn from a distribution fX (x), we take the expectation to define the MSE as
b = (✓
MSE(✓, ✓) b2
✓)
+ replace ✓b by g(X)
b = (✓
MSE(✓, ✓) g(X))2
+ take expectation over X
⇥ ⇤
b = EX (✓ g(X))2 .
MSE(✓, ✓)
Thus we have arrived at the definition of MSE. We call this the frequentist version, because
the parameter ✓ is deterministic.

Definition 8.8 (Mean squared error, frequentist). The mean squared error of an
estimate g(X) w.r.t. the true parameter ✓ is
⇥ ⇤
MSEfreq (✓, g(·)) = EX (✓ g(X))2 . (8.57)

If the parameter ✓ is high-dimensional, so is the estimate g(X), and the MSE is


⇥ ⇤
MSEfreq (✓, g(·)) = EX k✓ g(X)k2 . (8.58)

Note that in the above definition the MSE is measured between the true parameter ✓ and
the estimator g(·). We use the function g(·) here because we have taken the expectation
of all the possible inputs X. So we are not comparing ✓ with a value g(X) but with the
function g(·).
If we take a Bayesian approach such as the MAP, then ✓ itself is a random variable ⇥.
To compute the MSE, we then need to take the average across all the possible choices of
ground truth ⇥. This leads to
⇥ ⇤
b = EX (✓ g(X))2
MSE(✓, ✓)
+ replace ✓ by ⇥
⇥ ⇤
b = EX (⇥ g(X))2
MSE(✓, ✓)
+ take expectation over ⇥
⇥ ⇤
b = EX,⇥ (⇥ g(X))2 .
MSE(✓, ✓)
Therefore, we have arrived at our definition of the MSE, in the Bayesian setting.

522
8.4. MINIMUM MEAN-SQUARE ESTIMATION

Definition 8.9 (Mean squared error, Bayesian). The mean squared error of an es-
timate g(X) w.r.t. the true parameter ⇥ is
⇥ ⇤
MSEBayes (⇥, g(·)) = E⇥,X (⇥ g(X))2 . (8.59)

If the parameter ⇥ is high-dimensional, so is the estimate g(X), and the MSE is


⇥ ⇤
MSEBayes (⇥, g(·)) = E⇥,X k⇥ g(X)k2 . (8.60)

The di↵erence between the Bayesian MSE and the frequentist MSE is the expectation over ⇥.
Practically speaking, the frequentist MSE is more of an evaluation metric than an objective
function for solving an inverse problem. The reason is that in an inverse problem, we never
have access to the true parameter ✓. (If we knew ✓, there would be no problem to solve.)
Bayesian MSE is more meaningful. It says that we do not know the true parameter ✓, but
we know its statistics. We are trying to find the best g(·) that minimizes the error. Our
solution will depend on the statistics of ⇥ but not on the unknown true parameter ✓.
When we say minimum mean squared error estimation, we typically refer to the
Bayesian MMSE. In this case, the problem we solve is
⇥ ⇤
g(·) = argmin E⇥,X (⇥ g(X))2 . (8.61)
g(·)

As you can see from Definition 8.9, the goal of the


⇥ Bayesian MMSE
⇤ is to find a function
g : RN ! R such that the joint expectation E⇥,X (⇥ g(X))2 is minimized. In the case
where ⇥ is a vector, the problem becomes
⇥ ⇤
g(·) = argmin E⇥,X k⇥ g(X)k2 , (8.62)
g(·)

where g(·) : RN ⇥d ! Rd if ⇥ is a d-dimensional vector. The function g will take a sequence


of N observed numbers and estimate the parameter ⇥.

What is the Bayesian MMSE estimate?


The Bayesian MMSE estimate is obtained by minimizing the MSE:
⇥ ⇤
g(·) = argmin E⇥,X (⇥ g(X))2 . (8.63)
g(·)

8.4.3 MMSE estimate = conditional expectation

Theorem 8.2. The Bayesian MMSE estimate is


⇥ ⇤
✓bMMSE = argmin E⇥,X (⇥ g(X))2
g(·)

= E⇥|X [⇥ | X = x]. (8.64)

523
CHAPTER 8. ESTIMATION

Proof. First of all, we decompose the joint expectation:


Z
⇥ ⇤ ⇥ ⇤
E⇥,X (⇥ g(X))2 = E⇥|X (⇥ g(X))2 | X = x fX (x) dx.
⇥ ⇤
Since fX (x) 0 for all x, and E⇥|X (⇥ g(X))⇥2 | X = x 0 because
⇤ it is a square, it
follows that the integral is minimized when E⇥|X (⇥ g(X)) | X = x is minimized.
2

The conditional expectation can be evaluated as


E⇥|X [(⇥ g(X))2 | X = x]

= E⇥|X ⇥2 2⇥g(X) + g(X)2 X = x
 
2
= E⇥|X ⇥ X = x 2E⇥|X ⇥ X = x g(x) + g(x)2
| {z } | {z }
def def
= V (x) = u(x)

= V (x) 2u(x)g(x) + g(x) + u(x)2


2
u(x)2
= V (x) u(x)2 + (u(x) g(x))2
V (x) u(x)2 , 8g(·),
where the last inequality holds because no matter what g(·) we choose, the square term
(u(x) g(x))2 is non-negative. Therefore, E⇥|X [(⇥ g(X))2 | X = x] is lower-bounded by
V (x) u(x)2 , which is a bound that is independent of g(·). If we can find a g(·) such that
this lower bound can be met, the corresponding g(·) is the minimizer.
To this end we only need to make E⇥|X [(⇥ g(X))2 | X = x] equal V (x) u(x)2 ,
but this is easy: the equality holds if and only if (u(x) g(x))2 = 0. In other words, if we
choose g(·) such that g(x) = u(x), the corresponding g(·) is the minimizer. This g(·), by
substituting the definition of u(x), is

g(x) = E⇥|X ⇥ X = x . (8.65)

This completes the proof.


What is the MMSE estimate?

The MMSE estimate is

✓bMMSE (x) = E⇥|X [⇥ | X = x]. (8.66)

We emphasize that ✓bMMSE (x) is a function of x, because for a di↵erent set of observations
x we will have a di↵erent estimated value. Since x is a random realization of the random
vector X, we can also define the MMSE estimator as
b MMSE (X) = E⇥|X [⇥ | X].
⇥ (8.67)
b MMSE returns a random parameter. The
In this notation, we emphasize that the estimator ⇥
input to the estimator is the random vector X. Because we are not looking at a particular
realization X = x but the general X, ⇥ b MMSE is a function of X and not x.

524
8.4. MINIMUM MEAN-SQUARE ESTIMATION

Conditional expectation of what?

An MMSE estimator is the conditional expectation of ⇥ given X = x:


 Z
E⇥|X ⇥ X = x = ✓ f⇥|X (✓|x) d✓. (8.68)

This is the expectation using the posterior distribution f⇥|X (✓|x). It should be compared
to the peak of the posterior, which returns us the MAP estimate. The posterior distribution
is constructed through Bayes’ theorem:

fX|⇥ (x|✓)f⇥ (✓)


f⇥|X (✓|x) = . (8.69)
fX (x)

Therefore, to evaluate the expectation of the condition distribution, we need to include the
normalization constant fX (x), which was omitted in MAP.

The discussion about the mean squared error and the vector estimates can be skipped if
this is your first time reading the book.

What is the mean squared error when using the MMSE estimator?
The mean squared error conditioned on the observation is
def
b MMSE (X)) = E⇥|X [(⇥ b MMSE (X))2 | X]
MSE(⇥, ⇥ ⇥
= Var⇥|X [⇥|X],

which is the conditional variance.


The overall mean squared error, unconditioned, is
⇥ ⇤
MSE(⇥, ⇥b MMSE (·)) = EX Var⇥|X [⇥|X]
= Var⇥ [⇥].

Proof. Let us prove


⇥ these⇤two statements. The resulting MSE is obtained by substituting
b MMSE (x) = E⇥|X ⇥ X into the MSE(⇥, ⇥
⇥ b MMSE (X)). To this end, we have that

E⇥|X [(⇥ b MMSE (X))2 | X] = V (X)


⇥ u(X)2
+ (u(X) b MMSE (X))2
⇥ .
| {z }
b MMSE (X)=E⇥|X [⇥|X]=u(X)
=0, because ⇥

The variables V and u are defined as


⇥ ⇤
V (X) = E⇥|X ⇥2 X = 2nd moment of ⇥ using f⇥|X (✓|x),
⇥ ⇤
u(X) = E⇥|X ⇥ X = 1st moment of ⇥ using f⇥|X (✓|x).

525
CHAPTER 8. ESTIMATION

Since Var[Z] = E[Z 2 ] E[Z]2 for any random variable Z, it follows that

E⇥|X [(⇥ b MMSE (X))2 | X] = V (X) u(X)2



⇥ ⇤ ⇥ ⇤ 2
= E⇥|X ⇥2 X E⇥|X ⇥ X
= variance of ⇥ using f⇥|X (✓|x)
def
= Var⇥|X [⇥|X].

Substituting this conditional variance into the MSE definition,


Z
MSE(⇥, ⇥ b MMSE (·)) = E⇥|X [(⇥ ⇥ b MMSE (X))2 | X = x]fX (x) dx
Z
= Var⇥|X [⇥|X = x]fX (x) dx

= Var⇥ [⇥].

What happens if the parameter is a vector?


The MMSE estimate is ✓bMMSE (x) = E⇥|X [⇥|X = x].
The MSE is
⇢ n o
b MMSE (·)) = Tr EX Cov(⇥|X) .
MSE(⇥, ⇥ (8.70)

Proof. The first statement, that the MMSE estimate is

✓bMMSE (x) = E⇥|X [⇥|X = x],

b MMSE (X) =
is easy to understand since it just follows from the scalar case. The estimator is ⇥
E⇥|X [⇥|X]. The corresponding MSE is

b MMSE (·)) = E⇥,X [k⇥ ⇥


MSE(⇥, ⇥ b MMSE (X)k2 ]

= EX E⇥|X [k⇥ ⇥ b MMSE (X)k2 | X] ,

where we have used the law of total expectation to decompose the joint expectation. Using
the matrix identity below, we have that

EX E⇥|X [k⇥ ⇥ b MMSE (X)k2 | X]
⇢ h n o i
= EX E⇥|X Tr (⇥ ⇥ b MMSE (X))(⇥ ⇥ b MMSE (X))T | X
⇢ ⇢ h i
= Tr EX E⇥|X (⇥ ⇥ b MMSE (X))(⇥ ⇥ b MMSE (X))T | X .

526
8.4. MINIMUM MEAN-SQUARE ESTIMATION

However, since the MMSE estimator is the condition expectation of the posterior, it follows
that the inner expectation is the conditional covariance. Therefore, we arrive at the second
statement:
⇢ ⇢ h i
MSE(⇥, ⇥ b MMSE (·)) = Tr EX E⇥|X (⇥ ⇥ b MMSE (X))(⇥ ⇥ b MMSE (X))T | X
⇢ n o
= Tr EX Cov(⇥|X) .

To prove the two statements above, we need some tools from linear algebra. The two
specific matrix identities are given by the following lemma:

Lemma 8.1. The following are matrix identities:


For any random vector ⇥ 2 Rd ,

k⇥k2 = Tr(⇥T ⇥) = Tr(⇥⇥T ).

For any random vector ⇥ 2 Rd ,

E⇥ [Tr(⇥⇥T )] = Tr(E⇥ [⇥⇥T ]).

The proof of these two results is straightforward. The first is due to the cyclic property of
the trace operator. The second statement is true because the trace is a linear operator that
sums the diagonal of a matrix.

The end of the discussion. Please join us again.

Example 8.22. Let


( (
✓x ↵✓
✓e , x 0, ↵e , ✓ 0,
fX|⇥ (x|✓) = and f⇥ (✓) =
0, x < 0, 0, ✓ < 0.

Find the ML, MAP, and MMSE estimates for a single observation X = x.
Solution. We first find the posterior distribution:

fX|⇥ (x|✓)f⇥ (✓)


f⇥|X (✓|x) =
fX (x)
(↵+x)✓
↵✓e
= R1 (↵+x)✓
0
↵✓e d✓
(↵+x)✓
↵✓e
= ↵
(↵+x)2

= (↵ + x)2 ✓e (↵+x)✓
.

527
CHAPTER 8. ESTIMATION

The MMSE estimate is the conditional expectation of the posterior:

✓bMMSE (x) = E⇥|X [⇥|X = x]


Z 1
= ✓f⇥|X (✓|x) d✓
0
Z 1
= ✓(↵ + x)2 ✓e (↵+x)✓ d✓
0
Z 1
= (↵ + x) ✓2 · (↵ + x)e (↵+x)✓
d✓
0
| {z }
2nd moment of exponential distribution
2 2
= (↵ + x) · = .
(↵ + x)2 ↵+x

The MAP estimate is the peak of the posterior:

✓bMAP (x) = argmax log fX|⇥ (x|✓) + log f⇥ (✓)



= argmax ✓x + log ✓ ↵✓ + log ↵.

1
Taking the derivative and setting it to zero yields x+ ✓ ↵ = 0. This implies that

1
✓bMAP (x) = .
↵+x
Finally, the ML estimate is
1
✓bML (x) = argmax log fX|⇥ (x|✓) = .
✓ x

Practice Exercise 8.8. Following the previous example, derive the estimates for
multiple observations X = x.

Solution. The posterior is

fX|⇥ (x|✓)f⇥ (✓)


f⇥|X (✓|x) =
fX (x)
QN
( n=1 fX|⇥ (xn |✓))f⇥ (✓)
=
fX (x)
P
(↵+ N n=1 xn )✓
↵✓e
= R1 PN
↵✓e (↵+ n=1 xn )✓ d✓
0
N
!2
X PN
= ↵+ xn ✓e (↵+ n=1 xn ) ✓
.
n=1

528
8.4. MINIMUM MEAN-SQUARE ESTIMATION

PN
Therefore, we are only replacing x by the sum n=1 xn in the posterior. Hence, the
estimates are:
2
✓bMMSE (x) = PN ,
↵+ n=1 xn
1
✓bMAP (x) = PN ,
↵+ n=1 xn
1
✓bML (x) = PN .
n=1 xn

This example shows that as N ! 1, the ML estimate ✓bML (x) ! 0. The reason is that the
likelihood is an exponential distribution. Therefore, the peak is always at 0. The posterior is
an Erlang distribution, and therefore the peak is o↵set by ↵ in the denominator. However,
as N ! 1 the posterior distribution is dominated by the likelihood, so the peak is shifted
towards 0. Finally, since the Erlang distribution is asymmetric, the mean is di↵erent from
the peak. Hence, the MMSE estimate is di↵erent from the MAP estimate.

8.4.4 MMSE estimator for multidimensional Gaussian


The multidimensional Gaussian has some very important uses in data science. Accordingly,
we devote this subsection to the discussion of the MMSE estimate of a Gaussian. The main
result is stated as follows.

What is the MMSE estimator for a multi-dimensional Gaussian?


Theorem 8.3. Suppose ⇥ 2 Rd and X 2 RN are jointly Gaussian with a joint PDF
 ✓  ◆
⇥ µ⇥ ⌃⇥⇥ ⌃⇥X
⇠ Gaussian , .
X µX ⌃X⇥ ⌃XX

The MMSE estimator is


b MMSE (X) = µ⇥ + ⌃⇥X ⌃ 1 (X
⇥ µX ). (8.71)
XX

The proof of this result is not difficult but it is tedious. The flow of the argument is:
Step 1: Show that the posterior distribution f⇥|X (✓|x) is a Gaussian.
Step 2: To do so we need to complete the squares for matrices.
Step 3: Once we have the f⇥|X (✓|x), the posterior mean is the MMSE estimator.

The proof below can be skipped if this is your first time reading the book.

529
CHAPTER 8. ESTIMATION

Proof. The posterior PDF is


f⇥,X (✓, x)
f⇥|X (✓|x) =
fX (x)
(    )
T 1
✓ µ⇥ ⌃⇥⇥ ⌃⇥X ✓ µ⇥
p 1d+N exp 1
2
(2⇡) |⌃| x µX ⌃X⇥ ⌃XX x µX
= n ⇥ ⇤T ⇥ ⇤o .
p 1 1 1
exp 2
x µX ⌃XX x µX
(2⇡)N |⌃XX |

Without loss of generality, we assume that µX = µ⇥ = 0. Then the posterior becomes


1
f⇥|X (✓|x) = p
(2⇡)d |⌃|/|⌃ XX |
(    )
T 1
1 ✓ ⌃⇥⇥ ⌃⇥X ✓ 1 T 1
⇥ exp + x ⌃XX x .
2 x ⌃X⇥ ⌃XX x 2
| {z }
H(✓,x)

The tedious task here is to simplify H(✓, x).


Regardless of what the 2-by-2 matrix inverse is, the matrix will take the form
 1 
⌃⇥⇥ ⌃⇥X A B
= ,
⌃X⇥ ⌃XX C D
for some choices of matrices A, B, C and D. Therefore, the function H(✓, x) can be written
as
1n T o
H(✓, x) = ✓ A✓ + ✓ T Bx + xT C✓ + xT Dx xT ⌃XX 1
x . (8.72)
2
Our goal is to complete the square for H(✓, x). To this end, we propose to write
1n o
H(✓, x) = (✓ Gx)T A(✓ Gx) + Q(x) , (8.73)
2
for some matrix G and function Q(·) of x only. If we compare Equation (8.72) and Equa-
tion (8.73), we observe that G must satisfy
1
G= A B.
Therefore, if we can determine A and B, we will know G. If we know G, we have completed
the square for H(✓, x). If we can complete the square for H(✓, x), we can write

exp{ Q(x)/2} 1
f⇥|X (✓|x) = p ⇥ exp (✓ Gx)T A(✓ Gx) .
(2⇡)d |⌃|/|⌃XX | 2
| {z } | {z }
constant in ✓ a Gaussian

Hence, the MMSE estimate, which is the posterior mean E[⇥|X = x], is simply Gx:

✓bMMSE (x) = E[⇥|X = x]


= Gx
1
= A Bx.

530
8.4. MINIMUM MEAN-SQUARE ESTIMATION

So it remains to determine A and B by solving the tedious matrix inversion problem. The
result is:6
1 1
A = (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) ,
1 1
B= (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) 1 ⌃⇥X ⌃XX ,
1 1 1
C= (⌃XX ⌃X⇥ ⌃⇥⇥ ⌃⇥X ) ⌃X⇥ ⌃⇥⇥ ,
1
D= (⌃XX ⌃X⇥ ⌃⇥⇥ ⌃⇥X ) 1 .

Therefore, plugging everything into the equation,

✓bMMSE (x) = A 1
Bx
1
= ⌃⇥,X ⌃XX x.

For non-zero means, we can repeat the same arguments above and show that

✓bMMSE (x) = µ⇥ + ⌃⇥,X ⌃XX


1
(x µX ).

End of the proof. Please join us again.

Practice Exercise 8.9. Suppose ⇥ 2 Rd and X 2 RN are jointly Gaussian with a


joint PDF  ✓  ◆
⇥ µ⇥ ⌃⇥⇥ ⌃⇥X
⇠ Gaussian , .
X µX ⌃X⇥ ⌃XX
We know that the MMSE estimator is
b MMSE (X) = µ⇥ + ⌃⇥X ⌃ 1 (X
⇥ µX ). (8.74)
XX

Find the mean squared error when using the MMSE estimator.
Solution. Conditioned on X = x, according to Equation (8.70), the MMSE is

b
MSE(⇥, ⇥(X)) = Tr {Cov[⇥|X]} .

The conditional covariance Cov[⇥|X] is the covariance of the posterior distribution


f⇥|X (✓|x), which is

Tr {Cov[⇥|X]} = Tr {A}
1 1
= Tr (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) .

6 See Matrix Cookbook https://www.math.uwaterloo.ca/ hwolkowi/matrixcookbook.pdf Section 9.1.5


~
on the Schur complement.

531
CHAPTER 8. ESTIMATION

The overall mean squared error is


⇣ ⌘ 
b
MSE ⇥, ⇥(·) b
= EX MSE(⇥, ⇥(X))
Z
b
= MSE(⇥, ⇥(x))f X (x) dx
Z
= Tr {Cov[⇥|X]} fX (x) dx
Z
1 1
= Tr (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) fX (x) dx
Z
1 1
= Tr (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) fX (x) dx
1 1
= Tr (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) .

For multidimensional Gaussian, does MMSE = MAP?


The answer is YES.
Theorem 8.4. Suppose ⇥ 2 Rd and X 2 RN are jointly Gaussian with a joint PDF
 ✓  ◆
⇥ µ⇥ ⌃⇥⇥ ⌃⇥X
⇠ Gaussian , .
X µX ⌃X⇥ ⌃XX

The MAP estimate is


b MAP (X) = µ⇥ + ⌃⇥X ⌃ 1 (X
⇥ µX ). (8.75)
XX

Proof. The proof of this result is straightforward. If we return to the proof of the MMSE
result, we note that

exp{ Q(x)/2} 1
f⇥|X (✓|x) = p ⇥ exp (✓ Gx)T A(✓ Gx) .
(2⇡)d |⌃|/|⌃XX | 2
| {z } | {z }
constant in ✓ a Gaussian

Therefore, the maximizer of this posterior distribution, which is the MAP estimate, is

✓bMAP (x) = argmax f⇥|X (✓|x)



1
= argmax (✓ Gx)T A(✓ Gx).
✓ 2

Taking the derivative w.r.t. ✓ and setting it zero, we have

✓bMAP (x) = Gx = ⌃⇥,X ⌃XX


1
x.

If the mean vectors are non-zero, we have ✓bMAP (x) = µ⇥ + ⌃⇥X ⌃XX
1
(x µX ).

532
8.4. MINIMUM MEAN-SQUARE ESTIMATION

8.4.5 Linking MMSE and neural networks


The blossoming of deep neural networks since 2010 has created a substantial impact on
modern data science. The basic idea of a neural network is to train a stack of matrices and
nonlinear functions (known as the network weights and the neuron activation functions,
respectively), among other innovative ideas, so that a certain training loss is minimized.
Expressing this by equations, the goal of the learning is equivalent to solving the optimization
problem 
gb(·) = argmin EX,⇥ k⇥ g(X)k2 , (8.76)
g(·)

where X 2 RM is the input data and ⇥ 2 Rd is the ground truth prediction. We want to
find g(·) such that the error is minimized.
The error we choose here is the `2 -norm error k · k2 . It is only one of many possi-
ble choices. You may recognize that this is exactly the same as the MMSE optimization.
Therefore, the neural network we are finding here is the MMSE estimator. Since the MMSE
estimator is the conditional expectation of the posterior distribution, the neural network
approximates the mean of the posterior distribution.
Often the struggle we have with deep neural networks is whether we can find the
optimal network parameters via optimization algorithms such as the stochastic gradient
descent algorithms. However, if we think about this problem more deeply, the equivalence
between the MMSE estimator and the posterior mean tells us that the hard part is related
to the posterior distribution. In the high-dimensional landscape, it is close to impossible to
determine the posterior and its mean. If we add to these difficulties and the nonconvexity
of the function g, training a network is very challenging.
One misconception about neural networks is that if we can achieve a low training error,
and if the model can also achieve a low testing error, then the network is good. This is a false
sense of satisfaction. If a model can achieve very good training and testing errors, then the
model is only good with respect to the error you choose. For example, if we choose the `2 -
norm error k·k2 and if our model achieves good training and testing errors (in terms of k·k2 ),
we can conclude that the model does well with respect to k · k2 . The more serious problem
here, unfortunately, is that k · k2 is not necessarily a good metric of performance (for both
training and testing) because training with k·k2 is equivalent to approximating the posterior
mean. There is absolutely no reason to believe that in the high-dimensional landscape, the
posterior mean is the optimal. If we choose the posterior mode or the posterior median,
we will also obtain a result. Why are the modes and medians “worse” than the mean?
In practice, it has been observed that training deep neural networks for image-processing
tasks generally leads to over-smoothed images. This demonstrates how minimizing the mean
squared error k · k2 can be a fundamental mismatch with the problem.

Is minimizing the MSE the best option?


No. Minimizing the MSE is equivalent to finding the mean of the posterior. There
is no reason why the mean is the “best”.
You can find the mode of the posterior, in which case you will get a MAP
estimator.
You can also find the median of the posterior, in which case you will get the
minimum absolute error estimator.

533
CHAPTER 8. ESTIMATION

Ultimately, you need to define what is “good” and what is “bad”.


The same principle applies to deep neural networks. Especially in the regression
setting, why is k · k2 a good evaluation metric for testing (not just training)?

8.5 Summary

In this chapter, we have discussed the basic principles of parameter estimation. The three
building blocks are:
Likelihood fX|⇥ (x|✓): the PDF that we observe samples X conditioned on the un-
known parameter ⇥. In the frequentist world, ⇥ is a deterministic quantity. In the
Bayesian world, ⇥ is random and so it has a PDF.
Prior f⇥ (✓): the PDF of ⇥. The prior f⇥ (✓) is used by all Bayesian computation.
Posterior f⇥|X (✓|x): the PDF that the underlying parameter is ⇥ = ✓ given that we
have observed X = x.
The three building blocks give us several strategies to estimate the parameters:
Maximum likelihood (ML) estimation: Maximize fX|⇥ (x|✓).
Maximum a posteriori (MAP) estimation: Maximize f⇥|X (✓|x).
Minimum mean-square estimation (MMSE): Minimize the mean squared error, which
is equivalent to finding the mean of f⇥|X (✓|x).
As discussed in this chapter, no single estimation strategy is universally “better” because
one needs to specify the optimality criterion. If the goal is to minimize the mean squared
error, then the MMSE estimator is the optimal strategy. If the goal is to maximize the
likelihood without assuming any prior knowledge, the ML estimator would be the optimal
strategy. It may appear that if we knew the ground truth parameter ✓ ⇤ we could minimize
the distance between the estimated parameter ✓ and the true value ✓ ⇤ . If the parameter
is a scalar, this will work. However, if the parameter is a vector, the noise of the distance
becomes an issue. For example, if one cares about the mean absolute error (MAE), the
optimal estimator would be the median of the posterior distribution instead of the mean of
the posterior in the MMSE case. Therefore, it is the end user’s responsibility to specify the
optimality criterion.
Whenever we consider parameter estimation, we tend to think that it is about estimat-
ing the model parameters, such as the mean of a Gaussian PDF. While in many statistics
problems this is indeed the case, parameter estimation can be much broader if we link it
with regression. Specifically, a regularized linear regression problem can be formulated as a
MAP estimation
✓ ⇤ = argmax kX✓ yk2 + R(✓) , (8.77)
✓ | {z } | {z }
log fX|⇥ (x|✓) log f⇥ (✓)

for some regularization R(✓), which is also the negative log of the prior. Expressed in this
way, we recognize that the MAP estimation can be used to recover signals. For example, we

534
8.6. REFERENCES

can model X as a linear degradation process of certain imaging systems. Then solving the
MAP estimation is equivalent to finding the best signal explaining the degraded observation
using the posterior as the criterion. There is rich literature dealing with solving MAP esti-
mation problems similar to these in subjects such as computational imaging, communication
systems, remote sensing, radar engineering, and recommendation systems, to name a few.

8.6 References

Basic
8-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 8 and Chapter 9.
8-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 6 and Chapter 8.

8-3 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 8.
8-4 Henry Stark and John W. Woods, Probability and Random Processes with Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2002. Chapter 5.
8-5 Todd K. Moon and Wynn C. Stirling, Mathematical Methods and Algorithms for Signal
Processing, Prentice-Hall, 2000. Chapter 12.

Theoretical analysis
8-6 H. Vincent Poor, An Introduction Signal Detection and Estimation, Springer, 1998.

8-7 Steven M. Kay, Fundamentals of Statistical Signal Processing: Estimation Theory,


Prentice-Hall, 1993.
8-8 Bernard C. Levy, Principles of Signal Detection and Parameter Estimation, Springer,
2008.

8-9 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 2001. Chapter 8.
8-10 Larry Wasserman, All of Statistics: A Concise Course in Statistical Inference, Springer,
2010.
8-11 Erich L. Lehmann, Elements of Large-Sample Theory, Springer, 1999. Chapter 7.

8-12 George Casella and Roger L. Berger Statistical Inference, Duxbury, 2002. Chapter 7.

535
CHAPTER 8. ESTIMATION

Machine-learning
8-13 Christopher Bishop, Pattern Recognition and Machine Learning, Springer, 2006. Chap-
ter 2 and Chapter 3.
8-14 Richard O. Duda, Peter E. Hart and David G. Stork, Pattern Classification, Wiley
2001. Chapter 3.

8.7 Problems

Exercise 1.
Let X1 , . . . , XN be a sequence of i.i.d. Bernoulli random variables with P[Xn = 1] = ✓.
Suppose that we have observed x1 , . . . , xN .

(a) Show that the PMF of Xn is pXn (xn | ✓) = ✓xn (1 ✓)1 xn


. Find the joint PMF

pX1 ,...,XN (x1 , . . . , xN ).

b i.e.,
(b) Find the maximum likelihood estimate ✓,

✓bML = argmax log pX1 ,...,XN (x1 , . . . , xN ).


Express your answer in terms of x1 , . . . , xN .


b ML ✓| > 0.1].
(c) Let ✓ = 1/2. Use Chebyshev’s inequality to find an upper bound for P[|⇥

Exercise 2.
Let Yn = ✓ + Wn be the output of a noisy channel where the input is a scalar ✓ and
Wn ⇠ N (0, 1) is an i.i.d. Gaussian noise. Suppose that we have observed y1 , . . . , yN .
(a) Express the PDF of Yn in terms of ✓ and yn . Find the joint PDF of Y1 , . . . , YN .

(b) Find the maximum likelihood estimate ✓bML . Express your answer in terms of y1 , . . . , yN .
b ML ].
(c) Find E[⇥

Exercise 3.
Let X1 , . . . , XN be a sequence of i.i.d. Gaussian random variables with unknown mean ✓1
and variance ✓2 . Suppose that we have observations x1 , . . . , xN .
(a) Express the PDF of Xn in terms of xn , ✓1 and ✓2 . Find the joint PDF of X1 , . . . , XN .

(b) Find the maximum likelihood estimates of ✓1 and ✓2 .

536
8.7. PROBLEMS

Exercise 4.
In this problem we study a single-photon image sensor. First, recall that photons arrive
according to a Poisson distribution, i.e., the probability of observing k photons is
k
e
P[Y = k] = ,
k!
where is the (unknown) underlying photon arrival rate. When photons arrive at the single-
photon detector, the detector generates a binary response “1” when one or more photons
are detected, and “0” when no photon is detected.
(a) Let B be the random variable denoting the response of the single-photon detector.
That is, (
1, Y 1,
B=
0, Y = 0.
Find the PMF of B.
(b) Suppose we have obtained T independent measurements with realizations B1 = b1 ,
B2 = b2 , ..., BT = bT . Show that the underlying photon arrival rate can be estimated
by !
PT
t=1 bt
= log 1 .
T

(c) Get a random image from the internet and turn it into a grayscale array with values
between 0 and 1. Write a MATLAB or Python program to synthetically generate a
sequence of T = 1000 binary images. Then use the previous result to reconstruct the
grayscale image.

Exercise 5.
Consider a deterministic vector s 2 Rd and random vectors
fY |⇥ (y|✓) = Gaussian(s✓, ⌃),
2
f⇥ (✓) = Gaussian(µ, ).
(a) Show that the posterior distribution is given by
f⇥|Y (✓|y) = Gaussian(m, q 2 ), (8.78)
where
d2 = sT ⌃ 1 s,
✓ ◆ ⇣ µ⌘
1
2 1 1
m= d + 2 sT ⌃ y+ 2
,
1
q2 = 1 .
d2 + 2

(b) Show that the MMSE estimate ✓bMMSE (y) is given by


2 T
s ⌃ 1y + µ
✓bMMSE (y) = 2 d2 + 1
. (8.79)

537
CHAPTER 8. ESTIMATION

(c) Show that the MSE is given by

b MMSE (Y )) = 1
MSE(⇥, ⇥ 1 . (8.80)
d2 + 2

What happens when ! 0?


(d) Give an interpretation of d2 . What happens when d2 ! 0 and when d2 ! 1?

Exercise 6.
Prove the following identity:
 1
⌃⇥⇥ ⌃⇥X
⌃X⇥ ⌃XX
 1 1 1
(⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) 1 (⌃⇥⇥ ⌃⇥X ⌃XX ⌃X⇥ ) 1 ⌃⇥X ⌃XX
= 1 1 1 .
(⌃XX ⌃X⇥ ⌃⇥⇥ ⌃⇥X ) 1 ⌃X⇥ ⌃⇥⇥ (⌃XX ⌃X⇥ ⌃⇥⇥ ⌃⇥X ) 1

Hint: You can perform reverse engineering by checking whether the product of the left-hand
side and the right-hand side would give you the identity matrix.

Exercise 7.
Let X1 , X2 , X3 and X4 be four i.i.d. Poisson random variables with mean ✓ = 4. Find the
b
mean and variance of the following estimators ⇥(X) for ✓ and determine whether they are
biased or unbiased.
b
⇥(X) = (X1 + X2 )/2
b
⇥(X) = (X3 + X4 )/2
b
⇥(X) = (X1 + 2X2 )/3
b
⇥(X) = (X1 + X2 + X3 + X4 )/4

Exercise 8.
Let X1 , . . . , XN be i.i.d. random variables with a uniform distribution of [0, ✓]. Consider the
following estimator:
b
⇥(X) = max(X1 , . . . , XN ). (8.81)

(a) Show that the PDF of ⇥b is f b (✓) = N [FX (x)]N 1


fX (x), where fX and FX are re-

spectively the PDF and CDF of Xn .
b is a biased estimator.
(b) Show that ⇥
b Is it a consistent estimator?
(c) Find the variance of ⇥.
b is unbiased.
(d) Find a constant c so that c⇥

Exercise 9.
Let X1 , . . . , XN be i.i.d. Gaussian random variables with unknown mean ✓ and known
variance = 1.

538
8.7. PROBLEMS

(a) Show that the log-likelihood function is


N
N 1X
log L(✓ | x) = log(2⇡) (xn ✓)2 . (8.82)
2 2 n=1

PN PN
(b) Let X 2 = N1 n=1 x2n and X = 1
N n=1 xn . Show that X 2 > (X)2 if and only if
PN
n=1 (xn ✓)2 0 for all ✓.

(c) Use Python to plot the function log L(✓ | x), when X = 2 and X 2 = 1.

Exercise 10.
Let X1 , . . . , XN be i.i.d. uniform random variables over the interval [0, ✓].
Let T = max(X1 , . . . , XN ).
PN
(a) Consider the estimator h(X) = N1 n=1 Xn . Is h(·) an unbiased estimator?
PN
(b) Consider the estimator g(X) = N1 n=1 Xn . Is g(·) an unbiased estimator?
(c) Show that ✓ ◆
N +1
E[g(X)|T = t] = t.
N

(d) Let gb(X) = E[g(X)|T ] = N +1


N T . Show that
✓ ◆
(N + 1)2
g (X)2 ] =
E[b ✓2 .
N (N + 2)

(e) Show that ✓ ◆


1
E[(b
g (X) ✓)2 ] = ✓2 .
N (N + 2)

Exercise 11.
The Kullback-Leibler divergence between two distributions p1 (x) and p2 (x) is defined as
Z
p1 (x)
KL(p1 k p2 ) = p1 (x) log dx. (8.83)
p2 (x)
Suppose we approximate p1 using a distribution p2 . Let us choose p2 = Gaussian(µ, ⌃).
Show that µ and ⌃, which minimize the KL divergence, are such that

µ = Ex⇠p1 (x) [x] and ⌃ = Ex⇠p1 (x) [(x µ)(x µ)T ].

Exercise 12.
Pd
(a) Recall that the trace operator is defined as tr[A] = i=1 [A]i,i . Prove the matrix
identity
xT Ax = tr[AxxT ], (8.84)
where A 2 Rd⇥d .

539
CHAPTER 8. ESTIMATION

(b) Show that the likelihood function


N ⇢
Y n o
1 1 1
p(D | ⌃) = exp (xn µ)T ⌃ (xn µ) (8.85)
n=1
(2⇡)d/2 |⌃| 1/2 2

can be written as
( " N
#)
1 1 X
1 N/2 1 T
p(D|⌃) = |⌃ | exp tr ⌃ (xn µ)(xn µ) . (8.86)
(2⇡)N d/2 2 n=1

(c) Let A = ⌃ 1 ⌃ b ML , and 1 , ..., d be the eigenvalues of A. Show that the result from
part (b) leads to

d
!N/2 ( d
)
1 Y NX
p(D|⌃) = i exp i . (8.87)
b ML |N/2
(2⇡)N d/2 |⌃ 2 i=1
i=1

Pd
Hint: For matrix A with eigenvalues 1 , ..., d, tr[A] = i=1 i.

(d) Find 1, . . . , d such that Equation (8.87) is maximized.

(e) With the choice of i


b ML .
given in (d), derive the ML estimate ⌃
b ML ? You do not need to prove it. Just
(f) What would be the alternative way of finding ⌃
briefly describe the idea.
b ML is a biased estimate of the covariance matrix because E[⌃
(g) ⌃ b ML ] 6= ⌃. Can you
suggest an unbiased estimate ⌃ b unbias such that E[⌃
b unbias ] = ⌃? You don’t need to
prove it. Just state the result.

540
Chapter 9

Confidence and Hypothesis

In Chapters 7 and 8 we learned about regression and estimation, which allow us to determine
the underlying parameters of our statistical models. After obtaining the estimates, we would
like to quantify the accuracy of the estimates and draw statistical conclusions. Additionally,
we would like to understand the confidence of these estimates along with their statistical
significance. This chapter presents a few principles that involve analyzing the confidence of
the estimates and conducting hypothesis testing. There are two main questions that we will
address:

How good is our estimate? This is a fundamental question about the estimator ⇥, b a
1
random variable with a PDF, a mean, and a variance. The estimator we construct
today may be di↵erent from the estimator we construct tomorrow due to variations in
the observed data. Therefore, the quality of the estimator depends on the randomness
and the number of samples used to construct it. To measure the quality of the estimator
we need to introduce an important concept known as the confidence.
Is there statistical significance? Suppose that we ran a campaign and observed that
there is a change in the statistics. On what basis do we claim that the change is
statistically significant? How should the cuto↵ be determined? If we claim that a
result is statistically significant but there is no significance in reality, how much error
will we su↵er? These questions are the subjects of hypothesis testing.
These two principal questions are critical for modern data science. If they are not properly
answered, our statistical conclusions could potentially be flawed. A toy example:
Imagine that you are developing a COVID-19 vaccine. You tested the vaccine on three
patients, and all of them show positive responses to the vaccine. You felt excited because
your vaccine has a 100% success rate. You submit your vaccine application to FDA. Within
1 second your application is rejected. Why? The answer is obvious. You only have three
testing samples. How reliable can these three samples be?
While you are laughing at this toy example, it raises deep statistical questions. First,
why are three samples not enough? Well, it is because the variance of the estimator can
potentially be huge. More samples are better because if the estimator is the sample average of
the individual responses, the estimator will behave like a Gaussian according to the Central
1 Not all random variables have a well-defined PDF, mean, and variance. E.g., a Cauchy variable does

not have a mean.

541
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Limit Theorem. The variance of this Gaussian will diminish as we have more samples.
Therefore, if we want to control the variance of the estimator, we need more samples. Second,
even if we have many samples, how confident is this estimator with respect to the unknown
population parameter? Note that the population parameter is unknown, and so we cannot
measure things such as the mean squared error. We need a tool to report confidence. Third,
for simple estimators such as the sample average, we can approximate it by a Gaussian.
However, if the estimator is more complicated, e.g., the sample median, how do we estimate
the variance and the confidence? Fourth, suppose that we have expanded the vaccine test
to, say, 951 patients, and we have obtained some statistics. To what extent can we declare
that the vaccine is e↵ective? We need a decision rule that turns the statistics into a binary
decision. Finally, even if we declare that the vaccine is e↵ective with a confidence of 95%,
what about the remaining 5%? What if we want to push the confidence to 99%? What is
the trade-o↵?
As you can see, these questions are the recurring themes of all data science problems.
No matter if you are developing a medical diagnostic system, a computer vision algorithm,
a speech recognition system, a recommendation system, a search engine, stock forecast,
fraud detection, or robotics controls, you need to answer these questions. This chapter will
introduce useful concepts related to data analysis in the form of five basic principles:
1. Confidence interval (Section 9.1). A confidence interval is a random interval that
includes the true parameter. We will discuss how a confidence interval is constructed
and the correct way to interpret the confidence interval.
2. Bootstrapping (Section 9.2). When constructing the confidence interval, we need the
variance of the estimator. However, since we do not know the true distribution, we
need an alternative way to estimate the variance. Bootstrapping is designed for this
purpose.
3. Hypothesis testing (Section 9.3). Many statistical tasks require a binary decision at
the end, e.g., there is a disease versus there is no disease. Hypothesis testing is a
principle for making a systematic decision with statistical guarantees.
4. Neyman-Pearson decision (Section 9.4). The simple hypothesis testing procedure has
many limitations that can only be resolved if we understand a more general framework.
We will study such a framework, called the Neyman-Pearson decision rule.
5. ROC and PR curves (Section 9.5). No decision rule is perfect. There is always a
trade-o↵ between how much we can detect and how much we will miss. The receiver
operating characteristic (ROC) curve and the precision-recall (PR) curve can give us
more insight into this trade-o↵. We will establish the equivalence between the ROC
and the PR curve and correct any misconceptions about them.
After reading this chapter, we hope that you will be able to apply these principles
to your favorite data analysis problems correctly. With these principles, you can tell your
customers or bosses the statistical significance of your conclusions. You will also be able to
help your friends understand the many misconceptions that they may find on the internet.

542
9.1. CONFIDENCE INTERVAL

9.1 Confidence Interval

The first topic we discuss in this chapter is the confidence interval. At a high level, the
confidence interval tells us the quality of our estimator with respect to the number of sam-
ples. We begin this section by reviewing the randomness of an estimator. Then we develop
the concept of the confidence interval. We discuss several methods for constructing and
interpreting these confidence intervals.

9.1.1 The randomness of an estimator


Imagine that we have a dataset X = {X1 , . . . , XN }, where we assume that Xn are i.i.d.
copies drawn from a distribution fX (x; ✓). We want to construct an estimator ⇥ b of ✓ from
the dataset X . For example, if fX is a Gaussian distribution with an unknown mean ✓, we
would like to estimate ✓ using the sample average ⇥. b In statistics, an estimator ⇥
b is also
known as a statistic, which is constructed from the samples. In this book we use the terms
“estimator” and “statistic” interchangeably. Written as equations, an estimator is a function
of the samples:
b
⇥ = g(X1 , . . . , XN ),
|{z} | {z }
estimator function of X

b
where g is a function that takes the samples X1 , . . . , XN and returns a random variable ⇥.
For example, the sample average
N
X
⇥b= 1 Xn
N n=1
| {z }
g(X1 ,...,XN )

is an estimator because it is computed by summing the samples X1 , . . . , XN and dividing it


by N .

What is an estimator?
An estimator ⇥b is a function of the samples X1 , . . . , XN :

b = g(X1 , . . . , XN ).
⇥ (9.1)

b is a random variable. It has a PDF, CDF, mean, variance, etc.


By construction, ⇥b is a random variable because it is a function of the random samples.


Therefore, ⇥b has its own PDF, CDF, mean, variance, etc. Since ⇥ b is a random variable,
we should report both the estimator’s value and the estimator’s confidence when reporting
its performance. The confidence measures the quality of ⇥ b when compared to the true
parameter ✓. It provides a measure of the reliability of the estimator ⇥. b If ⇥
b fluctuates a
great deal we may not be confident of our estimates. Let’s consider the following example.

543
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Example 9.1. A class of 1000 students took a test. The distribution of the score is
roughly a Gaussian with mean 50 and standard deviation 20. A teaching assistant
was too lazy to calculate the true population mean. Instead, he sampled a subset of 5
scores listed as follows:
Student ID 1 2 3 4 5
Scores 11 97 1 78 82
He calculated the average, which is 53.8. This is a very good estimate of the class
average (which is 50). What is wrong with his procedure?

Solution. He was just lucky. It quite possible that if he sampled another 5 scores, he
would get something very di↵erent. For example, if he looks at the 11 to 15 student
scores, he could get:

Student ID 11 12 13 14 15
Scores 44 29 19 27 15

In this case the average is 26.8.


Both 53.8 and 26.8 are legitimate estimates, but they are the random realizations
of a random variable ⇥.b This ⇥ b has a PDF, CDF, mean, variance, etc. It may be
misleading to simply report the estimated value from a particular instant, so the
confidence of the estimator must be specified.

b We next discuss the distribution of ⇥.


Distributions of ⇥. b Figure 9.1 illustrates several
key ideas. Suppose that the population distribution fX (x) is a mixture of two Gaussians.
Let ✓ be the mean of this distribution (somewhere between the two peak locations). We
sample N = 50 data points X1 , . . . , XN from this distribution. However, the 50 data points
we sample today could di↵er from the 50 data points we sample tomorrow. If we compute
the sample average from each of these finite-sample distributions, we will obtain a set of
sample averages ⇥. b Notably, we have a set of ⇥b because today we have one ⇥ b and tomorrow
b b
we have another ⇥. By plotting the histogram of the sample averages ⇥, we will have a
distribution.
The histogram of ⇥ b depends on several factors. According to Central Limit Theorem,
the shape of f⇥ b
b (✓) is a Gaussian because ⇥ is the average of N i.i.d. random variables.
b
If ⇥ is not the average of i.i.d. random variables, the shape is not necessarily a Gaussian.
This results in additional complications, so we will discuss some tools for dealing with this
problem. The spread of the sample distribution is mainly driven by the number of samples
we have in each subdataset. As you can imagine, the more samples we have in a subdataset
the more accurate the distribution. Thus you will have a more accurate sample average. The
fluctuation of the sample average will also be smaller.
Before we continue, let’s summarize the randomness of ⇥: b

What is the randomness of ⇥?b


b is generated from a finite-sample dataset. Each time we draw a finite-sample

dataset, we introduce randomness.

544
9.1. CONFIDENCE INTERVAL

b Given a population, our datasets


Figure 9.1: Pictorial illustration of the randomness of the estimator ⇥.
are usually a subset of the population. Computing the sample average from these finite-sample distribu-
tions introduces the randomness to ⇥. b If we plot the histogram of the sample averages, we will obtain
a distribution. The mean of this distribution is the population mean, but there is a nontrivial amount of
fluctuation. The purpose of the concept of confidence interval is to quantify this fluctuation.

b is the sample average, the PDF is (roughly) a Gaussian. If ⇥


If ⇥ b is not a sample
average, the PDF is not necessarily a Gaussian.
The spread of the fluctuation depends on the number of samples in each sub-
dataset.

9.1.2 Understanding confidence intervals


b Instead of studying ⇥
The confidence interval is a probabilistic statement about ⇥. b as a
point, we construct an interval
h i
I= ⇥ b ✏, ⇥ b +✏ , (9.2)

for some ✏ to be determined. Note that this interval is a random interval : If we have a
b we will have a di↵erent I. We call I the confidence interval for
di↵erent realization of ⇥,
b
the estimator ⇥.
Given this random interval, we ask: What is the probability that I includes ✓? That
means that we want to evaluate the probability
h i
P[✓ 2 I] = P ⇥ b ✏✓⇥ b +✏ .

b not ✓. This is because


We emphasize that the randomness in this probability is caused by ⇥,
the interval I changes when we conduct a di↵erent experiment to obtain a di↵erent ⇥.b The

545
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

situation is similar to that illustrated on the left-hand side of Figure 9.2. The confidence
interval I changes but the true parameter ✓ is fixed.

Figure 9.2: Confidence interval is the random interval I = [⇥b ✏, ⇥ b + ✏], not the deterministic interval
[✓ ✏, ✓ + ✏]. The random interval in the former case does not require any knowledge about the true
parameter ✓, whereas the latter requires ✓. By claiming a 95% confidence interval, we say that there
is 95% chance that the random interval will include the true parameter. So if you have 100 random
realizations of the confidence intervals, then 95 on average will include the true parameter.

Confidence intervals can be confusing. Often the confusion arises because of the fol-
lowing identity:
h i h i
P ⇥b ✏✓⇥ b +✏ =P ✏✓ ⇥ b ✏
h i
=P ✏ ✓ ⇥ b ✏ ✓
h i
=P ✓ ✏⇥ b ✓+✏ . (9.3)

Although the values of the two probabilities are the same, the two events are interpreted
di↵erently. The right-hand side of Figure 9.2 illustrates P[✓ ✏  ⇥ b  ✓ + ✏]. The interval
b
[✓ ✏, ✓+✏] is fixed. What is the probability that the estimator ⇥ lies within this deterministic
interval? To find this probability, we need to know the true parameter ✓, which is not
available. By contrast, the other probability P[⇥ b ✏  ✓  ⇥ b + ✏] does not require any
knowledge about the true parameter ✓. What is the probability that the true parameter is
included inside the random interval? If the probability is high, we say that there is a good
chance that our confidence interval will contain the true parameter. This is observed in the
left-hand side of Figure 9.2.
In practice we often set P[⇥b ✏✓⇥ b + ✏] to be greater than a certain confidence
level, say 95%, and then we determine ✏. Once we have determined ✏, we can claim that

546
9.1. CONFIDENCE INTERVAL

b ✏, ⇥
with 95% probability the interval [⇥ b + ✏] will include the unknown parameter ✓. We
do not need to know ✓ at any point in this process.
To make this more general, we define 1 ↵ as the confidence level for some parame-
ter ↵. For example, if we would like to have a 95% confidence level, we set ↵ = 0.05. Then
the probability inequality h i
P ⇥b ✏✓⇥ b +✏ 1 ↵ (9.4)

b ✏, ⇥
tells us that there is at least a 95% chance that the random interval I = [⇥ b + ✏] will
include the true parameter ✓. In this case we say that I is a “95% confidence interval”.

What is a 95% confidence interval?


b ✏, ⇥
It is a random interval [⇥ b + ✏] such that there is 95% probability for it to
include the true parameter ✓.
It is not the deterministic interval [✓ ✏, ✓ + ✏], because we never know ✓.

Let’s consider the following two examples to clarify any misconceptions.

Example 9.2. After analyzing the life expectancy of people in the United States, it
was concluded that the 95% confidence interval is (77.8, 79.1) years old. Is the following
claim valid?
About 95% of the people in the United States have a life expectancy between 77.8
years old and 79.1 years old.
Solution. No. The confidence interval tells us that with 95% probability the random
interval (77.8, 79.1) will include the true average. We emphasize that (77.8, 79.1) is
random because it is constructed from a small set of data points. If we survey another
set of people we will have another interval.
Since we do not know the true average, we do not know the percentage of people
whose life expectancy is between 77.8 years old and 79.1 years old. It could be that the
true average is 80 years old, which is out of the range. It could also be that the true
average is 77.9 years old, which is within the range, but only 10% of the population
may have life expectancy in (77.8, 79.1).

Example 9.3. After studying the SAT scores of 1000 high school students, it was
concluded that the 95% confidence interval is (1134, 1250) points. Is the following
claim valid?
There is a 95% probability that the average SAT score in the population is in the
range 1134 and 1250.

Solution. Yes, but it can be made clearer. The average SAT score in the population
remains unknown. It is a constant and it is deterministic, so there is no probability
associated with it. A better way to say this is: “There is 95% probability that the

547
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

random interval 1134 and 1250 will include the average SAT score.” We emphasize
that the 95% probability is about the random interval, not the unknown parameter.

9.1.3 Constructing a confidence interval


Let’s consider an example. Suppose that we have a set of i.i.d. observations X1 , . . . , XN
that are Gaussians with an unknown mean ✓ and a known variance 2 . We consider the
maximum-likelihood estimator, which is the sample average:
XN
b= 1
⇥ Xn .
N n=1
Our goal is to construct a confidence interval.

Figure 9.3: Conceptual illustration of how to construct a confidence interval. Starting with the pop-
ulation, we draw random subsets. Each random subset gives us an estimator, and correspondingly an
interval.

Before we consider the equations, let’s look at a graph illustrating what we want to
achieve. Figure 9.3 shows a population distribution, which is a Gaussian in this example.
We draw N samples from the Gaussian to construct a random subset. Based on this random
subset we construct the estimator ⇥. b Since this estimator is based on the particular random
subset we have, we can follow the same approach by drawing another random subset. To
di↵erentiate the estimators constructed by the di↵erent random subsets, let’s call the esti-
mators ⇥b (1) and ⇥
b (2) , respectively. For each estimator we construct an interval [⇥
b ✏, ⇥+✏]
b
to obtain two di↵erent intervals:
b (1)
I 1 = [⇥ b (1) + ✏]
✏, ⇥ and b (2)
I 2 = [⇥ b (2) + ✏].
✏, ⇥

548
9.1. CONFIDENCE INTERVAL

If we can determine ✏, we have found the confidence interval.


We can determine the confidence interval by observing the histogram of ⇥, b which in
our case is the histogram of the sample average, since the histogram of ⇥ b is well-defined,
especially if we are looking at the sample average. The histogram of the sample average is a
Gaussian because the average of N i.i.d. Gaussian random variables is Gaussian. Therefore,
the width of this Gaussian is determined by the answer to this question:
b
For what ✏ can we cover 95% of the histogram of ⇥?
To find the answer, we set up the following probability inequality:
2 3
b
|⇥ E[⇥]|b
P4 q  ✏5 1 ↵.
b
Var[⇥]

This probability says that we want to find an ✏ such that the majority of ⇥ b is living close
to its mean. The level 1 ↵ is our confidence level, which is typically 95%. Equivalently, we
let ↵ = 0.05.
In the above equation, we can define the quotient as

b E[⇥]
def ⇥
b
Zb = q .
b
Var[⇥]

We know that Zb is a zero-mean unit-variance Gaussian because it is the standardized vari-


b is a Gaussian the normalized
able. [Note: Not all normalized variables are Gaussian, but if ⇥
variable will remain a Gaussian.] Thus, the probability inequality we are looking at is
h i
b ✏
P |Z| 1 ↵.
| {z }
two tails of a standard Gaussian

The PDF of Zb is shown in Figure 9.4. As you can see, to achieve 95% confidence we need
to pick an appropriate ✏ such that the shaded area is less than 5%.

0.4
0.35
0.3
0.25
0.2
0.15
0.1
0.05
0
-3 -2.5 -2 -1.5 -1 -0.5 0 0.5 1 1.5 2 2.5 3
q
b = (⇥
Figure 9.4: PDF of the random variable Z b b
E[⇥])/ b The shaded area denotes the
Var[⇥].
↵ = 0.05 confidence level.

549
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Since P[Zb  ✏] is the CDF of a Gaussian, it follows that


b  ✏] = P[ ✏  Zb  ✏]
P[|Z|
= P[Zb  ✏] P[Zb  ✏]
= (✏) ( ✏) .
Using the symmetry of the Gaussian, it follows that ( ✏) = 1 (✏) and hence
b  ✏] = 2 (✏)
P[|Z| 1.
b  ✏]
Equating this result with the probability inequality P[|Z| 1 ↵, we have that
⇣ ↵⌘
1
✏ 1 .
2
The remainder of this problem is solvable on a computer. On MATLAB, we can call
icdf to compute the inverse CDF of a standard Gaussian. On Python, the command is
stats.norm.ppf. The commands are as shown below.

% MATLAB code to compute the width of the confidence interval


alpha = 0.05;
mu = 0; sigma = 1; % Standard Gaussian
epsilon = icdf(’norm’,1-alpha/2,mu,sigma)

# Python code to compute the width of the confidence interval


import scipy.stats as stats
alph = 0.05;
mu = 0; sigma = 1; # Standard Gaussian
epsilon = stats.norm.ppf(1-alph/2, mu, sigma)
print(epsilon)

If everything is done properly, we see that for a 95% confidence level (↵ = 0.05) the corre-
sponding ✏ is ✏ = 1.96.
b and Var[⇥]
After determining ✏, it remains to determine E[⇥] b in order to complete the
probability inequality. To this end, we note that
" N
#
1 X
b =E
E[⇥] Xn = ✓,
N n=1
" N
#
1 X 2
b = Var
Var[⇥] Xn = ,
N n=1 N

if we assume that the population distribution is Gaussian(✓, 2 ), where ✓ is unknown but


is known. Substituting these into the probability inequality, we have that
2 3
b b 
|⇥ E[⇥]| b ✏p  ✓  ⇥ b + ✏p
P4 q  ✏5 = P ⇥
b
Var[⇥] N N

=P ⇥ b 1.96 p  ✓  ⇥ b + 1.96 p ,
N N

550
9.1. CONFIDENCE INTERVAL

where we let ✏ = 1.96 for a 95% confidence level. Therefore, the 95% confidence interval is

b 1.96 p , ⇥
⇥ b + 1.96 p . (9.5)
N N
As you can see, we do not need to know the value of ✓ at any point of the derivation because
the confidence interval in Equation (9.5) does not involve ✓. This is an important di↵erence
with the other probability P[✓ ✏  ⇥ b  ✓ + ✏], which requires ✓.

How to construct a confidence interval


b
Compute the estimator ⇥.
Determine the width of the confidence interval ✏ by inspecting the confidence
b is Gaussian, then ✏ =
level 1 ↵. If ⇥ 1
(1 ↵2 ).
b is not a Gaussian, replace the Gaussian CDF by the CDF of ⇥.
If ⇥ b
b ✏, ⇥
The confidence interval is [⇥ b + ✏].

9.1.4 Properties of the confidence interval


Some important properties of the confidence interval are listed below.
b is the same as probability of Z.
Probability of ⇥ b First, the two random variables ⇥
b
b
and Z have a one-to-one correspondence. We proved the following in Chapter 6:

2
b ⇠ Gaussian(✓,
If ⇥ ), then
N

b ✓
def ⇥
Zb = p ⇠ Gaussian(0, 1). (9.6)
/ N

2
For example, if ⇥ b ⇠ Gaussian(✓, ) with N = 1, ✓ = 1 and = 2, then a 95%
N
confidence level is

0.95 ⇡ P[ 1.96  Zb  1.96], (Zb is within 1.96 std from Z’s


b mean)
⇥b ✓
= P[ 1.96  p  1.96]
/ N

= P ✓ 1.96 p  ⇥ b  ✓ + 1.96 p
N N
= P[ 2.92  ⇥b  4.92]. (⇥b is within 1.96 std from ⇥’s
b mean)

Note that while the range for Zb is di↵erent from the range for ⇥,
b they both return the
same probability. The only di↵erence is that ⇥ b is constructed before the normalization
and Zb is constructed after the normalization.

551
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

b is the sample average. We


Standard error. In this estimation problem we know that ⇥
assume that the mean ✓ is unknown but the variance Var[⇥]b is known. The standard
b
deviation of ⇥ is called the standard error:
q
se = Var[⇥] b =p . (9.7)
N

Critical value. The value 1.96 in our example is often known as the critical value. It
is defined as ⇣
1 ↵⌘
z↵ = 1 . (9.8)
2
The z↵ value gives us a multiplier applied to the standard error that will result in a
value within the confidence interval. This is because, by the definition of the confidence
interval, the interval is
 h i
b 1.96 p , ⇥
⇥ b + 1.96 p = ⇥ b z↵ se, ⇥ b + z↵ se
N N

Margin of error. The margin of error is defined as

margin of error = z↵ p . (9.9)


N
The margin of error is also the width of the confidence interval. As the name implies,
the margin of error tells us how much error the confidence interval includes when
predicting the population parameter.

Practice Exercise 9.1. Suppose that the number of photos a Facebook user uploads
per day is a random variable with = 2. In a set of 341 users, the sample average is
2.9. Find the 90% confidence interval of the population mean.

Solution. We set ↵ = 0.1. The z↵ -value is


⇣ ↵⌘
1
z↵ = 1 = 1.6449.
2
The 90% confidence interval is then

b 1.64 p 2 , ⇥
⇥ b + 1.64 p 2 = [2.72, 3.08].
341 341

Therefore, with 90% probability, the interval [2.72, 3.08] includes the population mean.

Example 9.4. Professional cyber-athletes have a standard deviation of = 73.4


actions per minute. If we want to estimate the average actions per minute of the
population, how many samples are needed to obtain a margin of error < 20 at 90%
confidence?

552
9.1. CONFIDENCE INTERVAL

Solution. With a 90% confidence level, the z↵ -value is


⇣ ↵⌘
1 1
z↵ = 1 = (0.95) = 1.645.
2
The margin of error is 20. So we have

z↵ p = 20.
N
Moving around the terms gives us
⇣ ⌘2
N z↵ = 36.45.
20
Therefore, we need at least N = 37 samples to ensure a margin of error of < 20 at a
90% confidence level.

Figure 9.5: Relationships between the standard error se, the z↵ value, and the margin of error. The
confidence level ↵ is the area under the curve for the tails of each PDF.

The concepts of standard error se, the z↵ value, and the margin of error are summarized
in Figure 9.5. The left-hand side is the PDF of Z. b It is the normalized random variable,
which is also the standard Gaussian. The right-hand side is the PDF of ⇥,b the unnormalized
b
random variable. The z↵ value is located in the Z-space. It defines the range of Zb in the
PDF within which we are confident about the true parameter. The corresponding value
b
in the ⇥-space is the margin of error. This is found by multiplying z↵ with the standard
b known as the standard error. Correspondingly, in the Z-space
deviation of ⇥, b the standard
deviation is the unity.
Two further points about the confidence interval should be mentioned:
Number of Samples N . The confidence interval is a function of N . As we increase the
number of samples, the distribution of the estimator ⇥b becomes narrower. Specifically,
b follows a Gaussian distribution
if ⇥
✓ 2

b
⇥ ⇠ Gaussian ✓, ,
N
p
then ⇥b! b as N grows. In the
✓ as N ! 1. Figure 9.6 illustrates a few examples of ⇥
limit when N ! 1, we observe that the interval becomes
 h i
b 1.96 p , ⇥
⇥ b + 1.96 p ! ⇥, b b = ⇥.
⇥ b
N N

553
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

h i
In this case, the statement ✓ 2 ⇥ b 1.96 p , ⇥ b + 1.96 p becomes ✓ = ⇥.b That
N N
means the estimator ⇥ b returns the correct true parameter ✓. Of course, it is possible
b
that E[⇥] 6= ✓, i.e., the estimator is biased. In that case, having more samples will
approach another estimate that is not ✓.

4
3.5 N = 10
N = 25
3 N = 100
2.5
2
1.5
1
0.5
0
-1 -0.75 -0.5 -0.25 0 0.25 0.5 0.75 1

Figure 9.6: The PDF of ⇥ b as the number of samples N grows. Here, we assume that Xn are i.i.d.
Gaussian random variables with mean ✓ = 0 and variance 2 = 1.

b When defining the confidence interval we constructed an interme-


Distribution of Z.
diate variable
b ✓

Zb = p .
/ N
Since Xn ’s are i.i.d. Gaussian, it follows that Z is also Gaussian. This gives us a way
to calculate the probability using the standard Gaussian table. What happens when
Xn ’s are not Gaussian? The good news is that even if Xn ’s are not Gaussian, for
sufficiently large N , the random variable ⇥ b is more or less Gaussian, because of the
Central Limit Theorem. Therefore, even if Xn ’s are not Gaussian we can still use the
Gaussian probability table to construct ↵ and ✏.

9.1.5 Student’s t-distribution


b The
In the discussions above, we estimate the population mean ✓ using the estimator ⇥.
2
assumption was that the variance was known a priori and hence is fixed. In practice,
however, there are many situations where 2 is not known. Thus we not only need to use
the mean estimator ⇥b but also the variance estimator S,
b which can be defined as
N
X
def 1
Sb2 = (Xn b 2,
⇥)
N 1 n=1

b is the estimator of the mean. What is the confidence interval for ⇥?


where ⇥ b
For a confidence interval to be valid, we expect it to take the form of
" #
b Sb b Sb
I = ⇥ z↵ p , ⇥ + z ↵ p ,
N N

554
9.1. CONFIDENCE INTERVAL

b
which is essentially the confidence interval we have just derived but with replaced by S.
However, there is a problem with this. When we derive the confidence interval assuming a
known , the z↵ value is determined by checking the standard Gaussian

b ✓

Zb = p ,
/ N

which gives us z↵ = 1
(1 ↵/2). The whole derivation is based on the fact that Zb is a
b the new random variable
standard Gaussian. Now that we have replaced by S,

def
b ✓

T = p (9.10)
b N
S/

is not a standard Gaussian.


It turns out that the distribution of T is Student’s t-distribution with N 1 degrees
of freedom. The PDF of Student’s t-distribution is given as follows.

Definition 9.1. If X is a random variable following Student’s t-distribution of ⌫


degrees of freedom, then the PDF of X is

⌫+1 ✓ ◆ ⌫+1

2 x2 2

fX (x) = p ⌫ 1+ . (9.11)
⌫⇡ 2

We may compare Student’s t-distribution with the Gaussian distribution. Figure 9.7 shows
the standard Gaussian and several t distributions with ⌫ = N 1 degrees of freedom. Note
that Student’s t-distribution has a similar shape to the Gaussian but it has a heavier tail.

0.4
0.35 Gaussian(0,1)
t-dist, N = 11
0.3 t-dist, N = 3
0.25 t-dist, N = 2
0.2
0.15
0.1
0.05
0
-5 -4 -3 -2 -1 0 1 2 3 4 5

Figure 9.7: The PDF of Student’s t-distribution with ⌫ = N 1 degrees of freedom.

b
⇥p✓
Since T = S/
b N is a t-random variable, to determine the z↵ value we can follow the
same procedure by considering the CDF of T . Let the CDF of the Student’s t-distribution
with ⌫ degrees of freedom be

⌫ (z) = CDF of X at z.

555
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

If we want P[|T |  z↵ ] = 1 ↵, it follows that


⇣ ↵⌘
z↵ = ⌫ 1 1 . (9.12)
2
b is
Therefore, the new confidence interval, assuming an unknown S,
" #
b b
I= ⇥ b z↵ pS , ⇥ b + z↵ pS ,
N N
with z↵ defined in Equation (9.12), using ⌫ = N 1.

Practice Exercise 9.2. A survey asked N = 14 people for their rating of a movie. As-
b and the variance estimator is S.
sume that the mean estimator is ⇥ b Find the confidence
interval.

Solution. If we use Student’s t-distribution, it follows that


⇣ ↵⌘
z↵ = 131 1 = 2.16,
2
where the degrees of freedom are ⌫ = 14 1 = 13. Thus the confidence interval is
" #
b
S b
S
I= ⇥ b 2.16 p , ⇥ b + 2.16 p .
N N

The MATLAB and Python codes to report the z↵ value of a Student’s t-distribution
are shown below. They are both called through the inverse CDF function. In MATLAB it
is icdf, and in Python it is stats.t.ppf.

% MATLAB code to compute the z_alpha value of t distribution


alpha = 0.05;
nu = 13;
z = icdf(’norm’,1-alpha/2,nu)

# Python code to compute the z_alpha value of t distribution


import scipy.stats as stats
alph = 0.05
nu = 13
z = stats.t.ppf(1-alph/2, nu)
print(z)

Example 9.5. A class of 10 students took a midterm exam. Their scores are given in
the following table.

Student 1 2 3 4 5 6 7 8 9 10
Score 72 69 75 58 67 70 60 71 59 65

Find the 95% confidence interval.

556
9.1. CONFIDENCE INTERVAL

Solution. The mean and standard deviation of the datasets are respectively ⇥ b = 66.6
and Sb = 5.61. The critical z↵ value is determined by Student’s t-distribution:
⇣ ↵⌘
z↵ = 9 1 1 = 2.26.
2
The confidence interval is
" #
b b
b z↵ pS ,
⇥ b + z↵ pS
⇥ = [62.59, 70.61] .
N N

Therefore, with 95% probability, the interval [62.59, 70.61] will include the true popu-
lation mean.

Remark 1. Make sure you understand the meaning of “population mean” in this
example. Since we have ten students, isn’t the population mean just the average of the
ten scores? This is incorrect. In statistics, we assume that these ten students are the
realizations of some underlying (unknown) random variable X with some PDF fX (x).
The population mean ✓ is therefore the expectation E[X], where the expectation is
taken w.r.t. fX . The sample average ⇥,b which is the average of the ten numbers, is an
estimator of the population mean ✓.

Remark 2. You may be wondering why we are using Student’s t-distribution here
when we do not even know the PDF of X. The answer is that it is an approximation.
When X is Gaussian, the sample average ⇥ b is a Student’s t-distribution, assuming
b This result is attributed
that the variance is approximated by the sample variance S.
to the original paper of William Gosset, who developed Student’s t-distribution.

The above example can be solved computationally. An implementation through Python


is given below, and the MATLAB implementation is straightforward if you translate it from
the Python.
# Python code to generate a confidence interval
import numpy as np
import scipy.stats as stats
x = np.array([72, 69, 75, 58, 67, 70, 60, 71, 59, 65])
Theta_hat = np.mean(x) # Sample mean
S_hat = np.std(x) # Sample standard deviation
nu = x.size-1 # degrees of freedom
alpha = 0.05 # confidence level
z = stats.t.ppf(1-alph/2, nu)
CI_L = Theta_hat-z*S_hat/np.sqrt(N)
CI_U = Theta_hat+z*S_hat/np.sqrt(N)
print(CI_L, CI_U)

What is Student’s t-distribution?


It was developed by William Gosset in 1908. When he published the paper he
used the pseudonym Student.

557
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

b PDF when the vari-


We use Student’s t-distribution to model the estimator ⇥’s
ance 2 is replaced by the sample variance Sb2 .
Student’s t-distribution has a heavier tail than a Gaussian.

9.1.6 Comparing Student’s t-distribution and Gaussian


We now discuss an important theoretical result regarding the relationship between a Stu-
dent’s t-distribution and Gaussian distribution. The main result is that the standard Gaus-
sian is a limiting distribution of the t distribution as the degrees of freedom ⌫ ! 1.

Theorem 9.1. As ⌫ ! 1, the Student’s t-distribution approaches the standard Gaus-


sian distribution:
( ✓ ◆ ⌫+1 )
⌫+1
2 y2 2
1 t2
lim p ⌫ 1+ =p e 2. (9.13)
⌫!1 ⌫⇡ 2 ⌫ 2⇡

The proof of the theorem requires Stirling’s approximation, which is not essential for this
book. Feel free to skip it if needed.

Proof. There are two results we need to use:


q
z z
Stirling’s approximation:2 (z) ⇡ 2⇡ z e .
Exponential approximation: (1 + xk ) k
!e x
, as k ! 1.
We have that
q ⌫+1
2⇡ ⌫+1 2
⌫+1 ⌫+1 2e
2 2
p ⌫ ⇡ p q ⌫
⌫⇡ 2 ⌫⇡ 2⇡

⌫ 2
2 2e
r ✓ ◆⌫ p
1 ⌫ 1 ⌫+1 2 ⌫+1
=p p p
⌫⇡ ⌫+1 e ⌫ ⌫
p ✓ ◆ ⌫2
1 ⌫ ⌫+1
=p p
⌫⇡ 2e ⌫
✓ ◆ ⌫2
1 1
=p 1+ .
2⇡e ⌫

Putting a limit of ⌫ ! 1, we have that


✓ ◆ ⌫2
1 1 1 1 1
lim p 1+ =p e2 = p .
⌫!1 2⇡e ⌫ 2⇡e 2⇡
2 K. G. Binmore, Mathematical analysis: A straightforward approach. Cambridge University Press, 1977.

Section 17.7.2.

558
9.2. BOOTSTRAPPING

The other limit follows from the fact that


✓ ◆ ⌫+1
t2 2
t2
lim 1 + =e 2 .
⌫!1 ⌫
Combining the two limits proves the theorem. ⇤

End of the proof. Please join us again.

This theorem has several implications:


When N is large, S 2 ! 2 . The Gaussian approximation kicks in, and so Student’s
t-distribution is more or less the same as the Gaussian.
Student’s t-distribution is better for small N , usually N  30. If N 30, using the
Gaussian approximation suffices.
If X is Gaussian, Student’s t-distribution is an excellent model. If X is not Gaussian,
Student’s t-distribution will have some issues unless N increases.

9.2 Bootstrapping

When P estimating the confidence interval, we focus exclusively on the sample average ⇥ b =
N
(1/N ) n=1 Xn . There are, however, many estimators that are not sample averages. For
example, we might be interested in an estimator that estimates the sample median: ⇥ b =
median{X1 , . . . , XN }. In such cases, the Gaussian-based analysis or the Student’s t-based
analysis we just derived would not work.
Stepping back a little further, it is important to understand the hierarchy of estimation.
Figure 9.8 illustrates a rough breakdown of the various techniques. On the left-hand side
of the tree, we have three point estimation methods: MLE, MAP, and MMSE. They are
so-called point estimation methods because they are reporting a point — a single value.
This stands in contrast to the right-hand side of the tree, in which we report the confidence
interval. Note that point estimates and confidence intervals do not conflict with each other.
The point estimates are used for the actual engineering solution and the confidence intervals
are used to report the confidence about the point estimates. Under the branch of confidence
intervals we discussed sample average. However, if we want to study an estimator that is
not the sample average, we need the technique known as the bootstrapping — a method
for estimating the confidence interval. Notably, it does not give you a better point estimate.
As we have frequently emphasized, since ⇥ b is a random variable, it has its own PDF,
CDF, mean, variance, etc. The confidence interval introduced in the previous section pro-
vides one way to quantify the randomness of ⇥. b Throughout the derivation of the confidence
interval we need to estimate the variance Var(⇥). b For simple problems such as the sample
average, analyzing Var(⇥) b is not difficult. However, if ⇥
b is a more complicated statistic, e.g.,
b
the median, analyzing Var(⇥) may not be as straightforward. Bootstrapping is a technique
that is suitable for this purpose.

559
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Figure 9.8: Hierarchy of estimation. Bootstrapping belongs to the category of confidence interval. It is
used to report the confidence intervals for estimators that are not the sample averages.

Why is it difficult to provide a confidence interval for estimators such as the median?
A couple of difficulties arise:
Many estimators do not have a simple expression for the variance. For simple esti-
mators such as the sample average ⇥ b = (1/N ) PN Xn , the variance is 2 /N . If the
n=1
estimator is the median ⇥b = median{X1 , . . . , XN }, the variance of ⇥b will depend on
the underlying distribution of the Xn ’s. If the estimator is something beyond the sam-
b can be even more complicated to determine. Therefore,
ple median, the variance of ⇥
techniques such as Central Limit Theorem do not apply here.
We typically have only one set of data points. We cannot re-collect more i.i.d. samples
to estimate the variance of the estimator. Therefore, our only option is to squeeze the
information from the data we have been given.

When do we use bootstrapping?


Bootstrapping is a technique to estimate the confidence interval.
We use bootstrapping when the estimator does not have a simple expression for
the variance.
Bootstrapping allows us to estimate the variance without re-collecting more data.
Bootstrapping does not improve your point estimates.

9.2.1 A brute force approach


Before we discuss the idea of bootstrapping, we need to elaborate on the difficulty of esti-
mating the variance using repeated measurements. Suppose that we somehow have access to
the population distribution. Let us denote the CDF of this population distribution by FX ,

560
9.2. BOOTSTRAPPING

and the PDF by fX . By having access to the population distribution we can synthetically
generate as many samples Xn ’s as we want. This is certainly hypothetical, but let’s assume
that it is possible for now.
If we have full access to the population distribution, then we are able to draw K
replicate datasets X 1 , . . . , X K from FX :

(1) (1)
X (1) = {X1 , . . . , XN } ⇠ FX ,
(2) (2)
X (2) = {X1 , . . . , XN } ⇠ FX , (9.14)
..
.
(K) (K)
X (K) = {X1 , . . . , X N } ⇠ FX .

Each dataset X (K) contains N data points, and by virtue of i.i.d. all the samples have the
same underlying distribution FX .
For each dataset we construct an estimator ⇥ b = g(·) for some function g(·). The
estimator takes the data points of the dataset X and returns a value. Since we have K
datasets, correspondingly we will have K estimators:

b (1) = g(X (1) ) = g(X (1) , . . . , X (1) ),


⇥ 1 N
b (2) = g(X (2) ) = g(X (2) , . . . , X (2) ),
⇥ (9.15)
1 N
..
.
b (K) = g(X (K) ) = g(X (K) , . . . , X (K) ).
⇥ 1 N

Note that these estimators g(·) can be anything. It can be the sample average or it can be
the sample median. There is no restriction.
b we need to analyze
Since we are interested in constructing the confidence interval for ⇥,
b
the mean and variance of ⇥. The true mean and the estimated mean of ⇥ b are

b = true mean of ⇥,
E[⇥] b (9.16)
b = estimated mean based on ⇥
M(⇥) b (1) , . . . , ⇥
b (K)
K K
def 1 X b (k) 1 X
= ⇥ = g(X (k) ), (9.17)
K K
k=1 k=1

b are
respectively. Similarly, the true variance and the estimated variance of ⇥
b = true variance of ⇥,
Var[⇥] b (9.18)
b = estimated variance based on ⇥
V(⇥) b (1) , . . . , ⇥
b (K)
K ⇣
X ⌘2
def 1 b (k) M(⇥) b
= ⇥
K
k=1

1 X⇣ ⌘2
K
= g(X (k) ) b
M(⇥) . (9.19)
K
k=1

561
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

b is a random variable, and {⇥


These two equations should be familiar: Since ⇥ b (k) } are i.i.d.
b we can compute the average of ⇥
copies of ⇥, b (1) , . . . , ⇥
b (K) and the corresponding variance.
As the number of repeated trials K approaches 1, the estimated variance V(⇥) b will converge
b
to Var(⇥) according to the law of large numbers.
We can summarize the procedure we have just outlined. To produce an estimate of the
variance, we run the algorithm below.

Algorithm 1: Brute force method to generate an estimated variance


Assume: We have access to FX .
Step 1: Generate datasets X (1) , . . . , X (K) from FX .
Step 2: Compute M(⇥)b and V(⇥) b based on the samples.
b
Output: The estimated variance is V(⇥).

The problem, however, is that we only have one dataset X (1) . We do not have access to
X (2) , . . . , X (K) , and we do not have access to FX . Therefore, we are not able to approxi-
mate the variance using the above brute force simulation. Bootstrapping is a computational
technique to mimic the above simulation process by using the available data in X (1) .

9.2.2 Bootstrapping
The idea of bootstrapping is illustrated in Figure 9.9. Imagine that we have a population
CDF FX and PDF fX . The dataset we have in hand, X , is a collection of the random realiza-
tions of the random variable X. This dataset X contains N data points X = {X1 , . . . , XN }.

Figure 9.9: A conceptual illustration of bootstrapping. Given the observed dataset X , we synthetically
construct K bootstrapped datasets (colored in yellow) by sampling with replacement from X . We
then compute the estimators, e.g., computing the median, for every bootstrapped dataset. Finally, we
construct the estimator’s histogram (in blue) to compute the bootstrapped mean and variance.

In bootstrapping, we synthesize K bootstrapped datasets Y (1) , . . . , Y (K) , where each


bootstrapped dataset Y (k) consists of N samples redrawn from X . Essentially, we draw with

562
9.2. BOOTSTRAPPING

replacement N samples from the observed dataset X :


(1) (1)
Y (1) = {Y1 , . . . , YN } = N random samples from X ,
..
.
(K) (K)
Y (K) = {Y1 , . . . , YN } = N random samples from X .

b according to our desired function g(·). For example,


Afterward, we construct our estimator ⇥
if g(·) = median, we have

b (1) = g(Y (1) ) = median(Y (1) ),


⇥ boot
..
.
b (K) = g(Y (K) ) = median(Y (K) ).
⇥ boot

Then, we define the bootstrapped mean and the bootstrapped variance as


K
b 1 X b (k)
Mboot (⇥) = ⇥boot , (9.20)
K
k=1

1 X ⇣ b (k) ⌘2
K
b =
Vboot (⇥) ⇥boot b
Mboot (⇥) . (9.21)
K
k=1

The procedure we have just outlined can be summarized as follows.


Algorithm 2: Bootstrapping to generate an estimated variance
Assume: We do NOT have access to FX , but we have one dataset X .
Step 1: Generate datasets Y (1) , . . . , Y (K) from X , by sampling with replacement from
X.
b and Vboot (⇥)
Step 2: Compute Mboot (⇥) b based on the samples.
b
Output: The bootstrapped variance is Vboot (⇥).

The only di↵erence between this algorithm and the previous one is that we are not synthe-
sizing data from the population but rather from the observed dataset X .
What makes bootstrapping work? The basic principle of bootstrapping is based on
three approximations:
(a)
b ⇡ Vfull (⇥)
VarF (⇥) b
(b)

(c)
b ⇡ Vboot (⇥)
VarFb (⇥) b

b which is the
In this set of equations, the ultimate quantity we want to know is VarF (⇥),
b under F . (By “under F ” we mean that the variance was found by integrating
variance of ⇥
with respect to the distribution FX .) However, since we do not have access to F , we have

563
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

to approximate VarF (⇥) b by Vfull (⇥). b Vfull (⇥)


b is the sample variance computed from the
K hypothetical datasets X (1) , . . . , X (K) . We call it “full” because we can generate as many
hypothetical datasets as we want. It is marked as the approximation (a) above.
In the bootstrapping world, we approximate the underlying distribution F by some
other distribution Fb . For example, if F is the CDF of a Gaussian distribution, we can
choose Fb to be the finite-sample staircase function approximating F . In our case, we use the
observed dataset X to serve as a proxy Fb to F . This is the second approximation, marked by
(b). Normally, if you have a reasonably large X , it is safe to assume that this finite-sample
dataset X has a CDF Fb that is close to the true CDF F .
The third approximation is to find a numerical estimate VarFb (⇥) b via the simulation
procedure we have just outlined. This is essentially the same line of argument for (a) but
now applied to the bootstrapping world. We mark this approximation by (c). Its goal is to
approximate VarFb (⇥)b via Vboot (⇥).b
The three approximations have their respective influence on the accuracy of the boot-
strapped variance:

How does bootstrapping work?


It is based on three approximations:
(a): A hypothetical approximation. The best we can do is that we have access
to F . It is practically impossible to achieve, but it gives us intuition.
(b): Approximate F by Fb , where Fb is the empirical CDF of the observed data.
This is usually the source of error. The approximation error reduces when you
use more samples to approximate F .
(c): Approximate the theoretical bootstrapped variance by a finite approxima-
tion. This approximation error is usually small because you can generate as many
bootstrapped datasets as you want.

One “mysterious” property of bootstrapping is the sampling with replacement scheme


used to synthesize the bootstrapped samples. The typical questions are:
(1) Why does sampling from the observed dataset X lead to meaningful boot-
strapped datasets Y (1) , . . . , Y (K) ? To answer this question we consider the following
toy example. Suppose we have a dataset X containing N = 20 samples, as shown
below.

X = [0 0 0 0 0 0 1 1 1 1 2 2 2 2 2 2 2 2 2 2]

This dataset is generated from a random variable X with a PDF fb having three states:
0 (30%), 1 (20%), 2 (50%). As we draw samples from X , the percentage of the states
will determine the likelihood of one state being drawn. For example, if we randomly
pick a sample Yn from X , we have a 30% chance of having Yn to be 0, 20% chance
of having it to be 1, and 50% chance of having it to be 2. Therefore, the PDF of Yn
(the randomly drawn sample from X ) will be 0 (30%), 1 (20%), 2 (50%), the same
as the original PDF. If you think about this problem more deeply, by “sampling with
replacement” we essentially assign each Xn with an equal probability of 1/N . If one
of the states is more popular, the individual probabilities will add to form a higher
probability mass.

564
9.2. BOOTSTRAPPING

(2) Why can’t we do sampling without replacement, aka permutation? We need to


understand that sampling without replacement is the same as permuting the data in X .
By permuting the data in X , the simple probability assignments such as P[X = 0] = 20
6
,
P[X = 1] = 20 and P[X = 2] = 20 will be destroyed. Moreover, permuting the data
4 10

does not change the mean and variance of the data because we are only shu✏ing the
order. As far as constructing the confidence interval is concerned, shu✏ing the order
is not useful.
On computers it is easy to generate the bootstrapped dataset, along with their mean
and variance. In MATLAB the key step is to call a for loop. Inside the for loop, we draw
N random indices randi from 1 to N and pick the samples. The estimator Thetahat is then
constructed by calling your target estimator function g(·). In this example the estimator is
the median. After the for loop, we compute the mean and variance of ⇥. b These are the
bootstrapped mean and variance, respectively.

% MATLAB code to estimate a bootstrapped variance


X = [72, 69, 75, 58, 67, 70, 60, 71, 59, 65];
N = size(X,2);
K = 1000;
Thetahat = zeros(1,K);
for i=1:K % repeat K times
idx = randi(N,[1, N]); % sampling w/ replacement
Y = X(idx);
Thetahat(i) = median(Y); % estimator
end
M = mean(Thetahat) % bootstrapped mean
V = var(Thetahat) % bootstrapped variance

The Python commands are similar. We call np.random.randint to generate random


integers and we pick samples according to Y = X[idx]. After generating the bootstrapped
dataset, we compute the bootstrap estimators Thetahat.

# Python code to estimate a bootstrapped variance


import numpy as np
X = np.array([72, 69, 75, 58, 67, 70, 60, 71, 59, 65])
N = X.size
K = 1000
Thetahat = np.zeros(K)
for i in range(K):
idx = np.random.randint(N, size=N)
Y = X[idx]
Thetahat[i] = np.median(Y)
M = np.mean(Thetahat)
V = np.var(Thetahat)

After we have constructed the bootstrapped variance, we can define the bootstrapped
standard error as q
se b
b boot = Vboot (⇥). (9.22)

565
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Accordingly we define the bootstrapped confidence interval as


⇥ ⇤
I= ⇥ b z↵ se b + z↵ se
b boot , ⇥ b boot , (9.23)
where z↵ is the critical value of the Gaussian.
The validity of the confidence intervals constructed by bootstrapping is subject to
b is roughly a Gaussian, the bootstrapped confidence interval will be
the validity of z↵ . If ⇥
b
reasonably good. If ⇥ is not Gaussian, there are advanced methods to replace z↵ with better
estimates. This topic is beyond the scope of this book; we refer interested readers to Larry
Wasserman, All of Statistics, Springer 2003, Chapter 8.

9.3 Hypothesis Testing

Imagine that you are a vaccine company developing COVID-19 vaccines. You gave the
vaccine to 934 patients, and 928 patients have developed antigens. How confident can you
be that your vaccine is e↵ective? Questions like this are becoming more common nowadays
in situations in which we need to make statistically informed choices between YES and NO.
The subject of this section is hypothesis testing — a principled statistical procedure used
to evaluate statements that should be accepted or rejected.

9.3.1 What is a hypothesis?


A hypothesis is a statement that requires testing by observation to determine whether it is
true or false. A few examples:
The coin is unbiased.
Students entering the graduate program have GPA 3.
More people like orange juice than lemonade.
Algorithm A performs better than Algorithm B.
As you can see from these examples, a hypothesis is something we can test based on the
data. Therefore, being “correct” or “wrong” depends on the statistics we have and the cuto↵
threshold. Accepting or rejecting a hypothesis does not mean that the statement is correct
or wrong, since the truth is unknown. If we accept a hypothesis, we have made a better
decision solely based on the statistical evidence. It is possible that tomorrow when you have
collected more data we may reject a previously accepted hypothesis.
The procedure for testing whether a hypothesis should be accepted or rejected is known
as hypothesis testing. In hypothesis testing, we often have two opposite hypotheses:
H0 : Null hypothesis. It is the “status quo”, or the current status.
H1 : Alternative hypothesis. It is the alternative to the null hypothesis.
To better understand hypothesis testing, consider a courthouse. By default, any person
being prosecuted is assumed to be innocent. The police need to show sufficient evidence in
order to prove the person guilty. The null hypothesis is the default assumption. Hypothesis
testing asks whether we have strong enough evidence to reject the null hypothesis. If our
evidence is not strong enough, we must assume that the null hypothesis is possibly true.

566
9.3. HYPOTHESIS TESTING

Example 9.6. Suggest a null hypothesis and an alternative hypothesis regarding


whether a coin is unbiased.

Solution: Let ✓ be the probability of getting a head.


H0 : ✓ = 0.5, and H1 : ✓ > 0.5. This is a one-sided alternative.
H0 : ✓ = 0.5, and H1 : ✓ < 0.5. This is another one-sided alternative.
H0 : ✓ = 0.5, and H1 : ✓ 6= 0.5. This is a two-sided alternative.

Practice Exercise 9.3. Suggest a null and an alternative hypothesis regarding whether
more than 62% of people in the United States use Microsoft Windows.

Solution: Let ✓ be the proportion of people using Microsoft Windows in United States.
H0 : ✓ 0.62, and H1 : ✓ < 0.62. This is a one-sided alternative.

Practice Exercise 9.4. Suggest a null and an alternative hypothesis regarding whether
self-checkout at Walmart is faster than using a cashier.

Solution: Let ✓ be the proportion of people that check out faster with self-checkout..
H0 : ✓ 0.5, and H1 : ✓ < 0.5. This is a one-sided alternative.

9.3.2 Critical-value test


In hypothesis testing, there are two major approaches: the critical-value test, and the
p-value test. The two tests are more or less equivalent. If you reject the null hypothesis using
the critical-value test, you will reject the hypothesis using the p-value. In this subsection,
we will discuss the critical-value test. Let us consider a toy problem:
Suppose that we have a 4-sided die and our goal is to test whether the die is unbiased.
To do so, we define the null and the alternative hypotheses as
H0 : ✓ = 0.25, which is our default belief.
H1 : ✓ > 0.25, which is a one-sided alternative.
There is no particular reason for considering the one-sided alternative other than the fact
that the calculation is slightly easier. You are welcome to consider the two-sided alternative.
We must obtain data prior to conducting any hypothesis testing. Let’s assume that we
have thrown the die N = 1000 times. We find that “3” appears 290 times (we could just as
well have chosen 1, 2, or 4). We let X1 , . . . , X1000 be the N = 1000 binary random variables
representing whether we have obtained a “3” or not. If the true probability is ✓ = 0.25, then
we will have P[Xn = 3] = ✓ = 0.25 and P[Xn 6= 3] = 1 ✓ = 0.75. We know that we cannot
access the true probability, so we can only construct an estimator of the probability:
XN
b= 1
⇥ Xn .
N n=1

567
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

In this experiment, we can show that ⇥ b = 290/1000 = 0.29.


To make our problem slightly easier, we pretend that we know the variance Var[Xn ].
In practice, we certainly do not know Var[Xn ], and so we need to estimate the variance. If
we knew the variance, it should be Var[Xn ] = ✓(1 ✓) = 0.25(1 0.25) = 0.1875, because
Xn is a Bernoulli random variable with a mean ✓.
The question asked by hypothesis testing is: How far is “⇥ b = 0.29” from “✓ = 0.25”?
If the statistic generated by our data, ⇥ b = 0.29, is “far” from the hypothesized ✓ = 0.25,
then we need to reject H0 because H0 says that ✓ = 0.25. However, if there is no strong
evidence that ✓ > 0.25, we will need to assume that H0 may possibly be true. So the key
question is what is meant by “far”.
b Since ⇥
For many problems like this one, it is possible to analyze the PDF of ⇥. b is the
b
sample average of a sequence of Bernoulli random variables, it follows that ⇥ is a binomial
(with a scaling constant 1/N ). If N is large enough, e.g., N 30, the Central Limit Theorem
b is also very close to a Gaussian. Therefore, we can more or less claim that
tells us that ⇥
✓ 2

b ⇠ Gaussian ✓,
⇥ .
N

b to obtain Z:
With a simple translation and scaling, we can normalize ⇥ b

b ✓

Zb = p ⇠ Gaussian (0, 1) .
/ N

Figure 9.10 illustrates the range of values for this problem. There are two axes: the ⇥- b
b
axis (which is the estimator) and the Z-axis (which is the normalized variable). The values
corresponding to each axis are shown in the figure. For example. ⇥ b = 0.29 is equivalent
to Zb = 2.92, and ⇥ b = 0.25 is equivalent to Zb = 0, etc. Therefore, when we ask how far
b = 0.29” is from “✓ = 0.25”, we can map this question from the ⇥-axis
“⇥ b b
to the Z-axis,
and ask the relative position of Zb from the origin.

Figure 9.10: The mapping between ⇥ b and Z.b To decide whether we want to reject or keep H0 , the
b
critical-value approach compares Z relative to the critical value z↵ .

On a computer, obtaining these values is quite straightforward. Using MATLAB, find-


ing Zb can be done by calling the following commands. The Python code is analogous.

568
9.3. HYPOTHESIS TESTING

% MATLAB command to estimate the Z_hat value.


Theta_hat = 0.29; % Your estimate
theta = 0.25; % Your hypothesis
sigma = sqrt(theta*(1-theta)); % Known standard deviation
N = 1000; % Number of samples
Z_hat = (Theta_hat - theta)/(sigma/sqrt(N));

# Python command to estimate the Z_hat value


import numpy as np
Theta_hat = 0.29 # Your estimate
theta = 0.25 # Your hypothesis
N = 1000 # Number of samples
sigma = np.sqrt(theta*(1-theta)) # Known standard deviation
Z_hat = (Theta_hat - theta)/(sigma / np.sqrt(N))
print(Z_hat)

One essential element of hypothesis testing is the cuto↵ threshold, which is defined
b Typically,
through the critical level ↵. It is the area under the curve of the PDF of Z.
↵ is chosen to be a small value, such as ↵ = 0.05 (corresponding to a 5% margin). The
corresponding cuto↵ is known as the critical value. It is defined as

z↵ = cuto↵ location where area under the curve is ↵.

If Zb is Gaussian(0,1) and if we are looking at the right-hand tail, it follows that


1
z↵ = (1 ↵) . (9.24)

In our example, we find that z0.05 = 1.65, which is marked in Figure 9.10.
On computers, determining the critical value z↵ is straightforward. In MATLAB the
command is icdf, and in Python the command is stats.norm.ppf.

% MATLAB code to compute the critical value


alpha = 0.05;
z_alpha = icdf(’norm’, 1-alpha, 0, 1);

# Python code to compute the critical value


import scipy.stats as stats
alpha = 0.05
z_alpha = stats.norm.ppf(1-alpha, 0, 1)

Do we have enough evidence to reject H0 in this example? Of course! The estimated


b = 0.29 is equivalent to Zb = 2.92, which is much too far from the cuto↵ z↵ = 1.65.
value ⇥
In other words, we conclude that at a 5% critical level we have strong evidence to believe
that the die is biased. Therefore, we need to reject H0 .
This conclusion makes a lot of sense if you think about it carefully. The estimator
b = 0.29 is obtained from N = 1000 independent experiments. If we were only conducting

N = 20 experiments, it might be consistent with the null hypothesis to have ⇥ b = 0.29.

569
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

However, if we have N = 1000 experiments, having ⇥ b = 0.29 does not seem likely when
there is no systematic bias. If there is no systematic bias, the estimator ⇥b should slightly
jitter around ⇥b = 0.25, but it is quite unlikely to vary wildly to ⇥
b = 0.29. Thus, based on
the available statistics, we decide to reject the null hypothesis.
The decision based on comparing the critical value is known as the critical-value test.
The idea (for testing a right-hand tail of a Gaussian random variable) is summarized in
three steps:

How to conduct a critical-value test


p
Set a critical value z↵ . Compute Zb = (⇥
b ✓)/( / N ).
If Zb z↵ , then reject H0 .
If Zb < z↵ , then keep H0 .
If you are testing a left-hand tail, you can switch the order of the inequalities.

The critical-value test belongs to a larger family of testing procedures based on deci-
sion theory. To give you a preview of the general theory of hypothesis testing, we define a
decision rule, a function that maps a realization of the estimator to a binary decision space.
In our problem the estimator is Zb (or equivalently ⇥).
b We denote its realization by zb. The
binary decision space is {H0 , H1 }, corresponding to whether we want to claim H0 or H1 .
Claiming H0 is equivalent to keeping H0 , and claiming H1 is equivalent to rejecting H0 .
For the critical-value test, the decision rule (·) : R ! {0, 1} is given by the equation (for
testing a right-hand tail):
(
1, if zb z↵ , (claim H1 ),
(b
z) = (9.25)
0, if zb < z↵ , (claim H0 ).

Example 9.7. It was found that only 35% of the children in a kindergarten eat
broccoli. The teachers conducted a campaign to get more kids to eat broccoli, after
which it was found that 390 kids out of 1009 kids reported that they had eaten broccoli.
Has the campaign successfully increased the number of kids eating broccoli? Assume
that the standard deviation is known.

Solution. We setup the null and the alternative hypothesis.

H0 : ✓ = 0.35, H1 : ✓ > 0.35.

We construct an estimator ⇥ b = (1/N ) PN Xn , where Xn is Bernoulli with proba-


n=1
bility ✓. Based on ✓, 2 = ✓(1 ✓) = 0.227. (Again, in practice we do not know the
true variance, but in this problem we pretend that we know it.)
By the Central Limit Theorem, ⇥ b is roughly a Gaussian. We compute the test
b = 390 = 0.387. Standardization gives Zb = ⇥ b ✓
statistics ⇥ 1009
p
/ N
= 2.432. At a 5%
critical level, we have that z↵ = 1.65. So Zb = 2.432 > 1.65 = z↵ , and hence we need
to reject the null hypothesis. Even if we choose a 1% critical level so that z↵ = 2.32,
our estimator Zb = 2.432 > 2.32 = z↵ will still reject the null hypothesis.

570
9.3. HYPOTHESIS TESTING

A graphical illustration of this problem is shown in Figure 9.11. It can be seen


b = 0.387 is actually quite far away from the cuto↵ 1.65. Thus, we need to reject
that ⇥
the null hypothesis.

Figure 9.11: Example of a critical-value test. In this example, the test statistic ⇥ b = 0.387 is
b
equivalent to Z = 2.432, which is significantly larger than the cuto↵ z↵ = 1.65. Therefore, we
b = 0.387
have strong evidence to reject the null hypothesis, because the probability of obtaining ⇥
is very low if H0 is true.

9.3.3 p-value test


An alternative to the critical-value test is the p-value test. Instead of looking at the cuto↵
value z↵ , we inspect the probability of obtaining our observation if H0 is true. To understand
how the p-value test works, we consider another toy problem.
Suppose that we have two hypotheses about flipping a coin:
H0 : ✓ = 0.9, which is our default belief.
H1 : ✓ < 0.9, which is a one-sided alternative.
It was found that with N = 150 coin flips, the coin landed on heads 128 times. Thus the
b = 128 = 0.853. Then, by following our previous procedures, we have that
estimator is ⇥ 150

b ✓
⇥ 0.853 0.9
Zb = p =q = 1.92.
/ N 0.9(1 0.9)
150

At this point we can follow the previous subsection by computing the critical value z↵
and make the decision. However, let’s take a di↵erent route. We want to know what is the
probability under the curve if we integrate the PDF of Zb from 1 to 1.92. This is easy.
Since Zb is Gaussian(0, 1), it follows from the CDF of a Gaussian that

P[Zb  1.92] = 0.0274.


| {z }
p-value

Referring to Figure 9.12, the value 0.0274 is the pink area under the curve, which is the
PDF of Z.b Since the area under the curve is less than the critical level ↵ (say 5%), we reject
the null hypothesis.
On computers, computing the p-value is done using the CDF commands.

571
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Figure 9.12: The p-value test asks us to look at the probability of Z b  zb. If this probability (the p-value)
is less than the critical level ↵, we have significant evidence to reject the null hypothesis.

% MATLAB code to compute the p-value


p = cdf(’norm’, -1.92, 0, 1);

# Python code to compute the p-value


import scipy.stats as stats
p = stats.norm.cdf(-1.92,0,1)

In this example, the probability P[Zb  1.92] is known as the p-value. It is the
probability of Zb  z, under the distribution mandated by the null hypothesis, where z
is the (normalized) estimated value based on data. Using our example, z is 1.92. By
“distribution mandated by the null hypothesis” we mean that the PDF of Zb is the PDF that
the null hypothesis
p wants. In the above example the PDF is Gaussian(0, 1), corresponding
to Gaussian(✓, / N ) for ⇥.b
More formally, the p-value for a left-hand tail test is defined as

z ) = P[Zb  zb],
p-value(b

where zb is the random realization of Zb estimated from the data. The decision rule based
on the p-value is (for the left-hand tail):
(
1, P[Zb  zb] < ↵ (claim H1 ),
(b
z) = (9.26)
0, b
P[Z  zb] ↵ (claim H0 ).

If the alternative hypothesis is right-handed, then the probability becomes P[Zb zb] instead.
Relationship between critical-value and p-value tests. There is a one-to-one corre-
spondence between the p-value and the critical value. In the p-value test, if Zb is Gaussian,
it follows that

p-value = P[Zb  zb] = (b


z ),

572
9.3. HYPOTHESIS TESTING

where is CDF of the standard Gaussian. Taking the inverse, the corresponding zb is
1
zb = (p-value).

In practice, we do not need to take any inverse of the p-value to obtain zb because it is
directly available from the data.
To test the p-value, we compare it with the critical level ↵ by checking

p-value < ↵.

Taking the inverse of both sides, it follows that the decision rule is equivalent to
1 1
(p-value) < (↵),
| {z } | {z }
b
z z↵

where the quantity on the right-hand side is the critical value z↵ . Therefore, if the test
statistic fails in the p-value test it will also fail in the critical-value test, and vice versa.

What is the di↵erence between the critical-value test and p-value test?
Critical-value test: Compare w.r.t. critical value, which is the cuto↵ on the Z-
axis.
p-value test: Compare w.r.t. ↵, which is the probability.
Both will give you the same statistical conclusion. So it does not matter which
one you use.

Example 9.8. We flip a coin for N = 150 times and find that 128 are heads. Consider
two hypotheses
H0 : ✓ = 0.9, which is our default belief.
H1 : ✓ 6= 0.9, which is a two-sided alternative.
For a critical level of ↵ = 0.05, shall we keep or reject H0 ?
b = 128/150 = 0.853. The normalized statistic is
Solution. We know that ⇥

b ✓
⇥ 0.853 0.9
Zb = p =q = 1.92.
/ N 0.9(1 0.9)
150

To compute the p-value, we observe that the two-sided test means that we consider
the two tails. Thus, we have
b > 1.92]
p-value = P[|Z|
= 2 ⇥ P[Zb > 1.92]
= 2 ⇥ 0.0274 = 0.055.

573
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

For a critical level of ↵ = 0.05, the p-value is larger. This means that the probability
of obtaining |Z| > 1.92 is not extreme enough. Therefore, we do not have sufficient
evidence to reject the null hypothesis.
If we take the critical-value test, we will reach the same conclusion. The critical
value for ↵ = 0.05 is determined by taking the inverse CDF at 1 0.025, giving
⇣ ↵⌘
1
z↵ = 1 = 1.96.
2

Since Zb = 1.92 has not passed this threshold, we conclude that there is not enough
evidence to reject the null hypothesis.

Figure 9.13: Example of a two-sided test using the p-value and the z↵ -value.

9.3.4 Z-test and T -test


The critical-value test and the p-value tests are generic tools for hypothesis testing. In this
subsection we introduce the Z-test and the T -test. It is important to understand that the
Z-test and the T -test refer to the distributional assumptions we make about the variance.
They define the distribution we use to conduct the test but not the tools. In fact, both the
Z-test and the T -test can be implemented using the critical-value test or the p-value test.
Figure 9.14 illustrates the hierarchy of the tests.

Figure 9.14: When conducting a hypothesis testing of the sample average, we may or may not know
the variance. If we know the variance, we use the Gaussian distribution to conduct either a p-value test
or a critical-value test. If we do not know the variance, we use Student’s t-distribution.

The di↵erence between the Gaussian distribution and the T distribution is mainly

574
9.3. HYPOTHESIS TESTING

attributable to the knowledge about the population variance. If the variance is known,
the distribution of the estimator (which in our case is the sample average) is Gaussian. If
the variance is estimated from the sample, the distribution of the estimator will follow a
Student’s t-distribution.
To introduce the Z-test and the T -test we consider the following two examples. The
first example is a Z-test.

Example 9.9 (Z-test). Suppose we have a Gaussian random variable with unknown
mean ✓ and a known variance = 11.6. We draw N = 25 samples and construct an
b = 80.94. We propose two hypotheses:
estimator ⇥
H0 : ✓ = 85, which is our default belief.
H1 : ✓ < 85, which is a one-sided alternative.
For a critical level of ↵ = 0.05, shall we keep or reject the null hypothesis?

Solution. The test statistic is


b ✓

Zb = p = 1.75.
/ N

b
Since the individual samples are assumed to follow a Gaussian, the sample average ⇥
b
is also a Gaussian. Hence, Z is distributed according to Gaussian(0, 1).

Figure 9.15: A one-sided Z-test using the p-value and the z↵ -value.
For a critical level of 0.05, a one-sided critical value is
1
z↵ = (1 ↵) = 1.645.

Since Zb = 1.75, which is more extreme than the critical value, we conclude that we
need to reject H0 .
If we use the p-value test, we have that the p-value is

P[Zb  1.75] = ( 1.75) = 0.0401.

575
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Since the p-value is smaller than the critical level ↵ = 0.05, it implies that Zb = 1.75
is more extreme. Hence, we reject H0 .
The following example is a T -test. In a T -test we do not know the population variance
but only know the sample variance S.b Thus the test statistic we use is a T random variable.

Example 9.10 (T -test). Suppose we have a Gaussian random variable with unknown
mean ✓ and an unknown variance . We draw N = 100 samples and construct an
b = 130.1, with a sample variance Sb = 21.21. We propose two hypotheses:
estimator ⇥
H0 : ✓ = 120, which is our default belief.
H1 : ✓ 6= 120, which is a two-sided alternative.
For a critical level of ↵ = 0.05, shall we keep or reject the null hypothesis?

Solution. The test statistic is


b ✓

Tb = p = 4.762.
b N
S/

Note that while the sample average ⇥b is a Gaussian, the test statistic Tb is distributed
according to a T distribution with N 1 degrees of freedom. For a critical level of
0.05, a two-sided critical value is
⇣ ↵⌘
t↵ = 991 1 = 1.984.
2

Since Tb = 4.762, which is more extreme than the critical value, we conclude that we
need to reject H0 .
If we use the p-value test, we have that the p-value is

P[|Tb| 4.762] = 2 ⇥ P[Tb 4.762] = 3.28 ⇥ 10 6


.

Since the p-value is (much) smaller than the critical level ↵ = 0.05, it implies that
|Tb| 4.762 is quite extreme. Hence, we reject H0 .

Figure 9.16: A two-sided T -test using the p-value and the z↵ -value.

For this example, the MATLAB and Python commands to compute t↵ and the p-value are

576
9.4. NEYMAN-PEARSON TEST

% MATLAB code to compute critical-value and p-value


t_alpha = icdf(’t’, 1-0.025, 99);
p = 1-cdf(’t’, 4.762, 99);

# Python code to compute critical value and p-value


import scipy.stats as stats
t_alpha = stats.t.ppf(1-0.025,99)
p = 1-stats.t.cdf(4.762,99)

What are the Z-test and the T -test?


Both are hypothesis testings for the sample averages.
Z-test: Assume known variance. Hence, use the Gaussian distribution.
T -test: Assume unknown variance. Hence, use the Student’s t-distribution.

Remark. We are exclusively analyzing the sample average in this section. There are other
types of estimators we can analyze. For example, we can discuss the di↵erence between the
two means, the ratio of two random variables, etc. If you need tools for these more advanced
problems, please refer to the reference section at the end of this chapter.

9.4 Neyman-Pearson Test

The hypothesis testing procedures we discussed in the previous section are elementary in
the sense that we have not discussed much theory. This section aims to fill the gap so that
you can understand hypothesis testing from a broader perspective. This generalization will
also help to bridge statistics to other disciplines such as classification in machine learning
and detection in signal processing. We call this theoretical analysis the Neyman-Pearson
framework.

9.4.1 Null and alternative distributions


When we discussed hypothesis testing in the previous section, we focused exclusively on the
null hypothesis H0 . Regardless of whether we are studying the Z-test or the T -test, using
the critical value or the p-value, all the distributions are associated with the distribution
under H0 .
What do we mean by “distribution under H0 ”? Using ⇥ b as an example, the PDF of
b 2
⇥ is assumed to be Gaussian(✓, /N ). This Gaussian, centered at ✓, is the distribution
assumed under H0 . As we decide whether to keep or rejectH0 , we look at the critical value
and the p-value of the test statistic under Gaussian(✓, 2 /N ).
Importantly, the analysis of hypothesis testing is not just about H0 — it is also about
the alternative hypothesis H1 , which uses a di↵erent PDF. For example, H1 could use

577
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

b we can check how


Gaussian(✓0 , 2 /N ) for ✓0 > ✓. Therefore, for the same testing statistic ⇥,
close it is to H1 .
To capture both distributions, we define

f0 (y) = fY (y | H0 ),
f1 (y) = fY (y | H1 ).

The first PDF defines the distribution when the true model is H0 . The second PDF is the
distribution when the true model is H1 .

2
Example 9.11. Consider an estimator Y ⇠ Gaussian(✓, /N ). Define two hypotheses
H0 : ✓ = 120 and H1 : ✓ > 120. The two PDFs are then
2
f0 (y) = fY (y|H0 ) = Gaussian(120, /N ),
0
f1 (y) = fY (y|H1 ) = Gaussian(✓ , 2
/N ), ✓0 > 120.

A graph of the two distributions is shown in Figure 9.17. In this figure we plot the
PDF under the null hypothesis and the PDF under an alternative hypothesis. The decision
is based on the null, where we marked the critical value.

Figure 9.17: The PDF of the estimator under hypotheses H0 and H1 . The yellow region defines the
rejection zone R↵ . If the estimator has a realization Y = y that falls into the rejection zone R↵ , we
need to reject H0 .

Students are frequently confused about the exact equation of the PDF under H1 . If
the alternative hypothesis is defined as ✓ > 120, shall we define the PDF as a Gaussian
centered at 130 or 151.4? They are both valid alternative hypotheses. The answer is that
we are going to express all equations based on ✓0 . For example, if we want to analyze the
prediction error (this term will be explained later), the prediction error will be a function
of ✓0 . If ✓0 is close to ✓, we will expect a larger prediction error. However, if ✓0 is far away
from ✓, the prediction error may be small.
Whenever we discuss hypothesis testing, a decision rule is always implied. A decision
rule is a mapping (·) from sample space Y of the test statistic Y (or ⇥ b if you prefer) to the

578
9.4. NEYMAN-PEARSON TEST

binary space of {0, 1}:


(
1, if y 2 R↵ , (we will reject H0 ),
(y) = (9.27)
0, if y 62 R↵ , (we will keep H0 ).

Here R↵ is the rejection zone. For example, in a one-sided testing at a critical level ↵, the
1 1
rejection zone is R↵ = {y (1 ↵)}. Therefore, as long as y (1 ↵), we will
reject the null hypothesis. Otherwise, we will keep the null hypothesis. A rejection zone can
be one-sided, two-sided, or even more complicated.

Example 9.12. Consider H0 : ✓ = 0.35 and H1 : ✓ > 0.35. It was found that the
sample average over b 2
p 1009 samples is ⇥ = 0.387, with = 0.227. The normalized test
statistic is Zb = N (⇥b ✓)/ = 2.432. At a 5% critical level, define the decision rule
based on the critical-value approach.
1
Solution. If ↵ = 0.05, it follows that z↵ = (1 0.05) = 1.65. Therefore, the
decision rule is
(
1, if zb 1.65, (we will reject H0 ),
(b
z) =
0, if zb < 1.65, (we will keep H0 ),

b In this particular problem, we have zb = 2.432. Thus,


where zb is the realization of Z.
according to the decision rule, we need to reject H0 .

A decision rule is something you create. You do not need to follow the critical-value
or the p-value procedure — you can create your own decision rule. For example, you can
say “reject H0 when |y| > 0.000001”. There is nothing wrong with this decision rule except
that you will almost always reject the null hypothesis (so it is a bad decision rule). See
Figure 9.18 for a graph of a similar example. If you follow the critical-value or the p-value
procedures, it turns out that the resulting decision rule is equivalent to some form of optimal
decision rule. This concept is the Neyman-Pearson framework, which we will explain shortly.

9.4.2 Type 1 and type 2 errors


Since hypothesis testing is about applying a decision rule to the test statistics, and since
no decision rule is perfect, it is natural to ask about the error expected from a particular
decision rule. In this subsection we define the decision error. However, the terminology varies
from discipline to discipline. We will explain the decision error first through the statistics
perspective and then through the signal processing perspective.
Two tables of the cases that can be generated by a binary decision-making process are
shown in Figure 9.19. The columns of the tables are the true statements, i.e., whether the
test statistic has a population distribution under H0 or H1 . The rows of the tables are the
statements predicted by the decision rule, i.e., whether we should declare the statistics are
from H0 or H1 . Each combination of the truth and prediction has a label:
True positive: The truth is H1 , and you declare H1 .
True negative: The truth is H0 , and you declare H0 .
False positive: The truth is H0 , and you declare H1 .

579
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Figure 9.18: Two possible decision rules 1 (y) and 2 (y). In this example, 1 (y) is designed according
to the critical-value approach at ↵ = 0.025, whereas 2 (y) is arbitrarily designed. Both are valid decision
rules, although 2 should not be used because it tends to reject the null hypothesis more often than
desired.

False negative: The truth is H1 , and you declare H0 .


Di↵erent communities have di↵erent ways of labeling these quantities. In the statistics com-
munity the false negative rate (i.e., the number of false negative cases divided by the total
number of cases) is called the type 2 error, and the false positive rate is called the type 1
error. The true positive rate is called the power of the decision rule.
In the engineering community (e.g., radar engineering and signal processing) the ob-
jective is to detect whether a target (e.g., a missile or an enemy aircraft) is present. In this
context, the false positive rate is known as the probability of false alarm, since personnel
will be alerted when no target is present. The false negative rate is known as the probability
of miss because you miss a target. If the truth is H1 and the prediction is also H1 , we call
this the probability of detection.

Figure 9.19: Terminologies used in labeling the prediction error. The terms “Type 1 error” and “Type
2 error” are commonly used by the statistics community, whereas the terms “false alarm”, “miss” and
“detection” are more often used in the engineering community.

The diagram in Figure 9.20 will help to clarify these definitions. Given two hypotheses
H0 and H1 , there exists the corresponding distributions f0 (y) and f1 (y), which are the PDFs

580
9.4. NEYMAN-PEARSON TEST

b if you prefer). Supposing that our decision rule is to declare


of the test statistics Y (or ⇥
H1 when Y ⌘ for some ⌘, for example, ⌘ = 1.65 for a 5% critical level, there are two areas
under the curve that we need to consider.
Type 1 / False alarm. The blue region under the curve represents the probability of
declaring H1 (i.e., we choose to reject the null) while the truth is actually H0 (i.e., we
should have not rejected the null). Mathematically, this probability is
Z
pF = P[Y ⌘ | H0 ] = f0 (y) dy. (9.28)
y ⌘

Type 2 / Miss. The pink region under the curve represents the probability of declaring
H0 (i.e., we choose to keep the null) while the truth is actually H1 (i.e., we should
have rejected the null). Mathematically, this probability is
Z
pM = P[Y < ⌘ | H1 ] = f1 (y) dy. (9.29)
y<⌘

Figure 9.20: Definition of type 1 and type 2 errors.

The power of the decision rule is also known as the detection. It is defined as

pD = P[Y ⌘ | H1 ]. (9.30)

A plot illustrating the power of the decision rule is shown in Figure 9.21. Since pD is the
conditional probability of Y ⌘ given H1 , it is the complement of pM , and so we have the
identity
p D = 1 pM .
Some communities refer to the above quantities in terms of the counts instead of the
probabilities. The di↵erence is that the probabilities are normalized to [0, 1] whereas the
counts are just the raw integers obtained from running an experiment. We prefer to use the
probabilities because they are the theoretical values. If you tell us the distributions f0 and
f1 , we can report the probabilities. The counts, by contrast, are just another form of sample
statistics. The number of counts today may be di↵erent from the number of counts tomorrow

581
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Figure 9.21: The power of the decision rule is the area under the curve of f1 , integrated for y inside
the rejection zone.

because they are obtained from the experiments. The di↵erence between probabilities and
counts is analogous to the di↵erence between PMFs and histograms.
Since the probability of errors changes as the decision rule changes, it is necessary to
define pF , pD and pM as functions of . In addition, hypothesis testing is not limited to one-
sided tests. We can define the rejection zone as R↵ = {y | reject H0 using a critical level ↵}.
The probabilities pF and pM are defined as
Z Z
pF ( ) = (y)f0 (y) dy = f0 (y) dy, (9.31)
y2R↵
Z Z
pM ( ) = (y)f1 (y) dy = f1 (y) dy. (9.32)
y62R↵

Using the property that pD = 1 pM , we have that


Z
pD ( ) = 1 pM ( ) = f1 (y) dy. (9.33)
y2R↵

Note that the rejection zone does not need to depend on ↵. You can arbitrarily define the
rejection zone, and the probabilities pF , pM , and pD can still be defined.

Example 9.13. Find pF ( 1 ) and pF ( 2 ) for the decision rule in Figure 9.18.
Solution. Since f0 is a Gaussian with zero mean and unit variance, it follows that
Z 1
1 y2
pF ( 1 ) = p e 2 dy = 1 (1.92) = 0.025,
2⇡
Z1.96
1
1 y2
pF ( 2 ) = p e 2 dy = 1 (0.5) = 0.3085.
0.5 2⇡

9.4.3 Neyman-Pearson decision


At this point you have probably observed something about the critical-value test and the
p-value test. Among the four types of decision combinations, we are looking at the false

582
9.4. NEYMAN-PEARSON TEST

positive rate, or the probability of false alarm pF ( ). The critical-value test requires us to
find such that pF ( ) is equal to ↵. That is, if you tell us the critical level ↵ (e.g., ↵ = 0.05),
we will find a decision rule (by telling you the cuto↵) such that the false alarm rate is ↵.
Consider an example:

Example 9.14. Let ↵ = 0.05. Assume that f0 is a Gaussian with zero-mean and
unit-variance. Let us do a one-sided test for H0 : ✓ = 0 versus H1 : ✓ > 0. Find such
that pF ( ) = ↵.
Solution. Let the decision rule be
(
1, y ⌘,
(y) =
0, y < ⌘.

Our goal is to find ⌘. The probability of false alarm is


Z 1
1 y2
pF ( ) = p e 2 dy = 1 (⌘).
⌘ 2⇡
1
Equating this to ↵, it follows that 1 (⌘) = ↵ implies ⌘ = (1 ↵) = 1.65. So the
decision rule becomes (
1, y 1.65,
(y) =
0, y < 1.65.
If you apply this decision rule, you are guaranteed that the false alarm rate is ↵ = 0.05.

But why should we aim for pF ( ) equal to ↵? Isn’t a lower false alarm rate better?
Indeed, we would not mind having a lower false alarm, so we are happy to have any
that satisfies pF ( )  ↵. However, changing the equality to an inequality means that we
now have a set of instead of a unique . More important, we need to pay attention to
the trade-o↵ between pF ( ) and pD ( ). The smaller the pF ( ) a decision rule provides,
the smaller the pD ( ) you can achieve. This is immediately apparent from Figure 9.20 and
Figure 9.21. (If you move the cuto↵ to the right, the gray area and the blue area will both
shrink.) Therefore, the desired optimization should be formulated as: From all the decision
rules that have a false alarm rate of no larger than ↵, we pick the one that maximizes the
detection rate. The resulting decision rule is known as the Neyman-Pearson decision rule.

Definition 9.2. The Neyman-Pearson decision rule is defined as the solution to the
optimization

= argmax pD ( ),

subject to pF ( )  ↵. (9.34)

Figure 9.22 illustrates two decision rules ⇤ (y) and (y). The first decision rule ⇤ (y) is
obtained according to the critical-value approach, with ↵ = 0.025. As we will prove shortly,
this is also the optimal Neyman-Pearson decision rule for a one-sided hypothesis testing at
↵ = 0.025. The second decision rule (y) has a harsher cuto↵, meaning that you need an
extreme test statistic to reject the null hypothesis. Clearly, the p-value obtained by (y) is

583
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

less than ↵ = 0.025. Thus, (y) is a valid decision rule according to the Neyman-Pearson
formulation. However, (y) is not optimal because the detection rate is not maximized.

Figure 9.22: Two decision rules (y) and ⇤ (y). Assume that ↵ = 0.025. Then (y) is one of the many
feasible choices in the Neyman-Pearson optimization, but ⇤ (y) is the optimal solution.

Because of the complementary behavior of pF and pD , it follows that pD is maximized


when pF hits the upper bound. If we want to maximize the detection rate we need to stretch
the false alarm rate as much as possible. As a result, the Neyman-Pearson solution occurs
when pF ( ) = ↵, i.e., when the equality is met.
The Neyman-Pearson framework is a general framework for all distributions f0 and f1 ,
as opposed to the critical-value and p-value examples, which are either Gaussian or Student’s
t-distribution. The solution to the Neyman-Pearson optimization is a decision rule known
as the likelihood ratio test. The likelihood ratio is defined as follows.

Definition 9.3. The likelihood ratio for two distributions f1 (y) and f0 (y) is

f1 (y)
L(y) = . (9.35)
f0 (y)

It turns out that the solution to the Neyman-Pearson optimization takes the form of the
likelihood ratio.

Theorem 9.2. The solution to the Neyman-Pearson optimization is a decision rule


that checks the likelihood ratio
(
⇤ 1, L(y) ⌘,
(y) = (9.36)
0, L(y) < ⌘,

for some decision boundary ⌘ which is a function of the critical level ↵.

584
9.4. NEYMAN-PEARSON TEST

What is so special about Neyman-Pearson decision rule?


It is the optimal decision. Its optimality is defined w.r.t. maximizing the detection
rate while keeping a reasonable false alarm rate:

= argmax pD ( ),

subject to pF ( )  ↵.

If your goal is to maximize the detection rate while maintaining the false alarm
rate, you cannot do better than Neyman-Pearson.
Its solution is the likelihood ratio test:
(
⇤ 1, L(y) ⌘,
(y) =
0, L(y) < ⌘,

where L(y) = f1 (y)/f0 (y) is the likelihood ratio.


The critical-value test and the p-value test are special cases of the Neyman-
Pearson test.

Deriving the solution to the Neyman-Pearson optimization can be skipped if this is your
first time reading the book.

Proof. Given ↵, choose ⇤ such that the false alarm rate is maximized: pF ( ⇤ ) = ↵. Then,
by substituting the definition of ⇤ into the false alarm rate,
Z 1
⇤ ⇤
↵ = pF ( ) = (y)f0 (y) dy
1
Z Z
= 1 · f0 (y) dy + 0 · f0 (y) dy. (9.37)
L(y) ⌘ L(y)<⌘

Now, consider another decision rule that is not optimal but is feasible. That means that
satisfies pF ( )  ↵. Therefore,
Z 1
↵ pF ( ) = (y)f0 (y) dy
Z 1 Z
= (y) · f0 (y) dy + (y) · f0 (y) dy. (9.38)
L(y) ⌘ L(y)<⌘

Our goal is to show that pD ( ⇤ ) pD ( ), because by proving this result we can claim that

maximizes the detection rate.
By combining Equation (9.37) and Equation (9.38), we have

0  pF ( ⇤ ) pF ( )
Z Z
= (1 (y))f0 (y) dy (y)f0 (y) dy. (9.39)
L(x) ⌘ L(y)<⌘

585
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

f1 (y)
Define L(y) = f0 (y) .
Then L(y) ⌘ if and only if f1 (y) ⌘f0 (y). So,
Z Z
pD ( ⇤ ) pD ( ) = (1 (y))f1 (y) dy (y)f1 (y) dy
L(y) ⌘ L(y)<⌘
Z Z
= (1 (y))⌘f0 (y) dy (y)⌘f0 (y) dy
L(y) ⌘ L(y)<⌘
"Z Z #
=⌘ (1 (y))f0 (y) dy (y)f0 (y) dy 0,
L(y) ⌘ L(y)<⌘


where the last inequality holds because of Equation (9.39). Therefore, we conclude that
maximizes pD . ⇤

End of the proof. Please join us again.

At this point, you may object that the likelihood ratio test (i.e., the Neyman-Pearson
decision rule) is very di↵erent from the hypothesis testing examples we have seen in the
previous chapter because now we need to handle the likelihood ratio L(y). Rest assured
that they are the same, as illustrated by the following example.

Example 9.15. Consider two hypotheses: H0 : Y ⇠ Gaussian(0, 2 ), and H1 : Y ⇠


Gaussian(µ, 2 ), with µ > 0. Construct the Neyman-Pearson decision rule (i.e., the
likelihood ratio test).

Solution. Let us first define the likelihood functions. It is clear from the description
that
⇢ ⇢
1 y2 1 (y µ)2
f0 (y) = p exp 2
and f 1 (y) = p exp .
2⇡ 2 2 2⇡ 2 2 2

Therefore, the likelihood ratio is



f1 (y) 1
L(y) = = exp 2
(µ2 2µy) .
f0 (y) 2

The likelihood ratio test states that the decision rule is


(
⇤ 1, L(y) ⌘,
(y) =
0, L(y) < ⌘.

So it remains to simplify the condition L(y) R ⌘. To this end, we observe that

1
L(y) ⌘ () 2
(µ2 2µy) log ⌘
2
2
µ
() y log ⌘ .
2 µ
| {z }
def
=⌧

586
9.4. NEYMAN-PEARSON TEST

Therefore, instead of determining ⌘, we just need to define ⌧ because the decision rules
based on ⌘ and ⌧ are equivalent.
To determine ⌧ , Neyman-Pearson states that pF ( )  ↵ (and at the optimal point
the equality has to hold). Substituting this criterion into the decision rule,
Z
↵ = pF ( ) = f0 (y) dy
L(y) ⌘
Z
= f0 (y) dy
y ⌧
Z
1 y2
= p e 2 2 dy
2⇡ 2
y ⌧
⇣⌧ ⌘
=1 .

Taking the inverse of the CDF, we obtain ⌧ :


1
⌧= (1 ↵).

Putting everything together, the final decision rule is


(
1
⇤ 1, y (1 ↵),
(y) = 1
0, y< (1 ↵).
p
So if ↵ = 0.05 we will reject H0 when y 1.65 . We can also replace by / N if
the estimator is constructed from multiple measurements.

The above example tells us that even though the likelihood ratio test may appear
complicated at first glance, the decision is the same as the good old hypothesis testing rules
we have derived. The flexibility we have gained with the likelihood ratio test is the variety
of distributions we can handle. Instead of restricting ourselves to Gaussians or Student’s
t-distribution (which exclusively focuses on the sample averages), the likelihood ratio test
allows us to consider any distributions. The exact decision rule could be less obvious, but
the method is generalizable to a broad range of problems.

Practice Exercise 9.5. In a telephone system, the waiting time is defined as the
inter-arrival time between two consecutive calls. However, it is known that sometimes
the waiting time can be mistakenly recorded as the time between three consecutive
calls (i.e., by skipping the second one). Since the interarrival time of an independent
Poisson process is either an exponential random variable or an Erlang random variable,
depending on how many occurrences we are counting, we define the hypotheses
( (
e y, y 0, ye y , y 0,
f0 (y) = and f1 (y) =
0, y < 0, 0, y < 0.

Suppose we are given one measurement Y = y. Find the Neyman-Pearson decision


rule for ↵ = 0.05.

587
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Solution. The likelihood ratio is


y
f1 (y) ye
L(y) = = y
= y, y 0.
f0 (y) e

Substituting this into the decision rule, we have


(
⇤ 1, L(y) ⌘ () y ⌘,
(y) =
0, L(y) < ⌘ () y < ⌘.

It remains to determine ⌘. Inspecting pF ( ), we have that


Z
↵ = pF ( ⇤ ) = f0 (y) dy
L(y) ⌘
Z
= e y dy = e ⌘ .
y ⌘


Setting e = ↵, we have that ↵ = log ↵. Hence, the decision rule is
(
⇤ 1, L(y) ⌘ () y log ↵,
(y) =
0, L(y) < ⌘ () y < log ↵.

For ↵ = 0.05, we reject the null hypothesis when y 2.9957. Figure 9.23 illustrates
the hypothesis testing rule.

Figure 9.23: Neyman-Pearson decision rule at ↵ = 0.05.


Remark. This example is instructive in that we have only one measurement Y = y.
If we have repeated measurements and take the average, then the Central Limit The-
orem will kick in. In that case, we can resort to our favorite Gaussian distribution
or Student’s t-distribution instead of dealing with the exponential and the Erlang
distributions. However, the example demonstrates the usefulness of Neyman-Pearson,
especially when the distributions are complicated.

588
9.5. ROC AND PRECISION-RECALL CURVE

9.5 ROC and Precision-Recall Curve

Being a binary decision rule, the hypothesis testing procedure shares many similarities with
a two-class classification algorithm.3 Given a testing statistic or a testing sample, both
the hypothesis testing and a classification algorithm will report YES or NO. Therefore,
any performance evaluation metric developed for hypothesis testing is equally applicable to
classification and vice versa.
The topic we study in this section is the receiver operating characteristic (ROC) curve
and the precision-recall (PR) curve. The ROC curve and the PR curve are arguably the
most popular metrics in modern machine learning, in particular for classification, detection,
and segmentation tasks in computer vision. There are many unresolved questions about
these two curves and there are many debates about how to use them. Our goal is not to add
another voice to the debate; rather, we would like to fill in the gap between the hypothesis
testing theory (particularly the Neyman-Pearson framework) and these two sets of curves.
We will establish the equivalence between the two curves and leave the open-ended debates
to you.

9.5.1 Receiver Operating Characteristic (ROC)


Our approach to understanding the ROC curve and the PR curve is based on the Neyman-
Pearson framework. Under this framework, we know that the optimal decision rule w.r.t to
the Neyman-Pearson criterion is the solution to the optimization

(↵) = argmax pD ( )

subject to pF ( )  ↵.

As a result of this optimization, the decision rule ⇤ will achieve a certain false alarm rate
pF ( ⇤ ) and detection rate pD ( ⇤ ). Clearly, the decision rule ⇤ changes as we change the
critical level ↵. Accordingly we write ⇤ as ⇤ (↵) to reflect this dependency.
What this observation implies is that as we sweep through the range of ↵’s, we construct
di↵erent decision rules, each one with a di↵erent pF and pD . If we denote the decision rules
by 1 , 2 , . . . , M , we have M pairs of false alarm rate pF and detection rate pD :
Decision rule 1: False alarm rate pF ( 1 ) and detection rate pD ( 1 ).
Decision rule 2: False alarm rate pF ( 2 ) and detection rate pD ( 2 ).
..
.
Decision rule M: False alarm rate pF ( M) and detection rate pD ( M ).
3 In a classification algorithm, the goal is to look at the testing sample y and compute certain thresholding
(
1, wT (y) ⌧
criteria. For example, a typical decision rule of a classification algorithm is (y) = . Here,
0, wT (y) < ⌧
you can think of the vector w as the regression coefficient, and (·) is some kind of feature transform. The
equation says that class 1 will be reported if the inner product is larger than a threshold ⌧ , and class 0
will be reported otherwise. Therefore, a binary classification, when written in this form, is the same as a
hypothesis testing procedure.

589
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

If we plot pD ( ) on the y-axis as a function of pF ( ) on the x-axis, we obtain a curve shown


in Figure 9.24 (see the example below for the problem setting). The black curve shown on
the right is known as the receiver operating characteristic (ROC) curve.

Figure 9.24: An example of an ROC curve, where we consider two hypotheses: H0 : Y ⇠ Gaussian(0, 2),
and H1 : Y ⇠ Gaussian(3, 2). We construct the Neyman-Pearson decision rule for a range of critical
levels ↵. For each ↵ we compute the theoretical pF (↵) and pD (↵), shown on the left-hand side of the
figure. The pair of (pD , pF ) is then plotted as the right-hand side curve by sweeping the ↵’s.

The setup of the figure follows the example below.

Example 9.16. We consider two hypotheses: H0 : Y ⇠ Gaussian(0, 2), and H1 : Y ⇠


Gaussian(3, 2). Derive the Neyman-Pearson decision rule and plot the ROC curve.

Solution. We construct a Neyman-Pearson decision rule:


(
1
⇤ 1, y (1 ↵),
(y) = 1
0, y< (1 ↵).

1
where ⌧ is a tunable threshold. For example, if ↵ = 0.05, then (1 0.05) = 3.2897,
1
and if ↵ = 0.1, then (1 0.1) = 2.5631. Therefore, the false alarm rate and the
detection rate are functions of the critical level ↵.
For this particular example, we have the false alarm rate and detection rate in
closed form, as functions of ↵:
Z 1
1 y2
pF (↵) = p e 2 2 dy
1 (1 ↵) 2⇡ 2
✓ 1

(1 ↵)
=1 = ↵,

590
9.5. ROC AND PRECISION-RECALL CURVE

Z 1
1 (y µ)2
pD (↵) = p e 2 2 dy
1 (1 2⇡ 2
↵)
⇣ µ⌘
1
=1 (1 ↵) .

These give us the two curves on the left-hand side of Figure 9.24.

What is an ROC curve?


It is a plot showing pD on the y-axis and pF on the x-axis.
pD = detection rate (also known as the power of the test).
pF = false alarm rate (also known as the type 1 error of the test).

The ROC curve tells us the behavior of the decision rule as we change the threshold ↵.
A graphical illustration is shown in Figure 9.25. There are a few key observations we need
to pay attention to:

Figure 9.25: Interpreting the ROC curve.

The ROC curve must go through (0, 0). This happens when you always keep the
null hypothesis or always declare class 0, no matter what observations. If you always
keep H0 , certainly you will not make any false positive (or false alarm), because you
will never say H0 is wrong. Therefore, the detection rate (or the power of the test) is
also 0. This is a useless decision rule for both classification and hypothesis testing.
The ROC curve must go through (1, 1). This happens when you always reject the null
hypothesis, no matter what observations we have. If you always reject H0 , you will
always say that “there is a target”. As far as detection is concerned, you are perfect

591
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

because you have not missed any targets. However, the false positive rate is also high
because you will falsely declare a target when there is nothing. Therefore, this is also
a useless decision rule.
The ROC curve tells us the operating point of the decision rule as we change the thresh-
old. A threshold is a universal concept for both hypothesis testing and classification.
In hypothesis testing, we have the critical level ↵, say 0.05 or 0.1. In classification, we
also have a threshold for judging whether a sample should be classified as class 1 or
class 0. Often in classification, the intermediate estimates are probabilities or distances
to decision boundaries. These real numbers need to be binarized to generate a binary
decision. The ROC curve tells us that if you pick a threshold, your decision rule will
have a certain pF and pD as predicted by the curve. If you want to tolerate a higher
pF , you can move along the curve to find your operating point.
The ideal operating point on a ROC curve is when pF = 0 and pD = 1. However, this
is a hypothetical situation that does not happen in any real decision rule.

9.5.2 Comparing ROC curves


Because of how the ROC curves are constructed, every binary decision rule has its own ROC
curve. Typically, when one tries to compare classification algorithms, the area under the
curve (AUC) occupied by the ROC curve is compared. A decision rule having a larger AUC
is often a “better” decision rule.
To illustrate the idea of comparing estimators, we consider a trivial decision rule based
on a blind guess.

Example 9.17. (A blind guess decision) Consider a decision rule that we reject H0
with probability ↵ and keep H0 with probability 1 ↵. We call this a blind guess, since
the decision rule ignores observation y. Mathematically, this trivial decision rule is
(
1, with probability ↵,
(y) =
0, with probability 1 ↵.

Find pF , pD , and AUC.

Solution. For this decision rule we compute its false positive rate (or false alarm rate)
and its true positive rate (or detection rate). However, since (y) is now random, we
need to take the expectation over the two random states that (y) can take. This gives
us
Z
pF (↵) = E (y)f0 (y) dy
Z Z
= 1 · f0 (y) dyP[ (y) = 1] + 0 · f0 (y) dyP[ (y) = 0]
Z
= ↵ f0 (y) dy = ↵.

592
9.5. ROC AND PRECISION-RECALL CURVE

Similarly, the detection rate is


Z Z
pD (↵) = E (y)f1 (y) dy = ↵ f1 (y) dy = ↵.

If we plot pD as a function of pF , we notice that the function is a straight line going


from (0, 0) to (1, 1). This decision rule is useless. Comparing this with the Neyman-
Pearson decision rule, it is clear that Neyman-Pearson has a larger AUC. The AUC
for this trivial decision rule is the area of the triangle, which is 0.5.

Figure 9.26: The ROC curve of the blind guess decision rule is a straight line. The AUC is 0.5.
If you set ↵ = 0.5, then the decision rule becomes
(
1, with probability 12 ,
(y) =
0, with probability 12 .

This is equivalent to flipping a fair coin with probability 1/2 of declaring H0 and 1/2
declaring H1 . Its operating point is the yellow circle.

Computing the AUC can be done by calling special library functions. However, to
spell out the details we demonstrate something more elementary. The program below is a
piece of MATLAB code plotting two ROC curves corresponding to two di↵erent decision
rules. The first decision rule is the trivial decision rule, where we have just shown that
pF (↵) = pD (↵) = ↵. The second decision rule is the Neyman-Pearson decision rule, for
which we showed in Figure 9.24 that pF (↵) = ↵ and pD (↵) = 1 1
(1 ↵) µ .
Using the MATLAB code below, we can plot the two ROC curves shown in Figure 9.26.
% MATLAB code to plot ROC curve
sigma = 2; mu = 3;
alphaset = linspace(0,1,1000);
PF1 = zeros(1,1000); PD1 = zeros(1,1000);
PF2 = zeros(1,1000); PD2 = zeros(1,1000);
for i=1:1000
alpha = alphaset(i);

593
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

PF1(i) = alpha;
PD1(i) = alpha;

PF2(i) = alpha;
PD2(i) = 1-normcdf(norminv(1-alpha)-mu/sigma);
end
figure;
plot(PF1, PD1,’LineWidth’, 4, ’Color’, [0.8, 0, 0]); hold on;
plot(PF2, PD2,’LineWidth’, 4, ’Color’, [0, 0, 0]); hold off;

To compute the AUC we perform a numerical integration:


Z X
AUC = pD (↵) · dpF (↵) ⇡ pD (↵i ) · pF (↵i )
i
X ⇥ ⇤
= pD (↵i ) · pF (↵i ) pF (↵i 1) ,
i

where ↵i is the ith critical level we use to plot the ROC curve. (We assume that the ↵’s are
sorted in ascending order.) In MATLAB, the commands are

auc1 = sum(PD1.*[0 diff(PF1)])


auc2 = sum(PD2.*[0 diff(PF2)])

The AUC of the two decision rules computed by MATLAB are 0.8561 and 0.5005, respec-
tively. The small slack of 0.0005 is caused by the numerical approximation at the tail, which
can be ignored as long as you are consistent for all the ROC curves.
The commands for Python are analogous to the commands for MATLAB.

# Python code to plot ROC curve


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats

sigma = 2; mu = 3;
alphaset = np.linspace(0,1,1000)
PF1 = np.zeros(1000); PD1 = np.zeros(1000)
PF2 = np.zeros(1000); PD2 = np.zeros(1000)
for i in range(1000):
alpha = alphaset[i]
PF1[i] = alpha
PD1[i] = alpha
PF2[i] = alpha
PD2[i] = 1-stats.norm.cdf(stats.norm.ppf(1-alpha)-mu/sigma)
plt.plot(PF1,PD1)
plt.plot(PF2,PD2)

To compute the AUC, the Python code is (continuing from the previous code):

594
9.5. ROC AND PRECISION-RECALL CURVE

auc1 = np.sum(PD1 * np.append(0, np.diff(PF1)))


auc2 = np.sum(PD2 * np.append(0, np.diff(PF2)))

It is possible to get a decision rule that is worse than a blind guess. The following
example illustrates a trivial setup.

Practice Exercise 9.6. (Flipped Neyman-Pearson). Consider two hypotheses


2
H0 = Gaussian(0, ),
2
H1 = Gaussian(µ, ), µ > 0.

Let ↵ be the critical level. The Neyman-Pearson decision rule is


(
1
⇤ 1, y (1 ↵),
(y) = 1
0, y< (1 ↵).

Now, consider a flipped Neyman-Pearson decision rule


(
1
+ 1, y< (1 ↵),
(y) = 1
0, y (1 ↵).

+
Find pF , pD , and AUC for the new decision rule .

Solution. Since we flip the rejection zone, the probability of false alarm is
Z
+
pF (↵) = (y)f0 (y) dy
Z 1
(1 ↵)
1 y2
= p e 2 2 dy
2⇡ 2
1
✓ 1

(1 ↵)
=

=1 ↵.

Similarly, the probability of detection is


Z
+
pD (↵) = (y)f1 (y) dy
Z 1
(1 ↵)
1 (y µ)2
= p e 2 2 dy
2⇡ 2
1
✓ 1

(1 ↵) µ
=
⇣ µ⌘
1
= (1 ↵) .

595
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

If you plot pD as a function of pF , you will obtain a curve shown in Figure 9.27.
The AUC for this flipped decision rule is 0.1439, whereas that for Neyman-Pearson is
0.8561. The two numbers are complements of each other, meaning that their sum is
unity.

Figure 9.27: The ROC curve of a flipped Neyman-Pearson decision rule.

What if we arbitrarily construct a decision rule that is neither Neyman-Pearson nor


the blind guess? The following example demonstrates one possible choice.

Practice Exercise 9.7. Consider two hypotheses


2
H0 = Gaussian(0, ),
2
H1 = Gaussian(µ, ), µ > 0.

Let ↵ be the critical level. Consider the following decision rule:


(
1
| 1, |y| (1 ↵),
(y) = 1
0, |y| < (1 ↵).

|
Find pF , pD , and AUC for the new decision rule .

Solution. The probability of false alarm is


Z
|
pF (↵) = (y)f0 (y) dy
Z 1
(1 ↵)
1 y2
=1 p e 2 2 dy
1 (1 2⇡ 2
↵)
1 1
=1 (1 ↵) + (1 ↵)
= 2↵.

596
9.5. ROC AND PRECISION-RECALL CURVE

Similarly, the probability of detection is


Z
|
pD (↵) = (y)f1 (y) dy
Z 1
(1 ↵)
1 (y µ)2
=1 p e 2 2 dy
1 (1 ↵) 2⇡ 2
✓ 1
◆ ✓ 1

(1 ↵) µ (1 ↵) µ
=1 +
⇣ µ⌘ ⇣ µ⌘
1 1
=1 (1 ↵) + (1 ↵) .

If you plot pD as a function of pF , you will obtain a curve shown in Figure 9.28.
The AUC for this proposed decision rule is 0.7534, whereas that of Neyman-Pearson
is 0.8561. Therefore, the Neyman-Pearson decision rule is better.

Figure 9.28: The ROC curve of a proposed decision rule.

The MATLAB code we used to generate Figure 9.28 is shown below. Note that we
need to separate the calculations of the two curves, because the proposed curve can only
take 0 < ↵ < 0.5. The Python code is implemented analogously.

% MATLAB code to generate the ROC curve.


sigma = 2; mu = 3;
PF1 = zeros(1,1000); PD1 = zeros(1,1000);
PF2 = zeros(1,1000); PD2 = zeros(1,1000);
alphaset = linspace(0,0.5,1000);
for i=1:1000
alpha = alphaset(i);
PF1(i) = 2*alpha;
PD1(i) = 1-(normcdf(norminv(1-alpha)-mu/sigma)-...
normcdf(-norminv(1-alpha)-mu/sigma));
end
alphaset = linspace(0,1,1000);

597
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

for i=1:1000
alpha = alphaset(i);
PF2(i) = alpha;
PD2(i) = 1-normcdf(norminv(1-alpha)-mu/sigma);
end
figure;
plot(PF1, PD1,’LineWidth’, 4, ’Color’, [0.8, 0, 0]); hold on;
plot(PF2, PD2,’LineWidth’, 4, ’Color’, [0, 0, 0]); hold off;

import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats

sigma = 2; mu = 3;
PF1 = np.zeros(1000); PD1 = np.zeros(1000)
PF2 = np.zeros(1000); PD2 = np.zeros(1000)

alphaset = np.linspace(0,0.5,1000)
for i in range(1000):
alpha = alphaset[i]
PF1[i] = 2*alpha
PD1[i] = 1-(stats.norm.cdf(stats.norm.ppf(1-alpha)-mu/sigma) \
-stats.norm.cdf(-stats.norm.ppf(1-alpha)-mu/sigma))

alphaset = np.linspace(0,1,1000)
for i in range(1000):
alpha = alphaset[i]
PF2[i] = alpha
PD2[i] = 1-stats.norm.cdf(stats.norm.ppf(1-alpha)-mu/sigma)

plt.plot(PF1, PD1)
plt.plot(PF2, PD2)

9.5.3 The ROC curve in practice


If the Neyman-Pearson decision rule is the optimal rule, why don’t we always use it? The
problem is that in practice we may not have access to the distributions. For example, if we
classify images, how do we know that the data follows a Gaussian distribution or a mixture
of distributions? Consequently, the ROC curves we discussed in the subsections above are
the theoretical ROC curves. In practice, we plot the empirical ROC curves.
Plotting an empirical ROC curve for a binary classification method (and hypothesis
testing) is intuitive. The ingredients we need are a set of scores and a set of labels.
The scores are the probability values determining the likelihood of a sample belonging to
one class. Generally speaking, for empirical data this requires looking at the training data,
building a model, and computing the likelihood. We will not go into the details of how a
binary classifier is built. Instead, we assume that you have already built a binary classifier
and have obtained the scores. Our goal is to show you how to plot the ROC curve.

598
9.5. ROC AND PRECISION-RECALL CURVE

The following MATLAB code uses a dataset fisheriris. The code builds a binary
classifier and returns the scores.
% MATLAB code to train a classification algorithm.
% Do not worry if you cannot understand this code.
% It is not the focus on this book.
load fisheriris
pred = meas(51:end,1:2);
resp = (1:100)’>50;
mdl = fitglm(pred,resp,’Distribution’,’binomial’,’Link’,’logit’);
scores = mdl.Fitted.Probability;
labels = [ones(1,50), zeros(1,50)];
save(’ch9_ROC_example_data’,’scores’,’labels’);

To give you an idea of how the scores of the classifier look, we plot the histogram of
the scores in Figure 9.29. As you can see, there is no clear division between the two classes.
No matter what threshold ⌧ we use, some cases will be misclassified.

Figure 9.29: The distribution of probability scores obtained from a binary classifier for the dataset
fisheriris. The green vertical lines represent the threshold for turning the scores into binary decisions.
Any score greater than ⌧ will be classified as Class 1, and any score that is less than ⌧ will be classified
as Class 0. These predicted labels would then be compared to the true labels to plot the ROC curve.

Recall that the ROC curve is a function of pD versus pF . Using terminology from
statistics, pD is the true positive rate and pF is the false positive rate. By sweeping a range
of decision thresholds (over the scores), we can compute the corresponding pF ’s and pD ’s.
On a computer this can be done by setting up two columns of labels: the true label labels
and the predicted labels prediction. For any threshold ⌧ , we binarize the scores to turn
them into a decision vector. Then we count the number of true positives, true negatives,
false positives, and false negatives. The total of these numbers will give us pF and pD .
In MATLAB, the above description can be easily implemented by sweeping through
the range of ⌧ .
% MATLAB code to generate an empirical ROC curve
load ch9_ROC_example_data

599
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

tau = linspace(0,1,1000);
for i=1:1000
idx = (scores <= tau(i));
predict = zeros(1,100);
predict(idx) = 1;
true_positive = 0; true_negative = 0;
false_positive = 0; false_negative = 0;
for j=1:100
if (predict(j)==1) && (labels(j)==1)
true_positive = true_positive + 1; end
if (predict(j)==1) && (labels(j)==0)
false_positive = false_positive + 1; end
if (predict(j)==0) && (labels(j)==1)
false_negative = false_negative + 1; end
if (predict(j)==0) && (labels(j)==0)
true_negative = true_negative + 1; end
end
PF(i) = false_positive/50;
PD(i) = true_positive/50;
end
plot(PF, PD, ’LineWidth’, 4, ’Color’, [0, 0, 0]);

The Python codes of this problem are similar. We give them here for completeness.

# Python code to generate an empirical ROC curve


import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats
scores = np.loadtxt(’ch9_ROC_example_data.txt’)
labels = np.append(np.ones(50), np.zeros(50))
tau = np.linspace(0,1,1000)
PF = np.zeros(1000)
PD = np.zeros(1000)
for i in range(1000):
idx = scores<= tau[i]
predict = np.zeros(100)
predict[idx] = 1
true_positive = 0; true_negative = 0
false_positive = 0; false_negative = 0
for j in range(100):
if (predict[j]==1) and (labels[j]==1): true_positive += 1
if (predict[j]==1) and (labels[j]==0): false_positive += 1
if (predict[j]==0) and (labels[j]==1): false_negative += 1
if (predict[j]==0) and (labels[j]==0): true_negative += 1
PF[i] = false_positive/50
PD[i] = true_positive/50
plt.plot(PF, PD)

600
9.5. ROC AND PRECISION-RECALL CURVE

The empirical ROC curve for this problem is shown in Figure 9.30. Each point on the
curve is a coordinate (pF , pD ), evaluated at a particular threshold ⌧ . Mathematically, the
decision rule we used was
(
1, score(y) ⌧,
(y) =
0, score(y) < ⌧.

For every ⌧ , we have a false alarm rate and a detection rate. Since this is an empirical
dataset with only 100 samples, there are many occasions where pF does not change but
pD increases, or pD stays constant but pF increases. For this particular example, we can
compute the AUC, which is 0.7948.

Figure 9.30: The empirical ROC curve for the dataset fisheriris, using a classifier based on the
logistic regression.
Note that the empirical ROC is rough. It does not have the smooth concave shape of
the theoretical ROC curve. One can prove that if the decision rule is Neyman-Pearson, i.e.,
if we conduct a likelihood ratio test, then the resulting ROC curve is concave. Otherwise,
you can still obtain an empirical ROC curve for real datasets and classifiers. However, the
shape is not necessarily concave.

9.5.4 The Precision-Recall (PR) curve


In modern data science, an alternative performance metric to the ROC curve is the precision-
recall (PR) curve. The precision and recall are defined as follows.

Definition 9.4. Let TP = true positive, FP = false positive, FN = false negative.


The precision is defined as
TP pD
precision = = , (9.40)
TP + FP p D + pF
and the recall is defined as
TP pD
recall = = = pD . (9.41)
TP + FN p D + pM

601
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

In this definition, TP, FP, and FN are the numbers of samples that are classified as true
positive, false positive, and false negative, respectively. However, both precision and recall are
defined as ratios of numbers. The ratios can be equivalently defined through the rates. Using
our terminology, this gives us the definitions in terms of pD , pF and pM . Since pD = 1 pM ,
it also holds that the recall is pD .
Let us take a moment to consider the meanings of precision and recall. Precision is
defined as
TP # true positives
precision = = . (9.42)
TP + FP total # positives you claim
The numerator of the precision is the number of true positive samples and the denominator
is the total number of positives that you claim. This includes the true positives and the
false positives. Therefore, precision measures how trustworthy your claim is. There are two
scenarios to consider:
High precision: This means that among all the positives you claim, many of them are
the true positives. Therefore, whatever you claim is trustworthy. One possibility for
obtaining a high precision is that the critical level ↵ of the Neyman-Pearson decision
rule approaches 1. In other words, you are very accepting of the null hypotheses. Thus,
whenever you reject, it will be a reliable reject.
Low precision: This means that you are overclaiming the positives, and so there are
many false positives. Thus, even though you claim many positives, not all are trust-
worthy. One reason why low precision occurs is that you are too eager to reject the
null. Thus you tend to overkill the unnecessary cases.
A similar analysis can be applied to the recall. The recall is defined as
TP # true positives
recall = = . (9.43)
TP + FN total # positives in the distribution
The di↵erence between the recall and the precision is the denominator. For recall, the
denominator is the total number of positives in the distribution. We are not interested
in knowing what you have claimed but in knowing how many of them are there in the
distribution. If you examine the definition using pD , you can see that recall is the probability
of detection — how successfully you can detect a target. A high recall and a low recall can
occur in two situations:
High recall: This means that you are very good at detecting the target or rejecting
the null appropriately. A high recall can happen when the critical level ↵ is low so that
you never miss a target. However, if the critical level ↵ is low, you will su↵er from a
low precision.
Low recall: This means that you are too accepting of the null hypotheses, and so you
never claim that there is a target. As a result the number of successful detections is
low. However, having a low recall can buy you high precision because you do not reject
the null unless it has extreme evidence (hence there is no false alarm.)
As you can see from the discussions above, the precision-recall has a trade-o↵, just as
the ROC curve does. Since the PR curve and ROC curve are derived from pF and pD , there
is a one-to-one correspondence. This can be proved by rearranging the terms in the previous
theorem.

602
9.5. ROC AND PRECISION-RECALL CURVE

Theorem 9.3. The false alarm rate pF and the detection rate pD can be expressed
in terms of the precision and recall as

recall(1 precision)
pF = , (9.44)
precision
pD = recall.

This result implies that whenever we have an ROC curve we can convert it to a PR curve.
Moreover, whenever we have a PR curve we can convert it to an ROC curve. Therefore,
there is no additional information one can squeeze out by converting the curves. What we
can claim, at most, is that the two curves o↵er di↵erent ways of interpreting the decision
rule.
To illustrate the equivalence between an ROC curve and a PR curve, we plot two
di↵erent decision rules in Figure 9.31. Any point on the ROC curve will have a corresponding
point on the PR curve, and vice versa.

Figure 9.31: There is a one-to-one correspondence between the ROC curve and the PR curve.

The MATLAB and Python codes for generating the PR curve are straightforward.
Assuming that we have run the code used to generate Figure 9.28, we plot the PR curve as
follows (this will give us Figure 9.31).

% MATLAB code to generate a PR curve


precision1 = PD1./(PD1+PF1);
precision2 = PD2./(PD2+PF2);
recall1 = PD1;
recall2 = PD2;
plot(recall1, precision1, ’LineWidth’, 4); hold on;
plot(recall2, precision2, ’LineWidth’, 4); hold off;

603
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Practice Exercise 9.8. Suppose that the decision rule is a blind guess:
(
1, with probability ↵,
(y) =
0, with probability 1 ↵,

Plot the ROC curve and the PR curve.

Solution: As we have shown earlier, pF (↵) and pD (↵) for this decision rule are pF (↵) =
↵ and pD (↵) = ↵. Therefore,
pD ↵ 1
precision = = = , and recall = pD = ↵.
pD + p F ↵+↵ 2
Thus the PR curve is a straight line with a level of 0.5.

Figure 9.32: The PR curve of a blind-guess decision rule is a straight line.

Practice Exercise 9.9. Convert the ROC curve in Figure 9.30 to a PR curve.

Solution: The conversion is done by first computing pF and pD . Defining the precision
and recall in terms of pF and pD , we plot the PR curves below.

Figure 9.33: The PR curve of a real dataset.

604
9.6. SUMMARY

As you can see from the figure, the PR curve behaves very di↵erently from the
ROC curve. It is sometimes argued that the two curves can be interpreted di↵erently,
even though they describe the same decision rule for the same dataset.

9.6 Summary

In this chapter, we have discussed five principles for quantifying the confidence of an esti-
mator and making statistical decisions. To summarize the chapter, we clarify a few common
misconceptions about these topics.
Confidence interval. Students frequently become confused about the meaning of a
confidence interval. It is not the interval that 95% of the samples will fall inside. It
is also not the interval within which the estimator has a 95% chance to show up.
A confidence interval is a random interval that has a 95% chance of including the
population parameter. A better way to think about a confidence interval is to think of
it as an alternative to a point estimate. A point estimate only gives a point, whereas
a confidence interval extends the point to an interval. All the randomness of the point
estimate is also there in the confidence interval. However, if the confidence interval is
narrow, there is a good chance for the point estimate to be accurate.
Bootstrapping. The most common misconception about bootstrapping is that it can
create something from nothing. Another misconception is that bootstrapping can make
your estimates better. Both beliefs are wrong. Bootstrapping is a technique for esti-
mating the estimator’s variance, and consequently it provides a confidence interval.
Bootstrapping does not improve the point estimate, no matter how many bootstrap-
ping samples you synthesize. Bootstrapping works because the sampling with the re-
placement step is equivalent to drawing samples from the empirical distribution. The
whole process relies on the proximity between the empirical distribution and the true
population. If you do not have enough samples and the empirical distribution does not
approximate the population, bootstrapping will not work. Therefore, bootstrapping
does not create something from nothing; it uses whatever you have and tells you how
reliable the estimate is.
Hypothesis testing. Students are often overwhelmed at first by the great number of
tests one can use for hypothesis testing, e.g., p-value, critical value, Z-test, T -test, 2
test, F -test, etc. Our advice is to forget about them and remember that hypothesis
testing is a court trial. Your job is to decide whether you have enough evidence to
declare that the defendant is guilty. To reach a guilty verdict, you need to make sure
that the test statistic is unlikely to happen. Therefore, the best practice is to draw
the distributions of the test statistic and ask yourself how likely is it that the test
statistic has such a value. When you draw the pictures of the distributions, you will
know whether you should use a Gaussian Z, a Student’s t, a 2 , a F -statistic, etc.
When you examine the likelihood of the test statistic, you will know whether you want
to use the p-value or the critical value. If you follow this principle, you will never be
confused by the oceans of tests you find in the textbooks.

605
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Neyman-Pearson. Beginners often find Neyman-Pearson abstract and do not under-


stand why it is useful. In this chapter, however, we have explained why we need to
understand Neyman-Pearson. It is a very general framework for many kinds of hy-
pothesis testing problems. All it says is that if we want to maximize the detection rate
while maintaining the false alarm rate, then the optimal testing procedure boils down
to the critical-value test and the p-value test. This gives us a certificate that our usual
hypothesis testing is optimal according to the Neyman-Pearson framework.
ROC and PR curves. On the internet nowadays there is a huge quantity of articles,
blogs, and tutorials about how to plot the ROC curve and the PR curve. Often these
curves are explained through programming examples such as Python, R, or MATLAB.
Our advice for studying the ROC curve and the PR curve is to go back to the Neyman-
Pearson framework. These two curves do not come out of the blue. The ROC curve is
the natural figure explaining the objective and the constraint in the Neyman-Pearson
framework. By changing the coordinates, we obtain the PR curve. Therefore, the two
curves are the same in terms of the amount of information, but they o↵er di↵erent
interpretations.

9.7 Reference

Confidence Interval
9-1 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 9.1.
9-2 Michael J Evans and Je↵rey S. Rosenthal, Probability and Statistics, W. H. Freeman,
2nd Edition, 2009. Chapter 6.3.
9-3 Robert V. Hogg, Joseph W. McKean, and Allen T. Craig, Introduction to Mathematical
Statistics, Pearson, 7th Edition, 2013. Chapter 4.2.
9-4 Larry Wasserman, All of Statistics, Springer 2003. Chapter 6.
9-5 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 8.4.

Bootstrapping
9-6 Trevor Hastie, Robert Tibshirani, and Jerome Friedman, Elements of Statistical Learn-
ing, Springer, 2nd Edition. Chapter 8.2.
9-7 Larry Wasserman, All of Statistics, Springer 2003. Chapter 8.
9-8 Michael J Evans and Je↵rey S. Rosenthal, Probability and Statistics, W. H. Freeman,
2nd Edition, 2009. Chapter 6.4.
9-9 Robert V. Hogg, Joseph W. McKean, and Allen T. Craig, Introduction to Mathematical
Statistics, Pearson, 7th Edition, 2013. Chapter 4.9.

606
9.8. PROBLEMS

Hypothesis Testing
9-10 Robert V. Hogg, Joseph W. McKean, and Allen T. Craig, Introduction to Mathematical
Statistics, Pearson, 7th Edition, 2013. Chapter 4.5.
9-11 Athanasios Papoulis and S. Unnikrishna Pillai, Probability, Random Variables and
Stochastic Processes, McGraw-Hill, 4th Edition, 2001. Chapter 8.
9-12 Alberto Leon-Garcia, Probability, Statistics, and Random Processes for Electrical En-
gineering, Prentice Hall, 3rd Edition, 2008. Chapter 8.5.
9-13 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008. Chapter 9.
9-14 Michael J Evans and Je↵rey S. Rosenthal, Probability and Statistics, W. H. Freeman,
2nd Edition, 2009. Chapter 6.3.
9-15 Larry Wasserman, All of Statistics, Springer 2003. Chapter 10.

9-16 Laura Simon, Introduction to Mathematical Statistics, Penn State University STAT
415 Textbook, Online materials. Accessed 12/2020. https://online.stat.psu.edu/
stat415/

Neyman-Pearson and ROC curves


9-17 Robert V. Hogg, Joseph W. McKean, and Allen T. Craig, Introduction to Mathematical
Statistics, Pearson, 7th Edition, 2013. Chapter 8.
9-18 H. Vincent Poor, An Introduction Signal Detection and Estimation, Springer, 1998.
9-19 Bernard C. Levy, Principles of Signal Detection and Parameter Estimation, Springer,
2008.
9-20 Steven M. Kay, Fundamentals of Statistical Signal Processing: Estimation Theory,
Prentice-Hall, 1993.
9-21 Steven M. Kay, Fundamentals of Statistical Signal Processing: Detection Theory, Prentice-
Hall, 1998.

9.8 Problems

Exercise 1.
Consider i.i.d. Gaussian random variables X1 , . . . , XN with an unknown mean ✓ and a known
variance 2 = 1. Suppose N = 30. Find the confidence level 1 ↵ for the confidence intervals
of the mean ⇥:b
b
(a) I = [⇥ 2.14
p b+
,⇥ 2.14
p ]
N N

b
(b) I = [⇥ 1.85
p b+
,⇥ 1.85
p ]
N N

607
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

Exercise 2.
Suppose that we have conducted an experiment with N = 100 samples. A 95% confidence
interval of the mean was 0.45  µ  0.82.
(a) Would a 99% confidence interval calculated from the sample data be wider or narrower?
(b) Is it correct to interpret the confidence interval as saying that there is a 95% chance
that µ is between 0.49 and 0.82? You may answer yes, no, or partially correct. Explain.
(c) Is it correct to say that if we conduct the experiment 1000 times, there will be 950
confidence intervals that will contain µ? You may answer yes, no, or partially correct.
Explain.

Exercise 3.
Suppose that we have conducted an experiment. We know that = 25. We obtained N = 20
b = 1014.
samples and found that the sample mean is ⇥
b
(a) Construct a 95% two-sided confidence interval of ⇥.
b
(b) Construct a 95% one-sided confidence interval (the lower tail) of ⇥.

Exercise 4.
Let X1 , . . . , XN be i.i.d. Gaussian with Xn ⇠ Gaussian(0, 1). Let Yn = eXn , and suppose
we have N = 100 samples. We want to compute a 95% confidence interval for skewness.
(a) Randomly subsample the dataset with B = 30 samples. Repeat the exercise 5 times.
Plot the resulting histograms using MATLAB or Python.
(b) Repeat (a) for M = 500 times and compute the 95% bootstrapped confidence interval
of the skewness.
(c) Try using a larger B = 70 and a smaller B = 10. Report the 95% bootstrapped
confidence interval of the skewness.

Exercise 5.
b = max{X1 , . . . , XN }.
Let X1 , . . . , XN be i.i.d. uniform with Xn ⇠ Uniform(0, ✓). Let ⇥
Generate a dataset of N = 50 with ✓ = 1.
b
(a) Find the distribution of the estimator ⇥.
b = ✓] = 1
(b) Show that P[⇥ (1 b = ✓] = 0.
(1/n))N . Thus, as N ! 1, we have P[⇥

(c) Use Python or MATLAB to generate the histogram of ⇥ b from bootstrapping. How
does the bootstrapped histogram look as N grows? Why?

Exercise 6.
Let X be a Gaussian random variable with unknown mean and unknown variance. It was
found that with N = 15,
N
X N
X
Xn = 250, Xn2 = 10000.
n=1 n=1

608
9.8. PROBLEMS

Find a 95% confidence interval of the mean of X.

Exercise 7.
b be the sample mean of a dataset containing N samples. It is known that the samples
Let ⇥
are drawn from Gaussian(✓, 32 ). Find N such that

b
P[⇥ b + 1] = 0.95.
1✓⇥

Exercise 8.
Which of the following statements are valid hypothesis testing problems?
(a) H0 : µ = 25 and H1 : µ 6= 25.
(b) H0 : > 10 and H1 : = 10.
(c) H0 : X = 50 and H1 : X 6= 50.

(d) H0 : p-value = 0.1, H1 : p-value = 0.5.

Exercise 9.
It is claimed that the mean is ✓ = 12 with a standard deviation 0.5. Consider H0 : ✓ = 12
and H1 : ✓ < 12. Ten samples are obtained, and it is found that ⇥ b = 13.5. With a 95%
confidence level, should we accept or reject the null hypothesis?

Exercise 10.
Consider a hypothesis testing problem: H0 : ✓ = 175 versus an alternative hypothesis H1 :
✓ > 175. Assume N = 10 and = 20.
b > 185.
(a) Find the type 1 error if the critical region is ⇥
(b) Find the type 2 error if the true mean is 195.

Exercise 11.
Consider H0 : ✓ = 30000 versus an alternative hypothesis H1 : ✓ > 30000. Suppose N = 16,
and let = 1500.
(a) If we want ↵ = 0.01, what is z↵ ?
(b) What is the type 2 error when ✓ = 31000?

Exercise 12.
2
Let Wn ⇠ Gaussian(0, ), and consider two hypotheses:

H0 : Xn = ✓0 + Wn , n = 1, . . . , N,
H1 : Xn = ✓1 + Wn , n = 1, . . . , N.
PN
Let X = (1/N ) n=1 Xn .

609
CHAPTER 9. CONFIDENCE AND HYPOTHESIS

(a) Show that the likelihood of observing X1 , . . . , XN given H0 is


( N
)
1 1 X 2
fX (x|H0 ) = exp (Xn ✓0 ) .
(2⇡ 2 )N/2 2 2 n=1

(b) Find the likelihood fX (x|H1 ) of observing X1 , . . . , XN given H1 .


(c) The likelihood ratio test states that

fX (x|H1 ) H1
? ⌧.
fX (x|H0 ) H0

Show that the likelihood ratio test is given by


2
✓0 + ✓1 log ⌧
X ?H
H0
1
+ .
2 N (✓1 ✓0 )

610
Chapter 10

Random Processes

In modern data science, many problems involve time. The stock market changes every
minute; a speech signal changes every millisecond; a car changes its steering angle constantly;
the examples are endless. A common theme among all these examples is randomness. We
do not know whether a stock will go up or down tomorrow, although we may be able to
make some predictions based on previous observations. We do not know the next word of a
sentence, but we can guess based on the context. Random processes are tools that can be
applied to these situations. We treat a random process as an infinitely long vector of random
variables where the correlations between the individual variables define the statistical prop-
erties of the process. If we can determine these correlations, we will be able to summarize
the past and predict the future.
The objective of this chapter is to introduce the basic concepts of random processes.
Given the breadth of the subject, we can only cover the most elementary results, but they
are sufficient for many engineering and data science problems. However, there are complex
situations for which these elementary results will be insufficient. The references at the end
of this chapter contain more in-depth discussions of random processes.

Plan of this chapter


We begin by outlining the definition of random processes and ways to characterize their
randomness in Section 10.1. In Section 10.2 we discuss the mean function, the autocorrelation
function, and the autocovariance function of a random process. In Section 10.3 we look at
a special subclass of random processes known as the wide-sense stationary processes. Wide-
sense stationary processes allow us to use tools in the Fourier domain to make statistical
statements. Based on wide-sense stationary processes, we discuss power spectral density in
Section 10.4. With this concept, we can ask what will happen to the random process when we
pass it through a linear transformation. In Section 10.5 we discuss such interactions between
the random process and a linear time-invariant system. Finally, we discuss a practical usage
of random processes in the subject of optimal linear filters in Section 10.6.

611
CHAPTER 10. RANDOM PROCESSES

10.1 Basic Concepts

10.1.1 Everything you need to know about a random process


Here is the single most important thing you need to remember about random processes:

What is a random process?


A random process is a function indexed by a random key.

That’s it. Now you may be wondering what exactly a “function indexed by a random key”
means. To help you see the picture, we consider two examples.

Example 10.1. We consider a set of straight lines. We define two random variables a
and b that are uniformly distributed in a certain range. We then define a function:

f (t) = at + b, 2  t  2. (10.1)

Clearly, f (t) is a function of time t. But since a and b are random, f (t) is also random.
The randomness is caused by a and b. To emphasize this dependency, we write f (t) as

f (t, ⇠) = a(⇠)t + b(⇠), 2  t  2,

where ⇠ 2 ⌦ denotes the random index of the constants (a, b) and ⌦ is the sample
space of ⇠. Therefore, by picking a di↵erent pair of constants (a(⇠), b(⇠)), we will have
a di↵erent function f (t, ⇠), which in our case is a straight line of di↵erent slope and
y-intercept.
1

0.5
f(t)

-0.5

-1
-2 -1 0 1 2
t

Figure 10.1: The set of straight lines f (x) = ax + b where a, b 2 R.


As a special case of the example, suppose that the sample space contains only
two pairs of constants: (a, b) = (1.2, 0.6) and (a, b) = ( 0.75, 1.8). The probability of

612
10.1. BASIC CONCEPTS

getting either pair is 12 . Then the function f (t, ⇠) will take two forms:
(
1.2t + 0.6, with probability 12 ,
f (t, ⇠) =
0.75t + 1.8, with probability 12 .

Every time you pick a sample you pick one of the two functions, either f (t, ⇠1 ) or
f (t, ⇠2 ). So we say that f (t, ⇠) is a random process because it is a function f (t) indexed
by a random key ⇠.

Example 10.2. This example studies the function

f (t) = cos(!0 t + ⇥), 1  t  1,

where ⇥ is a random phase distributed uniformly over the range [0, 2⇡]. Depending on
the randomness of ⇥, the function f (t) will take a di↵erent phase o↵set. To emphasize
this dependency, we write

f (t, ⇠) = cos(!0 t + ⇥(⇠)), 1  t  1. (10.2)


2

1
f(t)

-1

-2
-1 -0.5 0 0.5 1
t
Figure 10.2: The set of phase-shifted cosines f (t) = cos(!0 t + ✓) where ✓ 2 [0, 2⇡].
Again, ⇠ denotes the index of the random variable ⇥. Since ⇥ is drawn uniformly
from the interval [0, 2⇡], the following functions are two possible realizations:
✓ ◆
3⇡
f (t, ⇠1 ) = cos !0 t + , 1  t  1,
4
✓ ◆
7⇡
f (t, ⇠2 ) = cos !0 t , 1  t  1.
3

Just as with the previous example, f (t) is a function indexed by a random key ⇠.

These two examples should give you a feeling for what to expect from a random process.
A random process is quite similar to a random variable because they are both contained
in a certain sample space. For (discrete) random variables, the sample space is a collection
of outcomes {⇠1 , ⇠2 , . . . , ⇠N }. The random variable X : F ! R is a mapping that maps
⇠n to X(⇠n ), where X(⇠n ) is a number. For random processes, the sample space is also

613
CHAPTER 10. RANDOM PROCESSES

{⇠1 , ⇠2 , . . . , ⇠N }. However, the mapping X does not map ⇠n to a number X(⇠n ) but to a
function X(t, ⇠n ). A function has the time index t, which is absent in the number. Therefore,
for the same ⇠n , X(t1 , ⇠n ) can take one value and X(t2 , ⇠n ) can take another value.

Figure 10.3: The sample space of a random process X(t, ⇠) contains many functions. Therefore, each
random realization is a function.

Figure 10.3 shows the sample space of a random process. Each outcome in the sample
space is a function. The probability of getting a function is specified by the probability
mass or the probability density of the associated random key ⇠. If you put your hand into
the sample space, the sample you pick will be a function that will change with time and is
indexed by the random key. From our discussions of joint random variables in Chapter 5,
you can think of the function as a vector. When you pull a sample from the sample space,
you pull the entire vector and not just an element.

10.1.2 Statistical and temporal perspectives


Since a random process is a function indexed by a random key, it is a two-dimensional object.
It is a function both of time t and of the random key ⇠. That’s why we use the notation
X(t, ⇠) to denote a random process. These two axes play di↵erent roles, as illustrated in
Figure 10.4.
Temporal perspective: Let us fix the random key at ⇠ = ⇠0 . This gives us a function
X(t, ⇠0 ). Since ⇠ is already fixed at ⇠0 , we are looking at a particular realization drawn
from the sample space. This realization is expressed as a function X(t, ⇠0 ), which is just
a deterministic function that evolves over time. There is no randomness associated with
it. This is analogous to a random variable. While X itself is a random variable, by fixing
the random key ⇠ = ⇠0 , X(⇠0 ) is just a real number. For random processes, X(t, ⇠0 ) now
becomes a function.
Since X(t, ⇠0 ) is a function that evolves over time, we view it along the horizontal axis.
For example, we can study the sequence
X(t1 , ⇠0 ), X(t2 , ⇠0 ), . . . , X(tK , ⇠0 ),
where t1 , . . . , tK are the time indices of the function. This sequence is deterministic and is
just a sequence of numbers, although the numbers evolve as t changes.

Statistical perspective: The other perspective, which could be slightly more abstract,
is the statistical perspective. Let us fix the time at t = t0 . The random key ⇠ can take any

614
10.1. BASIC CONCEPTS

(a) Temporal perspective (b) Statistical perspective

Figure 10.4: Temporal and statistical perspectives of a random process. For the temporal perspective
(which we call the horizontal perspective), we fix the random key ⇠ and look at the function in time.
For the statistical perspective (which we call the vertical perspective), we fix the time and look at the
function at di↵erent random keys.

state defined in the sample space. So if the sample space contains {⇠1 , . . . , ⇠N }, the sequence
{X(t0 , ⇠1 ), . . . , X(t0 , ⇠N )} is a sequence of random variables, because the ⇠’s can go from
one state to another state.
A good way to visualize the statistical perspective is the vertical perspective in which
we write the sequence as a vertical column of random variables:
X(t0 , ⇠1 )
X(t0 , ⇠2 )
..
.
X(t0 , ⇠N )

That is, if you fix the time at t = t0 , you are getting a sequence of random variables. The
probability of getting a particular value X(t0 ) depends on which random state you land on.

Why do we bother to di↵erentiate the temporal perspective and the statistical per-
spective? The reason is that the operations associated with the two are di↵erent, even if
sometimes they give you the same result. For example, if we take the temporal average of
the random process, we get a number:
Z
1 T
X(⇠) = X(t, ⇠) dt. (10.3)
T 0
We call this the “temporal average” because we have integrated the function over time. The
resulting value will not change with time. However, X(⇠) depends on the random key you
provide. If you pick a di↵erent random realization, X(⇠) will take a di↵erent value. So the
temporal average is a random variable.
On the other hand, if we take the statistical average of the random process, we get
Z
E[X(t)] = X(t, ⇠) p(⇠) d⇠, (10.4)

615
CHAPTER 10. RANDOM PROCESSES

where p(⇠) is the PDF of the random key ⇠. We call this the statistical average because we
have taken the expectation over all possible random keys. The resulting object E[X(t)] is
deterministic but a function of time.
No matter how you look at the temporal average or the statistical average, they are
di↵erent with the following exception: that X(⇠) = const and E[X(t)] = const, for example,
X(⇠) = E[X(t)] = 0. This happens only for some special (and useful) random processes
known as ergodic processes that allow us to approximate the statistical average using the
temporal average, with some guarantees derived from the law of large numbers. We will
return to this point later.

Example 10.3. Let A ⇠Uniform[0, 1]. Define X(t, ⇠) = A(⇠) cos(2⇡t).


In this example, the magnitude A(⇠) is a random variable depending on the
random key ⇠. For example if we draw ⇠1 , perhaps we will get a value A(⇠1 ) = 0.5.
Then X(t, ⇠1 ) = 0.5 cos(2⇡t). To take another example, if we draw ⇠2 , we may get
A(⇠2 ) = 1. Then X(t, ⇠2 ) = 1 cos(2⇡t). Figure 10.5 shows a few random realizations
of the cosines. We can look at X(t, ⇠) from the statistical and the temporal views.
1
X 1 (t)
X 2 (t)
0.5 X 3 (t)
X 4 (t)
X 5 (t)
0

-0.5

-1
-2 -1 0 1 2

Figure 10.5: Five di↵erent realizations of the random process X(t) = A cos(2⇡t).
Statistical View: Fix t (for example t = 10). In this case, we have

X(t, ⇠) = A(⇠) cos(2⇡(10)) = A(⇠) cos(20⇡),

which is a random variable because cos(20⇡) is a constant. The randomness of


X comes from the fact that A(⇠) ⇠ Uniform[0, 1].
Temporal View: Fix ⇠ (for example A(⇠) = 0.7). In this case, we have

X(t, ⇠) = 0.7 cos(2⇡t),

which is a deterministic function of t.

Example 10.4. Let A be a discrete random variable with a PMF


1 1
P(A = +1) = and P(A = 1) = .
2 2

616
10.1. BASIC CONCEPTS

We define the function X[n, ⇠] = A(⇠)( 1)n . In this example, A can only take two
states. If A = +1, then X[n, ⇠] = ( 1)n . If A = 1, then X[n, ⇠] = ( 1)n+1 .
1.5 1.5
X 1 (n) X 2 (n)
1 1

0.5 0.5

0 0

-0.5 -0.5

-1 -1

-1.5 -1.5
0 1 2 3 4 5 0 1 2 3 4 5

Figure 10.6: Realizations of the random process X[n] = A( 1)n .


The graphical illustration of this example is shown in Figure 10.6. Again, we can
look at X[n, ⇠] from two views.

Statistical View: Fix n, say n = 10. Then,


(
( 1)10 = 1, with prob 1/2,
X(⇠) =
( 1)11 = 1, with prob 1/2,

which is a Bernoulli random variable.


Temporal View: Fix ⇠. Then,
(
( 1)n , if A = +1,
X[n] =
( 1)n+1 , if A = 1,

which is a time series.


In this example, we see that the sample space of X(n, ⇠) consists of only two functions
with probabilities
1
P(X[n] = ( 1)n ) = ,
2
1
P(X[n] = ( 1)n+1 ) = ,
2
Therefore, if there is a sequence outside the sample space, e.g.,
⇥ ⇤
P X[n] = 1 1 1 1 1 1 ··· =0

then the probability of obtaining that sequence is 0.

What do we mean by statistical average and temporal average?


Statistical average: Take the expectation of X(t, ⇠) over ⇠. This is the vertical

617
CHAPTER 10. RANDOM PROCESSES

average.
Temporal average: Take the expectation of X(t, ⇠) over t. This is the horizontal
average.
In general, statistical average 6= temporal average.

10.2 Mean and Correlation Functions

Given a random variable, we often want to know the expectation and variance, and often
we also want to know the expectation and variance for the random processes. Nevertheless,
we need to consider the time axis. In this section, we discuss the mean function and the
autocorrelation function.

10.2.1 Mean function

Definition 10.1. The mean function µX (t) of a random process X(t) is

µX (t) = E [X(t)] . (10.5)

Let’s consider the “expectation” of X(t). Recall that a random process is actually X(t, ⇠)
where ⇠ is the random key. Therefore, the expectation is taken with respect to ⇠, or to state
it more explicitly, Z
µX (t) = E[X(t)] = X(t, ⇠) p(⇠) d⇠,

where p(⇠) is the PDF of the random key. This is an abstract definition, but it is not difficult
to understand if you follow the example below.

Example 10.5. Let A ⇠Uniform[0, 1], and let X(t) = A cos(2⇡t). Find µX (t).

Solution. The solution to this problem is actually very simple:

µX (t) = E[X(t)] = E[A cos(2⇡t)]


1
= cos(2⇡t)E[A] = cos(2⇡t).
2
1
So the answer is µX (t) = 2 cos(2⇡t).

We can link the equations to the definition more explicitly. To do so, we rewrite
X(t) as
X(t, ⇠) = A(⇠) cos(2⇡t).

618
10.2. MEAN AND CORRELATION FUNCTIONS

Then we take the expectation over A:


Z Z 1
µX (t) = X(t, a) pA (a) da = a cos(2⇡t) · 1 da
⌦ 0
 1
a2 1
= cos(2⇡t) = cos(2⇡t).
2 0 2

0.5

-0.5

-1

-2 -1.5 -1 -0.5 0 0.5 1 1.5 2

Figure 10.7: The mean function of X(t) = A cos(2⇡t).

An illustration is provided in Figure 10.7, in which we observe many random


realizations of the random process X(t, ⇠). On top of these, we also see the mean
function. The way to visualize the mean function is to use the statistical perspective.
That is, fix a time t and look at all the possible values that the function can take. For
example, if we fix t = t0 , then we will have a set of realizations of one random variable:

0.71 cos(2⇡t0 ), 0.58 cos(2⇡t0 ), . . . , 0.93 cos(2⇡t0 ) ! take expectation

Therefore, when we take the expectation, it is that of the underlying random variable.
If we move to another timestamp t = t1 , we will have a di↵erent expectation because
cos(2⇡t0 ) now becomes cos(2⇡t1 ).

The MATLAB/Python codes used to generate Figure 10.7 are shown below. You can
also replace the line 0.5*cos(2*pi*t) by the mean function mean(X) (in MATLAB).

% MATLAB code for Example 10.5


x = zeros(1000,20);
t = linspace(-2,2,1000);
for i=1:20
X(:,i) = rand(1)*cos(2*pi*t);
end
plot(t, X, ’LineWidth’, 2, ’Color’, [0.8 0.8 0.8]); hold on;
plot(t, 0.5*cos(2*pi*t), ’LineWidth’, 4, ’Color’, [0.6 0 0]);

# Python code for Example 10.5


x = np.zeros((1000,20))

619
CHAPTER 10. RANDOM PROCESSES

t = np.linspace(-2,2,1000)
for i in range(20):
x[:,i] = np.random.rand(1)*np.cos(2*np.pi*t)
plt.plot(t,x,color=’gray’)
plt.plot(t,0.5*np.cos(2*np.pi*t),color=’red’)
plt.show()

Example 10.6. Let ⇥ ⇠Uniform[ ⇡, ⇡], and let X(t) = cos(!t + ⇥). Find µX (t).

Solution.
Z ⇡
1
µX (t) = E [cos(!t + ⇥)] = cos(!t + ✓) · d✓ = 0.
⇡ 2⇡

Again, as in the previous example, we can try to map this simple calculation with the
definition. Write X(t) as
X(t, ⇠) = cos(!t + ⇥(⇠)).
Then the expectation is
Z
µX (t) = cos(!t + ✓)p⇥ (✓) d✓
Z⌦⇡
1
= cos(!t + ✓) · d✓ = 0.
⇡ 2⇡

0.5

-0.5

-1

-2 -1.5 -1 -0.5 0 0.5 1 1.5 2

Figure 10.8: The mean function of X(t) = cos(!t + ⇥).


Figure 10.8 illustrates the random realizations for X(t) = cos(!t + ⇥) and the
mean function. The zero mean should not be a surprise because if we take the statistical
average (the vertical average) across all the possible values at any time instant, the
positive and negative values of the realizations will make the mean zero.
We should emphasize that the statistical average is not the same as the temporal
average, even if they give you the same value. Why do we say that? If we calculate
the temporal average of the function cos(!t + ✓0 ) for a specific value ⇥ = ✓0 , then we

620
10.2. MEAN AND CORRELATION FUNCTIONS

have Z T
1
X= cos(!t + ✓0 ) dt = 0,
T 0
assuming that T is a multiple of the cosine period. This implies that the temporal
average is zero, which is the same as the statistical average. This gives us an example
in which the statistical average and the temporal average have the same value, although
we know they are two completely di↵erent things.

The MATLAB/Python codes used to generate Figure 10.8 are shown below.

% MATLAB code for Example 10.6


x = zeros(1000,20);
t = linspace(-2,2,1000);
for i=1:20
X(:,i) = cos(2*pi*t+2*pi*rand(1));
end
plot(t, X, ’LineWidth’, 2, ’Color’, [0.8 0.8 0.8]); hold on;
plot(t, 0*cos(2*pi*t), ’LineWidth’, 4, ’Color’, [0.6 0 0]);

# Python code for Example 10.6


x = np.zeros((1000,20))
t = np.linspace(-2,2,1000)
for i in range(20):
Theta = 2*np.pi*(np.random.rand(1))
x[:,i] = np.cos(2*np.pi*t+Theta)
plt.plot(t,x,color=’gray’)
plt.plot(t,np.zeros((1000,1)),color=’red’)
plt.show()

Example 10.7. Let us consider a discrete-time random process. Let X[n] = S n , where
S ⇠Uniform[0, 1]. Find µX [n].
Z 1
1
µX [n] = E[sn ] = sn ds = .
0 n+1

In this example the randomness goes with the constant s. Thus, if we write X[n] as

X[n, ⇠] = [S(⇠)]n ,

the expectation is
Z Z 1
1
E[X[n]] = sn pS (s) ds = sn · 1 ds = .
⌦ 0 n+1

The graphical illustration is provided in Figure 10.9.

621
CHAPTER 10. RANDOM PROCESSES

1.2

0.8

0.6

0.4

0.2

-0.2
0 5 10 15 20

Figure 10.9: The mean function of X[n] = S n , where S ⇠ Uniform[0, 1].

The MATLAB code used to generate Figure 10.9 is shown below. We skip the Python
implementation because it is straightforward.

% MATLAB code for Example 10.7


t = 0:20;
for i=1:20
X(:,i) = rand(1).^t;
end
stem(t, X, ’LineWidth’, 2, ’Color’, [0.8 0.8 0.8]); hold on;
stem(t, 1./(t+1), ’LineWidth’, 2, ’MarkerSize’, 8);

10.2.2 Autocorrelation function


In random processes, the notions of “variance” and “covariance” are trickier than for random
variables. Let us first define the concept of an autocorrelation function.

Definition 10.2. The autocorrelation function of a random process X(t) is

RX (t1 , t2 ) = E [X(t1 )X(t2 )] . (10.6)

RX (t1 , t2 ) is not difficult to calculate — just integrate X(t1 )X(t2 ) using the appropriate
PDFs.

Example 10.8. Let A ⇠Uniform[0, 1], X(t) = A cos(2⇡t). Find RX (t1 , t2 ).

Solution.

RX (t1 , t2 ) = E [A cos(2⇡t1 )A cos(2⇡t2 )]


1
= E[A2 ] cos(2⇡t1 ) cos(2⇡t2 ) = cos(2⇡t1 ) cos(2⇡t2 ).
3

622
10.2. MEAN AND CORRELATION FUNCTIONS

Example 10.9. Let ⇥ ⇠Uniform[ ⇡, ⇡], X(t) = cos(!t + ⇥). Find RX (t1 , t2 ).

Solution.

RX (t1 , t2 ) = E [cos(!t1 + ⇥) cos(!t2 + ⇥)]


Z ⇡
1
= cos(!t1 + ✓) cos(!t2 + ✓) d✓
2⇡ ⇡
Z ⇡ 
(a) 1 1
= cos(!(t1 + t2 ) + 2✓) + cos(!(t1 t2 )) d✓
2⇡ ⇡ 2
1 ⇣ ⌘
= cos !(t1 t2 ) ,
2
where in (a) we applied the trigonometric formula:
1
cos A cos B = [cos(A + B) + cos(A B)],
2

As you can see, the calculations are not difficult. The tricky thing is the interpretation
of RX (t1 , t2 ).

How do we understand the meaning of E[X(t1 )X(t2 )]?


E [X(t1 )X(t2 )] is analogous to the correlation E[XY ] between two random variables
X and Y .

The autocorrelation function E [X(t1 )X(t2 )] is analogous to the correlation E[XY ] in rela-
tion to a pair of random variables. In our discussions of E[XY ], we mentioned that E[XY ]
could be regarded as the inner product of two vectors, and so it is a measure of the closeness
between X and Y . Now, if we substitute X and Y with X(t1 ) and X(t2 ) respectively, then
we are e↵ectively asking about the closeness between X(t1 ) and X(t2 ). So, in a nutshell, the
autocorrelation function tells us the correlation between the function at two di↵erent time
stamps.
What do we mean by the correlation between two timestamps? Remember that X(t1 )
and X(t2 ) are two random variables. Consider the following example.

Example 10.10. Let X(t) = A cos(2⇡t), where A ⇠ Uniform[0, 1]. Find E[X(0)X(0.5)].

Solution. If X(t) = A cos(2⇡t), then

X(0) = A cos(0) = A,
X(0.5) = A cos(⇡) = A.

When you have two random variables, you consider their correlations. Using this ex-

623
CHAPTER 10. RANDOM PROCESSES

ample, we have that

E[X(0)X(0.5)] = E[A · A]
1
= E[A2 ] = .
3

A picture will reveal what is happening. Figure 10.10 presents the realizations of the
random process X(t) = A cos(2⇡t). If we consider X(0) and X(0.5), each of them is a
random variable, and thus we can ask about their PDFs. It is obvious from the illustration
that the random variable X(0) has a PDF that is a uniform distribution from 0 to 1,
whereas the random variable X(0.5) has a PDF that is a uniform distribution from 1 to 0.
Mathematically, the PDFs are
( (
1, 0  x  1, 1, 1  x  0,
fX(0) (x) = and fX(0.5) (x) =
0, otherwise 0, otherwise.

Since X(0) and X(0.5) have their own PDFs, we can calculate their correlation. This will
give us E[X(0)X(0.5)] which after some calculations is E[X(0)X(0.5)] = 13 .

0.5

-0.5

-1

-2 -1.5 -1 -0.5 0 0.5 1 1.5 2

Figure 10.10: The autocorrelation between X(0) and X(0.5) should be regarded as the correlation
between two random variables. Each random variable has its own PDF.

We can now consider the autocorrelation for any t1 and t2 . When you are evaluating
the autocorrelation function, you are not just evaluating at t = 0 and t = 0.5, you are
also evaluating the correlation for all pairs of t1 and t2 . Now you want to know what the
correlation is between t = 0 and t = 0.5, t = 2 and t = 3.1, etc. Of course, there are
infinitely many pairs of time instants. The point of the autocorrelation function is to tell
you the correlation of all the pairs. In other words, if we tell you RX (t1 , t2 ), you will be able
to plug in a value of t1 and a value of t2 and tell us the correlation at (t1 , t2 ). How is this
possible? To find out, let’s consider the following example.

Example 10.11. Let A ⇠Uniform[0, 1], X(t) = A cos(2⇡t). Find RX (0, 0.5), and draw
RX (t1 , t2 ).

624
10.2. MEAN AND CORRELATION FUNCTIONS

Solution. From the previous example, we know that


1
RX (t1 , t2 ) = cos(2⇡t1 ) cos(2⇡t2 ).
3
Therefore, RX (0, 0.5) = 13 cos(2⇡0) cos(2⇡0.5) = 13 , which is the same as if we had
computed it from the first principle.
The autocorrelation function tells you how one point of a time series is correlated
with another point of the time series. If RX (t1 , t2 ) gives a high value, then it means the
random variables at t1 and t2 have a strong correlation. To understand this, suppose
we let t1 = 0, and let us vary t2 . Then
1 1
RX (0, t2 ) = cos(2⇡0) cos(2⇡t2 ) = cos(2⇡t2 ).
3 3
This is a periodic function that cycles through itself whenever t2 is an integer. As
we recall from Figure 10.10, if t2 = 0.5, the random variable X(t2 ) will take only
the negative values, but otherwise it is correlated with X(0). On the other hand, if
t2 = 0.25, then Figure 10.10 says that the random variable X(t2 ) is a constant 0, and
so the correlation with X(0) is zero.
Clearly, RX (t1 , t2 ) is a 2-dimensional function of t1 and t2 . You need to tell RX
which of the two time instants you want to compare, and then RX will tell you the
correlation. So no matter what happens, you must specify two time instants. Because
RX (t1 , t2 ) is a 2-dimensional function, we can visualize it by calculating all the possible
values it takes. For example, if RX (t1 , t2 ) = 13 cos(2⇡t1 ) cos(2⇡t2 ), we can plot RX as
a function of t1 and t2 . Figure 10.11 shows the plot.
-1

1
-0.75

-0.5
0.5
-0.25
t2

0
0
0.25

-0.5 0.5

0.75

-1
1
-1 -0.75 -0.5 -0.25 0 0.25 0.5 0.75 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2 t1

1
Figure 10.11: The autocorrelation function RX (t1 , t2 ) = 3
cos(2⇡t1 ) cos(2⇡t2 ).

The MATLAB/Python code for Figure 10.11 is shown below.


% MATLAB code for Example 10.11
t = linspace(-1,1,1000);
R = (1/3)*cos(2*pi*t(:)).*cos(2*pi*t);
imagesc(t,t,R);

# Python code for Example 10.11


import numpy as np

625
CHAPTER 10. RANDOM PROCESSES

import matplotlib.pyplot as plt


t = np.linspace(-1,1,1000)
R = (1/3)*np.outer(np.cos(2*np.pi*t), np.cos(2*np.pi*t))
plt.imshow(R, extent=[-1, 1, -1, 1])
plt.show()

To understand the 2D function shown on the right hand side of Figure 10.11, we can
take a closer look by drawing Figure 10.12. For any two time instants t1 and t2 , we have
two random variables X(t1 ) and X(t2 ). The joint expectation E[X(t1 )X(t2 )] will return us
some value, and this is a point in the 2D plot RX (t1 , t2 ). The value tells us the correlation
between X(t1 ) and X(t2 ). In the example in which t1 = 0 and t2 = 0.5, the correlation is
1
3 . Interestingly, if we pick another pair of time instants t1 = 0.5 and t2 = 0, the joint
expectation is E[X( 0.5)X(0)] = 13 , which is the same value. However, this 13 is located
at a di↵erent valley than E[X(0)X(0.5)] in the 2D plot.

Figure 10.12: To understand the autocorrelation function, pick two time instants t1 and t2 , and then
evaluate the joint expectation E[X(t1 )X(t2 )].

The above example shows a periodic autocorrelation function. The fact that it is peri-
odic is coincidental because the random process X(t) is a periodic function. In general, an
arbitrary random process can have an arbitrary autocorrelation function that is not periodic.
There are, of course, various properties of the autocorrelation functions and special types
of autocorrelation functions. We will study one of them, called the wide-sense stationary
processes, later.

Example 10.12. Let ⇥ ⇠Uniform[ ⇡, ⇡], X(t) = cos(!t + ⇥). Draw the autocorrela-
tion function RX (t1 , t2 ).

Solution. From the previous example we know that


1 ⇣ ⌘
RX (t1 , t2 ) = cos !(t1 t2 ) .
2
Figure 10.13 shows the realizations, and the mean and autocorrelation functions.

626
10.2. MEAN AND CORRELATION FUNCTIONS

Note that the autocorrelation function has a structure: Every row is a shifted
version of the previous row. We call this a Toeplitz structure. An autocorrelation with
a Toeplitz structure is specified once we know any of the rows. A Toeplitz structure also
implies that the autocorrelation function does not depend on the pair (t1 , t2 ) but only
on the di↵erence t1 t2 . In other words, RX (0, 1) is the same as RX (11.6, 12.6), and so
knowing RX (0, 1) is enough to know all RX (t0 , t0 + t). Not all random processes have
a Toeplitz autocorrelation function. Random processes with a Toeplitz autocorrelation
function are “nice” processes that we will study in detail later.
-1

1
-0.75

-0.5
0.5
-0.25

t2
0
0
0.25

-0.5 0.5

0.75

-1
1
-1 -0.75 -0.5 -0.25 0 0.25 0.5 0.75 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2 t1

⇣ ⌘
1
Figure 10.13: The autocorrelation function RX (t1 , t2 ) = 2
cos !(t1 t2 ) .

The MATLAB code used to generate Figure 10.13 is shown below.

% MATLAB code for Example 10.12


t = linspace(-1,1,1000);
R = Toeplitz(0.5*cos(2*pi*t(:)));
imagesc(t,t,R);
grid on;
xticks(-1:0.25:1);
yticks(-1:0.25:1);

Practice Exercise 10.1. Let ⇥ ⇠Uniform[0, 2⇡], X(t) = cos(!t + ⇥). Find the PDF
of X(0).

Solution. Let Z = X(0) = cos ⇥. Then the CDF of Z is

FZ (z) = P[Z  z]
= P[cos ⇥  z]
1 1
= P[cos z  ⇥  2⇡ cos z]
1
cos z
=1 .

627
CHAPTER 10. RANDOM PROCESSES

Then by the fundamental theorem of calculus,


1
fZ (z) = p .
⇡ 1 z2

A similar concept to the autocorrelation function is the autocovariance function. The


idea is to remove the mean before computing the correlation. This is analogous to the
covariance Cov(X, Y ) = E[(X µX )(Y µY )] as opposed to the correlation E[XY ] in the
random variable case.

Definition 10.3. The autocovariance function of a random process X(t) is

CX (t1 , t2 ) = E [(X(t1 ) µX (t1 )) (X(t2 ) µX (t2 ))] . (10.7)

As one might expect, the autocovariance function is closely related to the autocorrelation
function.

Theorem 10.1.
CX (t1 , t2 ) = RX (t1 , t2 ) µX (t1 )µX (t2 ). (10.8)

Proof. Plugging in the definition, we have that

CX (t1 , t2 ) = E [(X(t1 ) µX (t1 )) (X(t2 ) µX (t2 ))]


= E [X(t1 )X(t2 ) X(t1 )µX (t2 ) X(t2 )µX (t1 ) + µX (t1 )µX (t2 )]
= RX (t1 , t2 ) µX (t1 )µX (t2 ) µX (t1 )µX (t2 ) + µX (t1 )µX (t2 )
= RX (t1 , t2 ) µX (t1 )µX (t2 ).

Practice Exercise 10.2. Suppose X(t) = A cos(2⇡t) for A ⇠ Uniform[0, 1]. Find
CX (t1 , t2 ).

Solution.

CX (t1 , t2 ) = RX (t1 , t2 ) µX (t1 )µX (t2 )


1 1 1
= cos(2⇡t1 ) cos(2⇡t2 ) cos(2⇡t1 ) · cos(2⇡t2 )
3 2 2
1
= cos(2⇡t1 ) cos(2⇡t2 ).
12

Practice Exercise 10.3. Suppose X(t) = cos(!t + ⇥) for ⇥ ⇠ Uniform[ ⇡, ⇡]. Find
CX (t1 , t2 ).

628
10.2. MEAN AND CORRELATION FUNCTIONS

Solution.

CX (t1 , t2 ) = RX (t1 , t2 ) µX (t1 )µX (t2 )


✓ ◆
1
= cos !(t1 t2 ) 0·0
2
✓ ◆
1
= cos !(t1 t2 ) .
2

In some problems we are interested in modeling the correlation between two random
processes X(t) and Y (t). This gives us the cross-correlation and the cross-covariance func-
tions.

Definition 10.4. The cross-correlation function of X(t) and Y (t) is

RX,Y (t1 , t2 ) = E [X(t1 )Y (t2 )] . (10.9)

Definition 10.5. The cross-covariance function of X(t) and Y (t) is

CX,Y (t1 , t2 ) = E [(X(t1 ) µX (t1 )) (Y (t2 ) µY (t2 ))] . (10.10)

Remark. If µX (t1 ) = µY (t2 ) = 0, then CX,Y (t1 , t2 ) = RX,Y (t1 , t2 ) = E[X(t1 )Y (t2 )].

10.2.3 Independent processes


How do we establish independence for two random processes? We know that for two random
variables to be independent, the joint PDF can be written as a product of two PDFs:

fX,Y (x, y) = fX (x)fY (y). (10.11)

If we extrapolate this idea to random processes, a natural formulation would be

fX(t),Y (t) (x, y) = fX(t) (x)fY (t) (y). (10.12)

But this definition has a problem because X(t) and Y (t) are functions. It is not enough to
just look at one time index, say t = t0 . The way to think about this situation is to consider
a pair of random vectors X and Y . When you say X and Y are independent, you require
fX,Y (x, y) = fX (x)fY (y). The PDF fX (x) itself is a joint distribution, i.e., fX (x) =
fX1 ,...,XN (x1 , . . . , xN ). Therefore, for random processes, we need something similar.

Definition 10.6. Two random processes X(t) and Y (t) are independent if for any
t1 , . . . , t N ,

fX(t1 ),...,X(tN ),Y (t1 ),...,Y (tN ) (x1 , . . . , xN , y1 , . . . , yN )


= fX(t1 ),...,X(tN ) (x1 , . . . , xN ) ⇥ fY (t1 ),...,Y (tN ) (y1 , . . . , yN ).

629
CHAPTER 10. RANDOM PROCESSES

This definition is reminiscent of fX,Y (x, y) = fX (x)fY (y). The requirement here is that
the factorization holds for any N , including very small N and very large N , because X(t)
and Y (t) are infinitely long.

Independence means that the behavior of one process will not influence the behavior
of the other process. We define uncorrelated as follows.

Definition 10.7. Two random processes are X(t) and Y (t) uncorrelated if

E [X(t1 )Y (t2 )] = E [X(t1 )] E [Y (t2 )] , (10.13)

Independence implies uncorrelation, as we can see from the following. If X(t) and Y (t) are
independent, it follows that
Z
E [X(t1 )Y (t2 )] = X(t1 , ⇠)Y (t2 , ⇣)fX,Y (⇠, ⇣) d⇠ d⇣
Z
= X(t1 , ⇠)Y (t2 , ⇣)fX (⇠)fY (⇣) d⇠ d⇣, independence
Z Z
= X(t1 , ⇠)fX (⇠) d⇠ Y (t2 , ⇣)fY (⇣) d⇣ = E[X(t1 )]E[Y (t2 )].

If two random processes are uncorrelated, they are not necessarily independent.

)
Independent X and Y uncorrelated X and Y
:

Example 10.13. Let Y (t) = X(t) + N (t), where X(t) and N (t) are independent.
Then

RX,Y (t1 , t2 ) = E [X(t1 )Y (t2 )] = E [X(t1 ) (X(t2 ) + N (t2 ))]


= RX (t1 , t2 ) + µX (t1 )µN (t2 ).

10.3 Wide-Sense Stationary Processes

As we have seen in the previous sections, some random processes have a “nice” autocor-
relation function, in the sense that the 2D function RX (t1 , t2 ) has a Toeplitz structure.
Random processes with this property are known as wide-sense stationary (WSS) processes.
WSS processes belong to a very small subset in the entire universe of random processes,
but they are practically the most useful ones. Before we discuss how to use them, we first
present a formal definition of a WSS process.1
1 Many textbooks introduce strictly stationary processes before discussing a wide-sense stationary process.

We skip the former because, throughout our book, we only use WSS processes. Readers interested in strictly
stationary processes can consult the references listed at the end of this chapter.

630
10.3. WIDE-SENSE STATIONARY PROCESSES

10.3.1 Definition of a WSS process

Definition 10.8. A random process X(t) is wide-sense stationary if:


1. µX (t) = constant, for all t, and
2. RX (t1 , t2 ) = RX (t1 t2 ) for all t1 , t2 .

There are two criteria that define a WSS process. The first criterion is that the mean is a
constant. That is, the mean function does not change with time. The second criterion is that
the autocorrelation function only depends on the di↵erence t1 t2 and not on the absolute
starting point. For example, RX (0.1, 1.1) needs to be the same as RX (6.3, 7.3), because the
intervals are both 1.
How can these two criteria be mapped to the Toeplitz structure we discussed in the
previous examples? Figure 10.14 shows the autocorrelation function RX (t1 , t2 ), which is a
2D function. We take three cross sections corresponding to t2 = 0.13, t2 = 0 and t2 = 0.3.
As you can see from the figure, each RX (t1 , t2 ) is a shifted version of another one. To obtain
any value RX (t1 , t2 ) on the function, there is no need to probe to the 2D map; you only
need to probe to the red curve and locate the position marked as t1 t2 , and you will be
able to obtain the value RX (t1 , t2 ).
-1 1
t2 = -0.13
-0.75
t2 = 0
-0.5 0.5 t2 = 0.3

-0.25

0
t2

0.25

-0.5
0.5

0.75
-1
1 -1 -0.75 -0.5 -0.25 0 0.25 0.5 0.75 1
-1 -0.75 -0.5 -0.25 0 0.25 0.5 0.75 1
t1 t1
⇣ ⌘
1
Figure 10.14: Cross sections of the autocorrelation function RX (t1 , t2 ) = 2
cos !(t1 t2 ) .

Not all random processes have a Toeplitz autocorrelation function. For example, the
random process X(t) = A cos(2⇡t) is not a WSS process, because the autocorrelation func-
tion is
1
RX (t1 , t2 ) = cos(2⇡t1 ) cos(2⇡t2 ),
3
which cannot be written as the di↵erence t1 t2 .

Remark 1. WSS processes can also be defined using the autocovariance function instead
of the autocorrelation function, because if a process is WSS, then the mean function is a
constant. If the mean function is a constant, then CX (t1 , t2 ) = RX (t1 , t2 ) µ2 . So any
geometric structure that RX possesses will be translated to CX , as the constant µ2 will not

631
CHAPTER 10. RANDOM PROCESSES

influence the geometry. Therefore, it is equally valid to say that a WSS process has
CX (t1 , t2 ) = CX (t1 t2 ).

Remark 2. Because a WSS is completely characterized by the di↵erence t1 t2 , there is


no need to keep track of the absolute indices t1 and t2 . We can rewrite the autocorrelation
function as
RX (⌧ ) = E[X(t + ⌧ )X(t)]. (10.14)
There is nothing new in this equation: It only says that instead of writing RX (t + ⌧, t), we
can write RX (⌧ ) because the time index t plays no role in terms of RX . Thus from now on,
for any WSS processes we will write the autocorrelation function as RX (⌧ ).

10.3.2 Properties of RX (⌧ )
When X(t) is WSS, RX (⌧ ) has several important properties.

Corollary 10.1. RX (0) = average power of X(t).

Proof. Since
RX (0) = E[X(t + 0)X(t)] = E[X(t)2 ],
and since E[X(t)2 ] is the average power, RX (0) is the average power of X(t). ⇤

Corollary 10.2. RX (⌧ ) is symmetric. That is, RX (⌧ ) = RX ( ⌧ ).

Proof. Note that RX (⌧ ) = E[X(t + ⌧ )X(t)]. By switching the order of multiplication in the
expectation, we have
E[X(t + ⌧ )X(t)] = E[X(t)X(t + ⌧ )] = RX ( ⌧ ).

Corollary 10.3.

2(RX (0) RX (⌧ ))
P(|X(t + ⌧ ) X(⌧ )| > ✏)  .
✏2

This result says that if RX (⌧ ) is slowly decaying from RX (0), the probability of having a
large deviation |X(t + ⌧ ) X(⌧ )| is small.

Proof.
P(|X(t + ⌧ ) X(⌧ )| > ✏)  E[(X(t + ⌧ ) X(⌧ ))2 ]/✏2
⇣ ⌘
= E[X(t + ⌧ )2 ] 2E[X(t + ⌧ )X(t)] + E[X(t)2 ] /✏2
⇣ ⌘
= 2E[X(t)2 ] 2E[X(t + ⌧ )X(t)] /✏2
⇣ ⌘
= 2 RX (0) RX (⌧ ) /✏2 .

632
10.3. WIDE-SENSE STATIONARY PROCESSES

Corollary 10.4. |RX (⌧ )|  RX (0), for all ⌧ .

Proof. By Cauchy’s inequality E[XY ]2  E[X 2 ]E[Y 2 ], we can show that

RX (⌧ )2 = E[X(t)X(t + ⌧ )]2
 E[X(t)2 ]E[X(t + ⌧ )2 ]
= E[X(t)2 ]2 = RX (0)2 .

10.3.3 Physical interpretation of RX (⌧ )


How should we understand the autocorrelation function RX (⌧ ) for WSS processes? Cer-
tainly, by definition, RX (⌧ ) = E[X(t + ⌧ )X(t)] means that we can analyze RX (⌧ ) from the
statistical perspective. But in this section we want to take a slightly di↵erent approach by
answering the question from a computational perspective.
Consider the following function:
Z T
bX (⌧ ) def 1
R = X(t + ⌧ )X(t) dt. (10.15)
2T T

This function is the temporal average of X(t+⌧ )X(t), as opposed to the statistical average.
Why do we want to consider this temporal average? We first show the main result, that
bX (⌧ )] = RX (⌧ ).
E[R

RT
bX (⌧ ) def
Lemma 10.1. Let R = 1
X(t + ⌧ )X(t) dt. Then
2T T
h i
E RbX (⌧ ) = RX (⌧ ). (10.16)

Proof.
h i Z T
b 1
E RX (⌧ ) = E [X(t + ⌧ )X(t)] dt
2T T
Z T Z T
1 1
= RX (⌧ ) dt = RX (⌧ ) dt = RX (⌧ ).
2T T 2T T


This lemma implies that if the signal X(t) is long enough, we can approximate RX (⌧ )
bX (⌧ ). The approximation is asymptotically consistent, in the sense that E[R
by R bX (⌧ )] =
b
RX (⌧ ). Now, the more interesting question is the interpretation of RX (⌧ ). What is it?

bX (⌧ )?
How should we understand R
bX (⌧ ) is the “unflipped convolution”, or correlation, of X(⌧ ) and X(t + ⌧ ).
R

633
CHAPTER 10. RANDOM PROCESSES

Correlation is analogous to convolution. For convolution, the definition is


Z T
Y (⌧ ) = X(t ⌧ )X(t) dt, (10.17)
T

whereas for correlation, the definition is


Z T
Y (⌧ ) = X(t + ⌧ )X(t) dt. (10.18)
T

Clearly, RbX (⌧ ) is the latter. A graphical illustration of the di↵erence between convolution
and correlation is provided in Figure 10.15. The only di↵erence between the two is that the
correlation does not flip the function, whereas the convolution does flip the function.
0.6 0.6

0.5 0.5

0.4 0.4

0.3 0.3

0.2 0.2

0.1 0.1

0 0

-0.1 -0.1
-10 -5 0 5 10 -10 -5 0 5 10
(a) Convolution (b) Correlation

Figure 10.15: The di↵erence between convolution and correlation. In convolution, the function X(t) is
flipped before we compute the result. For correlation, the function is not flipped.

The temporal correlation is easy to visualize. Starting with the function X(t+⌧ ), if you
make ⌧ larger or smaller, then e↵ectively you are shifting X(t) left or right. The integration
RT
T
X(t + ⌧ )X(t) dt calculates the energy accumulated. If the integral is large, there is a
strong correlation between X(t) and X(t + ⌧ ). Otherwise the correlation is small. Here is
an extreme example:

Example 10.14. Consider a random process X(t) such that for every t, X(t) is an
i.i.d. Gaussian random variable with zero mean and unit variance. Then
(
E[X 2 (t)], ⌧ = 0,
RX (⌧ ) = E[X(t + ⌧ )X(t)] =
E[X(t + ⌧ )]E[X(t)], ⌧ 6= 0.

Using the fact that X(t) is i.i.d. Gaussian for all t, we can show that E[X 2 (t)] = 1 for
any t, and E[X(t + ⌧ )]E[X(t)] = 0. Therefore, we have
(
1, ⌧ = 0,
RX (⌧ ) =
0. ⌧ 6= 0.

634
10.3. WIDE-SENSE STATIONARY PROCESSES

The equation says that since the random process is i.i.d. Gaussian, shifting and in-
tegrating will give maximum correlation at the origin. As soon as the shift is not at
the origin, the correlation is zero. This makes sense because the samples are just i.i.d.
Gaussian. One pixel o↵set is enough to destroy any correlation.
Now let’s calculate the temporal correlation. We know that
Z T
bX (⌧ ) = 1
R X(t + ⌧ )X(t) d⌧.
2T T

This equation says that we shift X(t) to the left and right and then integrate. If ⌧
is not zero, the product X(t + ⌧ )X(t) will sometimes be positive and sometimes be
negative. After integrating the entire period, we cancel out most of the terms. Let’s
plot the functions and see if all these steps make sense. In Figure 10.16(a), we show
two random realizations of the random process X(t). They are just i.i.d. Gaussian
samples.
In Figure 10.16(b) we plot the temporal autocorrelation function R bX (⌧ ). Since
b
RX (⌧ ) itself is a random process, it has di↵erent realizations. We plot two random
realizations, which are computed based on shifting and integrating X(t). In the same
plot, we also show the statistical expectation RX (⌧ ). As we can see from the plot,
the temporal correlation and the statistical correlation match reasonably well except
for the fluctuation in RbX (⌧ ), which is expected because it is computed from a finite
number of samples.
4
1.2
correlation of sample 1
3 correlation of sample 2
1 auto-correlation function

2
0.8
1
0.6
0

0.4
-1

0.2
-2

-3 0

-4 -0.2
0 200 400 600 800 1000 0 500 1000 1500 2000

(a) X(t) bX (⌧ )
(b) R

Figure 10.16: (a) A random process X(t) with two di↵erent realizations. (b) As we calculate the
temporal correlation of each of the two realizations, we obtain a noisy function that is nearly an
impulse. If we take the average of many of these realizations, we obtain a pure delta function.

On a computer, the commands to do the autocorrelation function are xcorr in MAT-


LAB and np.correlate in Python. Below are the codes used to generate Figure 10.16.
% MATLAB code to demonstrate autocorrelation
N = 1000; % number of sample paths
T = 1000; % number of time stamps
X = 1*randn(N,T);
xc = zeros(N,2*T-1);
for i=1:N

635
CHAPTER 10. RANDOM PROCESSES

xc(i,:) = xcorr(X(i,:))/T;
end
plot(xc(1,:),’b:’, ’LineWidth’, 2); hold on;
plot(xc(2,:),’k:’, ’LineWidth’, 2);

# Python code to demonstrate autocorrelation


N = 1000
T = 1000
X = np.random.randn(N,T)
xc= np.zeros((N,2*T-1))
for i in range(N):
xc[i,:] = np.correlate(X[i,:],X[i,:],mode=’full’)/T
plt.plot(xc[0,:],’b:’)
plt.plot(xc[1,:],’k:’)
plt.show()

bX (⌧ ) ! RX (⌧ ) as T ! 1? The answer to this question


Under what conditions will R
is provided by an important theorem called Mean-Square Ergodic Theorem, which can be
thought of as the random process version of the weak law of large numbers. We leave the
discussion of the mean ergodic theorem to the Appendix.

Everything you need to know about a WSS process


The mean of a WSS process is a constant (does not need to be zero)
The correlation function only depends on the di↵erence, so RX (t1 , t2 ) is Toeplitz.
You can write RX (t1 , t2 ) as RX (⌧ ), where ⌧ = t1 t2 .
RX (⌧ ) tells you how much correlation you have with someone located at a time
instant ⌧ from you.

10.4 Power Spectral Density

Beginning with this section we are going to focus on WSS processes. By WSS, we mean that
the autocorrelation function RX (t1 , t2 ) has a Toeplitz structure. Putting it in other words,
we assume RX (t1 , t2 ) can be simplified to RX (⌧ ), where ⌧ = t1 t2 . We call this property
time invariance.

10.4.1 Basic concepts


R1
Assuming that RX (⌧ ) is square integrable, i.e., 1 RX (⌧ )2 d⌧ < 1, we can now define the
Fourier transform of RX (⌧ ) which is called the power spectral density.

636
10.4. POWER SPECTRAL DENSITY

Theorem 10.2 (Einstein-Wiener-Khinchin Theorem). The power spectral density


SX (!) of a WSS process is
Z 1
SX (!) = RX (⌧ ) e j!⌧ d⌧ = F(RX (⌧ )),
1
R1
assuming that 1
RX (⌧ )2 d⌧ < 1 so that the Fourier transform of RX (⌧ ) exists.

2↵|⌧ |
Practice Exercise 10.4. Let RX (⌧ ) = e . Find SX (!).

Solution. Using the Fourier transform table,


4↵
SX (!) = F {RX (⌧ )} = .
4↵2 + !2
Figure 10.17 shows the autocorrelation function and the power spectral density.
1 1
RX ( ) SX ( )
0.8 0.8

0.6 0.6

0.4 0.4

0.2 0.2

0 0
-2 -1 0 1 2 -10 -5 0 5 10

2↵|⌧ |
Figure 10.17: Example for RX (⌧ ) = e , with ↵ = 1.

Why is Theorem 10.2 a theorem rather than a definition? This is because power spectral
density has its definition. There is no way that you can get any “power” information merely
by looking at the Fourier transform of RX (⌧ ). We will discuss the origin of the power spectral
density later, but for now, we only need to know that SX (!) is the Fourier transform of
RX (⌧ ).

Remark. The power spectral density is defined for WSS processes. If the process is not
WSS, then RX will be a 2D function instead of a 1D function of ⌧ , so we cannot take the
Fourier transform in ⌧ . We will discuss this in detail shortly.

Practice Exercise 10.5. Let X(t) = a cos(!0 t+⇥), ⇥ ⇠ Uniform[0, 2⇡]. Find SX (!).

Solution. We know that the autocorrelation function is


a2
RX (⌧ ) = cos(!0 ⌧ )
2 ✓ ◆
2
a ej!0 ⌧ + e j!0 ⌧
= .
2 2

637
CHAPTER 10. RANDOM PROCESSES

By taking the Fourier transform of both sides, we have



a2 2⇡ (! !0 ) + 2⇡ (! + !0 )
SX (!) =
2 2
2
⇡a
= [ (! !0 ) + (! + !0 )] .
2
The result is shown in Figure 10.18.
0.5 2
RX ( ) SX ( )
1.5

0 1

0.5

-0.5 0
-2 -1 0 1 2 -10 -5 0 5 10

a2
Figure 10.18: Example for RX (⌧ ) = 2
cos(!0 ⌧ ), with a = 1 and !0 = 2⇡.

N0 !
Practice Exercise 10.6. Let SX (!) = 2 rect( 2W ). Find RX (⌧ ).

Solution. Since SX (!) = F(RX (⌧ )), the inverse holds:

N0 W
RX (⌧ ) = sinc(W ⌧ ).
2 ⇡
This example shows what we call the bandlimited white noise. The power spectral
density SX (!) is uniform, meaning that it covers all frequencies (or wavelengths in
optics). It is called “white noise” because white light is essentially a mixture of all
wavelengths.
The bandwidth of the power spectral density W defines the zero crossings of
RX (⌧ ). It is easy to show that when W ! 1, RX (⌧ ) converges to a delta function.
This happens when X(t) is i.i.d. Gaussian. Therefore, the pure Gaussian noise random
process is also known as the white noise process. Reshaping the i.i.d. Gaussian noise
to an arbitrary power spectral density can be done by passing it through a linear filter,
as we will explain later.
2 1.5
RX ( ) SX ( )
1.5
1
1
0.5
0.5
0
0

-0.5 -0.5
-2 -1 0 1 2 -10 -5 0 5 10

N0 !
Figure 10.19: Example for SX (!) = 2
rect( 2W ), with N0 = 2 and W = 5.

638
10.4. POWER SPECTRAL DENSITY

Finding SX (!) from RX (⌧ ) is straightforward, at least in principle. The more inter-


esting questions to ask are: (1) Why do we need to learn about power spectral density? (2)
Why do we need WSS to define power spectral density?

How is power spectral density useful?


Power spectral densities are useful when we pass a random process through some
linear operations, e.g., convolution, running average, or running di↵erence.
Power spectral densities are the Fourier transforms of the autocorrelation func-
tions. Fourier transforms are useful for speeding up computation and drawing
random samples from a given power spectral density.

A random process itself is not interesting until we process it; there are many ways to do
this. The most basic operation is to send the random process through a linear time-invariant
system, e.g., a convolution. Convolution is equivalent to filtering the random process. For
example, if the input process contains noise, we can design a linear time-invariant filter to
denoise the random process. The power spectral density, which is the Fourier transform
of the autocorrelation function, makes the filtering easier because everything can be done
in the spectral (Fourier) domain. Moreover, we can analyze the performance and quantify
the limit using standard results in Fourier analysis. For some specialized problems such as
imaging through atmospheric turbulence, the distortions happen in the phase domain. This
can be simulated by drawing samples from the power spectral density, e.g., the Kolmogorov
spectrum or the von Kármán spectrum. Power spectral densities have many important
engineering applications.

Why does the power spectral density require wide-sense stationarity?


If a process is WSS, then RX will have a Toeplitz structure.
A Toeplitz matrix is important. If you do eigendecomposition to a Toeplitz ma-
trix, the eigenvectors are the Fourier bases.
So if RX is Toeplitz, then you can diagonalize it using the Fourier transform.
Therefore, the power spectral density can be defined.

Why does power spectral density require WSS? This has to do with the Toeplitz
structure of the autocorrelation function. To make our discussion easier let us discretize
the autocorrelation function RX (t1 , t2 ) by considering RX [m, n]. (You can do a mental
calculation by converting t1 to integer indices m, and t2 to n. See any textbook on signals
and systems if you need help. This is called the “discrete time signal”.) Following the range
of t1 and t2 , RX [m, n] can be expressed as:
2 3
RX [0] RX [1] · · · RX [N 1]
6 RX [1] RX [0] · · · RX [N 2]7
6 7
R=6 .. .. .. .. 7,
4 . . . . 5
RX [N 1] RX [N 1] · · · RX [0]
where we used the fact that RX [m, n] = RX [m n] for WSS processes and RX [k] = RX [ k].
We call the resulting matrix R the autocorrelation matrix, which is a discretized version

639
CHAPTER 10. RANDOM PROCESSES

of the autocorrelation function RX (t1 , t2 ). Looking at R, we again observe the Toeplitz


structure. For example, Figure 10.20 shows one Toeplitz structure and one non-Toeplitz
structure.

Figure 10.20: We show two autocorrelation functions RX [m, n] on the left-hand side. The first autocor-
relation function comes from a WSS process that has a Toeplitz structure. The second autocorrelation
function does not have Toeplitz structure. For the Toeplitz matrix, we can diagonalize it using the
Fourier transform. The eigenvalues are the power spectral density.

Any Toeplitz matrix R can be diagonalized using the Fourier transforms. That is, we
can write R as
R = F H ⇤F ,
where F is the (discrete) Fourier transform matrix and ⇤ is a diagonal matrix. This can be
understood as the eigendecomposition of R. The important point here is that only Toeplitz
matrices can be eigendecomposed using the Fourier transforms; an arbitrary symmetric
matrix cannot. Figure 10.20 illustrates this point. If your matrix is Toeplitz, you can diago-
nalize it, and hence you can define the power spectral density, just as in the first example. If
your matrix is not Toeplitz, then the power spectral density is undefined. To get the Toeplitz
matrix, you must start with a WSS process.
Before moving on, we define cross power spectral densities, which will be useful in
some applications.

Definition 10.9. The cross power spectral density between two random processes
X(t) and Y (t) is

SX,Y (!) = F(RX,Y (⌧ )) where RX,Y (⌧ ) = E[X(t + ⌧ )Y (t)],


(10.19)
SY,X (!) = F(RY,X (⌧ )) where RY,X (⌧ ) = E[Y (t + ⌧ )X(t)].

Remark. In general, SX,Y (!) 6= SY,X (!). Rather, since RX,Y (⌧ ) = RY,X ( ⌧ ), we have
SX,Y (!) = SY,X (!).

10.4.2 Origin of the power spectral density


To understand the power spectral density, it is crucial to understand where it comes from
and why it is the Fourier transform of the autocorrelation function.

640
10.4. POWER SPECTRAL DENSITY

We begin by assuming that X(t) is a WSS random process with mean µX and auto-
correlation RX (⌧ ). We now consider the notion of power. Consider a random process X(t).
The power within a period [ T, T ] is
Z T
1
PbX = |X(t)|2 dt.
2T T

PbX defines the power because the integration alone is the energy, and the normalization by
1/2T gives us the power. However, there are two problems. First, since X(t) is random, the
power PbX is also random. Is there a way we can eliminate the randomness? Second, T is
a finite period of time. It does not capture the entire process, and so we do not know the
power of the entire process.
A natural solution to these two problems is to consider
" Z T #
def 1 2
PX = E lim |X(t)| dt . (10.20)
T !1 2T T

Here, we take the limit of T to infinity so that we can compute the power of the entire
process. We also take the expectation to eliminate the randomness. Therefore, PX can be
regarded as the average power of the complete random process X(t).
Next, we need one definition and one lemma. The definition defines SX (!), and the
lemma will link SX (!) with the power PX .

Definition 10.10. The power spectral density (PSD) of a WSS process is defined as
h i
E |X eT (!)|2
SX (!) = lim , (10.21)
T !1 2T
where Z T
eT (!) =
X X(t)e j!t
dt (10.22)
T

is the Fourier transform of X(t) limited to [ T, T ].

This definition is abstract, but in a nutshell, it simply considers everything in the Fourier
domain. The ratio |X eT (!)|2 /2T is the power, but in the frequency domain. The reason is
that if X(t) is Fourier transformable, then Parseval’s theorem will hold. Parseval’s theorem
states that energy in the original space is conserved in the Fourier space. Since the ratio
eT (!)|2 /2T is the energy divided by time, it is the power. However, this is still not enough
|X
to help us understand power spectral density: We need a lemma.

Lemma 10.2. Define


" Z #
T
def 1
PX = E lim |X(t)|2 dt .
T !1 2T T

641
CHAPTER 10. RANDOM PROCESSES

Then Z 1
1
PX = SX (!) d!. (10.23)
2⇡ 1

The lemma has to be read together with the previous definition. If we can prove the lemma,
we know that by integrating SX (!) we will obtain the power. Therefore, SX (!) can be
viewed as a density function, specifically the density function of the power. SX (!) is called
the power spectral density because everything is defined in the Fourier domain. Putting this
all together gives us “power spectral density”.

Proof. First, we recall that PX is the expectation of the average power of X(t). Let

X(t) T  t  T,
XT (t) =
0 otherwise.

It follows that integrating over 1 to 1 is equivalent to


Z 1 Z T
|XT (t)|2 dt = |X(t)|2 dt.
1 T

By Parseval’s theorem, energy is conserved in both the time and the frequency domain:
Z 1 Z 1
1 eT (!)|2 d!.
|XT (t)|2 dt = |X
1 2⇡ 1

Therefore, PX satisfies
" Z T #
1
PX = E lim |X(t)|2 dt
T !1 2T T
 Z 1
1 1 eT (!)|2 d!
= E lim |X
T !1 2⇡ 2T 1
Z 1
1 1 h e i
= lim E |XT (!)|2 d!.
2⇡ 1T|
!1 2T
{z }
def
= SX (!)

The power spectral densities are functions whose integrations give us the power. If we
want to determine the power of a random process, the Einstein-Wiener-Khinchin theorem
(Theorem 10.2) says that SX (!) is just the Fourier transform of RX (⌧ ):
Z 1
SX (!) = RX (⌧ ) e j!⌧ d⌧ = F(RX (⌧ )).
1

The proof of the Einstein-Wiener-Khinchin theorem is quite intricate, so we defer


the proof to the Appendix. The significance of the theorem is that it turns an abstract
quantity, the power spectral density, into a very easily computable quantity, namely the
Fourier transform of the autocorrelation function. For now, we will happily use this theorem
because it saves us a great deal of trouble when we want to determine the power spectral
density from the first principles.

642
10.5. WSS PROCESS THROUGH LTI SYSTEMS

10.5 WSS Process through LTI Systems

Random processes have limited usefulness until we can apply operations to them. In this
section we discuss how WSS processes respond to a linear time-invariant (LTI) system. This
technique is most useful in signal processing, communication, speech analysis, and imaging.
We will be brief here since you can find most of this information in any standard textbook
on signals and systems.

10.5.1 Review of linear time-invariant systems


When we say a “system”, we mean that there exists an input-output relationship as shown
in Figure 10.21.

Figure 10.21: A system can be viewed as a black box that takes an input X(t) and turns it into an
output Y (t).

Linear time-invariant (LTI) systems are the simplest systems we use in engineering
problems. An LTI system has two properties.

Linearity. Linearity means that when two input random processes are added and
scaled, the output random processes will also be added and scaled in exactly the
same way. Mathematically, linearity says that if X1 (t) ! Y1 (t) and X2 (t) !
Y2 (t), then
aX1 (t) + bX2 (t) ! aY1 (t) + bY2 (t).

Time-invariant: Time invariance means that if we shift the input random process
by a certain time period, the output will be shifted in the same way. Mathemat-
ically, time invariance means that if X(t) ! Y (t), then

X(t + ⌧ ) ! Y (t + ⌧ ).

If a system is linear time-invariant, the input-to-output relation is given by convolution:

The convolution between two functions X(t) and h(t) is defined as


Z 1
Y (t) = h(t) ⇤ X(t) = h(⌧ ) X(t ⌧ ) d⌧,
1

643
CHAPTER 10. RANDOM PROCESSES

in which we call h(t) the system response or impulse response.

The function h(t) is called the impulse response because if X(t) = (t), then according to
the convolution equation we have
Z 1
Y (t) = h(⌧ ) (t ⌧ ) d⌧ = h(t).
1

Therefore, if we send an impulse to the system, the output will be h(t).


Convolution is commutative, meaning that h(t) ⇤ X(t) = X(t) ⇤ h(t). Written as inte-
grations, we have
Z 1 Z 1
h(⌧ ) X(t ⌧ ) d⌧ = h(t ⌧ ) X(⌧ ) d⌧. (10.24)
1 1

For LTI systems, Y (t) can be determined through the Fourier transforms.

The Fourier transform of a (squared-integrable) function X(t) is


Z 1
X(!) = F{X(t)} = X(⌧ ) e j!⌧ d⌧. (10.25)
1

A basic property of convolution is that convolution in the time domain is equivalent to


multiplication in the Fourier domain. Therefore

Y (!) = H(!)X(!), (10.26)

where H(!) = F{h(t)} is the Fourier transform of h(t), and Y (!) = F(Y (t)) is the Fourier
transform of Y (t).
In the rest of this section we study the pair of input and output random processes that
are defined as follows

X(t) = input. It is a WSS random process.


Y (t) = output. It is constructed by sending X(t) through an LTI system with
impulse response h(t). Therefore, Y (t) = h(t) ⇤ X(t).

10.5.2 Mean and autocorrelation through LTI Systems


Since X(t) is WSS, the mean function of X(t) stays constant, i.e., µX (t) = µX . The following
theorem gives the mean function of the output.

Theorem 10.3. If X(t) passes through an LTI system to yield Y (t), the mean function
of Y (t) is Z 1
E[Y (t)] = µX h(⌧ ) d⌧. (10.27)
1

644
10.5. WSS PROCESS THROUGH LTI SYSTEMS

Proof. Suppose that Y (t) = h(t) ⇤ X(t). Then,


Z 1
µY (t) = E[Y (t)] = E h(⌧ )X(t ⌧ ) d⌧
1
Z 1
= h(⌧ )E[X(t ⌧ )] d⌧
1
Z 1 Z 1
= h(⌧ )µX d⌧ = µX h(⌧ ) d⌧,
1 1

where the second to last equality is valid because X(t) is WSS, so that E[X(t ⌧ )] = µX .

The theorem suggests that if the input X(t) has a constant mean, the output Y (t)
should also have a constant mean. This should not be a surprise because if the system is
linear, a constant input will give a constant output.

Example 10.15. Consider a WSS random process X(t) such that each sample is an
i.i.d. Gaussian random variable with zero mean and unit variance. We send this process
through an LTI system with impulse response h(t), where
(
10(1 |t|), 1  t  1,
h(t) =
0, otherwise.

The mean function of X(t) is µX (t) = 0, and that of Y (t) is µY (t) = 0. Figure 10.22
illustrates a numerical example, in which we see that the random processes X(t) and
Y (t) have di↵erent shapes but the mean functions remain constant.
4
0.2
X(t)
R X(t)
X
(t)
R Y(t)
2 Y(t) 0.15
Y
(t)

0.1
0

0.05

-2
0

-4 -0.05
-10 -5 0 5 10 -2 -1 0 1 2

(a) µX (t) and µY (t) (b) RX (t) and RY (t)

Figure 10.22: When sending a WSS random process through an LTI system, the mean and the
autocorrelation functions are changed.

Next, we derive the autocorrelation function of a random process when sent through
an LTI system.

Theorem 10.4. If X(t) passes through an LTI system to yield Y (t), the autocorre-

645
CHAPTER 10. RANDOM PROCESSES

lation function of Y (t) is


Z 1 Z 1
RY (⌧ ) = h(s)h(r)RX (⌧ + s r) ds dr. (10.28)
1 1

Proof. We start with the definition of Y (t):

RY (⌧ ) = E[Y (t)Y (t + ⌧ )]
Z 1 Z 1
=E h(s)X(t s) ds h(r)X(t + ⌧ r) dr
1 1
Z 1Z 1
(a)
= h(s)h(r)E [X(t s)X(t + ⌧ r) ds dr]
1 1
Z 1Z 1
= h(s)h(r)RX (⌧ + s r) ds dr,
1 1

where in (a) we assume that integration and expectation are interchangeable.



A shorthand notation of the above formula is RY (t) = [h~(h⇤RX )](t), where ⇤ denotes
the convolution and ~ denotes the correlation. Figure 10.22(b) shows the autocorrelation
functions RX and RY . In this example RX is a delta function because for i.i.d. Gaussian
noise the power spectral density is a constant. After convolving with the system response,
the autocorrelation RY has a di↵erent shape.

10.5.3 Power spectral density through LTI systems


Denoting the Fourier transform of the impulse response by H(!) = F(h(t)), we derive the
power spectral density of the output.

Theorem 10.5. If X(t) passes through an LTI system to yield Y (t), the power spec-
tral density of Y (t) is
SY (!) = |H(!)|2 SX (!). (10.29)

Proof. By definition, the power spectral density SY (!) is the Fourier transform of the
autocorrelation function RY (!). Therefore,
Z 1
SY (!) = RY (⌧ )e j!⌧ d⌧
1
Z 1Z 1Z 1
= h(s)h(r)RX (⌧ + s r) ds dre j!⌧ d⌧.
1 1 1

Letting u = ⌧ + s r, we have
Z 1Z 1Z 1
SY (!) = h(s)h(r)RX (u)e j!(u s+r) ds dr du
1 1 1
Z 1 Z 1 Z 1
= h(s)ej!s ds h(r)e j!r dr RX (u)e j!u du
1 1 1

= H(!)H(!)SX (!),

646
10.5. WSS PROCESS THROUGH LTI SYSTEMS

where H(!) is the complex conjugate of H(!).



It is tempting to think that since Y (t) = h(t) ⇤ X(t), the power spectral density should
also be SY (!) = H(!)X(!), but this is not true. The above result shows that we need an
additional complex conjugate H(!) because SY (!) is the power, which means the square
of the signal. Note that RX is “squared” because we have convolved it with itself, and RY
is also squared. Therefore, to match RX and RY , the impulse response h also needs to be
squared in the Fourier domain.

Example 10.16. A WSS process X(t) has a correlation function

RX (⌧ ) = sinc(⇡⌧ ).

Suppose that X(t) passes through an LTI system with input/output relationship

d2 d d2 d
2 2
Y (t) + 2 Y (t) + 4Y (t) = 3 2 X(t) 3 X(t) + 6X(t).
dt dt dt dt
Find RY (⌧ ).

Solution: The sinc function has a Fourier transform given by


⇡ ⇣ ! ⌘
sinc(W t) ! rect .
F W 2W
Therefore, the autocorrelation function is
⇡ ⇣!⌘
RX (⌧ ) = sinc(⇡⌧ ) ! rect .
F ⇡ 2⇡
By taking the Fourier transform on both sides, we have
(
1, ⇡  !  ⇡,
SX (!) =
0, elsewhere.

The system response is found from the di↵erential equation:

3(j!)2 3(j!) + 6
H(!) =
2(j!)2 + 2(j!) + 4
⇥ ⇤
3 (2 ! 2 ) j!
= .
2 [(2 ! 2 ) + j!]

Taking the magnitude square yields


⇥ ⇤ ⇥ ⇤
3 (2 ! 2 ) j! 3 (2 ! 2 ) + j!
|H(!)|2 =
2 [(2 ! 2 ) + j!] 2 [(2 ! 2 ) j!]
9 (2 ! 2 )2 + ! 2 9
= = .
4 (2 ! 2 )2 + ! 2 4

647
CHAPTER 10. RANDOM PROCESSES

Therefore, the output power spectral density is


9
SY (!) = |H(!)|2 SX (!) = SX (!).
4
Taking the inverse Fourier transform, we have
9
RY (⌧ ) = sinc(⇡⌧ ).
4

Example 10.17. A random process X(t) has zero mean and RX (t, s) = min(t, s).
Consider a new process Y (t) = et X(e 2t ).
1. Is Y (t) WSS?

2. Suppose Y (t) passes through a LTI system to yield an output Z(t) according to

d d
Z(t) + 2Z(t) = Y (t) + Y (t).
dt dt
Find RZ (⌧ ).

Solution:
1. In order to verify whether Y (t) is WSS, we need to check the mean function and
the autocorrelation function. The mean function is
⇥ ⇤ ⇥ ⇤
E[Y (t)] = E et X(e 2t ) = et E X(e 2t ) .

Since X(t) has zero mean, E[X(t)] = 0 for all t. This implies that if u = e 2t ,
then E[X(u)] = 0 because u is just another time instant. Thus E[X(e 2t )] = 0,
and hence E[Y (t)] = 0.
The autocorrelation is
h i
E [Y (t + ⌧ )Y (t)] = E et+⌧ X(e 2(t+⌧ ) )et X(e 2t )
h i
= e2t+⌧ E X(e 2(t+⌧ ) )X(e 2t )
= e2t+⌧ RX (e 2(t+⌧ )
,e 2t
).

Substituting RX (t, s) = min(t, s), we have that

e2t+⌧ RX (e 2(t+⌧ )
,e 2t
) = e2t+⌧ min(e 2(t+⌧ ) , e 2t )

e 2(t+⌧ ) , ⌧ 0
= e2t+⌧
e 2t , ⌧ <0
⇢ ⌧
e , ⌧ 0
=
e⌧ , ⌧ <0
|⌧ |
=e .

648
10.5. WSS PROCESS THROUGH LTI SYSTEMS

|⌧ |
So RY (⌧ ) = e . Since RY (⌧ ) is a function of ⌧ , Y (t) is WSS.
2. The system response is given by
1 + j!
H(!) = .
2 + j!
The magnitude is therefore

1 + !2
|H(!)|2 = .
4 + !2
Hence, the output autocorrelation function is

|⌧ | 2
RY (⌧ ) = e ! SY (!) = ,
1 + !2
and

SZ (!) = |H(!)|2 SY (!)


1 + !2 2 2
= = .
4 + !2 1 + !2 4 + !2
Therefore
1 2|⌧ |
RZ (⌧ ) = e .
2

10.5.4 Cross-correlation through LTI Systems


The above analyses are developed for the autocorrelation function. If we consider the cross-
correlation between two random processes, say X(t) and Y (t), then the above results do not
hold. In this section, we discuss the cross-correlation through LTI systems.
To begin with, we need to define WSS for a pair of random processes.

Definition 10.11. Two random processes X(t) and Y (t) are jointly WSS if
1. X(t) is WSS and Y (t) is WSS, and

2. RX,Y (t1 , t2 ) = E [X(t1 )Y (t2 )] is a function of t1 t2 .

If X(t) and Y (t) are jointly WSS, we write


def
RX,Y (t1 , t2 ) = RX,Y (⌧ ) = E [X(t + ⌧ )Y (⌧ )] .

The definition of “jointly WSS” is necessary here because RX,Y is defined by X and Y . Just
knowing that X(t) and Y (t) are WSS does not allow one to say that RX,Y (t1 , t2 ) can be
written as the time di↵erence.
If we flip the order of X and Y to consider RY,X (⌧ ) and not RX,Y (⌧ ), then we need
to flip the argument. The following lemma explains why.

649
CHAPTER 10. RANDOM PROCESSES

Lemma 10.3. For any random processes X(t) and Y (t), the cross-correlation RX,Y (⌧ )
is related to RY,X (⌧ ) as
RX,Y (⌧ ) = RY,X ( ⌧ ). (10.30)

Proof. Recall the definition of RY,X ( ⌧ ) = E [Y (t ⌧ )X(t)]. This can be simplified as


follows:
RY,X ( ⌧ ) = E [Y (t ⌧ )X(t)]
= E [X(t)Y (t ⌧ )]
= E [X(t + ⌧ )Y (t0 )]
0

= RX,Y (⌧ ),
0
where we substituted t = t ⌧.

Example 10.18. Let X(t) and N (t) be two independent WSS random processes with
expectations E[X(t)] = µX and E[N (t)] = 0, respectively. Let Y (t) = X(t) + N (t). We
want to show that X(t) and Y (t) are jointly WSS, and we want to find RX,Y (⌧ ).

Solution. Before we show the joint WSS property of X(t) and Y (t), we first show
that Y (t) is WSS:

E[Y (t)] = E[X(t) + N (t)] = µX .


RY (t1 , t2 ) = E [(X(t1 ) + N (t1 ))(X(t2 ) + N (t2 ))]
= E [(X(t1 )X(t2 )] + E [(N (t1 )N (t2 )]
= RX (t1 t2 ) + RN (t1 t2 ).

Thus, Y (t) is WSS.


To show that X(t) and Y (t) are jointly WSS, we need to check the cross-
correlation function:

RX,Y (t1 , t2 ) = E[X(t1 )Y (t2 )]


= E [X(t1 )(X(t2 ) + N (t2 ))]
= E [X(t1 )(X(t2 )] + E [X(t1 )N (t2 )]
= RX (t1 , t2 ) + E[X(t1 )]E[N (t2 )]
= RX (t1 , t2 ).

Since RX,Y (t1 , t2 ) is a function of t1 t2 , and since X(t) and Y (t) are WSS, X(t) and
Y (t) must be jointly WSS.

Finally, to find RX,Y (⌧ ), we substitute ⌧ = t1 t2 and obtain RX,Y (⌧ ) = RX (⌧ ).

Knowing the definition of jointly WSS, we consider the cross-correlation between X(t)
and Y (t). Note that here we are asking about the cross-correlation between the input and
the output of the same LTI system, as illustrated in Figure 10.23. The pair X(t) and
Y (t) = h(t) ⇤ X(t) are special because Y (t) is the convolved version of X(t).

650
10.5. WSS PROCESS THROUGH LTI SYSTEMS

Figure 10.23: The source of the signals when defining RX (⌧ ), RX,Y (⌧ ), RY,X (⌧ ) and RY (⌧ ).

Theorem 10.6. Let X(t) and Y (t) be jointly WSS processes, and let Y (t) = h(t) ⇤
X(t). Then the cross-correlation RY,X (⌧ ) is

RY,X (⌧ ) = h(⌧ ) ⇤ RX (⌧ ). (10.31)

Proof. Recalling the definition of cross-correlation, we have

RY,X (⌧ ) = E[Y (t + ⌧ )X(t)]


 Z 1
= E X(t) X(t + ⌧ r)h(r) dr
1
Z 1 Z 1
= E[X(t)X(t + ⌧ r)]h(r) dr = RX (⌧ r)h(r) dr,
1 1

which is the convolution RY,X (⌧ ) = h(⌧ ) ⇤ RX (⌧ ).


We next define the cross power spectral density of two jointly WSS processes as the
Fourier transform of the cross-correlation function.

Definition 10.12. The cross power spectral density of two jointly WSS processes
X(t) and Y (t) is defined as

SX,Y (!) = F[RX,Y (⌧ )],


SY,X (!) = F[RY,X (⌧ )].

The relationship between SX,Y and SY,X can be seen from the following theorem.

Theorem 10.7. For two jointly WSS random processes X(t) and Y (t), the cross
power spectral density satisfies the property that

SX,Y (!) = SY,X (!), (10.32)

where (·) denotes the complex conjugate.

651
CHAPTER 10. RANDOM PROCESSES

Proof. Since SX,Y (!) = F[RX,Y (⌧ )] by definition, it follows that


Z 1
F[RX,Y (⌧ )] = RX,Y (⌧ )e j!⌧ d⌧
1
Z 1 Z 1
0
= RY,X ( ⌧ )e j!⌧ d⌧ = RX,Y (⌧ 0 )ej!⌧ d⌧ 0 ,
1 1

which is exactly the conjugate SY,X (!).



When sending the random process through an LTI system, the cross-correlation power
spectral density is given by the theorem below.

Theorem 10.8. If X(t) passes through an LTI system to yield Y (t), then the cross
power spectral density is

SY,X (!) = H(!)SX (!),


SX,Y (!) = H(!)SX (!).

Proof. By taking the Fourier transform on RY,X (⌧ ) we have that SY,X (!) = H(!)SX (!).
Since RX,Y (⌧ ) = RY,X ( ⌧ ), it holds that SX,Y (!) = H(!)SX (!).

Example 10.19. Let X(t) be a WSS random process with


⌧ 2 /2 ! 2 /2
RX (⌧ ) = e , H(!) = e .

Find SX,Y (!), RX,Y (⌧ ), SY (!) and RY (⌧ ).

Solution. First, by the Fourier transform table we know that


p 2
SX (!) = 2⇡e ! /2 .
! 2 /2
Since H(!) = e , we have

SX,Y (!) = H(!)SX (!)


p 2
= 2⇡e ! .

The cross-correlation function is


hp i
1 !2
RX,Y (!) = F 2⇡e
1 ⌧2
=p e 4 .
2

652
10.6. OPTIMAL LINEAR FILTER

The power spectral density of Y (t) is

SY (!) = |H(!)|2 SX (!)


p 3! 2
= 2⇡e 2 .

Therefore, the autocorrelation function of Y (t) is


hp 3! 2
i
RY (⌧ ) = F 1 2⇡e 2

1 ⌧ 2 /6
=p e .
3

10.6 Optimal Linear Filter

In the previous sections, we have built many tools to analyze random processes. Our next
goal is to apply these techniques. To that end, we will discuss optimal linear filter design,
which is a set of estimation techniques for predicting and recovering information from a time
series.

10.6.1 Discrete-time random processes


We begin by introducing some notations. In the previous sections, we have been using
continuous-time random processes to study statistics. In this section, we mainly focus on
discrete-time random processes. The shift from continuous-time to discrete-time is straight-
forward as far as the theories are concerned — we switch the continuous-time index t to
a discrete-time index n. However, shifting to discrete-time random processes can simplify
many difficult problems because many discrete-time problems can be solved by matrices and
vectors. This will make the computations and implementations much easier. To make this
transition easier, we provide a few definitions and results without proof.

Notations for discrete-time random processes


We denote the discrete-time indices by m and n, corresponding to the continuous-
time indices t1 and t2 , respectively.
A discrete-time random process is denoted by X[n].
Its mean function and the autocorrelation function are

µX [n] = E[X[n]],
RX [m, n] = E[X[m]X[n]].

We say that X[n] is WSS if µX [n] = constant, and RX [m, n] is a function of


m n.

653
CHAPTER 10. RANDOM PROCESSES

If X[n] is WSS, we write RX [m, n] as

RX [m, n] = RX [m n] = RX [k],

where k = m n is the interval.


If X[n] is WSS, we define the power spectral density as

SX (ej! ) = F{RX [k]},

where SX (ej! ) denotes the discrete-time Fourier transform.

When a random process X[n] is sent through an LTI system with an impulse response
h[n], the output is
X1
Y [n] = h[n] ⇤ X[n] = h[k]X[n k]. (10.33)
k= 1

When a WSS process X[n] passes through an LTI system h[n] to yield an output Y [n],
the auto- and cross-correlation function and power spectral densities are
RY [k] = E[Y [n + k]Y [n]], SY (ej! ) = F{RY [k]} = |H(ej! )|2 SX (ej! ).
RXY [k] = E[X[n + k]Y [n]], SXY (ej! ) = F{RXY [k]} = H(ej! )SX (ej! ).
RY X [k] = E[Y [n + k]X[n]], SY X (ej! ) = F{RY X [k]} = H(ej! )SX (ej! ).

10.6.2 Problem formulation


The problem we study here is known as the optimal linear filter design. Suppose that there
is a WSS process X[n] that we want to process. For example, if X[n] is a corrupted version
of some clean time-series, we may want to remove the noise by filtering (also known as
averaging) X[n]. Conceptualizing the denoising process as a linear time-invariant system
with an impulse response h[n], our goal is to determine the optimal h[n] such that the
estimated time series Yb [n] is as close to the true time series Y [n] as possible.
Referring to Figure 10.24, we refer to X[n] as the input function and to Y [n] as the
target function. X[n] and Y [n] are related according to the equation
K
X1
Y [n] = h[k]X[n k] + E[n], (10.34)
k=0
| {z }
b [n]
Y

where E[n] is a noise random process to model the error. The linear part of the equation
is known as the prediction and is constructed by sending X[n] through the system. For
simplicity we assume that X[n] is WSS. Thus, it follows that Y [n] is also WSS. We may
also assume that we can estimate RX [k], RY X [k], RXY [k] and RY [k].

654
10.6. OPTIMAL LINEAR FILTER

Figure 10.24: A schematic diagram illustrating the optimal linear filter problem: Given an input function
X[n], we want to design a filter h[n] such that the prediction Yb [n] is close to the target function Y [n].

Example 10.20. If we let K = 3, Equation (10.34) gives us

Y [n] = h[0]X[n] + h[1]X[n 1] + h[2]X[n 2] + E[n].

That is, the current sample Y [n] is a linear combination of the previous samples X[n],
X[n 1] and X[n 2].

Given X[n] and Y [n], what would be the best guess of the impulse response h[n] so
that the prediction is as close to the true values as possible? From our discussions of linear
regression, we know that this is equivalent to solving the optimization problem

K
!2
X1
minimize Y [n] h[k]X[n k] . (10.35)
{h[k]}K 1
k=0 k=0

The choice of the squared error is more or less arbitrary, depending on how we want to
model E[n]. By using the square norm, we implicitly assume that the error is Gaussian.
This may not be true, but it is commonly used because the squared norm is di↵erentiable.
We will follow this tradition.
The challenge associated with the minimization is that in most of the practical set-
tings the random processes X[n] and Y [n] are changing rapidly because they are random
processes. Therefore, even if we solve the optimization problem, the estimates h[k] will be
random variables since we are solving a random equation. To eliminate this randomness, we
take the expectation over all the possible choices of X[n] and Y [n], yielding

K
!2
X1
minimize Y [n] h[k]X[n k] ,
{h[k]}K 1
k=0 k=0
+
2 !2 3
K
X1
minimize EX,Y 4 Y [n] h[k]X[n k] 5.
{h[k]}K 1
k=0 k=0

The resulting impulse responses h[k], derived by solving the above minimization, is
known as the optimal linear filter. It is the best linear model for describing the input-
output relationships between X[n] and Y [n].

655
CHAPTER 10. RANDOM PROCESSES

What is the optimal linear filter?


The optimal linear filter is the solution to the optimization problem
2 !2 3
KX1
minimize EX,Y 4 Y [n] h[k]X[n k] 5 . (10.36)
{h[k]}K 1
k=0 k=0

10.6.3 Yule-Walker equation


To solve the optimal linear filter problem, we first perform some (slightly tedious) algebra
to obtain the following results:

PK 1
Lemma 10.4. Let Yb [n] = k=0 h[k]X[n k] be the prediction of Y [n]. The squared-
norm error can be written as
⇣ ⌘2
EX,Y Y [n] Yb [n]
K
X1 K
X1 K
X1
= RY [0] 2 h[k]RY X [k] + h[k]h[j]RX [j k]. (10.37)
k=0 k=0 j=0

Thus we can express the error in terms of RY X [k], RX [k] and RY [k].

Proof. We expand the error as follows:


⇣ ⌘2 h i h i
⇥ ⇤
EX,Y Y [n] Yb [n] = EY (Y [n])2 2EX,Y Y [n]Yb [n] + EX (Yb [n])2 .

The first term is the autocorrelation of Y [n]:


⇥ ⇤
EY (Y [n])2 = E [Y [n + 0]Y [n]] = RY [0]. (10.38)

The second term is


" #
h i K
X1
EX,Y b
Y [n]Y [n] = EX,Y Y [n] h[k]X[n k]
k=0
K
X1
= h[k]EX,Y [Y [n]X[n k]]
k=0
K
X1
= h[k]RY X [k]. (10.39)
k=0

656
10.6. OPTIMAL LINEAR FILTER

The third term is


2 ! 0K 1 13
h i K
X1 X
EX (Yb [n])2 = EX 4 h[k]X[n k] @ h[j]X[n j]A5
k=0 j=0
2 3
K
X1 K
X1
= EX 4 h[k]h[j]X[n k]X[n j]5
k=0 j=0
K
X1 K
X1
= h[k]h[j]EX [X[n k]X[n j]]
k=0 j=0
K
X1 K
X1
= h[k]h[j]RX [j k]. (10.40)
k=0 j=0

This completes the proof.



The significance of this theorem is that it allows us to write the error in terms of RY X [k],
RX [k] and RY [k]. As we have mentioned, while we can solve the randomized optimization
Equation (10.35), the resulting solution will be a random vector depending on the particular
realizations X[n] and Y [n]. Switching from Equation (10.35) to Equation (10.36) eliminates
the randomness because we have taken the expectation. The resulting optimization according
to the theorem is also convenient. Instead of seeking individual realizations, we only need
to know the overall statistical description of the data through RY X [k], RX [k] and RY [k].
These can be estimated through modeling or pseudorandom signals.
The solution to the optimal linear filter problem is summarized by the Yule-Walker
equation:

Theorem 10.9. The solution {h[0], . . . , h[K 1]} to the optimal linear filter problem
2 !2 3
K
X1
minimize EX,Y 4 Y [n] h[k]X[n k] 5 (10.41)
{h[k]}K 1
k=0 k=0

is given by the following matrix equation:


0 1
0 1 RX [0] RX [1] ··· RX [K 1] 0 1
RY X [0] h[0]
B . C
B RY X [1] C B .. CB h[1] C
B C B RX [1] RX [0] ··· CB C
B .. C=B CB .. C, (10.42)
@ . A B .. .. .. .. C@ . A
@ . . . . A
RY X [K 1] h[K 1]
RX [K 1] RX [k 2] ··· RX [0]

which is known as the Yule-Walker equation.

Therefore, by solving the simple linear problem given by the Yule-Walker equation, we will
find the optimal linear filter solution.
Proof. Since the error is a squared norm, the optimal solution is obtained by taking the

657
CHAPTER 10. RANDOM PROCESSES

derivative:
⇣ ⌘2
d
EX,Y Y [n] Yb [n]
dh[i]
8 9
d < =
KX1 K
X1 K
X1
= RY [0] 2 h[k]RY X [k] + h[k]h[j]RX [j k]
dh[i] : ;
k=0 k=0 j=0
K
X1
=0 2RY X [i] + 2 h[k]RX [i k],
k=0

in which the derivative of the last term is computed by noting that


K 1K 1
d X X
h[k]h[j]RX [j k]
dh[i] j=0
k=0
K 1 K 1
d X d XX
= h[j]2 RX [0] + h[k]h[j]RX [j k]
dh[i] j=0 dh[i]
k=0 j6=k
K
X1
=2 h[k]RX [i k].
k=0

Equating the derivative to zero yields


K
X1
RY X [i] = h[k]RX [i k], i = 0, . . . , K 1,
k=0

and putting the above equations into the matrix-vector form we complete the proof.

The matrix in the Yule-Walker equation is a Toeplitz matrix, in which each row is
a shifted version of the preceding row. This matrix structure is a consequence of a WSS
process so that the autocorrelation function is determined by the time di↵erence k and not
by the starting and end times.
Remark. If we take the derivative of the loss w.r.t. h[i], we have that
⇣ ⌘2 h⇣ ⌘ i
d
0= EX,Y Y [n] Yb [n] = 2E Y [n] Yb [n] X[n i] .
dh[i]

This condition is known as the orthogonality condition, as it says that the error Y [n] Yb [n]
is orthogonal to the signal X[n i].

10.6.4 Linear prediction


We now demonstrate how to use the Yule-Walker equation in modeling an autoregressive
process. The procedure in this simple example can be used in speech processing and time-
series forecasting.
Suppose that we have a WSS random process Y [n]. We would like to predict the future
samples by using the most recent K samples through an autoregressive model. Since the

658
10.6. OPTIMAL LINEAR FILTER

model is linear, we can write


K
X
Yb [n] = h[k]Y [n k] + E[n]. (10.43)
k=1

In this model, we say that the predicted value Yb [n] is a linear combination of the past K
samples, albeit to approximation error E[n].
The problem we need to solve is
⇣ ⌘2
minimize E Y [n] Yb [n] .
h[k]

Since Yb [n] is written in terms of the past samples of Y [n] in this problem, in the Yule-Walker
equation we can replace X with Y . Consequently, we can write the matrix equation from
0 1 0 10 1
RY X [0] RX [0] RX [1] ··· RX [K 1] h[0]
B RY X [1] C B RX [1] RX [0] ··· RX [K 2] C B h[1] C
B C B CB C
B . C=B .. .. .. .. CB .. C,
@ .. A @ . . . . A@ . A
RY X [K 1] RX [K 1] RX [k 2] ··· RX [0] h[K 1]

to 0 1 0 10 1
RY [1] RY [0] RY [1] ··· RY [K 1] h[0]
B RY [2] C B RY [1] RY [0] ··· RY [K 2] C B h[1] C
B C B CB C
B .. C=B . . .. . CB .. C. (10.44)
@ . A @ .. .. . .. A@ . A
RY [K] RY [K 1] RY [k 2] ··· RY [0] h[K 1]
| {z } | {z }
r R
On a computer, solving the Yule-Walker equation requires a few steps. First, we need
to estimate the correlation
N
1 X
RY [k] = E[Y [n + k]Y [n]] ⇡ Y [n + k]Y [n].
N n=1

The averaging on the right-hand side is often done using xcorr in MATLAB or np.correlate
in Python. A graphical illustration of the input and the autocorrelation function is shown
in Figure 10.25.
After we have found RY [n], we need to construct the Yule-Walker equation. For this
linear prediction problem, the left-hand side of the Yule-Walker equation is the vector r,
defined according to Equation (10.44). The Yule-Walker equation also requires the matrix R.
This R can be constructed via the Toeplitz matrix as

R = Toeplitz RY [0], RY [1], . . . , RY [K 1] .

In MATLAB, we can call Toeplitz to construct the matrix. In Python, the command is
lin.Toeplitz.
To solve the Yule-Walker equation, we need to invert the matrix R. There are built-in
commands for such an operation. In MATLAB, the command is \ (the backslash), whereas
in Python the command is np.linalg.lstsq.

659
CHAPTER 10. RANDOM PROCESSES

0.2 0.4
Y[n] R Y[k]
0.3
0.1
0.2

0 0.1

0
-0.1
-0.1

-0.2 -0.2
0 50 100 150 200 250 300 -300 -200 -100 0 100 200 300
(a) Y [n] (b) RY [k]

Figure 10.25: An example time-series and its autocorrelation function.

% MATLAB code to solve the Yule Walker Equation


y = load(’data_ch10.txt’);
K = 10;
N = 320;

y_corr = xcorr(y);
R = Toeplitz(y_corr(N+[0:K-1]));
lhs = y_corr(N+[1:K]);
h = R\lhs;

# Python code to solve the Yule Walker Equation


y = np.loadtxt(’./data_ch10.txt’)
K = 10
N = 320

y_corr = np.correlate(y,y,mode=’full’)
R = lin.Toeplitz(y_corr[N-1:N+K-1]) #call scipy.linalg
lhs = y_corr[N:N+K]
h = np.linalg.lstsq(R,lhs,rcond = None)[0]

Note that in both the MATLAB and Python codes the Toeplitz matrix R starts with
the index N . This is because, as you can see from Figure 10.25, the origin of the autocor-
relation function is the middle index of the computed autocorrelation function. For r, the
starting index is N + 1 because the vector starts with RY [1].
To predict the future samples, we recall the autoregressive model for this problem:
K
X1
Yb [n] = h[k]Y [n k].
k=0

Therefore, given Y [n 1], Y [n 2], . . . , Y [n K], we can predict Yb [n]. Then we insert this
predicted Yb [n] into the sequence and increment the estimation problem to the next time
index. By repeating the process, we will be able to predict the future samples of Y [n].

660
10.6. OPTIMAL LINEAR FILTER

Figure 10.26 illustrates the prediction results of the Yule-Walker equation. As you can
see, the predictions are reasonably meaningful since the patterns follow the trend.
0.2

0.1

-0.1

-0.2
Prediction
Input
-0.3
0 50 100 150 200 250 300 350

Figure 10.26: An example of the predictions made by the autoregressive model.

The MATLAB and Python codes are shown below.

% MATLAB code to predict the samples


z = y(311:320);
yhat = zeros(340,1);
yhat(1:320) = y;

for t = 1:20
predict = z’*h;
z = [z(2:10); predict];
yhat(320+t) = predict;
end

plot(yhat, ’r’, ’LineWidth’, 3); hold on;


plot(y, ’k’, ’LineWidth’, 4);

# Python code to predict the samples


z = y[310:320]
yhat = np.zeros((340,1))
yhat[0:320,0] = y

for t in range(20):
predict = np.inner(np.reshape(z,(1,10)),h)
z = np.concatenate((z[1:10], predict))
yhat[320+t,0] = predict

plt.plot(yhat,’r’)
plt.plot(y,’k’)
plt.show()

661
CHAPTER 10. RANDOM PROCESSES

10.6.5 Wiener filter


In the previous formulation, we notice that the impulse response has a finite length. There
are, however, problems in which the impulse response is infinite. For example, a recur-
sive filter h[n] will be infinitely long. The extension from finite length to infinite length is
straightforward. We can model the problem as
1
X
Y [n] = h[k]X[n k] + E[n].
k= 1

However, when h[n] is infinitely long the Yule-Walker equation does not hold because the
matrix R will be infinitely large. Nevertheless, the building block equation for Yule-Walker
is still valid:
1
X
RY X [i] = h[k]RX [i k]. (10.45)
k= 1

To maintain the spirit of the Yule-Walker equation while enabling computation, we


recognize that the infinite sum on the right-hand side is, in fact, a convolution. Thus we
can take the (discrete-time) Fourier transform of both sides to obtain

SY X (ej! ) = H(ej! )SX (ej! ). (10.46)

Therefore, the corresponding optimal linear filter (in the Fourier domain) is

SY X (ej! )
H(ej! ) = , (10.47)
SX (ej! )

and ⇢ j!
1 SY X (e )
h[n] = F j! )
.
SX (e
The filter obtained in this way is known as the Wiener filter.

Example 10.21. (Denoising) Suppose X[n] = Y [n] + W [n], where W [n] is the noise
term that is independent of Y [n], as shown in Figure 10.27.

Figure 10.27: Design of a Wiener filter that takes an input function X[n] and outputs an estimate
Yb [n] that is close to the true function Y [n].
Now, given the input function X[n], can we construct the Wiener filter h[n] such
that the predicted function Yb [n] is as close to Y [n] as possible? The Wiener filter for
this problem is also the optimal denoising filter.

662
10.6. OPTIMAL LINEAR FILTER

Solution. The following correlation functions can easily be seen:

RX [k] = E[X[n + k]X[n]]


= E[(Y [n + k] + W [n + k])(Y [n] + W [n])]
= E[Y [n + k]Y [n]] + E[Y [n + k]W [n]]
+ E[W [n + k]Y [n]] + E[W [n + k]W [n]]
= E[Y [n + k]Y [n]] + 0 + 0 + E[W [n + k]W [n]]
= RY [k] + RW [k].

Similarly, we have

RY X [k] = E[Y [n + k]X[n]]


= E[Y [n](Y [n + k] + W [n + k])] = RY [k].

Consequently, the optimal linear filter is

SY X (ej! )
H(ej! ) =
SX (ej! )
F{RY X [k]}
=
F{RX [k]}
SY (ej! )
= .
SY (e ) + SW (ej! )
j!

What is the Wiener filter for a denoising problem?

Suppose the corrupted function X[n] is related to the clean function Y [n] through
X[n] = Y [n] + W [n], for some noise function W [n].
The Wiener filter is
SY (ej! )
H(ej! ) = . (10.48)
SY (e ) + SW (ej! )
j!

To perform the filtering, the denoised function Yb [n] is

Yb [n] = F 1
H(ej! )X(ej! ) .

Figure 10.28 shows an example of applying the Wiener filter to a noise removal prob-
lem. In this example we let W [n] be an i.i.d. Gaussian process with standard deviation
= 0.05 and mean µ = 0. The noisy samples of random process X[n] are defined as
X[n] = Y [n] + W [n], where Y [n] is the clean function. As you can see from Figure 10.28(a),
the Wiener filter is able to denoise the function reasonably well.
The optimal linear filter used for this denoising task is infinitely long. This can be seen
in Figure 10.28(b), where the filter length is the same as the length of the observed time
series X[n]. If X[n] is longer, the filter h[n] will also become longer. Therefore, finite-length
approaches such as the Yule-Walker equation do not apply here.

663
CHAPTER 10. RANDOM PROCESSES

0.2
0.25 h[n]

0.1
0.2

0.15
0
0.1
-0.1
0.05
Noisy Input X[n]
Wiener Filtered Yhat[n] 0
-0.2
Ground Truth Y[n]
-0.05
0 50 100 150 200 250 300 -300 -200 -100 0 100 200 300

(a) Noise removal by Wiener filtering (b) Wiener filter

Figure 10.28: (a) Applying a Wiener filter to denoise a function. (b) The Wiener filter used for the
denoising task.

The MATLAB / Python codes used to generate Figure 10.28(a) are shown below.
The main commands here are scipy.fft and scipy.ifft, which are available in the scipy
library. The commands Yhat = H.*fft(x, 639) in MATLAB execute the Wiener filtering
step. Here, we resample the function x to 639 samples so that it matches with the Wiener
filter H. Similar commands in Python are H * fft(x, 639).
% MATLAB code for Wiener filtering
w = 0.05*randn(320,1);
x = y + w;

Ry = xcorr(y);
Rw = xcorr(w);
Sy = fft(Ry);
Sw = fft(Rw);
H = Sy./(Sy + Sw);
Yhat = H.*fft(x, 639);
yhat = real(ifft(Yhat));

plot(x, ’LineWidth’, 4, ’Color’, [0.7, 0.7, 0.7]); hold on;


plot(yhat(1:320), ’r’, ’LineWidth’, 2);
plot(y, ’k:’, ’LineWidth’, 2);

# Python code for Wiener filtering


from scipy.fft import fft, ifft
w = 0.05*np.random.randn(320)
x = y + w

Ry = np.correlate(y,y,mode=’full’)
Rw = np.correlate(w,w,mode=’full’)
Sy = fft(Ry)
Sw = fft(Rw)
H = Sy / (Sy+Sw)
Yhat = H * fft(x, 639)

664
10.6. OPTIMAL LINEAR FILTER

yhat = np.real(ifft(Yhat))

plt.plot(x,color=’gray’)
plt.plot(yhat[0:320],’r’)
plt.plot(y,’k:’)

Example 10.22. (Deconvolution) Suppose that the corrupted function is generated


according to a linear process given by
1
X
X[n] = g[`]Y [n `] + W [n],
`= 1

where g[n] is the impulse response of some kind of degradation process and W [n] is
the Gaussian noise term, as shown in Figure 10.29. Find the optimal linear filter (i.e.,
the Wiener filter) to estimate Yb [n].

Figure 10.29: Design of a Wiener filter that takes an input function X[n] and outputs an estimate
Yb [n] that is close to the true function Y [n].

Solution. To construct the Wiener filter, we first determine the cross-correlation func-
tion:
" 1
#
X
RY X [k] = E [Y [n + k]X[n]] = E Y [n + k] g[`]Y [n `] + W [n] .
`= 1

Using algebra, it follows that


" 1
#
X
E Y [n + k] g[`]Y [n `] + W [n]
`= 1
1
X
= g[`]E[Y [n + k]Y [n `]] + E[Y [n + k]W [n]]
`= 1
X1
= g[`]RY [k + `] + 0 = (g ~ RY )[k],
`= 1

which is the correlation between g and RY . Therefore, the cross power spectral density
SY X (ej! ) is

SY X (ej! ) = G(ej! )SY (ej! ).

665
CHAPTER 10. RANDOM PROCESSES

The autocorrelation of this problem is

RX [k] = E [X[n + k]X[n]]


= E [((g ⇤ Y )[n + k] + W [n + k])((g ⇤ Y )[n] + W [n])]
= E [(g ⇤ Y )[n + k](g ⇤ Y )[n]] + E[W [n + k]W [n]]
= (g ~ (g ⇤ RY ))[k] + RW [k],

where, according to the previous section, the first part is the correlation ~ followed by
a convolution ⇤. Therefore, the power spectral density of X is

SX (ej! ) = |G(ej! )|2 SY (ej! ) + SW (ej! ).

Combining the results, the Wiener filter is

SY X (ej! ) G(ej! )SY (ej! )


H(ej! ) = = .
SX (ej! ) |G(ej! )|2 SY (ej! ) + SW (ej! )

What is the Wiener filter for a deconvolution problem?

Suppose that the corrupted function X[n] is related to the clean function Y [n]
through X[n] = (g ⇤ Y )[n] + W [n], for some degradation g[n] and noise W [n].

The Wiener filter is

G(ej! )SY (ej! )


H(ej! ) = . (10.49)
|G(ej! )|2 SY (ej! ) + SW (ej! )

To perform the filtering, the estimated function Yb [n] is

Yb [n] = F 1
H(ej! )X(ej! ) .

As an example of the deconvolution problem, we show a WSS function Y [n] in Fig-


ure 10.30. This clean function Y [n] is constructed by passing an i.i.d. noise process through
an arbitrary LTI system so that the WSS property is guaranteed. Given this Y [n], we con-
struct a degradation process in which the impulse response is given by g[n]. In this example,
we assume that g[n] is a uniform function. We then add noise W [n] to the time series to
obtain the corrupted observation X[n]. The reconstruction by the Wiener filter is shown in
Figure 10.30.
The MATLAB and Python codes used to generate Figure 10.30 are shown below.
% MATLAB code to solve the Wiener deconvolution problem
load(’ch10_wiener_deblur_data’);
g = ones(32,1)/32;
w = 0.02*randn(320,1);
x = conv(y,g,’same’) + w;

Ry = xcorr(y);

666
10.6. OPTIMAL LINEAR FILTER

0.6

0.4

0.2

-0.2

-0.4
Noisy Input X[n]
-0.6 Wiener Filtered Yhat[n]
Ground Truth Y[n]
-0.8
50 100 150 200 250 300

Figure 10.30: Reconstructing time series from degraded observations using a Wiener filter.

Rw = xcorr(w);
Sy = fft(Ry);
Sw = fft(Rw);
G = fft(g,639);

H = (conj(G).*Sy)./(abs(G).^2.*Sy + Sw);
Yhat = H.*fft(x, 639);
yhat = real(ifft(Yhat));

figure;
plot(x, ’LineWidth’, 4, ’Color’, [0.5, 0.5, 0.5]); hold on;
plot(16:320+15, yhat(1:320), ’r’, ’LineWidth’, 2);
plot(1:320, y, ’k:’, ’LineWidth’, 2);

# Python code to solve the Wiener deconvolution problem


y = np.loadtxt(’./ch10_wiener_deblur_data.txt’)
g = np.ones(64)/64
w = 0.02*np.random.randn(320)
x = np.convolve(y,g,mode=’same’) + w

Ry = np.correlate(y,y,mode=’full’)
Rw = np.correlate(w,w,mode=’full’)
Sy = fft(Ry)
Sw = fft(Rw)
G = fft(g,639)
H = (np.conj(G)*Sy)/( np.power(np.abs(G),2)*Sy + Sw )

Yhat = H * fft(x, 639)


yhat = np.real(ifft(Yhat))

plt.plot(x,color=’gray’)

667
CHAPTER 10. RANDOM PROCESSES

plt.plot(np.arange(32,320+32),yhat[0:320],’r’)
plt.plot(y,’k:’)

Caveat to Wiener filtering. In practice, the above Wiener filter needs to be modified
because SY (ej! ) and SW (ej! ) cannot be estimated from the data via the temporal corre-
lation (as we did in the MATLAB/Python programs). The reason is that we never have
access to Y [n] and W [n]. In this case, one has to guess the power spectral densities SY (ej! )
and SW (ej! ). The noise power SW (ej! ) is usually not difficult to estimate. For example,
in the program we showed above, the noise power spectral density is Sw = 0.02^2*320
(MATLAB), which is the noise standard deviation times the number of samples.
The signal SY (ej! ) is often the hard part. In the absence of any knowledge about the
ground truth’s power spectral density, the Wiener filter does not work. However, for certain
problems in which SY (ej! ) can be predetermined by prior knowledge, the Wiener filter is
guaranteed to be optimal — optimal in the mean-squared-error sense over the entire time
axis.
Wiener filter versus ridge regression. The Wiener filter equation can be interpreted
as a ridge regression. Denoting the forward observation model by

x = Gy + w,

the corresponding ridge regression minimization is

yb = argmin kx Gyk2 + kyk2


y

= (GT G + I) 1
GT x.

If G is a convolutional matrix, the above solution can be written in the Fourier domain (by
using the Fourier transform as the eigenvectors):
" #
G(e j! )
Yb (ej! ) = X(ej! ).
|G(ej! )|2 +
| {z }
H(ej! )

Comparing this “optimal linear filter” with the Wiener filter, we observe that the Wiener
filter has slightly more generality:
" #
b j! G(ej! )SY (ej! )
Y (e ) = X(ej! ).
|G(ej! )|2 SY (ej! ) + SW (ej! )

Therefore, in the absence of SY (ej! ) and assuming that SW (ej! ) is a constant (e.g., for
Gaussian noise), the Wiener filter is exactly a ridge regression.

668
10.7. SUMMARY

10.7 Summary

Random processes are very useful tools for analyzing random variables over time. In this
chapter, we have introduced some of the most basic mechanisms:
Statistical versus temporal analysis: The statistical analysis of a random process
looks at the random process vertically. It treats X(t) as a random variable and studies
the randomness across di↵erent realizations. The temporal analysis is the horizontal
perspective. It treats X(t) as a function in time with a fixed random index. In general,
statistical average 6= temporal average.
Mean function µX (t): The mean function is the expectation of the random process.
At every time t, we take the expectation to obtain the expected value E[X(t)].
Autocorrelation function RX (t1 , t2 ). This is the joint expectation of the random pro-
cess at two di↵erent time instants t1 and t2 . The corresponding values X(t1 ) and X(t2 )
are two random variables, and so the joint expectation measures how correlated these
two variables are.
Wide-sense stationary (WSS): This is a special class of random processes in which
µX (t) is a constant and RX (t1 , t2 ) is a function of t1 t2 . When this happens, the auto-
correlation function (which is originally a 2D function) will have a Toeplitz structure.
We write RX (t1 , t2 ) as RX (⌧ ), where ⌧ = t1 t2 .
Power spectral density (PSD): This is the Fourier transform of the autocorrelation
function RX (⌧ ), according to the Einstein-Wiener-Khinchin theorem. It is called the
power spectral density because we can integrate it in the Fourier space to retrieve the
power. This provides us with some convenient computational tools for analyzing data.
Random process through a linear time-invariant (LTI) system: This tells us how a
random process behaves after going through an LTI system. The analysis can be done
at the realization level, where we look at each random process, or at the statistical
level, where we look at the autocorrelation function and the PSD.
Optimal linear filter: A set of techniques that can be used to retrieve signals by using
the statistical information of the data and the system. We introduced two specific
approaches: the Yule-Walker equation for a finite-length filter and the Wiener filter
for an infinite-length filter. We demonstrated how these techniques could be applied
to forecast a time series and recover a time series from corrupted measurements.
While we have covered some of the most basic ideas in random processes, there are
also several topics we have not discussed. These include, but are not limited to: strictly
stationary process, a more restrictive class of random process than WSS; Poisson process,
a useful model for arrival analysis; Markov chain, a discrete-time random process where
the current state only depends on the previous state. Readers interested in these materials
should consult the references listed at the end of this chapter.

669
CHAPTER 10. RANDOM PROCESSES

10.8 Appendix

The Einstein-Wiener-Khinchin theorem


The Einstein-Wiener-Khinchin theorem is a fundamental result. It states that for any wide-
sense stationary process, the power spectral density SX (!) is the Fourier transform of the
autocorrelation function.

Theorem 10.10 (The Einstein-Wiener-Khinchin theorem). For a WSS random pro-


cess X(t),
SX (!) = F {RX (⌧ )} , (10.50)
whenever the Fourier transform of RX (⌧ ) exists.

Proof. First, let’s recall the definition of SX (!):

def 1 h e i
SX (!) = lim E |XT (!)|2 . (10.51)
T !1 2T

By expanding the expectation, we have


" Z ! Z !⇤ #
T T
e 2
E[|XT (!)| ] = E X(t)e j!t
dt X(✓)e j!✓
d✓
T T
Z T Z T Z T Z T
j!(t ✓) j!(t ✓)
= E [X(t)X(✓)] e dt d✓ = RX (t ✓)e dt d✓.
T T T T
(10.52)

Our next step is to analyze RX (t ✓). Define

QX (v) = F {RX (⌧ )} . (10.53)

Then, by inverse Fourier transform


Z 1
1
RX (⌧ ) = QX (v)ejv⌧ dv,
2⇡ 1

and therefore Z 1
1
RX (t ✓) = QX (v)ejv(t ✓)
dv.
2⇡ 1

Substituting this into Equation (10.52) yields


Z T Z T ✓ Z 1 ◆
e 2 1 jv(t ✓)
E[|XT (!)| = QX (v)e dv e j!(t ✓) dt d✓
T T 2⇡ 1
Z 1 Z T ! Z !
T
1
= QX (v) ejt(v !) dt ej✓(! v) d✓ dv.
2⇡ 1 T T

670
10.8. APPENDIX

We now need to simplify the two inner integrals. Recall by Fourier pair that
✓ ◆ ✓ ◆
t !T
rect F T sinc .
T ! 2
This implies that
Z T Z T
jt(v !) j(! v)t
e dt = e dt
T T
Z 1
t j(! v)t sin((! v)T )
= rect( )e dt = 2T sinc((! v)T ) = 2T .
1 2T (! v)T

Hence, we have
h i Z 1 ✓ ◆2
e 2 1 sin((! v)T )
E |XT (!)| = QX (v) 2T dv. (10.54)
2⇡ 1 (! v)T

and so Z ✓ ◆2
1
1 eT (!)|2 = 2T sin((! v)T )
E[|X QX (v) dv. (10.55)
2T 2⇡ 1 (! v)T
As T ! 1 (see Lemma 10.5 below), we have
✓ ◆2
sin((! v)T )
2T ! 2⇡ (! v).
(! v)T
Therefore,
Z 1 " ✓ ◆2 #
1 h e 2
i 1 sin((! v)T )
lim E |XT (!)| = QX (v) lim 2T dv
T !1 2T 2⇡ 1 T !1 (! v)T
Z 1
= QX (v) (! v) dv = QX (!).
1

Since QX (!) = F[RX (⌧ )], we conclude that


1 eT (!)|2 ] = QX (!) = F[RX (⌧ )].
SX (!) = lim E[|X
T !1 2T

Lemma 10.5.
Z 1 ✓ ◆2
1 sin((! v)T )
lim QX (v)2T dv = QX (!). (10.56)
T !1 2⇡ 1 (! v)T

To prove this lemma, we first define T (!) = 2T ( sin(!T ) 2


!T ) . It is sufficient to show that
Z 1 ✓ ◆2
1 sin((! v)T )
lim QX (v)2T dv QX (!) ! 0 as T ! 1. (10.57)
T !1 2⇡ 1 (! v)T

We will proceed by demonstrating the following three facts about T (!):

671
CHAPTER 10. RANDOM PROCESSES

1. Z 1
1
T (!) d! = 1
2⇡ 1
.
2. For any 4 > 0, Z
T (!) d! ! 0 as T !1
{!:|!|>4}
.
2
3. For any |!| 4 > 0, we have | T (!)|  T 42 .

Proof of Fact 1.
Z 1 Z 1 ✓ ◆2
1 1 sin(!T )
T (!) d! = 2T d!.
2⇡ 1 2⇡ 1 !T
| {z }
sinc2 (!T )

Note that ✓ ◆
t
⇤ ! 2T sinc2 (!T ).
4T
Therefore,
Z 1 Z 1
1 1
2T sinc2 (!T ) d! = 2T sinc2 (!T )ej!0 d!
2⇡ 1 2⇡ 1
✓ ◆
0
=⇤ = 1.
4T

Proof of Fact 2. T (!) is symmetric, so, it is sufficient to check only one side:
Z 1 Z 1 ✓ ◆2
sin(!t)
T (!) d! = 2T d!
4 4 !T
Z
2T 1 sin2 (!t)
= d!
T2 4 !2
Z
2 1 1
 d! | sin(.)|2  1
T 4 !2
 1
2 1 2
= = ! 0 as T ! 1.
T ! 4 T4

Proof of Fact 3.
✓ ◆2 ✓ ◆
sin(!T ) 1 2 2
| T (!)| = 2T  2T =  .
!T (!T )2 !2 T T 42

Proof of Lemma. Consider QX (!). By Property 1,


Z 1 Z 1
1 1
QX (!) = QX (!). T (! v) dv = QX (!) T (! v) dv.
2⇡ 1 2⇡ 1

672
10.8. APPENDIX

Therefore,
Z 1
1
QX (v) T (! v) dv QX (!)
2⇡ 1
Z 1 Z 1
1 1
= QX (v) T (! v) dv QX (!) T (! v) dv
2⇡ 1 2⇡ 1
Z 1 Z 1
1 1
= (QX (v) QX (!)) T (! v) dv  QX (v) QX (!) T (! v) dv.
2⇡ 1 2⇡ 1

For any ✏ > 0, let 4 be a constant such that


|! v| < 4 whenever |QX (v) QX (!)| < ✏.
Then we can partition the above integral into
Z 1 Z !+4
1 1
QX (!) QX (v) T (! v) dv = QX (!) QX (v) T (! v) dv (1)
2⇡ 1 2⇡ ! 4
Z 1
1
+ QX (!) QX (v) T (! v) dv (2)
2⇡ !+4
Z !+4
1
+ QX (!) QX (v) T (! v) dv. (3)
2⇡ 1

Partition (1) above can be evaluated as follows:


Z !+4
1
QX (!) QX (v) T (! v) dv
2⇡ ! 4
Z !+4
1
 ✏ T (! v) dv
2⇡ ! 4
Z !+4

= T (! v) dv
2⇡ ! 4
Z 1

 T (! v) dv = ✏,
2⇡ 1

where the last inequality holds because T (! v) 0. Since ✏ can be arbitrarily small, the
only possibility for
Z !+4
1
QX (!) QX (v) T (! v) dv
2⇡ ! 4
for all ✏ is that the integral is 0.

Partition (2) above can be evaluated as follows:


Z 1
1
QX (!) QX (v) T (! v) dv
2⇡ !+4
Z 1
1
 QX (!) + QX (v) T (! v) dv
2⇡ !+4
Z 1 Z 1
1 1
= QX (!) T (! v) dv + QX (v) T (! v) dv.
2⇡ !+4 2⇡ !+4

673
CHAPTER 10. RANDOM PROCESSES

1
R1
By Property 2, 2⇡ !+4 T
(! v) dv ! 0 as T ! 1. By Property 3,
Z 1 Z 1
1 1 2
QX (v) T (! v) dv  QX (v) dv ! 0.
2⇡ !+4 2⇡ T 42 !+4
| {z }
<1 because QX (v)=F [RX (⌧ )]

Therefore, we conclude that


Z 1
1
QX (v) T (! v) dv ! 0 as T ! 1.
2⇡ !+4

and hence (1), (2) and (3) all ! 0 as T ! 1. So we have


Z 1 ✓ ◆2
1 sin((! v)T )
lim QX (v)2T dv QX (!) ! 0 as T ! 1,
T !1 2⇡ 1 (! v)T

which completes the proof.

10.8.1 The Mean-Square Ergodic Theorem


The mean-square ergodic theorem states that for any WSS random process, the statistical
average is the same as the temporal average. This provides an important tool in practice
because finding the statistical average is typically very difficult. With the mean ergodic
theorem, one can easily estimate the statistical average using the temporal average.

Theorem 10.11 (Mean-Square Ergodic Theorem). Let Y (t) be a WSS process,


with mean E[Y (t)] = m and autocorrelation function RY (⌧ ). Assume that the Fourier
transform of RY (⌧ ) exists. Define
Z T
def1
MT = Y (t) dt. (10.58)
2T T
h i
2
Then E MT m ! 0 as T ! 1.

Proof of Mean Ergodic Theorem. Let X(t) = Y (t) m. It follows that


Z T Z T
1 1
MT m= Y (t) dt m= X(t) dt.
2T T 2T T

We define the finite-window approximation of X(t):



X(t), T  t  T,
XT (t) =
0, elsewhere.

Then the di↵erence MT m can be computed as


Z T Z 1 eT (0)
1 1 j0t 1 e X
MT m= X(t) dt = X(t)e dt = XT (!) !=0
= .
2T T 2T 1 2T 2T

674
10.9. REFERENCES

Taking the expectation of the squares yields


h i
⇥ ⇤ E XeT (0) 2
E |MT m|2 = .
4T 2

Recall from the Einstein-Wiener-Khinchin theorem,


Z ✓ ◆2
1 h e 2
i 1 1
sin((! v)T )
E XT (!) = SX (v)2T dv.
2T 2⇡ 1 (! v)T

Putting the limit T ! 1, if we have that


Z 1 ✓ ◆2
1 sin((! v)T )
lim SX (v)2T dv = SX (!),
T !1 2⇡ 1 (! v)T

then we will have


1 h e 2
i 1 h e 2
i
E XT (!) ! SX (!) and E XT (0) ! SX (0).
2T 2T
Hence,
h i 1 h e i 1
2 2
lim E MT m = lim E XT (0) = lim SX (0) = 0.
T !1 T !1 2T T !1 2T

This completes the proof.

10.9 References

Basic texts
The following textbooks are basic texts about random processes. They o↵er many comple-
mentary materials to our book. For example, we omitted the topics of straightly stationary
processes and memoryless properties. We have also omitted a few classical examples, such
as the random telegraph signal, the incremental independence of Poisson processes, and
Markov chains. These materials can be found in the texts below.
10-1 John A. Gubner, Probability and Random Processes for Electrical and Computer En-
gineers, Cambridge University Press, Illustrated edition, 2006.
10-2 Alberto Leon-Garcia, Probability, Statistics, and Random Processes For Electrical En-
gineering, Pearson, 3rd Edition, 2007.
10-3 Athanasios Papoulis, S. Unnikrishna Pillai, Probability, Random Variables and Stochas-
tic Processes, McGraw-Hill, 4th Edition, 2012.
10-4 Henry Stark and John Woods, Probability and Random Processes With Applications
to Signal Processing, Prentice Hall, 3rd Edition, 2001.

675
CHAPTER 10. RANDOM PROCESSES

10-5 Eugene Wong and Bruce Hajek, Stochastic Processes in Engineering Systems, Springer-
Verlag, 1985.
10-6 Bruce Hajek, Random Processes for Engineers, Cambridge University Press, 2015.
10-7 Dimitri P. Bertsekas and John N. Tsitsiklis, Introduction to Probability, Athena Sci-
entific, 2nd Edition, 2008.
10-8 Robert G. Gallager, Stochastic Processes: Theory for Applications, Cambridge Uni-
versity Press, 1st Edition, 2014.

Signal and systems / Fourier transforms


The following references are classic references on signal and systems.
10-9 Alan Oppenheim and Ronald Schafer, Discrete-Time Signal Processing, 2nd Edition,
Prentice Hall 1999.
10-10 Alan Oppenheim and Alan Willsky, Signals and Systems, Pearson, 2nd Edition, 1996.
10-11 Martin Vetterli, Jelena Kovacevic, and Vivek K. Goyal, Foundations of Signal Pro-
cessing, Cambridge University Press, 3rd Edition, 2014.
10-12 Todd K. Moon and Wynn C. Stirling, Mathematical Methods and Algorithms for Signal
Processing, Prentice-Hall, 2000.

Engineering applications
10-13 John G. Proakis and Masoud Salehi, Communication Systems Engineering, Pearson,
2nd Edition, 2001.
10-14 Rodger E. Ziemer, William H. Tranter, Principles of Communications, Wiley, 7th
Edition, 2014.
10-15 Joseph W. Goodman, Statistical Optics, Wiley, 2015.

10.10 Problems

Exercise 1. (Video Solution)


Consider the random process

X(t) = 2A cos(t) + (B 1) sin(t),

where A and B are two independent random variables with E[A] = E[B] = 0, and E[A2 ] =
E[B 2 ] = 1.
(a) Find µX (t).
(b) Find RX (t1 , t2 ).

676
10.10. PROBLEMS

(c) Find CX (t1 , t2 ).

Exercise 2. (Video Solution)


Let X[n] be a discrete-time random process with mean function mX [n] = E{X[n]} and
correlation function RX [n, m] = E{X[n]X[m]}. Suppose that
1
X
Y [n] = h[n i]X[i]. (10.59)
i= 1

(a) Find µY [n].


(b) Find RXY [n, m].

Exercise 3. (Video Solution)


Let Y (t) = X(t) X(t d).
(a) Find RX,Y (⌧ ) and SX,Y (!).
(b) Find RY (⌧ ).
(c) Find SY (!).

Exercise 4. (Video Solution)


Let X(t) be a zero-mean WSS process with autocorrelation function RX (⌧ ). Let Y (t) =
X(t) cos(!t + ⇥), where ⇥ ⇠ uniform( ⇡, ⇡) and ⇥ is independent of the process X(t).
(a) Find the autocorrelation function RY (⌧ ).
(b) Find the cross-correlation function of X(t) and Y (t).
(c) Is Y (t) WSS? Why or why not?

Exercise 5. (Video Solution)


A WSS process X(t) with autocorrelation function

RX (⌧ ) = 1/(1 + ⌧ 2 )

is passed through an LTI system with impulse response

h(t) = 3 sin(⇡t)/(⇡t).

Let Y (t) be the system output. Find SY (!) and sketch SY (!).

Exercise 6. (Video Solution)


A white noise X(t) with power spectral density SX (!) = N0 /2 is applied to a lowpass filter
h(t) with impulse response
1 t/RC
h(t) = e , t > 0. (10.60)
RC
Find the followings.

677
CHAPTER 10. RANDOM PROCESSES

(a) SXY (!).


(b) RXY (⌧ ).
(c) SY (!).
(d) RY (⌧ ).

Exercise 7. (Video Solution)


Consider a WSS process X(t) with autocorrelation function

RX (⌧ ) = sinc(⇡⌧ ).

The process is sent to an LTI system with input-output relationship

d2 d d2 d
2 Y (t) + 2 Y (t) + 4Y (t) = 3 X(t) 3 X(t) + 6X(t).
dt2 dt dt2 dt
Find the autocorrelation function RY (⌧ ).

Exercise 8. (Video Solution)


Given the functions a(t), b(t) and c(t), let

g(t, 1) = a(t),
g(t, 2) = b(t),
g(t, 3) = c(t).

Let X(t) = g(t, Z), where Z is a discrete random variable with PMF P[Z = 1] = p1 ,
P[Z = 2] = p2 and P[Z = 3] = p3 . Find, in terms of the p1 , p2 , p3 , a(t), b(t) and c(t),
(a) µX (t).

(b) RX (t1 , t2 ).

Exercise 9.
|t|
In the previous problem, let a(t) = e , b(t) = sin(⇡t) and c(t) = 1.

(a) Choose p1 , p2 , p3 so that X(t) is WSS.


(b) Choose p1 , p2 , p3 so that X(t) is not WSS.

Exercise 10. (Video Solution)


Find the autocorrelation function RX (⌧ ) corresponding to each of the following power spec-
tral densities:
(a) (! !0 ) + (! + !0 ).
2
! /2
(b) e .
|!|
(c) e .

678
10.10. PROBLEMS

Exercise 11. (Video Solution)


2 2
A WSS process X(t) with autocorrelation function RX (⌧ ) = e ⌧ /(2 T ) is passed through
2 2
an LTI system with transfer function H(!) = e ! /(2 H ) . Denote the system output by
Y (t). Find the followings.
(a) SXY (!).
(b) RXY (⌧ ).
(c) SY (!).
(d) RY (⌧ ).

Exercise 12. (Video Solution)


A white noise X(t) with power spectral density SX (!) = N0 /2 is applied to a lowpass filter
h(t) with (
1 ! 2 , if |!|  ⇡,
H(!) =
0, otherwise.
Find E[|Y (t)|2 ], where Y (t) is the output of the filter.

Exercise 13. (Video Solution)


Let X(t) be a WSS process with correlation function
(
1 |⌧ |, if 1  ⌧  1,
RX (⌧ ) = (10.61)
0, otherwise.

It is known that when X(t) is input to a system with transfer function H(!), the system
output Y (t) has a correlation function
sin ⇡⌧
RY (⌧ ) = . (10.62)
⇡⌧
Find the transfer function H(!).

Exercise 14.
Consider the system Z t
t
Y (t) = e e⌧ X(⌧ ) d⌧.
1
Assume that X(t) is zero-mean white noise with power spectral density SX (!) = N0 /2.
Find the followings:
(a) SXY (!).
(b) RXY (⌧ ).
(c) SY (!).
(d) RY (⌧ ).

679
CHAPTER 10. RANDOM PROCESSES

680
Chapter A

Appendix

Useful Identities
P
1
1
1. rk = 1 + r + r2 + · · · = 1 r
k=0
Pn
n(n+1)
2. k = 1 + 2 + 3 + ··· + n = 2
k=1
P
1
xk x x2
3. ex = k! =1+ 1! + 2! + ···
k=0
P
1
1
4. krk 1
= 1 + 2r + 3r2 + · · · = (1 r)2
k=1
Pn
n3 n2 n
5. k 2 = 12 + 22 + 33 + · · · + n2 = 3 + 2 + 6
k=1
P
n
n
6. (a + b)n = k a k bn k
k=0

Common Distributions
Distribution PMF / PDF E[X] Var[X] MX (s)

Bernoulli pX (1) = p and pX (0) = 1 p p p(1 p) 1 p + pes


n
Binomial pX (k) = k pk (1 p)n k
np np(1 p) (1 p + pes )n
1 1 p pes
Geometric pX (k) = p(1 p)k 1
p p2 1 (1 p)es
k
e (es 1)
Poisson pX (k) = e
k! ⇢ ⇢
1 (x µ)2 2
2 2
s
Gaussian fX (x) = p exp 2
µ exp µs +
2⇡ 2 2 2
1 1
Exponential fX (x) = exp { x} 2 s
1 a+b (b a)2 esb esa
Uniform fX (x) = b a 2 12 s(b a)

681
CHAPTER A. APPENDIX

Sum of Two Random Variables


X1 X2 Sum X1 + X2
Bernoulli(p) Bernoulli(p) Binomial(2, p)
Binomial(n, p) Binomial(m, p) Binomial(m + n, p)
Poisson( 1) Poisson( 2) Poisson( 1 + 2)

Exponential( ) Exponential( ) Erlang(2, )


2 2 2 2
Gaussian(µ1 , 1) Gaussian(µ2 , 2) Gaussian(µ1 + µ2 , 1 + 2)

Fourier Transform Table


Z 1
j!t
F (!) = f (t) e dt.
1

f (t) ! F (!) f (t) ! F (!)


✓ ◆ ⇣ ! ⌘
1 Wt 2⇡
1. e at
u(t) ! ,a>0 10. sinc2 !
a + j! 2 W 2W
1 !0
2. eat u( t) ! ,a>0 11. e at
sin(!0 t)u(t) ! ,a>0
a j! (a + j!)2 + !02
2a a + j!
3. e a|t| ! 2 ,a>0 12. e at cos(!0 t)u(t) ! ,a>0
a + !2 (a + j!)2 + !02
a2 n 2 o p n 2 2
o
4. ! ⇡ae a|!| , a > 0 13. exp 2
t
2 ! 2⇡ exp 2
!
a 2 + t2
1
5. te at u(t) ! ,a>0 14. (t) !1
(a + j!)2
n!
6. tn e at u(t) ! n+1
,a>0 15. 1 ! 2⇡ (!)
✓ ◆ (a + j!) ⇣ ⌘
t !⌧ jwt0
7. rect ! ⌧ sinc 16. (t t0 ) !e
⌧ ⇣ 2! ⌘

8. sinc(W t) ! rect 17. ej!0 t ! 2⇡ (! !0 )
✓ ◆ W 2W⌘
⇣ !⌧
t ⌧
9. ! sinc2 18. f (t)ej!0 t ! F (! !0 )
⌧ 2 4

Some definitions:
sin(t)
sinc(t) =
(t
1, 0.5  t  0.5,
rect(t) =
0, otherwise.
(
1 2|t|, 0.5  t  0.5,
(t) =
0, otherwise.

682
Basic Trigonometric Identities

ej✓ = cos ✓ + j sin ✓


sin 2✓ = 2 sin ✓ cos ✓
cos 2✓ = 2 cos2 ✓ 1
1
cos A cos B = (cos(A + B) + cos(A B))
2
1
sin A sin B = (cos(A + B) cos(A B))
2
1
sin A cos B = (sin(A + B) + sin(A B))
2
1
cos A sin B = (sin(A + B) sin(A B))
2
cos(A + B) = cos A cos B sin A sin B
cos(A B) = cos A cos B + sin A sin B
sin(A + B) = sin A cos B + cos A sin B
sin(A B) = sin A cos B cos A sin B

683
Index

absolutely integrable, 183 definition, 143


almost sure convergence, 362 MATLAB and Python, 144
autocorrelation function properties, 146
2D visualization, 622 binomial series, 6
interpretation, 623, 633 binomial theorem, 6
LTI system, 644 proof, 9
properties, 632 birthday paradox, 31, 321
temporal average, 635 bootstrapping, 559
definition, 618 bootstrapped distribution, 562
MATLAB and Python, 625 confidence interval, 559
autocovariance function definition, 559
definition, 618 distribution of samples, 560
relation to autocorrelation function, 628 interpretation, 564
autoregressive model, 406, 658 MATLAB and Python, 565
linear prediction, 658 procedure, 562
MATLAB and Python, 407, 659 standard error, 565
prediction, 660 when to use, 560
Toeplitz, 659
Yule-Walker equation, 658 Cauchy distribution, 331, 360
Cauchy-Schwarz inequality, 261, 335
Basel problem, 5 Central Limit Theorem, 323, 366, 372, 381
basis functions, 405 Berry-Esseen Theorem, 375
Bayes’ theorem, 89 examples, 376
conditional probability, 81 interpretation, 375
law of total probability, 90 limitations, 378
Bayesian, 43 proof, 374
Bernoulli random variable characteristic function, 329
definition, 137 alternative definition, 329
MATLAB and Python, 137 Fourier transform, 330
maximum variance, 140 Chebyshev’s inequality, 341
properties, 138 proof, 342
bias-variance Cherno↵’s bound, 343
average predictor, 433 compare with Chebyshev, 344
MATLAB and Python, 434 Cherno↵, Herman, 343
noise-free case, 430 combination, 34
noisy case, 433 concave function, 336
trade o↵, 429 conditional distribution
binomial random variable conditional expectation, 275
alternative definition, 148 conditional PDF, 271

684
INDEX

conditional PMF, 267 examples, 650


conditional probability, 81 through LTI systems, 649
Bayes’ theorem, 89 cross-covariance function, 629
definition, 81 cross-correlation function, 629
independence, 85 cumulative distribution function
properties, 84 continuous, 186
ratio, 81 discrete, 121
confidence interval, 541 left- and right-continuous, 190
bootstrapping, 559 MATLAB and Python, 186
critical value, 552 properties, 188
definition, 546
distribution of estimator, 544 delta function, 178
estimator, 543 discrete cosine transform (DCT), 23
examples, 547
how to construct, 548 eigenvalues and eigenvectors, 295
interpretation, 545 Gaussian, 296
margin of error, 552 MATLAB and Python, 296
MATLAB and Python, 550 Erdős-Rényi graph, 140
number of samples, 553 MATLAB and Python, 480
properties, 551 even functions, 15
standard error, 551 event, 61
Student’s t-distribution, 554 event space, 61
conjugate prior, 513 expectation, 104
convergence in distribution, 367 continuous, 180
convergence in probability, 356 properties, 130, 182
convex function, 336 transformation, 182
convex optimization center of mass, 127
CVXPY, 451 discrete, 125
convolution, 220, 639 existence, 130, 183
correlation, 639 exponential random variables
filtering, 639 definition, 205
correlation, 633 MATLAB and Python, 205
autocorrelation function, 618 origin, 207, 209
autocovariance function, 618 properties, 206
cross-correlation function, 649 exponential series, 12
convolution, 639
field, 64
correlation coefficient
-field, 65
MATLAB and Python, 265
Borel -field, 65
properties, 263
Fourier transform, 644
definition, 263
table, 330
cosine angle, 26
characteristic function, 330
covariance, 261
frequentist, 43
covariance matrix, 289
Fundamental Theorem of Calculus, 17
independent, 289
chain rule, 19
cross power spectral density, 651
proof, 18
cross-correlation function
cross-covariance function, 629 Gaussian random variables
definition, 629 CDF, 214

685
INDEX

definition, 211 joint PDF, 247


MATLAB and Python, 212 joint PMF, 245
origin, 220 joint expectation, 257
properties, 212 cosine angle, 258
standard Gaussian, 213
geometric random variable kurtosis, 216
definition, 149 MATLAB and Python, 217
MATLAB and Python, 150
Laplace transform, 324
properties, 151
law of large numbers, 323, 351, 381
geometric sequence
strong law of large numbers, 360
finite, 4
weak law of large numbers, 354
infinite, 4
learning curve, 427
geometric series, 3
MATLAB and Python, 427
finite, 4
Legendre polynomial, 403
infinite, 4
MATLAB and Python, 404
harmonic series, 5 likelihood, 466, 468, 503
histogram, 2, 113 log-likelihood, 470
Hoe↵ding’s inequality, 348 linear algebra
Hoe↵ding lemma, 348 basis vector, 23
proof, 348 representation, 23
hypothesis testing span, 22
p-value test, 567, 571 standard basis vector, 22
T -test, 574 linear combination, 21
Z-test, 574 linear model, 21
alternative hypothesis, 566 linear prediction, 658
critical level, 569 linear programming, 414
critical-value test, 567 linear regression
definition, 566 MATLAB and Python, 30
MATLAB and Python, 568 linear time-invariant (LTI)
null hypothesis, 566 convolution, 639
definition, 643
impulse response, 643 system, 643
independence, 85
conditional probability, 88 marginal distribution, 250
versus disjoint, 86 Markov’s inequality, 339
independent proof, 339
random variables, 251 tight, 341
independent and identically distributed (i.i.d.), matrix calculus, 28
253 maximum-a-posteriori (MAP), 502
indicator function, 182 choosing prior, 505
inner product, 24 conjugate prior, 513
MATLAB and Python, 24 MAP versus LASSO, 519
MAP versus ML, 504
Jensen’s inequality, 336 MAP versus regression, 517
proof, 338 MAP versus ridge, 518
joint distribution posterior, 503, 511
definition, 241 prior, 503
joint CDF, 255 solution, 506

686
INDEX

maximum-likelihood MATLAB and Python, 291


1D Gaussian, 484 covariance, 293
consistent estimator, 494 transformation, 293
estimation, 468 whitening, 299
estimator, 491
high-dimensional Gaussian, 486 Neyman-Pearson test, 577
image reconstruction, 481 decision rule, 582
independent observations, 469 likelihood ratio, 584
invariance principle, 500 rejection zone, 578
MATLAB and Python, 472 likelihood ratio test, 578
number of training samples, 475 norm, 24, 26
Poisson, 485 `1 , 27
regression versus ML, 487 `1 , 27
social networks, 478 MATLAB and Python, 26
unbiased estimator, 492 weighted, 27
visualization, 471 normalization property, 112
mean, 199
odd functions, 15
mean function
open and closed intervals, 45
LTI system, 644
optimal linear filter, 653
definition, 618
deconvolution, 665
MATLAB and Python, 621
denoising, 662
mean squared error (MSE), 520, 522
orthogonality condition, 658
measure, 68
Wiener filter, 661
almost surely, 73
Yule-Walker equation, 656
finite sets, 68
input function, 654
intervals, 68
prediction, 654
Lebesgue integration, 71
target function, 654
measure zero sets, 71
orthogonality condition, 658
definition, 72
overdetermined system, 409
examples, 72
overfitting, 418
regions, 68
factors, 420
size, 69
LASSO, 454
median, 196
linear analysis, 425
minimum mean-square estimation (MMSE),
source, 429
520
conditional expectation, 523 parameter estimation, 165, 465
Gaussian, 529 Pascal triangle, 8
minimum-norm least squares, 411 Pascal’s identity, 7
mode, 198 performance guarantee
model selection, 165 average case, 321
moment, 133 worst case, 321
continuous case, 184 permutation, 33
moment-generating function, 322, 324 Poisson random variable
common distributions, 326 applications, 154
derivative, 325 definition, 152
existence, 331 origin, 157
sum of random variables, 327 photon arrivals, 161
multidimensional Gaussian, 290 Poisson approximation of binomial, 159

687
INDEX

properties, 155 random process


MATLAB and Python, 152 discrete time, 653
positive semi-definite, 297 definition, 612
posterior, 466, 503 example
power spectral density, 636 random amplitude, 612
Einstein-Wiener-Khinchin Theorem, 636 random phase, 613
through LTI systems, 646 function, 612
cross power spectral density, 640, 651 independent, 629
eigendecomposition, 639 index, 612
Fourier transform, 640 sample space, 614
origin, 640 statistical average, 614
wide-sense stationary, 639 temporal average, 614
PR (precision-recall) curve uncorrelated, 630
definition, 601 random variable, 104, 105
MATLAB and Python, 603 function of, 223
precision, 601 transformation of, 223
recall, 601 random vector, 286
principal-component analysis, 303 expectation, 288
limitations, 311 independent, 286
main idea, 303 regression, 391, 394
MATLAB and Python, 306 loss, 394
prior, 466, 503 MATLAB and Python, 400
probability, 43, 45 outliers, 412
measure of a set, 43 prediction model, 394
probability axioms, 74 solution, 397
additivity, 75 linear model, 395
corollaries, 77 outliers, 417
countable additivity, 75 squared error, 396
measure, 76 regularization, 440
non-negativity, 75 LASSO, 449
normalization, 75 MATLAB and Python, 442
probability density function, 172 parameter, 445
definition, 175 ridge, 440
discrete cases, 178 sparse solution, 449
properties, 174 robust linear regression, 412
intuition, 172 MATLAB and Python, 416
per unit length, 173 linear programming, 414
probability inequality, 323, 333 ROC
probability law, 66 comparing performance, 597
definition, 66 computation, 592
examples, 66 definition, 589
measure, 67 MATLAB and Python, 593
probability mass function, 104, 110 properties, 591
probability space Receiver operating characteristic, 589
(⌦, F, P), 58
sample average, 320, 351
Rademacher random variable, 140 sample space, 59
random number generator, 229 continuous outcomes, 59

688
INDEX

counterexamples, 61 Taylor approximation, 11


discrete outcomes, 59 first-order, 11
examples, 59 second-order, 11
exclusive, 61 exponential, 12
exhaustive, 61 logarithmic, 13
functions, 59 testing error, 420
set, 45 analysis, 424
associative, 56 testing set, 420
commutative, 56 Three Prisoners problem, 92
complement, 52 Toeplitz, 407, 630
countable, 45 training error, 420
De Morgan’s Law, 57 analysis, 421
di↵erence, 53 training set, 420
disjoint, 54 type 1 error
distributive, 56 definition, 579
empty set, 48 false alarm, 580
finite, 45 false positive, 579
improper subset, 47 power of test, 581
infinite, 45 type 2 error
intersection, 50 definition, 579
finite, 50 false negative, 579
infinite, 51 miss, 580
of functions, 46
partition, 55 underdetermined system, 409
proper subset, 47 uniform random variables, 202
subset, 47 MATLAB and Python, 203
uncountable, 45 union bound, 333
union, 48
finite, 48 validation, 165
infinite, 49 variance, 134
universal set, 48 properties, 135
simplex method, 414 continuous case, 184
skewness, 216
white noise, 638
MATLAB and Python, 217
wide-sense stationary, 630
statistic, 320
jointly, 649
Student’s t-distribution
Wiener filter, 661
definition, 554
deconvolution, 665
degrees of freedom, 555
definition, 661
MATLAB and Python, 556
denoising, 662
relation to Gaussian, 555
MATLAB and Python, 661
sum of random variables, 280
power spectral density, 662
Bernoulli, 327
recursive filter, 661
binomial, 328
Gaussian, 283, 329 Yule-Walker equation, 656
Poisson, 328 MATLAB and Python, 659
common distributions, 282
convolution, 281
symmetric matrices, 296

689

You might also like