JusBrasil's

Machine Learning

Architecture to

Predict Document's

Labels

What is 

What is 

Art

What is 

Art

Machine Learning

?

The Resurrection of the Artificial Intelligence

The Resurrection of the Artificial Intelligence

And many more.

The Resurrection of the Artificial Intelligence

Car

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Car

What is this?

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Machine Learning is as simple as Human Learning

Patterns from previous information

(Spoiler Alert: It's not that simple)

What is this?

Car

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Patterns from previous information

What is this?

Car

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

What is this?

WTF is happening here?

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Car

What is this?

Black Magic?

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Car

What is this?

Neuroscience try to understand

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Car

What is this?

AI/ML/Mathematics/Computer Science try to imitate through Mathematical Models

Machine Learning is as simple as Human Learning

(Spoiler Alert: It's not that simple)

Car

What is this?

Machine Learning is a mix of many Sciences

Information Theory

Information Theory

Linear Algebra

Machine Learning is a mix of many Sciences

Information Theory

Linear Algebra

Machine Learning is a mix of many Sciences

Statistics

Information Theory

Linear Algebra

Statistics

Probability

Machine Learning is a mix of many Sciences

...And JusBrasil wants to do the same

...And JusBrasil wants to do the same

Model

...And JusBrasil wants to do the same

Model

Decisão?

Julgamento?

Sentença?

Ato Serventuário?

...And JusBrasil wants to do the same

Trained Data

Supervised Learning

Trained Data

Learning Algorithm

Supervised Learning

Trained Data

Learning Algorithm

Model

Supervised Learning

Trained Data

Learning Algorithm

Model

Incoming Data

Supervised Learning

Trained Data

Learning Algorithm

Model

Incoming Data

Predictions

Supervised Learning

The problem?

Supervised Learning

Real world datasets are messy

Supervised Learning

Real world datasets are messy

Supervised Learning

All we want is the perfect fit

Supervised Learning

But over/under fitting is also a problem

Supervised Learning

Supervised Learning

Key to a good Supervised Learning:

Right dataset

Supervised Learning

Key to a good Supervised Learning:

Right dataset

Right features

Supervised Learning

Key to a good Supervised Learning:

Right dataset

Right features

Right algorithms

Supervised Learning

Key to a good Supervised Learning:

Right dataset

Right features

Right algorithms

Right techniques

Supervised Learning

Key to a good Supervised Learning:

Key to a good Supervised Learning:

A good Architecture

Supervised Learning

Architecture for Automagic Text Classification

First we need a way to gather trained data

Architecture for Automagic Text Classification

Telepathy: Platform for data training

Architecture for Automagic Text Classification

Xavier

Feature Engineering

Feature Engineering

Phase to select/extract features

Feature Engineering

Phase to select/extract features

Using TF-IDF to extract words importance

Feature Engineering

Phase to select/extract features

Using TF-IDF to extract words importance

vectorizer = TfidfVectorizer(sublinear_tf=True,
                            stop_words=stopwords.get_stop_words(),
                            token_pattern=r'\w{4,}',
                            max_features=10000,
                            ngram_range=(1,1),
                            strip_accents='unicode',
                            norm='l2')

Vectorized_X = vectorizer.fit_transform(X)

Process to create the model

Process to create the model

Model

Process to create the model

Strategy #1

Use pipeline to unify the process

Process to create the model

Strategy #2

Use Grid Search to tune parameters

Process to create the model

Main Pipeline

Length Transformer

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Process to create the model

Main Pipeline

Length Transformer

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Extract Features and vectorize it

Process to create the model

Main Pipeline

Length Transformer

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

transform feature vector

Process to create the model

Main Pipeline

Length Transformer

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

pipeline = Pipeline([
                    ('features', FeatureUnion([
                        ('lengthtransformer', LengthTransformer()),
                        ('tfidf', Pipeline([
                            ('vect', vectorizer),
                            ('to_dense', DenseTransformer()),
                        ])),
                    ])),
                    ('estimators', FeatureUnion([
                        ('perceptron', Perceptron(alpha=0.0001)),
                        ('lr', LogisticRegression(C=5)),
                        ('linearsvc', LinearSVC(dual=True,C=5)),
                        ])),
                    ('clf', ExtraTreesClassifier(n_estimators=70))
                ])

Process to create the model

Main Pipeline

Length Transformer

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

pipeline = Pipeline([
                    ('features', FeatureUnion([
                        ('lengthtransformer', LengthTransformer()),
                        ('tfidf', Pipeline([
                            ('vect', vectorizer),
                            ('to_dense', DenseTransformer()),
                        ])),
                    ])),
                    ('estimators', FeatureUnion([
                        ('perceptron', Perceptron(alpha=0.0001)),
                        ('lr', LogisticRegression(C=5)),
                        ('linearsvc', LinearSVC(dual=True,C=5)),
                        ])),
                    ('clf', ExtraTreesClassifier(n_estimators=70))
                ])

Pipeline's interface is similar to Estimator's interface

it has transform() and fit()

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

Grid Search

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

Grid Search

Useful to search best parameters automatically 

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

Grid Search

Useful to search best parameters automatically 

It receives a estimator (Pipeline in this case) and a list of parameters

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

Grid Search

Parameters Grid

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

Grid Search

Parameters Grid

Best parameters combination

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

def tune_parameters(clf,X,y):
    parameters = {
            'features__tfidf__vect__max_features':[10000],
            'features__tfidf__vect__ngram_range':[(1,1)],
            'estimators__lr__C':[5],
            'estimators__linearsvc__dual':[True],
            'estimators__linearsvc__C':[5],
            'estimators__perceptron__alpha':[0.0001],
            'clf__n_estimators':[70],
            }

    grid_search = GridSearchCV(clf, parameters, verbose=True, cv=FOLDS)

    grid_search.fit(X, y)

    print("Best score: %0.3f" % grid_search.best_score_)
    print("Best parameters iset:")
    best_parameters = grid_search.best_estimator_.get_params()
    for param_name in sorted(parameters.keys()):
        print("\t%s: %r" % (param_name, best_parameters[param_name]))

Process to create the model

Main Pipeline

Inner Pipeline

TFIDF vectorizer

Dense Transformer

Estimators (calling transform())

Perceptron

Logistic Regression

LinearSVC

Extra Randomized Trees

Tuning Pipeline's parameters

Length Transformer

def tune_parameters(clf,X,y):
    parameters = {
            'features__tfidf__vect__max_features':[10000],
            'features__tfidf__vect__ngram_range':[(1,1)],
            'estimators__lr__C':[5],
            'estimators__linearsvc__dual':[True],
            'estimators__linearsvc__C':[5],
            'estimators__perceptron__alpha':[0.0001],
            'clf__n_estimators':[70],
            }

    grid_search = GridSearchCV(clf, parameters, verbose=True, cv=FOLDS)

    grid_search.fit(X, y)

    print("Best score: %0.3f" % grid_search.best_score_)
    print("Best parameters iset:")
    best_parameters = grid_search.best_estimator_.get_params()
    for param_name in sorted(parameters.keys()):
        print("\t%s: %r" % (param_name, best_parameters[param_name]))

Grid Search run tasks in parallel

Process to create the model

Pipeline + Grid Search

Why Random Trees as Final Classifier?

Random Tree is a great method

Information Theory's Information Gain worked amazingly well

Variance Reduction worked well too!

Combining many trees is cool

Combining many trees is cool

And it works

Text

Ensemble Technique

Results

Previous dataset (highly biased) + previous process

Results

Previous dataset (highly biased) + previous process

<60% prediction precision

Results

Previous dataset (highly biased) + previous process

<60% prediction precision

Results

Previous dataset (highly biased) + new process

Results

Previous dataset (highly biased) + new process

~61% prediction precision

Results

Previous dataset (highly biased) + new process

~61% prediction precision

Results

New dataset (re-trained from scratch) + new process

Results

New dataset (re-trained from scratch) + new process

85% prediction precision (and growing)

Lessons Learned

Lessons Learned

Unbalanced datasets sucks.

Lessons Learned

Datasets with too little examples sucks.

Lessons Learned

Low quality datasets sucks even more.

Lessons Learned

There are good algorithms and bad algorithms for given situation. Chose wisely.

Lessons Learned

There are good algorithms and bad algorithms for given situation. Chose wisely.

Lessons Learned

Grid Search can be *really* slow. Make sure to run it in parallel.... otherwise...

Lessons Learned

It can be embarrassingly slow

Lessons Learned

Feature Union is a great idea. Don't stick only to TF-IDF.

Lessons Learned

Do not test your model against data used to train the model.

Lessons Learned

Do not test your model against data used to train the model.

Lessons Learned

Always cross validate.

Lessons Learned

Intuition fails in high dimensions

Lessons Learned

More data beats a cleverer algorithm

- Pedro Domingos, University of Washington

Next Steps

Improve dataset:

Improve dataset:

Train more documents

Improve dataset:

Train more documents

Re-train wrong data

Improve dataset:

Train more documents

Re-train wrong data

Crowd Sourcing?

Improve dataset:

Train more documents

Re-train wrong data

Crowd Sourcing?

Approves!

Migrate Xavier to Tsuru:

Make it a service!

Migrate Xavier to Tsuru:

Make it a service!

Expose API method to classify documents

classified_doc = api.get(method='classify_doc', doc)

Questions?

Thank you! 

MachineLearningJusbrasilDocCLass

By Rodrigo Araújo

MachineLearningJusbrasilDocCLass

  • 2,042