首页 > 解决方案 > 在 python 中训练测试拆分但考虑患者信息?

问题描述

我想知道是否有一种简单的方法可以在 python 中进行训练测试拆分(主要对交叉验证感兴趣),这样我最终不会在训练和测试中得到来自同一患者的数据点?也就是说,我想首先将患者分成训练和测试,然后相应地进行观察。

是否有这种场景的功能,还是我必须手动编码?

标签: pythonmachine-learningscikit-learncross-validationtrain-test-split

解决方案


Sklearn GroupKFold应该可以解决这个问题。具有非重叠组的K 折迭代器变体。同一组不会出现在两个不同的折叠中:

from sklearn.model_selection import GroupKFold

X = np.array([[1, 2], [3, 4], [5, 6], [7, 8]])
y = np.array([1, 2, 3, 4])
groups = np.array([0, 0, 2, 2])
group_kfold = GroupKFold(n_splits=2)

group_kfold.get_n_splits(X, y, groups)

推荐阅读