Я пытался вычислить точность и был озадачен тем фактом, что cross_val_score дает довольно низкий результат, чем при сравнении предсказанных результатов с правильными.
Первый способ подсчета, который дает
[0.8033333333333333, 0.7908333333333334, 0.8033333333333333, 0.7925,0.8066666666666666]
kf = KFold(shuffle=True, n_splits=5)
scores = []
for train_index, test_index in kf.split(X):
X_train, X_test = X[train_index], X[test_index]
y_train, y_test = y[train_index], y[test_index]
model = KNeighborsClassifier(n_jobs=-1, n_neighbors=5)
model.fit(X_train, y_train)
y_pred = model.predict(X_test)
scores.append(np.sum(y_pred == y_test) / len(y_test))
Второй способ дает array([0.46166667, 0.53583333, 0.40916667, 0.44666667, 0.3775 ])
:
model = KNeighborsClassifier(n_jobs=-1, n_neighbors=5)
cross_val_score(model, X, y, cv = 5, scoring='accuracy')
В чем моя ошибка?