scikit-learn:cross_val_predict 仅适用于分区

scikit-learn: cross_val_predict only works for partitions

我正在努力研究如何在 sklearn 中实现 TimeSeriesSplit。

下面 link 中的建议答案产生相同的 ValueError。

这里是我的代码中的相关部分:

from sklearn.model_selection import cross_val_predict
from sklearn import svm

features = df[df.columns[0:6]]
target = df['target']

clf = svm.SVC(random_state=0)

pred = cross_val_predict(clf, features, target, cv=TimeSeriesSplit(n_splits=5).split(features))

ValueError                                Traceback (most recent call last)
<ipython-input-57-d1393cd05640> in <module>()
----> 1 pred = cross_val_predict(clf, features, target, cv=TimeSeriesSplit(n_splits=5).split(features))

/home/jedwards/anaconda3/envs/py36/lib/python3.6/site-packages/sklearn/model_selection/_validation.py in cross_val_predict(estimator, X, y, groups, cv, n_jobs, verbose, fit_params, pre_dispatch, method)
    407 
    408     if not _check_is_permutation(test_indices, _num_samples(X)):
--> 409         raise ValueError('cross_val_predict only works for partitions')
    410 
    411     inv_test_indices = np.empty(len(test_indices), dtype=int)

ValueError: cross_val_predict only works for partitions

cross_val_predict 不能与 TimeSeriesSplit 一起使用,因为 TimeSeriesSplit 的第一个分区从来不是测试数据集的一部分,这意味着没有对其进行预测。

例如当你的数据集是 [1, 2, 3, 4, 5]

  • fold 1 - 训练:[1],测试:[2]
  • fold 2 - 训练:[1, 2],测试:[3]
  • fold 3 - 训练:[1, 2, 3],测试:[4]
  • fold 4 - 训练:[1, 2, 3, 4],测试:[5]

in none 的 folds 在测试集中为 1

如果您想预测 2-5,您可以手动循环遍历您的 CV 生成的拆分并自己存储 2-5 的预测。