This is a Twitter series on #FoundationsOfML. Today, I want to talk about another fundamental question:

❓ What is a model in Machine Learning?

Let's take a bird's eye view at different modeling paradigms... 👇🧵

Remember our purpose is to find some "optimal" program P for solving a task T, by maximizing a performance metric M using some experience E.

📝 In ML lingo, that program P is called a "model", or alternatively, a "hypothesis".

👉 The first step in coming up with a suitable model, is to think of a model family, or hypothesis space.

We can think of it as a class of programs, all very similar, such that one instance of that class is the actual program P that solves our task T optimally.

All the possible models of a given model family share a common structure, and differentiate themselves in specific decisions (or instructions, if you will) inside this common template.

A useful distinction here is between 1️⃣ Parametric and 2️⃣ Non-Parametric models.

1️⃣ Parametric models

Different models inside our model family have a fixed number of parameters (or weights), and differentiate from each other in the specific values of each parameter.

📝 Most of the models you've probably heard about, including logistic regression, naive Bayes, and all neural networks (with fixed architecture) are in this category.

🔥 We can cast the problem of finding the best model as the problem of finding the optimal value for each parameter, such that some performance metric M is maximized (or some error metric M' is minimized).

2️⃣ Non-parametric models

Different models of the same model family have a variable number of parameters that often depends on the size of the training set.

📝 Some simple examples of non-parametric models are K-nearest neighbors, support vector machines (with non-linear kernels), and decision trees.

1️⃣👍 One advantage of parametric models is that they often have very efficient training algorithms, since you can exploit the structure of the parameter space (e.g., you have gradients to follow).

1️⃣👍 Another advantage is that the size of the model is independent of the size of the training set, and is often proportional to the number of features, i.e., these models "compress" the training set into a fixed-size "formula" of sorts.

1️⃣👍 Additionally, parametric models are often easy to regularize by adding some cost associated with the model complexity (e.g., the number of non-zero values or their magnitude).

In short, parametric models are mathematically elegant and very malleable.

1️⃣👎 The biggest downside is that every model family implies significant assumptions about the data, and if we assume the wrong ones, we're very likely to underfit.

On the contrast, non-parametric models are much more ad-hoc.

2️⃣👍 The main advantage of these models is they often imply weaker assumptions about the data, and can adapt to difficult datasets easier than similarly complex parametric models.

2️⃣👎 The biggest downside is that each model family is its own world, with ad-hoc training algorithms and lots of model-specific decisions to fine-tune.

2️⃣👎 Another downside is that the model size is sometimes proportional to the training set size, which makes them less suitable for learning from very large datasets.

❓ Which is better?

The answer is, of course, it depends.

👉 It depends on the nature of the problem to solve, the amount and quality of the available data, and what you intend to do with that solution.

🔹 If you know the data well, and you're clear of your assumptions (e.g., linear relationships), go for the parametric model that best suits those assumptions.

🔹 If you know nothing, Jon Snow, some of the most powerful non-parametric models (e.g., decision trees and SVMs) will often perform near the state-of-the-art with little fine-tuning.

☝️ In any case, there is no substitute for experimentation. Make sure to evaluate different models and decide based on actual performance rather than intuition.