sklearn 使用GridSearchCV实现自动调参,选出最优参数

from sklearn.grid_search import GridSearchCV
from sklearn.svm import SVC
import tflearn
import tflearn.datasets.mnist as mnist
#加载数据
x_train, y_train, x_test, y_test = mnist.load_data(one_hot=False)
#构建模型,选择核函数并训练
clf = SVC()
clf.set_params(kernel='rbf', probability=True).fit(x_train[:1000,:], y_train[:1000])
preds1 = clf.predict(x_test[:1000,:])
print("基准测试集验证得分:"+str(np.mean(preds1 == y_test[:1000])))
#设置即将要变换的参数
param_grid = {'C': [0.0001, 0.001, 0.010.1, 1, 10, 100, 1000], 'gamma': [0.001, 0.0001]}    
#构建自动调参容器,n_jobs参数支持同时多个进程运行并行测试
grid_search = GridSearchCV(clf, param_grid, n_jobs = 1, verbose=10)    
grid_search.fit(x_train[:1000,:], y_train[:1000])
#选出最优参数    
best_parameters = grid_search.best_estimator_.get_params()    
for para, val in list(best_parameters.items()):    
    print(para, val)
#使用最优参数进行训练
clf = SVC(kernel='rbf', C=best_parameters['C'], gamma=best_parameters['gamma'], probability=True).fit(x_train[:1000,:], y_train[:1000])
preds1 = clf.predict(x_test[:1000,:])
print("最优测试集验证得分:"+str(np.mean(preds1 == y_test[:1000])))
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值