3

我正在尝试imblearn在 Python 中使用包中的 SMOTE,但我的数据有很多缺失值,并且出现以下错误:

ValueError:输入包含 NaN、无穷大或对于 dtype('float64') 来说太大的值。

我检查了这里的参数,似乎没有一个处理缺失值的。

有没有办法生成具有缺失值的合成样本?

4

2 回答 2

3

SMOTE 不会填充您的缺失值或 NaN 值。您需要将它们填满,然后进行 SMOTE 分析。处理缺失值完全是一项不同的任务,您可以从 sklearn 开始查看Imputer 。这是关于缺失值的另一篇关于 sklearn 的文章:估算缺失值

处理完 NaN 值后,将修改后的数据提供给SMOTE.

参考

于 2018-07-13T12:32:52.500 回答
-1

一个简单的例子如下:

# Imports
from collections import Counter
import numpy as np
from sklearn.datasets import load_breast_cancer
from sklearn.preprocessing import Imputer
from imblearn.over_sampling import SMOTE
from imblearn.pipeline import make_pipeline

# Load data
bc = load_breast_cancer()
X, y = bc.data, bc.target

# Initial number of samples per class
print('Number of samples for both classes: {} and {}.'.format(*Counter(y).values()))

# SMOTEd class distribution
print('Dataset has %s missing values.' % np.isnan(X).sum())
_, y_resampled = SMOTE().fit_sample(X, y)
print('Number of samples for both classes: {} and {}.'.format(*Counter(y_resampled).values()))

# Generate artificial missing values
X[X > 1.0] = np.nan
print('Dataset has %s missing values.' % np.isnan(X).sum())
_, y_resampled = make_pipeline(Imputer(), SMOTE()).fit_sample(X, y)
print('Number of samples for both classes: {} and {}.'.format(*Counter(y_resampled).values()))
于 2018-07-14T15:17:39.797 回答