From aa5f188418f05016fbc6ed8eb723f52a9b56e7b3 Mon Sep 17 00:00:00 2001 From: Lillian Weng Date: Sun, 1 Oct 2023 19:57:12 -0700 Subject: [PATCH] remove multiple lin reg from constant model notes --- .../loss_transformations.ipynb | 45 +-- ols/ols.ipynb | 328 ++++++++++++++++++ 2 files changed, 329 insertions(+), 44 deletions(-) create mode 100644 ols/ols.ipynb diff --git a/constant_model_loss_transformations/loss_transformations.ipynb b/constant_model_loss_transformations/loss_transformations.ipynb index d5e05dd6..bd1d86f1 100644 --- a/constant_model_loss_transformations/loss_transformations.ipynb +++ b/constant_model_loss_transformations/loss_transformations.ipynb @@ -1112,49 +1112,6 @@ "\n", "Practically, many other mathematical operations that modify the relative scales of `\"Age\"` and `\"Length\"` could have worked here.\n" ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "## Notation for Multiple Linear Regression\n", - "\n", - "### Terminology\n", - "There are several equivalent terms in the context of regression. The ones we use most often for this course are bolded. \n", - "* $x$ can be called a\n", - " * **Feature(s)**\n", - " * Covariate(s)\n", - " * **Independent variable(s)**\n", - " * Explanatory variable(s)\n", - " * Predictor(s)\n", - " * Input(s)\n", - " * Regressor(s)\n", - "* $y$ can be called an\n", - " * **Output**\n", - " * Outcome\n", - " * **Response**\n", - " * Dependent variable\n", - "* $\\hat{y}$ can be called a\n", - " * **Prediction**\n", - " * Predicted response\n", - " * Estimated value\n", - "* $\\theta$ can be called a\n", - " * **Weight(s)**\n", - " * **Parameter(s)**\n", - " * Coefficient(s)\n", - "* $hat{\\theta}$ can be called a\n", - " * **Estimator(s)**\n", - " * **Optimal parameter(s)**\n", - "* A datapoint $(x, y)$ is also called an **observation**.\n", - "\n", - "### Multiple Linear Regression Model\n", - "Define the multiple linear regression model:\n" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [] } ], "metadata": { @@ -1173,7 +1130,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.16" + "version": "3.10.9" } }, "nbformat": 4, diff --git a/ols/ols.ipynb b/ols/ols.ipynb new file mode 100644 index 00000000..82ea5512 --- /dev/null +++ b/ols/ols.ipynb @@ -0,0 +1,328 @@ +{ + "cells": [ + { + "cell_type": "raw", + "metadata": {}, + "source": [ + "---\n", + "title: Ordinary Least Squares\n", + "execute:\n", + " echo: true\n", + "format:\n", + " html:\n", + " code-fold: true\n", + " code-tools: true\n", + " toc: true\n", + " toc-title: Ordinary Least Squares\n", + " page-layout: full\n", + " theme:\n", + " - cosmo\n", + " - cerulean\n", + " callout-icon: false\n", + "---" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "::: {.callout-note collapse=\"true\"}\n", + "## Learning Outcomes\n", + "* Define linearity with respect to a vector of parameters $\\theta$\n", + "* Understand the use of matrix notation to express multiple linear regression\n", + "* Interpret ordinary least squares as the minimization of the norm of the residual vector\n", + "* Compute performance metrics for multiple linear regression\n", + ":::\n", + "\n", + "We've now spent a number of lectures exploring how to build effective models – we introduced the SLR and constant models, selected cost functions to suit our modeling task, and applied transformations to improve the linear fit.\n", + "\n", + "Throughout all of this, we considered models of one feature ($\\hat{y}_i = \\theta_0 + \\theta_1 x_i$) or zero features ($\\hat{y}_i = \\theta$). As data scientists, we usually have access to datasets containing *many* features. To make the best models we can, it will be beneficial to consider all of the variables available to us as inputs to a model, rather than just one. In today's lecture, we'll introduce **multiple Linear regression** as a framework to incorporate multiple features into a model. We will also learn how to accelerate the modeling process – specifically, we'll see how linear algebra offers us a powerful set of tools for understanding model performance.\n", + "\n", + "## Linearity\n", + "\n", + "An expression is **linear in $\\theta$** (a set of parameters) if it is a linear combination of the elements of the set. Checking if an expression can separate into a matrix product of two terms: a **vector of $\\theta$** s, and a matrix/vector **not involving $\\theta$**.\n", + "\n", + "\n", + "Example: $\\theta = [\\theta_1, \\theta_2, ... \\theta_p]$\n", + "\n", + "1. Linear in theta: $\\hat{y} = \\theta_0 + 2\\theta_1 + 3\\theta_2$\n", + "\n", + "$$\\hat{y} = \\begin{bmatrix} 1 \\space 2 \\space 3 \\end{bmatrix} \\begin{bmatrix} \\theta_0 \\\\ \\theta_1 \\\\ \\theta_2 \\end{bmatrix}$$\n", + "\n", + "2. Not linear in theta: $\\hat{y} = \\theta_0\\theta_1 + 2\\theta_1^2 + 3log(\\theta_2)$\n", + "\n", + "\n", + "## Notation for Multiple Linear Regression\n", + "[note from lillian: this section was at the end of the previous lecture] \n", + "### Terminology\n", + "There are several equivalent terms in the context of regression. The ones we use most often for this course are bolded. \n", + "* $x$ can be called a\n", + " * **Feature(s)**\n", + " * Covariate(s)\n", + " * **Independent variable(s)**\n", + " * Explanatory variable(s)\n", + " * Predictor(s)\n", + " * Input(s)\n", + " * Regressor(s)\n", + "* $y$ can be called an\n", + " * **Output**\n", + " * Outcome\n", + " * **Response**\n", + " * Dependent variable\n", + "* $\\hat{y}$ can be called a\n", + " * **Prediction**\n", + " * Predicted response\n", + " * Estimated value\n", + "* $\\theta$ can be called a\n", + " * **Weight(s)**\n", + " * **Parameter(s)**\n", + " * Coefficient(s)\n", + "* $hat{\\theta}$ can be called a\n", + " * **Estimator(s)**\n", + " * **Optimal parameter(s)**\n", + "* A datapoint $(x, y)$ is also called an **observation**.\n", + "\n", + "\n", + "## Multiple Linear Regression\n", + "\n", + "Multiple Linear regression is an extension of simple linear regression that adds additional features into the model. Say we collect information on several variables when making an observation. For example, we may record the age, height, and weekly hours of sleep for a student in Data 100. This single observation now contains data for multiple features. To accommodate for the fact that we now consider several feature variables, we'll adjust our notation slightly. Each observation can now be thought of as a row vector with an entry for each of $p$ features. \n", + "\n", + "observation\n", + "\n", + "The multiple Linear regression model takes the form:\n", + "\n", + "$$\\hat{y}_i = \\theta_0\\:+\\:\\theta_1x_{i1}\\:+\\:\\theta_2 x_{i2}\\:+\\:...\\:+\\:\\theta_p x_{ip}$$\n", + "\n", + "Our $i$th prediction, $\\hat{y}_i$, is a linear combination of the parameters, $\\theta_i$. Because we are now dealing with many parameter values, we'll collect them all into a **parameter vector** with dimensions $(p+1) \\times 1$ to keep things tidy.\n", + "\n", + "$$\\theta = \\begin{bmatrix}\n", + " \\theta_{0} \\\\\n", + " \\theta_{1} \\\\\n", + " \\vdots \\\\\n", + " \\theta_{p}\n", + " \\end{bmatrix}$$\n", + " \n", + "We are now working with two vectors: a row vector representing the observed data, and a column vector containing the model parameters. The multiple Linear regression model given above is **equivalent to the dot (scalar) product of the observation vector and parameter vector**. \n", + "\n", + "$$[1,\\:x_{i1},\\:x_{i2},\\:x_{i3},\\:...,\\:x_{ip}] \\theta = [1,\\:x_{i1},\\:x_{i2},\\:x_{i3},\\:...,\\:x_{ip}] \\begin{bmatrix}\n", + " \\theta_{0} \\\\\n", + " \\theta_{1} \\\\\n", + " \\vdots \\\\\n", + " \\theta_{p}\n", + " \\end{bmatrix} = \\theta_0\\:+\\:\\theta_1x_{i1}\\:+\\:\\theta_2 x_{i2}\\:+\\:...\\:+\\:\\theta_p x_{ip}$$\n", + "\n", + "Notice that we have inserted 1 as the first value in the observation vector. When the dot product is computed, this 1 will be multiplied with $\\theta_0$ to give the intercept of the regression model. We call this 1 entry the **intercept** or **bias** term.\n", + "\n", + "\n", + "## Linear Algebra Approach\n", + "\n", + "We now know how to generate a single prediction from multiple observed features. Data scientists usually work at scale – that is, they want to build models that can produce many predictions, all at once. The vector notation we introduced above gives us a hint on how we can expedite multiple Linear regression. We want to use the tools of linear algebra.\n", + "\n", + "Let's think carefully about what we did to generate the single prediction above. To make a prediction from the first observation in the data, we took the scalar product of the parameter vector and first observation vector. To make a prediction from the *second* observation, we would repeat this process to find the scalar product of the parameter vector and the *second* observation vector. If we wanted to find the model predictions for each observation in the dataset, we'd repeat this process for all $n$ observations in the data. \n", + "\n", + "$$\\hat{y}_1 = [1,\\:x_{11},\\:x_{12},\\:x_{13},\\:...,\\:x_{1p}] \\theta$$\n", + "$$\\hat{y}_2 = [1,\\:x_{21},\\:x_{22},\\:x_{23},\\:...,\\:x_{2p}] \\theta$$\n", + "$$\\vdots$$\n", + "$$\\hat{y}_n = [1,\\:x_{n1},\\:x_{n2},\\:x_{n3},\\:...,\\:x_{np}] \\theta$$\n", + "\n", + "Our observed data is represented by $n$ row vectors, each with dimension $(p+1)$. We can collect them all into a single matrix, which we call $\\mathbb{X}$.\n", + "\n", + "design_matrix\n", + "\n", + "The matrix $\\mathbb{X}$ is known as the **design matrix**. It contains all observed data for each of our $p$ features. It often (but not always) contains an additional column of all ones to represent the **intercept** or **bias column**. \n", + "\n", + "To review what is happening in the design matrix: each row represents a single observation. For example, a student in Data 100. Each column represents a feature. For example, the ages of students in Data 100. This convention allows us to easily transfer our previous work in DataFrames over to this new linear algebra perspective.\n", + "\n", + "row_col\n", + "\n", + "The multiple Linear regression model can then be restated in terms of matrices:\n", + "$$\\mathbb{\\hat{Y}} = \\mathbb{X} \\theta$$\n", + "\n", + "Here, $\\mathbb{\\hat{Y}}$ is the **prediction vector** with dimensions $(n \\times 1)$. It contains the prediction made by the model for each of $n$ input observations.\n", + "\n", + "We now have a new approach to understanding models in terms of vectors and matrices. To accompany this new convention, we should update our understanding of cost functions and model fitting.\n", + "\n", + "Recall our definition of MSE:\n", + "$$R(\\theta) = \\frac{1}{n} \\sum_{i=1}^n (y_i - \\hat{y}_i)^2$$\n", + "\n", + "At its heart, the MSE is a measure of *distance* – it gives an indication of how \"far away\" the predictions are from the true values, on average. \n", + "\n", + "When working with vectors, this idea of \"distance\" is represented by the **norm**. More precisely, the distance between two vectors $\\vec{a}$ and $\\vec{b}$ can be expressed as:\n", + "$$||\\vec{a} - \\vec{b}||_2 = \\sqrt{(a_1 - b_1)^2 + (a_2 - b_2)^2 + \\ldots + (a_n - b_n)^2} = \\sqrt{\\sum_{i=1}^n (a_i - b_i)^2}$$\n", + "\n", + "The double bars are mathematical notation for the norm. The subscript 2 indicates that we are computing the L2, or squared norm.\n", + "\n", + "Looks pretty familiar! We can rewrite the MSE to express it as a squared L2 norm in terms of the prediction vector, $\\hat{\\mathbb{Y}}$, and true target vector, $\\mathbb{Y}$:\n", + "\n", + "$$R(\\theta) = \\frac{1}{n} \\sum_{i=1}^n (y_i - \\hat{y}_i)^2 = \\frac{1}{n} ||\\mathbb{Y} - \\hat{\\mathbb{Y}}||_2^2$$\n", + "\n", + "Here, the superscript 2 outside of the norm double bars means that we are *squaring* the norm. If we plug in our linear model $\\hat{\\mathbb{Y}} = \\mathbb{X} \\theta$, we find the MSE cost function in vector notation:\n", + "\n", + "$$R(\\theta) = \\frac{1}{n} ||\\mathbb{Y} - \\mathbb{X} \\theta||_2^2$$\n", + "\n", + "Under the linear algebra perspective, our new task is to fit the optimal parameter vector $\\theta$ such that the cost function is minimized. Equivalently, we wish to minimize the norm $$||\\mathbb{Y} - \\mathbb{X} \\theta||_2 = ||\\mathbb{Y} - \\hat{\\mathbb{Y}}||_2$$. \n", + "\n", + "We can restate this goal in two ways:\n", + "\n", + "* Minimize the *distance* between the vector of true values, $\\mathbb{Y}$, and the vector of predicted values, $\\mathbb{\\hat{Y}}$\n", + "* Minimize the *length* of the **residual vector**, defined as:\n", + "$$e = \\mathbb{Y} - \\mathbb{\\hat{Y}} = \\begin{bmatrix}\n", + " y_1 - \\hat{y}_1 \\\\\n", + " y_2 - \\hat{y}_2 \\\\\n", + " \\vdots \\\\\n", + " y_n - \\hat{y}_n\n", + " \\end{bmatrix}$$\n", + "\n", + "## Geometric Perspective\n", + "\n", + "To derive the best parameter vector to meet this goal, we can turn to the geometric properties of our modeling set-up.\n", + "\n", + "Up until now, we've mostly thought of our model as a scalar product between horizontally-stacked observations and the parameter vector. We can also think of $\\hat{\\mathbb{Y}}$ as a **linear combination of feature vectors**, scaled by the parameters. We use the notation $\\mathbb{X}_{:, i}$ to denote the $i$th column of the design matrix. You can think of this as following the same convention as used when calling `.iloc` and `.loc`. \":\" means that we are taking all entries in the $i$th column.\n", + "\n", + "columns\n", + "\n", + "$$\n", + "\\hat{\\mathbb{Y}} = \n", + "\\theta_0 \\begin{bmatrix}\n", + " 1 \\\\\n", + " 1 \\\\\n", + " \\vdots \\\\\n", + " 1\n", + " \\end{bmatrix} + \\theta_1 \\begin{bmatrix}\n", + " x_{11} \\\\\n", + " x_{21} \\\\\n", + " \\vdots \\\\\n", + " x_{n1}\n", + " \\end{bmatrix} + \\ldots + \\theta_p \\begin{bmatrix}\n", + " x_{1p} \\\\\n", + " x_{2p} \\\\\n", + " \\vdots \\\\\n", + " x_{np}\n", + " \\end{bmatrix}\n", + " = \\theta_0 \\mathbb{X}_{:,\\:1} + \\theta_1 \\mathbb{X}_{:,\\:2} + \\ldots + \\theta_p \\mathbb{X}_{:,\\:p+1}$$\n", + "\n", + "This new approach is useful because it allows us to take advantage of the properties of linear combinations.\n", + "\n", + "Recall that the **span** or **column space** of a matrix is the set of all possible linear combinations of the matrix's columns. In other words, the span represents every point in space that could possibly be reached by adding and scaling some combination of the matrix columns. \n", + "\n", + "Because the prediction vector, $\\hat{\\mathbb{Y}} = \\mathbb{X} \\theta$, is a linear combination of the columns of $\\mathbb{X}$, we know that the **predictions are contained in the span of $\\mathbb{X}$**. That is, we know that $\\mathbb{\\hat{Y}} \\in \\text{Span}(\\mathbb{X})$.\n", + "\n", + "The diagram below is a simplified view of $\\text{Span}(\\mathbb{X})$, assuminh that each column of $\\mathbb{X}$ has length $n$. Notice that the columns of $\\mathbb{X}$ define a subspace of $\\mathbb{R}^n$, where each point in the subspace can be reached by a linear combination of $\\mathbb{X}$'s columns. The prediction vector $\\mathbb{\\hat{Y}}$ lies somewhere in this subspace.\n", + "\n", + "span\n", + "\n", + "Examining this diagram, we find a problem. The vector of true values, $\\mathbb{Y}$, could theoretically lie *anywhere* in $\\mathbb{R}^n$ space – its exact location depends on the data we collect out in the real world. However, our multiple Linear regression model can only make predictions in the subspace of $\\mathbb{R}^n$ spanned by $\\mathbb{X}$. Remember the model fitting goal we established in the previous section: we want to generate predictions such that the distance between the vector of true values, $\\mathbb{Y}$, and the vector of predicted values, $\\mathbb{\\hat{Y}}$, is minimized. This means that **we want $\\mathbb{\\hat{Y}}$ to be the vector in $\\text{Span}(\\mathbb{X})$ that is closest to $\\mathbb{Y}$**. \n", + "\n", + "Another way of rephrasing this goal is to say that we wish to minimize the length of the residual vector $e$, as measured by its $L_2$ norm. \n", + "\n", + "residual\n", + "\n", + "The vector in $\\text{Span}(\\mathbb{X})$ that is closest to $\\mathbb{Y}$ is always the **orthogonal projection** of $\\mathbb{Y}$ onto $\\text{Span}(\\mathbb{X})$. Thus, we should choose the parameter vector $\\theta$ that makes the **residual vector orthogonal to any vector in $\\text{Span}(\\mathbb{X})$**. You can visualize this as the vector created by dropping a perpendicular line from $\\mathbb{Y}$ onto the span of $\\mathbb{X}$. \n", + "\n", + "How does this help us identify the optimal parameter vector, $\\hat{\\theta}$? Recall that two vectors are orthogonal if their dot product is zero. A vector $\\vec{v}$ is orthogonal to the span of a matrix $M$ if $\\vec{v}$ is orthogonal to each column in $M$. Put together, a vector $\\vec{v}$ is orthogonal to $\\text{Span}(M)$ if:\n", + "\n", + "$$M^T \\vec{v} = \\vec{0}$$\n", + "\n", + "Because our goal is to find $\\hat{\\theta}$ such that the residual vector $e = \\mathbb{Y} - \\mathbb{X} \\theta$ is orthogonal to $\\text{Span}(\\mathbb{X})$, we can write:\n", + "\n", + "$$\\mathbb{X}^T e = \\vec{0}$$\n", + "$$\\mathbb{X}^T (\\mathbb{Y} - \\mathbb{X}\\hat{\\theta}) = \\vec{0}$$\n", + "$$\\mathbb{X}^T \\mathbb{Y} - \\mathbb{X}^T \\mathbb{X} \\hat{\\theta} = \\vec{0}$$\n", + "$$\\mathbb{X}^T \\mathbb{X} \\hat{\\theta} = \\mathbb{X}^T \\mathbb{Y}$$\n", + "\n", + "This last line is known as the **normal equation**. Any vector $\\theta$ that minimizes MSE on a dataset must satisfy this equation.\n", + "\n", + "If $\\mathbb{X}^T \\mathbb{X}$ is invertible, we can conclude:\n", + "$$\\hat{\\theta} = (\\mathbb{X}^T \\mathbb{X})^{-1} \\mathbb{X}^T \\mathbb{Y}$$\n", + "\n", + "This is called the **least squares estimate** of $\\theta$: it is the value of $\\theta$ that minimizes the squared loss. \n", + "\n", + "Note that the least squares estimate was derived under the assumption that $\\mathbb{X}^T \\mathbb{X}$ is *invertible*. This condition holds true when $\\mathbb{X}^T \\mathbb{X}$ is full column rank, which, in turn, happens when $\\mathbb{X}$ is full column rank. We will explore the consequences of this fact in lab and homework.\n", + "\n", + "## Evaluating Model Performance\n", + "\n", + "Our geometric view of multiple Linear regression has taken us far! We have identified the optimal set of parameter values to minimize MSE in a model of multiple features.\n", + "\n", + "Now, we want to understand how well our fitted model performs. One measure of model performance is the **Root Mean Squared Error**, or RMSE. The RMSE is simply the square root of MSE. Taking the square root converts the value back into the original, non-squared units of $y_i$, which is useful for understanding the model's performance. A low RMSE indicates more \"accurate\" predictions – that there is lower average loss across the dataset.\n", + "\n", + "$$\\text{RMSE} = \\sqrt{\\frac{1}{n} \\sum_{i=1}^n (y_i - \\hat{y}_i)^2}$$\n", + "\n", + "When working with SLR, we generated plots of the residuals against a single feature to understand the behavior of residuals. When working with several features in multiple Linear regression, it no longer makes sense to consider a single feature in our residual plots. Instead, multiple Linear regression is evaluated by making plots of the residuals against the predicted values. As was the case with SLR, a multiple Linear model performs well if its residual plot shows no patterns.\n", + "\n", + "residual_plot\n", + "\n", + "For SLR, we used the correlation coefficient to capture the association between the target variable and a single feature variable. In a multiple Linear setting, we will need a performance metric that can account for multiple features at once. **Multiple $R^2$**, also called the **coefficient of determination**, is the ratio of the variance of the predicted values $\\hat{y}_i$ to the variance of the true values $y_i$. It can be interpreted as the *proportion* of variance in the observations that is explained by the model. \n", + "\n", + "$$R^2 = \\frac{\\text{variance of } \\hat{y}_i}{\\text{variance of } y_i} = \\frac{\\sigma^2_{\\hat{y}}}{\\sigma^2_y}$$\n", + "\n", + "\n", + "As we add more features, our fitted values tend to become closer and closer to our actual values. Thus, $\\mathbb{R}^2$ increases.\n", + "\n", + "## OLS Properties\n", + "\n", + "1. When using the optimal parameter vector, our residuals $e = \\mathbb{Y} - \\hat{\\mathbb{Y}}$ are orthogonal to $span(\\mathbb{X})$ \n", + "\n", + "$$\\mathbb{X}^Te = 0 $$\n", + "\n", + "::: {.callout}\n", + "Proof: \n", + "\n", + "The optimal parameter vector, $\\hat{\\theta}$, solves the normal equations $\\implies \\hat{\\theta} = \\mathbb{X}^T\\mathbb{X}^{-1}\\mathbb{X}^T\\mathbb{Y}$\n", + "\n", + "$$\\mathbb{X}^Te = \\mathbb{X}^T (\\mathbb{Y} - \\mathbb{\\hat{Y}}) $$\n", + "\n", + "$$\\mathbb{X}^T (\\mathbb{Y} - \\mathbb{X}\\hat{\\theta}) = \\mathbb{X}^T\\mathbb{Y} - \\mathbb{X}^T\\mathbb{X}\\hat{\\theta}$$\n", + "\n", + "Any matrix multiplied with its own inverse is the identity matrix $\\mathbb{I}$\n", + "\n", + "$$\\mathbb{X}^T\\mathbb{Y} - (\\mathbb{X}^T\\mathbb{X})(\\mathbb{X}^T\\mathbb{X})^{-1}\\mathbb{X}^T\\mathbb{Y} = \\mathbb{X}^T\\mathbb{Y} - \\mathbb{X}^T\\mathbb{Y} = 0$$\n", + ":::\n", + "\n", + "2. For all linear models *with an intercept term*, the sum of residuals is zero.\n", + "\n", + "$$\\sum_i^n e_i = 0$$\n", + "\n", + "::: {.callout}\n", + "Proof:\n", + "\n", + "For all linear models *with an intercept term*, the average of the predicted $y$ values is equal to the average of the true $y$ values.\n", + "\n", + "$$\\bar{y} = \\bar{\\hat{y}}$$\n", + "\n", + "Rewriting the sum of residuals as two separate sums,\n", + "\n", + "$$\\sum_i^n e_i = \\sum_i^n y_i - \\sum_i^n\\hat{y}_i$$\n", + "\n", + "Each respective sum is a multiple of the average of the sum.\n", + "\n", + "$$\\sum_i^n e_i = n\\bar{y} - n\\bar{y} = n(\\bar{y} - \\bar{y}) = 0$$\n", + ":::\n", + "\n", + "3. The Least Squares estimate $\\hat{\\theta}$ is unique if and only if $\\mathbb{X}$ is full column rank.\n", + "\n", + "::: {.callout}\n", + "Proof: \n", + "\n", + "We know the solution to the normal equation $\\mathbb{X}^T\\mathbb{X}\\hat{\\theta} = \\mathbb{Y}$ is the least square estimate that fulfills the prior equality.\n", + "\n", + "$\\hat{\\theta}$ has a unique solution $\\iff$ the square matrix $\\mathbb{X}^T\\mathbb{X}$ is invertible.\n", + "\n", + "The rank of a square matrix is the maximum number of of linearly independent columns it contains. $\\mathbb{X}^T\\mathbb{X}$ has shape $(p + 1) \\times (p + 1)$, and therefore has max rank p + 1. \n", + "\n", + "$rank(\\mathbb{X}^T\\mathbb{X})$ = $rank(\\mathbb{X})$ (proof out of scope).\n", + "\n", + "Therefore $\\mathbb{X}^T\\mathbb{X}$ has rank p + 1 $\\iff$ $\\mathbb{X}$ has rank p + 1 $\\iff \\mathbb{X}$ is full column rank.\n", + ":::\n" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3 (ipykernel)", + "language": "python", + "name": "python3" + } + }, + "nbformat": 4, + "nbformat_minor": 4 +}