网格搜索实现
本文我们依然使用波士顿房价数据作为案例,进行分析。
下面是使用默认参数的随机森林模型的效果
# 从 sklearn.datasets 导入波士顿房价数据读取器。
from sklearn.datasets import load_boston
# 从读取房价数据存储在变量 boston 中。
boston = load_boston()
# 从sklearn.cross_validation 导入数据分割器。
from sklearn.model_selection import train_test_split
X = boston.data
y = boston.target
# 随机采样 25% 的数据构建测试样本,其余作为训练样本。
X_train, X_test, y_train, y_test = train_test_split(X,
y,
random_state=33,
test_size=0.25)
# 从 sklearn.preprocessing 导入数据标准化模块。
from sklearn.preprocessing import StandardScaler
# 分别初始化对特征和目标值的标准化器。
ss_X = StandardScaler()
ss_y = StandardScaler()
# 分别对训练和测试数据的特征以及目标值进行标准化处理。
X_train = ss_X.fit_transform(X_train)
X_test = ss_X.transform(X_test)
y_train = ss_y.fit_transform(y_train.reshape(-1,1))
y_test = ss_y.transform(y_test.reshape(-1,1))
from sklearn.ensemble import RandomForestRegressor
rfr = RandomForestRegressor()
rfr.fit(X_train, y_train)
rfr_y_predict = rfr.predict(X_test)
from sklearn.metrics import r2_score, mean_absolute_error, mean_squared_error
# 使用 R-squared、MSE 以及 MAE 指标对默认配置的随机回归森林在测试集上进行性能评估。
print('R-squared value of RandomForestRegressor:', rfr.score(X_test, y_test))
print('The mean squared error of RandomForestRegressor:', mean_squared_error(
ss_y.inverse_transform(y_test), ss_y.inverse_transform(rfr_y_predict)))
print('The mean absoluate error of RandomForestRegressor:', mean_absolute_error(
ss_y.inverse_transform(y_test), ss_y.inverse_transform(rfr_y_predict)))
from sklearn.model_selection import GridSearchCV
rfr = RandomForestRegressor()
parameters_range = dict(n_estimators=[20,40,60,80,100,120,140,160,180,200,300,500])
gs = GridSearchCV(rfr, parameters_range,cv=5,verbose=2,n_jobs=2)
search = gs.fit(X_train, y_train)
rfr_opt = search.best_estimator_
rfr_opt.fit(X_train, y_train)
rfr_y_predict = rfr_opt.predict(X_test)
from sklearn.metrics import r2_score, mean_absolute_error, mean_squared_error
# 使用 R-squared、MSE 以及 MAE 指标对默认配置的随机回归森林在测试集上进行性能评估。
print('R-squared value of RandomForestRegressor:', rfr_opt.score(X_test, y_test))
print('The mean squared error of RandomForestRegressor:', mean_squared_error(
ss_y.inverse_transform(y_test), ss_y.inverse_transform(rfr_y_predict)))
print('The mean absoluate error of RandomForestRegressor:', mean_absolute_error(
ss_y.inverse_transform(y_test), ss_y.inverse_transform(rfr_y_predict)))
我们可以看到,通过网格搜索得到的超参数的模型比默认参数的模型表现更好。当然这还取决于超参数搜搜范围的选取,更多的是凭经验。