forked from AKAmaestro/python-machine-learning-book
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
faq: Why is logistic regression considered a linear model?
- Loading branch information
Showing
6 changed files
with
45 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
# Why is logistic regression considered a linear model? | ||
|
||
The short answer is: Logistic regression is considered a linear model because the outcome **always** depends on the **sum** of the inputs. Or in other words, the output **cannot** depend on the product (or quotient etc.) of the input features! | ||
|
||
So, why is that? Let’s recapitulate the basics of logistic regression first, which hopefully makes things more clear. Logistic regression is an algorithm that learns a model for binary classification. A nice side-effect is that it gives us the *probability* that a sample belongs to class 1 (or vice versa: class 0). Our objective function is to minimize the so-called logistic function Φ (a certain kind of sigmoid function); it looks like this: | ||
|
||
data:image/s3,"s3://crabby-images/1d62f/1d62f04002486070d2894e58206db3087e66d881" alt="" | ||
|
||
Now, if *Φ(z)* is larger than *0.5* (alternatively: if *z* is larger than *0*), we classify an input as class 1 (and class 0, otherwise). This logistic (activation) function doesn't look very linear at all, right!? So, let's dig a bit deeper and take a look at the equation we use to compute *z* -- the net input function! | ||
|
||
data:image/s3,"s3://crabby-images/4d25c/4d25c7df727cb0bbdee4256c5c591e130c0f90ba" alt="" | ||
|
||
The net input function is simply the dot product of our input features and the respective model coefficients **w**: | ||
|
||
data:image/s3,"s3://crabby-images/7c9be/7c9be2cb83e14cbf3cc9333f7c42ba7016af0bc2" alt="" | ||
|
||
Here, x<sub>0</sub> refers to the weight of the bias unit which is always equal to 1 (a detail we don’t have to worry about here). I know, mathematical equations can be a bit "abstract" at times, so let's look at a concrete example. | ||
|
||
Let's assume we have a sample training point **x** consisting of 4 features (e.g., *sepal length*, *sepal width*, *petal length*, and *petal width* in the [*Iris dataset*](https://archive.ics.uci.edu/ml/datasets/Iris)): | ||
|
||
x = [1, 2, 3, 4] | ||
|
||
Now, let's assume our weight vector looks like this: | ||
|
||
w = [0.5, 0.5, 0.5, 0.5] | ||
|
||
Let's compute *z* now! | ||
|
||
z = w<sup>T</sup>x = 1*0.5 + 2*0.5 + 3*0.5 + 4*0.5 = 5 | ||
|
||
--- | ||
|
||
Not that it is important, but we have a 99.3% chance that this sample belongs to class 1: | ||
*Φ(z) = 1 / (1 + e<sup>-5</sup> = 148.41)* | ||
|
||
--- | ||
|
||
The key is that our model is ***additive*** | ||
our outcome *z* depends on the additivity of values, e.g., : | ||
|
||
*z = w<sub>1</sub>x<sub>1</sub> + w<sub>2</sub>x<sub>2</sub>* | ||
|
||
There's no interaction between input values, nothing like x<sub>1</sub>*<sub>2</sub> or so, which would make our model non-linear! |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.