File size: 8,322 Bytes
2d28ef1
 
929bfb3
 
f926bda
 
2d28ef1
d126ac0
 
c64c1e2
929bfb3
d126ac0
c64c1e2
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
---
license: apache-2.0
tags:
- text-classification
- generic
library_name: generic
---
## Hugging Face Transformers with Scikit-learn Classifiers 🀩🌟

This repository contains a small proof-of-concept pipeline that leverages longformer embeddings with scikit-learn Logistic Regression that does sentiment analysis. 
The training leverages the language module of [whatlies](https://github.com/koaning/whatlies).

# Classification Report
Below is the classification report πŸ‘‡πŸ»
           precision    recall  f1-score   support
           0       0.84      0.89      0.86        53
           1       0.86      0.81      0.84        47    
    accuracy                           0.85       100   
    macro avg      0.85      0.85      0.85       100
    weighted avg   0.85      0.85      0.85       100
    
# Pipeline
Below you can see the pipeline πŸ‘‡πŸ» (it's interactive! πŸͺ„)
<style>#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 {color: black;background-color: white;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 pre{padding: 0;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-toggleable {background-color: white;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 label.sk-toggleable__label {cursor: pointer;display: block;width: 100%;margin-bottom: 0;padding: 0.3em;box-sizing: border-box;text-align: center;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 label.sk-toggleable__label-arrow:before {content: "β–Έ";float: left;margin-right: 0.25em;color: #696969;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 label.sk-toggleable__label-arrow:hover:before {color: black;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-estimator:hover label.sk-toggleable__label-arrow:before {color: black;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-toggleable__content {max-height: 0;max-width: 0;overflow: hidden;text-align: left;background-color: #f0f8ff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-toggleable__content pre {margin: 0.2em;color: black;border-radius: 0.25em;background-color: #f0f8ff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 input.sk-toggleable__control:checked~div.sk-toggleable__content {max-height: 200px;max-width: 100%;overflow: auto;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {content: "β–Ύ";}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {background-color: #d4ebff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 input.sk-hidden--visually {border: 0;clip: rect(1px 1px 1px 1px);clip: rect(1px, 1px, 1px, 1px);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-estimator {font-family: monospace;background-color: #f0f8ff;border: 1px dotted black;border-radius: 0.25em;box-sizing: border-box;margin-bottom: 0.5em;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-estimator:hover {background-color: #d4ebff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel-item::after {content: "";width: 100%;border-bottom: 1px solid gray;flex-grow: 1;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-label:hover label.sk-toggleable__label {background-color: #d4ebff;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-serial::before {content: "";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 2em;bottom: 0;left: 50%;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-serial {display: flex;flex-direction: column;align-items: center;background-color: white;padding-right: 0.2em;padding-left: 0.2em;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-item {z-index: 1;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel {display: flex;align-items: stretch;justify-content: center;background-color: white;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel::before {content: "";position: absolute;border-left: 1px solid gray;box-sizing: border-box;top: 2em;bottom: 0;left: 50%;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel-item {display: flex;flex-direction: column;position: relative;background-color: white;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel-item:first-child::after {align-self: flex-end;width: 50%;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel-item:last-child::after {align-self: flex-start;width: 50%;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-parallel-item:only-child::after {width: 0;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-dashed-wrapped {border: 1px dashed gray;margin: 0 0.4em 0.5em 0.4em;box-sizing: border-box;padding-bottom: 0.4em;background-color: white;position: relative;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-label label {font-family: monospace;font-weight: bold;background-color: white;display: inline-block;line-height: 1.2em;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-label-container {position: relative;z-index: 2;text-align: center;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-container {/* jupyter\'s `normalize.less` sets `[hidden] { display: none; }` but bootstrap.min.css set `[hidden] { display: none !important; }` so we also need the `!important` here to be able to override the default hidden behavior on the sphinx rendered scikit-learn.org. See: https://github.com/scikit-learn/scikit-learn/issues/21755 */display: inline-block !important;position: relative;}#sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48 div.sk-text-repr-fallback {display: none;}</style><div id="sk-39946057-cc05-4ffc-aa91-2be5cb7e4f48" class="sk-top-container"><div class="sk-text-repr-fallback"><pre>Pipeline(steps=[(&#x27;embedding&#x27;,\n                 HFTransformersLanguage(model_name_or_path=&#x27;allenai/longformer-base-4096&#x27;)),\n                (&#x27;model&#x27;, LogisticRegression())])</pre><b>Please rerun this cell to show the HTML repr or trust the notebook.</b></div><div class="sk-container" hidden><div class="sk-item sk-dashed-wrapped"><div class="sk-label-container"><div class="sk-label sk-toggleable"><input class="sk-toggleable__control sk-hidden--visually" id="866ec933-b9b6-4e29-94ea-a8434aab47b7" type="checkbox" ><label for="866ec933-b9b6-4e29-94ea-a8434aab47b7" class="sk-toggleable__label sk-toggleable__label-arrow">Pipeline</label><div class="sk-toggleable__content"><pre>Pipeline(steps=[(&#x27;embedding&#x27;,\n                 HFTransformersLanguage(model_name_or_path=&#x27;allenai/longformer-base-4096&#x27;)),\n                (&#x27;model&#x27;, LogisticRegression())])</pre></div></div></div><div class="sk-serial"><div class="sk-item"><div class="sk-estimator sk-toggleable"><input class="sk-toggleable__control sk-hidden--visually" id="5732cbdd-b06b-453e-8291-0846f2ab2c8d" type="checkbox" ><label for="5732cbdd-b06b-453e-8291-0846f2ab2c8d" class="sk-toggleable__label sk-toggleable__label-arrow">HFTransformersLanguage</label><div class="sk-toggleable__content"><pre>HFTransformersLanguage(model_name_or_path=&#x27;allenai/longformer-base-4096&#x27;)</pre></div></div></div><div class="sk-item"><div class="sk-estimator sk-toggleable"><input class="sk-toggleable__control sk-hidden--visually" id="871360c4-c184-40fd-9d30-9f8b5ed73aa8" type="checkbox" ><label for="871360c4-c184-40fd-9d30-9f8b5ed73aa8" class="sk-toggleable__label sk-toggleable__label-arrow">LogisticRegression</label><div class="sk-toggleable__content"><pre>LogisticRegression()</pre></div></div></div></div></div></div></div>

# Hyperparameters
```
-'memory': None,
-'steps': [('embedding', HFTransformersLanguage(model_name_or_path='allenai/longformer-base-4096')),
          ('model', LogisticRegression())],
 - 'verbose': False,
 -'embedding': HFTransformersLanguage(model_name_or_path='allenai/longformer-base-4096'),
 -'model': LogisticRegression(),
 -'embedding_model_name_or_path': 'allenai/longformer-base-4096',
 -'model_C': 1.0,
 - 'model_class_weight': None,
 - 'model_dual': False,
 - 'model_fit_intercept': True,
 - 'model_intercept_scaling': 1,
 - 'model_l1_ratio': None,
 - 'model_max_iter': 100,
 - 'model_multi_class': 'auto',
 -'model_n_jobs': None,
 -'model_penalty': 'l2',
 -'model_random_state': None,
 -'model_solver': 'lbfgs',
 -'model_tol': 0.0001,
 -'model_verbose': 0,
 -'model_warm_start': False
 ```