Module 2: Machine Learning - Apprentissage non supervisé
- Partie 2.1: Les K plus Proches Voisins [Notebook]
- Partie 2.2: A linéaire [Notebook]
- Partie 2.3: Régression logistique [Notebook]
- Partie 2.4: SVM [Notebook]
Partie 2.3: Régression logistique
La régression est un algorithme d'apprentissage supervisé (classification binaire).
Objectifs * Visualiser les données * Étudier les liens de corrélation linéaire entre les variables * Réduire le nombre de dimensions
L'idée de l'ACP est de projeter les données sur des axes préservant la variance des données. Avec p=2 ou p=3, on peut visualiser ls données.
Principe : approximer un nuage de points X de dimension p par sa projection linéaire en dimension d < p.
L'ACP maximise la variance des points projectés.
On cherche à réaliser la projection x app Rp-->Rd, d<p
L'espace de projection P inclus dans Rd sera construit de manière progressive.
* D'abord on va chercher le meilleur axe de projection (1D) u1
* Ensuite le meilleur plan en trouvant le deuxième axe u2
* Et ainsi de suite jusqu'à obtenir P
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
from sklearn.preprocessing import LabelEncoder
from sklearn.preprocessing import StandardScaler
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import accuracy_score, f1_score, confusion_matrix
Importation des données
Le jeu de donnés contient des donnés récuellies chez des patients, il comporte 100 lignes et 9 colonnes. La colonne diagnosis_result est la variable à expliquer qui represente le resultat du diagnostic. Les 8 dernières colonnes représentent les variables explicatives.
Exploration
Variable à expliquer
Les classes M et B sont déséquilibrées M(62) et B(38), il faudra en tenir compte dans la suite. Un modèle naïf qui prédit la classe M aurait une accuracy de 62% sans avoir appris les données.
Variables explicatives
Les variables ont des échelles (ou ordres de grandeur) différentes, il faut supprimer la dimension
Centrage et Réduction
- Centrer une variable consiste à retrancher la moyenne de toutes les données, la nouvelle moyenne est 0.
- Réduire (ou normliser) une variable consiste à diviser toutes les données par l'écart-type, le nouvel écart-type est 1.
Encodage de la variable explicative
On encode les valeurs B et M en 0 et 1.
L'argument stratify c'est pour indiquer que l'on souhaite que la séparation soit équilibrée suivant la variable diagnosis_result.
Régression logistique avec Scikit-learn
Évaluation
Plusieurs métriques peuvent être utilsés pour évaluer un modèle de classification (binaire). Le plus utilsé est l'accuracy. * Accuracy: le taux de bonnes prédictions. Lorsque les classes sont déséquilibrées, elle peut être trompeuse. * Précision: le taux de bonnes prédictions sur les prédictions positives. * Rappel: le taux de bonnes prédictions sur les données positives. * F1_score:
y_pred = clf.predict(X_test)
acc = accuracy_score(y_test, y_pred)
f1 = f1_score(y_test, y_pred)
confmat = confusion_matrix(y_test, y_pred)
print('Accuracy: %0.2f' % acc)
print('F1 score: %0.2f' % f1)
plt.matshow(confmat, cmap=plt.cm.Greens, alpha=.3)
for i in range(confmat.shape[0]):
for j in range(confmat.shape[1]):
plt.text(x=j, y=i, s=confmat[i, j], va='center', ha='center')
plt.xlabel('Valeur prédite')
plt.ylabel('Vraie valeur')
plt.show()
Interprétaion
Le premier axe conserve 41,2% le deuxième axe 19,4% et le troisème axe 14,3%. Les trois axes permettent de conserver environ 75% de variance des données. Si l'on souhaite conserver plus de variance, on peut ajouter un axe supplémentaire ou plus. Remarquons qu'il est peu pertinent de conserver toute la variance, autant travailler avec les données initiales, il ne faut pas perdre de vue que l'un des objectifs de l'ACP, c'est la réduction du nombre de dimensions.
Références * Appilquez l'apprentissage statistique aux objets connectés * Appilquez l'apprentissage statistique aux objets connectés * Appilquez l'apprentissage statistique aux objets connectés
Contribuer à ce projet
Toute contribution de votre part serait vivement appréciée. Si vous souhaiter contribuer à ce projet, merci de consulter ce guide CONTRIBUTING
Signaler un bug
Si vous avez rencontré un bug durant l'éxecution de ce notebook, pour le signaler, il suffit d'ouvrir une issue.
Sponsors
* Rintio
* Solidar'IT
Copyright & Licence
Sous licence MIT