通用范例 General Examples - Ex 4: Imputing missing values before building an estimator

优质
小牛编辑
132浏览
2023-12-01

http://scikit-learn.org/stable/auto_examples/missing_values.htm

在这范例说明有时补充缺少的数据(missing values),可以得到更好的结果。但仍然需要进行交叉验证。来验证填充是否合适
。而missing values可以用均值、中位值,或者频繁出现的值代替。中位值对大数据之机器学习来说是比较稳定的估计值。

(一)引入函式库及内建测试资料库

引入之函式库如下

  1. sklearn.ensemble.RandomForestRegressor: 随机森林回归
  2. sklearn.pipeline.Pipeline: 串联估计器
  3. sklearn.preprocessing.Imputer: 缺失值填充
  4. sklearn.cross_validation import cross_val_score:交叉验证

(二)引入内建测试资料库(boston房产资料)

使用 datasets.load_boston() 将资料存入, boston 为一个dict型别资料,我们看一下资料的内容。

n_samples 为样本数

n_features 为特征数

  1. dataset = load_boston()
  2. X_full, y_full = dataset.data, dataset.target
  3. n_samples = X_full.shape[0]
  4. n_features = X_full.shape[1]
显示说明
(‘data’, (506, 13))机器学习数据
(‘feature_names’, (13,))房地产相关特征
(‘target’, (506,))回归目标
DESCR资料之描述

共有506笔资料及13个特征(‘CRIM’, ‘ZN’, ‘INDUS’, ‘CHAS’, ‘NOX’, ‘RM’, ‘AGE’, ‘DIS’, ‘RAD’,’TAX’, ‘PTRATIO’, ‘B’, ‘LSTAT’)用来描述房地产的週边状况,如CRIM (per capita crime rate by town)跟该区域之犯罪率有关。而迴归目标为房地产的价格,以1000美元为单位。也就是说这个范例希望以房地产的週遭客观数据来预测房地产的价格。

(三)利用整个数据集来预测

全部的资料使用随机森林回归函数进行交叉验证,得到一个分数。

Score with the entire dataset = 0.56

  1. estimator = RandomForestRegressor(random_state=0, n_estimators=100)
  2. score = cross_val_score(estimator, X_full, y_full).mean()
  3. print("Score with the entire dataset = %.2f" % score)

(四)模拟资料损失时之预测情形

设定损失比例,并估计移除missing values后的得分
损失比例75%,损失样本数为379笔,剩余样本为127笔。

将127笔资料进行随机森林回归函数进行交叉验证,并得到一个分数。

Score without the samples containing missing values = 0.49

  1. missing_rate = 0.75
  2. n_missing_samples = np.floor(n_samples * missing_rate)
  3. missing_samples = np.hstack((np.zeros(n_samples - n_missing_samples,
  4. dtype=np.bool),
  5. np.ones(n_missing_samples,
  6. dtype=np.bool)))
  7. rng.shuffle(missing_samples)
  8. missing_features = rng.randint(0, n_features, n_missing_samples)
  9. X_filtered = X_full[~missing_samples, :]
  10. y_filtered = y_full[~missing_samples]
  11. estimator = RandomForestRegressor(random_state=0, n_estimators=100)
  12. score = cross_val_score(estimator, X_filtered, y_filtered).mean()
  13. print("Score without the samples containing missing values = %.2f" % score)

(五)填充missing values,估计填充后的得分

每一笔样本资料都在13个特征中随机遗失一个特征资料,

使用sklearn.preprocessing.Imputer进行missing values的填充。

  1. class sklearn.preprocessing.Imputer(missing_values='NaN', strategy='mean', axis=0, verbose=0, copy=True)

填充后进行随机森林回归函数进行交叉验证,获得填充后分数。

  1. X_missing = X_full.copy()
  2. X_missing[np.where(missing_samples)[0], missing_features] = 0
  3. y_missing = y_full.copy()
  4. estimator = Pipeline([("imputer", Imputer(missing_values=0,
  5. strategy="mean",
  6. axis=0)),
  7. ("forest", RandomForestRegressor(random_state=0,
  8. n_estimators=100))])
  9. score = cross_val_score(estimator, X_missing, y_missing).mean()
  10. print("Score after imputation of the missing values = %.2f" % score)

利用数据填充后的迴归函数,去测试填充前的资料,预测的准确率获得提升。

Score after imputation of the missing values = 0.57

(六)完整程式码

Python source code: missing_values.py

http://scikit-learn.org/stable/auto_examples/missing_values.html#example-missing-values-py

  1. import numpy as np
  2. from sklearn.datasets import load_boston
  3. from sklearn.ensemble import RandomForestRegressor
  4. from sklearn.pipeline import Pipeline
  5. from sklearn.preprocessing import Imputer
  6. from sklearn.cross_validation import cross_val_score
  7. rng = np.random.RandomState(0)
  8. dataset = load_boston()
  9. X_full, y_full = dataset.data, dataset.target
  10. n_samples = X_full.shape[0]
  11. n_features = X_full.shape[1]
  12. # Estimate the score on the entire dataset, with no missing values
  13. estimator = RandomForestRegressor(random_state=0, n_estimators=100)
  14. score = cross_val_score(estimator, X_full, y_full).mean()
  15. print("Score with the entire dataset = %.2f" % score)
  16. # Add missing values in 75% of the lines
  17. missing_rate = 0.75
  18. n_missing_samples = np.floor(n_samples * missing_rate)
  19. missing_samples = np.hstack((np.zeros(n_samples - n_missing_samples,
  20. dtype=np.bool),
  21. np.ones(n_missing_samples,
  22. dtype=np.bool)))
  23. rng.shuffle(missing_samples)
  24. missing_features = rng.randint(0, n_features, n_missing_samples)
  25. # Estimate the score without the lines containing missing values
  26. X_filtered = X_full[~missing_samples, :]
  27. y_filtered = y_full[~missing_samples]
  28. estimator = RandomForestRegressor(random_state=0, n_estimators=100)
  29. score = cross_val_score(estimator, X_filtered, y_filtered).mean()
  30. print("Score without the samples containing missing values = %.2f" % score)
  31. # Estimate the score after imputation of the missing values
  32. X_missing = X_full.copy()
  33. X_missing[np.where(missing_samples)[0], missing_features] = 0
  34. y_missing = y_full.copy()
  35. estimator = Pipeline([("imputer", Imputer(missing_values=0,
  36. strategy="mean",
  37. axis=0)),
  38. ("forest", RandomForestRegressor(random_state=0,
  39. n_estimators=100))])
  40. score = cross_val_score(estimator, X_missing, y_missing).mean()
  41. print("Score after imputation of the missing values = %.2f" % score)
  1. results:
  2. Score with the entire dataset = 0.56
  3. Score without the samples containing missing values = 0.48
  4. Score after imputation of the missing values = 0.55