developers

Machine Learning for Everyone

Learn the basics of predictive modeling behind one of the most-used machine learning models

Dec 6, 20164 min read

We all know that machine learning is about handling data, but it also can be seen as:

The art of finding order in data by browsing its inner information.

Some background on predictive models

There are several types of predictive models. These models usually have several input columns and one target or outcome column, which is the variable to be predicted.

Predictive Model Table

So basically, a model performs mapping between inputs and an output, finding-mysteriously, sometimes-the relationships between the input variables in order to predict any other variable.

As you may notice, it has some commonalities with a human being who

reads the environment => processes the information => and performs a certain action
.

So what is this post about?

It's about becoming familiar with one of the most-used predictive models: Random Forest (official algorithm site), implemented in R, one of the most-used models due to its simplicity in tuning and robustness across many different types of data.

If you've never done a predictive model before and you want to, this may be a good starting point ;)

Don't get lost in the forest!

Random Forest Bear

The basic idea behind it is to build hundreds or even thousands of simple and less-robust models (aka decision trees) in order to have a less-biased model.

But how?

Every 'tiny' branch of these decision tree models will see just part of the whole data to produce their humble predictions. So the final decision produced by the random forest model is the result of voting by all the decision trees. Just like democracy.

And what is a decision tree?

You're already familiar with decision tree outputs: they produce

IF-THEN
rules, such as,
If the user has more than five visits, he or she will probably use the app
.

Decision Tree

Putting all together...

If a random forest has

three trees
(but normally 500-plus) and a new customer arrives, then the prediction whether said customer will buy a certain product will be 'yes' if 'two trees' predict 'yes'.

Random Forest

Having hundreds of opinions -decision trees- tends to produce a more accurate result on average -random forest-.

But don't panic, all of the above is encapsulated in the data scientist.

With this model, you will not be able to easily know how the model comes to assign a high or low probability to each input case. It acts more like a black box, similar to what is used for deep learning with neural networks, where every neuron contributes to the whole.

Next post...

Will contain an example -based on real data- of how random forest orders the customers according to their likelihood of matching certain business condition. Also, it will map around 20 variables into only two, therefore, it can be seen by the analyst ;)

Next Post

What language is convenient for learning machine learning?

Auth0 mainly uses R software to create predictive models as well as other data processes; for example:

  • Finding relationships between app features: which impacts the engineering area.
  • Finding anomalies or abnormal behavior: which leads to the development of anomaly detection features.
  • Improving web browsing docs: based on markov chains (likelihood of visiting
    Page B being on Page C
    )
  • Reducing times for answering support tickets using deep learning (not with R but with Keras)

If you want to develop your own data science projects, you could start with R. It has a enormous community from which you can learn (and teach). It's not always just a matter of complex algorithms, but also about having support when things don't go as expected. And this occurs often when you're doing new things.

R Logo

Finally, some numbers about community support

Despite the fact that R (and

Python
with
pandas
and
numpy
) has lots of packages, libraries, free books, and free courses, check these metrics: There are more than 160,000 questions in stackoverflow.com, and another ~15,000 in stats.stackexchange.com are tagged with R.