官术网_书友最值得收藏!

K-fold cross-validation

Let's walk through the steps of k-fold cross-validation:

  1. The data is divided into k-subsets.
  2. One set is kept for testing/development and the model is built on the rest of the data (k-1). That is, the rest of the data forms the training data.
  1. Step 2 is repeated k-times. That is, once the preceding step has been performed, we move on to the second set and it forms a test set. The rest of the (k-1) data is then available for building the model:

4. An error is calculated and an average is taken over all k-trials.

Every subset gets one chance to be a validation/test set since most of the data is used as a training set. This helps in reducing bias. At the same time, almost all the data is being used as validation set, which reduces variance.

As shown in the preceding diagram, k = 5 has been selected. This means that we have to divide the whole dataset into five subsets. In the first iteration, subset 5 becomes the test data and the rest becomes the training data. Likewise, in the second iteration, subset 4 turns into the test data and the rest becomes the training data. This goes on for five iterations.

Now, let's try to do this in Python by splitting the train and test data using the K neighbors classifier:

from sklearn.datasets import load_breast_cancer # importing the dataset
from sklearn.cross_validation import train_test_split,cross_val_score # it will help in splitting train & test
from sklearn.neighbors import KNeighborsClassifier
from sklearn import metrics

BC =load_breast_cancer()
X = BC.data
y = BC.target

X_train, X_test, y_train, y_test = train_test_split(X, y, random_state=4)

knn = KNeighborsClassifier(n_neighbors=5)
knn.fit(X_train, y_train)
y_pred = knn.predict(X_test)
print(metrics.accuracy_score(y_test, y_pred))

knn = KNeighborsClassifier(n_neighbors=5)
scores = cross_val_score(knn, X, y, cv=10, scoring='accuracy')
print(scores)
print(scores.mean())
主站蜘蛛池模板: 榆社县| 中西区| 铁岭县| 崇信县| 灵寿县| 铜鼓县| 博罗县| 凯里市| 佛教| 阿瓦提县| 贡嘎县| 城固县| 邵阳县| 江阴市| 宜阳县| 白山市| 定安县| 遵义市| 土默特左旗| 大余县| 阿合奇县| 响水县| 石阡县| 休宁县| 正安县| 苍山县| 酉阳| 岳池县| 介休市| 灵丘县| 焦作市| 当雄县| 根河市| 武川县| 朝阳市| 巴林左旗| 蒙城县| 台南县| 建昌县| 黑龙江省| 宁陵县|