Heim > Backend-Entwicklung > Python-Tutorial > Eine Einführung in vier Methoden zur Implementierung maschineller Lernfunktionen in Python

Eine Einführung in vier Methoden zur Implementierung maschineller Lernfunktionen in Python

不言
Freigeben: 2019-04-13 11:41:10
nach vorne
3468 Leute haben es durchsucht

Dieser Artikel bietet Ihnen eine Einführung in die vier Methoden zur Implementierung maschineller Lernfunktionen in Python. Ich hoffe, dass er für Freunde hilfreich ist.

In diesem Artikel stellen wir verschiedene Methoden zur Auswahl von Features aus einem Datensatz vor und diskutieren die Arten von Feature-Auswahlalgorithmen und ihre Implementierung in Python mithilfe der Scikit-learn-Bibliothek (sklearn):

  1. Univariate Merkmalsauswahl
  2. Rekursive Merkmalseliminierung (RFE)
  3. Hauptkomponentenanalyse (PCA)
  4. Merkmalsbedeutung (Merkmalsbedeutung)

Univariate Merkmalsauswahl

Statistische Tests können verwendet werden, um diejenigen Merkmale auszuwählen, die die stärkste Beziehung zur Ausgabevariablen haben.

Die scikit-learn-Bibliothek stellt die SelectKBest-Klasse bereit, die mit einem anderen Satz statistischer Tests verwendet werden kann, um eine bestimmte Anzahl von Funktionen auszuwählen.

Im folgenden Beispiel wird die Chi-Quadrat-Statistik (chi^2) verwendet, um auf nicht negative Merkmale zu testen und die vier besten Merkmale im Pima Indians Diabetes-Datensatz auszuwählen:

#Feature Extraction with Univariate Statistical Tests (Chi-squared for classification)

#Import the required packages

#Import pandas to read csv import pandas

#Import numpy for array related operations import numpy

#Import sklearn's feature selection algorithm

from sklearn.feature_selection import SelectKBest

#Import chi2 for performing chi square test from sklearn.feature_selection import chi2

#URL for loading the dataset

url ="https://archive.ics.uci.edu/ml/machine-learning-databases/pima-indians diabetes/pima-indians-diabetes.data"

#Define the attribute names

names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']

#Create pandas data frame by loading the data from URL

dataframe = pandas.read_csv(url, names=names)

#Create array from data values

array = dataframe.values

#Split the data into input and target

X = array[:,0:8]

Y = array[:,8]

#We will select the features using chi square

test = SelectKBest(score_func=chi2, k=4)

#Fit the function for ranking the features by score

fit = test.fit(X, Y)

#Summarize scores numpy.set_printoptions(precision=3) print(fit.scores_)

#Apply the transformation on to dataset

features = fit.transform(X)

#Summarize selected features print(features[0:5,:])
Nach dem Login kopieren

jeweils Die Bewertung des Attributs und der vier ausgewählten Attribute (die mit den höchsten Bewertungen): Plas, Test, Masse und Alter.

Score pro Feature:

[111.52   1411.887 17.605 53.108  2175.565   127.669 5.393

181.304]
Nach dem Login kopieren

Features:

[[148. 0. 33.6 50. ]

[85. 0. 26.6 31. ]

[183. 0. 23.3 32. ]

[89. 94. 28.1 21. ]

[137. 168. 43.1 33. ]]
Nach dem Login kopieren

Recursive Feature Elimination (RFE)

RFE über rekursive Löscheigenschaften und Erstellen Sie Modelle auf den verbleibenden Grundstücken, an denen Sie arbeiten möchten. Mithilfe der Modellgenauigkeit wird ermittelt, welche Attribute (und Kombinationen von Attributen) am meisten zur Vorhersage des Zielattributs beitragen. Im folgenden Beispiel werden RFE- und logistische Regressionsalgorithmen verwendet, um die drei wichtigsten Features auszuwählen. Die Wahl des Algorithmus ist nicht wichtig, solange er geschickt und konsistent ist:

#Import the required packages

#Import pandas to read csv import pandas

#Import numpy for array related operations import numpy

#Import sklearn's feature selection algorithm from sklearn.feature_selection import RFE

#Import LogisticRegression for performing chi square test from sklearn.linear_model import LogisticRegression

#URL for loading the dataset

url =

"https://archive.ics.uci.edu/ml/machine-learning-databases/pima-indians-dia betes/pima-indians-diabetes.data"

#Define the attribute names

names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']

#Create pandas data frame by loading the data from URL

dataframe = pandas.read_csv(url, names=names)

#Create array from data values

array = dataframe.values

#Split the data into input and target

X = array[:,0:8]

Y = array[:,8]

#Feature extraction

model = LogisticRegression() rfe = RFE(model, 3)

fit = rfe.fit(X, Y)

print("Num Features: %d"% fit.n_features_) print("Selected Features: %s"% fit.support_) print("Feature Ranking: %s"% fit.ranking_)
Nach dem Login kopieren

Nach der Ausführung erhalten wir:

Num Features: 3

Selected Features: [ True False False False False   True  True False]

Feature Ranking: [1 2 3 5 6 1 1 4]
Nach dem Login kopieren

Sie können sehen, dass RFE die ersten drei Merkmale als preg auswählt. Masse und Pediküre. Diese sind im support_array mit „True“ und im Ranking_array mit „Option 1“ markiert.

Hauptkomponentenanalyse (PCA)

PCA verwendet lineare Algebra, um einen Datensatz in eine komprimierte Form umzuwandeln. Typischerweise handelt es sich dabei um eine Datenreduktionstechnik. Eine Eigenschaft von PCA besteht darin, dass Sie die Anzahl der Dimensionen oder Hauptkomponenten im Ergebnis transformieren können.

Im folgenden Beispiel verwenden wir PCA und wählen drei Hauptkomponenten aus:

#Import the required packages

#Import pandas to read csv import pandas

#Import numpy for array related operations import numpy

#Import sklearn's PCA algorithm

from sklearn.decomposition import PCA

#URL for loading the dataset

url =

"https://archive.ics.uci.edu/ml/machine-learning-databases/pima-indians diabetes/pima-indians-diabetes.data"

#Define the attribute names

names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']

dataframe = pandas.read_csv(url, names=names)

#Create array from data values

array = dataframe.values

#Split the data into input and target

X = array[:,0:8]

Y = array[:,8]

#Feature extraction

pca = PCA(n_components=3) fit = pca.fit(X)

#Summarize components

print("Explained Variance: %s") % fit.explained_variance_ratio_

print(fit.components_)
Nach dem Login kopieren

Sie können sehen, dass der transformierte Datensatz (drei Hauptkomponenten) wenig Ähnlichkeit mit den Quelldaten aufweist. Wo:

Explained Variance: [ 0.88854663   0.06159078  0.02579012]

[[ -2.02176587e-03    9.78115765e-02 1.60930503e-02    6.07566861e-02

9.93110844e-01          1.40108085e-02 5.37167919e-04   -3.56474430e-03]

[ -2.26488861e-02   -9.72210040e-01              -1.41909330e-01  5.78614699e-02 9.46266913e-02   -4.69729766e-02               -8.16804621e-04  -1.40168181e-01

[ -2.24649003e-02 1.43428710e-01                 -9.22467192e-01  -3.07013055e-01 2.09773019e-02   -1.32444542e-01                -6.39983017e-04  -1.25454310e-01]]
Nach dem Login kopieren

Merkmalswichtigkeit

Merkmalswichtigkeit ist eine Technik zur Auswahl von Merkmalen mithilfe eines trainierten überwachten Klassifikators. Wenn wir einen Klassifikator (z. B. einen Entscheidungsbaum) trainieren, werten wir jedes Attribut aus, um eine Aufteilung zu erstellen. Wir können dieses Maß als Merkmalsselektor verwenden. Lassen Sie es uns im Detail wissen.

Random Forests sind aufgrund ihrer relativ guten Genauigkeit, Robustheit und Benutzerfreundlichkeit eine der beliebtesten Methoden des maschinellen Lernens. Sie bieten außerdem zwei unkomplizierte Methoden zur Merkmalsauswahl: Durchschnittliche Reduzierung der Verunreinigung und Durchschnittliche Reduzierung der Präzision.

Zufälliger Wald besteht aus vielen Entscheidungsbäumen. Jeder Knoten im Entscheidungsbaum ist eine Bedingung für ein einzelnes Merkmal, das den Datensatz in zwei Teile aufteilen soll, sodass ähnliche Antwortwerte im selben Satz landen. Die Metrik, die (lokal) optimale Bedingungen auswählt, wird Verunreinigung genannt. Für die Klassifizierung ist es normalerweise der Gini-Koeffizient

Verunreinigung oder Informationsgewinn/Entropie und für Regressionsbäume die Varianz. Daher kann beim Training eines Baums berechnet werden, um wie viel jedes Merkmal die gewichtete Verunreinigung im Baum reduziert. Für Wälder kann die Verunreinigungsreduzierung für jedes Merkmal gemittelt und die Merkmale nach diesem Maß eingestuft werden.

Sehen wir uns an, wie Sie den Random Forest-Klassifikator für die Merkmalsauswahl verwenden und die Genauigkeit des Klassifikators vor und nach der Merkmalsauswahl bewerten. Wir werden den Otto-Datensatz verwenden.

Dieser Datensatz beschreibt 93 unscharfe Details für über 61.000 Produkte, die in 10 Produktkategorien (z. B. Mode, Elektronik usw.) gruppiert sind. Das Eingabeattribut ist eine Art Anzahl unterschiedlicher Ereignisse.

Das Ziel besteht darin, Vorhersagen für neue Produkte als Array von Wahrscheinlichkeiten für jede der 10 Kategorien zu erhalten und zur Auswertung einen Mehrklassen-Protokollverlust (auch als Kreuzentropie bezeichnet) zu verwenden das Modell.

Wir beginnen mit dem Importieren aller Bibliotheken:

#Import the supporting libraries

#Import pandas to load the dataset from csv file

from pandas import read_csv

#Import numpy for array based operations and calculations

import numpy as np

#Import Random Forest classifier class from sklearn

from sklearn.ensemble import RandomForestClassifier

#Import feature selector class select model of sklearn

        from sklearn.feature_selection

        import SelectFromModel

         np.random.seed(1)
Nach dem Login kopieren

Definieren wir eine Möglichkeit, den Datensatz in Trainings- und Testdaten aufzuteilen; wir werden unseren Datensatz im Trainingsteil trainieren, der Testteil wird sein Wird zur Bewertung des trainierten Modells verwendet:

#Function to create Train and Test set from the original dataset def getTrainTestData(dataset,split):

np.random.seed(0) training = [] testing = []

np.random.shuffle(dataset) shape = np.shape(dataset)

trainlength = np.uint16(np.floor(split*shape[0]))

for i in range(trainlength): training.append(dataset[i])

for i in range(trainlength,shape[0]): testing.append(dataset[i])

training = np.array(training) testing = np.array(testing)

return training,testing
Nach dem Login kopieren

Wir müssen außerdem eine Funktion hinzufügen, um die Genauigkeit des Modells zu bewerten. Sie verwendet die vorhergesagte und tatsächliche Ausgabe als Eingabe, um die prozentuale Genauigkeit zu berechnen:

#Function to evaluate model performance

def getAccuracy(pre,ytest): count = 0

for i in range(len(ytest)):

if ytest[i]==pre[i]: count+=1

acc = float(count)/len(ytest)

return acc
Nach dem Login kopieren

Dies ist die Zeit zum Laden des Datensatzes. Wir laden die Datei train.csv; diese Datei enthält über 61.000 Trainingsinstanzen. Wir werden in unserem Beispiel 50.000 Instanzen verwenden, davon 35.000 Instanzen zum Trainieren des Klassifikators und 15.000 Instanzen zum Testen der Leistung des Klassifikators:

#Load dataset as pandas data frame

data = read_csv('train.csv')

#Extract attribute names from the data frame

feat = data.keys()

feat_labels = feat.get_values()

#Extract data values from the data frame

dataset = data.values

#Shuffle the dataset

np.random.shuffle(dataset)

#We will select 50000 instances to train the classifier

inst = 50000

#Extract 50000 instances from the dataset

dataset = dataset[0:inst,:]

#Create Training and Testing data for performance evaluation

train,test = getTrainTestData(dataset, 0.7)

#Split data into input and output variable with selected features

Xtrain = train[:,0:94] ytrain = train[:,94] shape = np.shape(Xtrain)

print("Shape of the dataset ",shape)

#Print the size of Data in MBs

print("Size of Data set before feature selection: %.2f MB"%(Xtrain.nbytes/1e6))
Nach dem Login kopieren
Wir achten hier auf die Datengröße; da unser Datensatz rund 35.000 Trainingsinstanzen mit 94 Attributen enthält; Werfen wir einen Blick darauf:

Shape of the dataset (35000, 94)

Size of Data set before feature selection: 26.32 MB
Nach dem Login kopieren

Wie Sie sehen können, haben wir 35.000 Zeilen und 94 Spalten in unserem Datensatz, was über 26 MB an Daten entspricht.

Im nächsten Codeblock konfigurieren wir den Random-Forest-Klassifikator; wir verwenden 250 Bäume, eine maximale Tiefe von 30 und die Anzahl der Zufallsmerkmale beträgt 7. Die anderen Hyperparameter sind die Sklearn-Standardwerte :

#Lets select the test data for model evaluation purpose

Xtest = test[:,0:94] ytest = test[:,94]

#Create a random forest classifier with the following Parameters

trees            = 250

max_feat     = 7

max_depth = 30

min_sample = 2

clf = RandomForestClassifier(n_estimators=trees,

max_features=max_feat,

max_depth=max_depth,

min_samples_split= min_sample, random_state=0,

n_jobs=-1)

#Train the classifier and calculate the training time

import time

start = time.time() clf.fit(Xtrain, ytrain) end = time.time()

#Lets Note down the model training time

print("Execution time for building the Tree is: %f"%(float(end)- float(start)))

pre = clf.predict(Xtest)

Let's see how much time is required to train the model on the training dataset:

Execution time for building the Tree is: 2.913641

#Evaluate the model performance for the test data

acc = getAccuracy(pre, ytest)

print("Accuracy of model before feature selection is %.2f"%(100*acc))
Nach dem Login kopieren

我们模型的准确性是:

特征选择前的模型精度为98.82

正如您所看到的,我们正在获得非常好的准确性,因为我们将近99%的测试数据分类到正确的类别中。这意味着我们正在对15,000个正确类中的14,823个实例进行分类。

那么,现在我的问题是:我们是否应该进一步改进?好吧,为什么不呢?如果可以的话,我们肯定会寻求更多的改进; 在这里,我们将使用功能重要性来选择功能。如您所知,在树木构建过程中,我们使用杂质测量来选择节点。选择具有最低杂质的属性值作为树中的节点。我们可以使用类似的标准进行特征选择。我们可以更加重视杂质较少的功能,这可以使用sklearn库的feature_importances_函数来完成。让我们找出每个功能的重要性:

#Once我们培养的模型中,我们的排名将所有功能的功能拉链(feat_labels,clf.feature_importances_):

print(feature)

('id', 0.33346650420175183)

('feat_1', 0.0036186958628801214)

('feat_2', 0.0037243050888530957)

('feat_3', 0.011579217472062748)

('feat_4', 0.010297382675187445)

('feat_5', 0.0010359139416194116)

('feat_6', 0.00038171336038056165)

('feat_7', 0.0024867672489765021)

('feat_8', 0.0096689721610546085)

('feat_9', 0.007906150362995093)

('feat_10', 0.0022342480802130366)
Nach dem Login kopieren

正如您在此处所看到的,每个要素都基于其对最终预测的贡献而具有不同的重要性。

我们将使用这些重要性分数来排列我们的功能; 在下面的部分中,我们将选择功能重要性大于0.01的模型训练功能:

#Select features which have higher contribution in the final prediction

sfm = SelectFromModel(clf, threshold=0.01) sfm.fit(Xtrain,ytrain)
Nach dem Login kopieren

在这里,我们将根据所选的特征属性转换输入数据集。在下一个代码块中,我们将转换数据集。然后,我们将检查新数据集的大小和形状:

#Transform input dataset

Xtrain_1 = sfm.transform(Xtrain) Xtest_1      = sfm.transform(Xtest)

#Let's see the size and shape of new dataset print("Size of Data set before feature selection: %.2f MB"%(Xtrain_1.nbytes/1e6))

shape = np.shape(Xtrain_1)

print("Shape of the dataset ",shape)

Size of Data set before feature selection: 5.60 MB Shape of the dataset (35000, 20)
Nach dem Login kopieren

你看到数据集的形状了吗?在功能选择过程之后,我们只剩下20个功能,这将数据库的大小从26 MB减少到5.60 MB。这比原始数据集减少了约80%

在下一个代码块中,我们将训练一个新的随机森林分类器,它具有与之前相同的超参数,并在测试数据集上进行测试。让我们看看修改训练集后得到的准确度:

#Model training time

start = time.time() clf.fit(Xtrain_1, ytrain) end = time.time()

print("Execution time for building the Tree is: %f"%(float(end)- float(start)))

#Let's evaluate the model on test data

pre = clf.predict(Xtest_1) count = 0

acc2 = getAccuracy(pre, ytest)

print("Accuracy after feature selection %.2f"%(100*acc2))

Execution time for building the Tree is: 1.711518 Accuracy after feature selection 99.97
Nach dem Login kopieren

你能看到!! 我们使用修改后的数据集获得了99.97%的准确率,这意味着我们在正确的类中对14,996个实例进行了分类,而之前我们只正确地对14,823个实例进行了分类。

这是我们在功能选择过程中取得的巨大进步; 我们可以总结下表中的所有结果:

评估标准 在选择特征之前 选择功能后
功能数量 94 20
数据集的大小 26.32 MB 5.60 MB
训练时间 2.91秒 1.71秒
准确性 98.82% 99.97%

上表显示了特征选择的实际优点。您可以看到我们显着减少了要素数量,从而降低了数据集的模型复杂性和维度。尺寸减小后我们的训练时间缩短,最后,我们克服了过度拟合问题,获得了比以前更高的精度。

Das obige ist der detaillierte Inhalt vonEine Einführung in vier Methoden zur Implementierung maschineller Lernfunktionen in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage