written by Eric J. Ma on 2017-10-27 | tags: data science machine learning random forest
Why I think random forests are a great baseline machine learning model.
I've been giving this some thought, and wanted to go out on a limb to put forth this idea:
I think Random Forests (RF) are a good "baseline" model to try, after establishing a "random" baseline case.
(Clarification: I'm using RF as a shorthand for "forest-based ML algorithms", including XGBoost etc.)
Before I go on, let me first provide some setup.
Let's say we have a two-class classification problem. Assume everything is balanced. One "dumb baseline"" case is a coin flip. The other "dumb baseline" is predicting everything to be one class. Once we have these established, we can go to a "baseline" machine learning model.
Usually, people might say, "go do logistic regression (LR)" as your first baseline model for classification problems. It sure is a principled choice! Logistic regression is geared towards classification problems, makes only linear assumptions about the data, and identifies directional effects as well. From a practical perspective, it's also very fast to train.
But I've found myself more and more being oriented towards using RFs as my baseline model instead of logistic regression. Here are my reasons:
scikit-learn
, it's a one-liner change to swap out LR for RF. The API is what matters, and as such, drop-in replacements are easily implemented!Just to be clear, I'm not advocating for throwing away logistic regression altogether. There are moments where interpretability is needed, and is more easily done by using LR. In those cases, LR can be the "baseline model", or even just back-filled in after training the baseline RF model for comparison.
Random Forests were the darling of the machine learning world before neural networks came along, and even now, remain the tool-of-choice for colleagues in the cheminformatics world. Given how easy they are to use now, why not just start with them?
@article{
ericmjl-2017-random-model,
author = {Eric J. Ma},
title = {Random Forests: A Good Default Model?},
year = {2017},
month = {10},
day = {27},
howpublished = {\url{https://ericmjl.github.io}},
journal = {Eric J. Ma's Blog},
url = {https://ericmjl.github.io/blog/2017/10/27/random-forests-a-good-default-model},
}
I send out a newsletter with tips and tools for data scientists. Come check it out at Substack.
If you would like to sponsor the coffee that goes into making my posts, please consider GitHub Sponsors!
Finally, I do free 30-minute GenAI strategy calls for teams that are looking to leverage GenAI for maximum impact. Consider booking a call on Calendly if you're interested!