机器学习之路:python 集成回归模型 随机森林回归RandomForestRegressor 极端随机森林回归ExtraTreesRegressor GradientBoostingRegressor回归 预测波士顿房价
python3 学习机器学习api
使用了三种集成回归模型
git: https://github.com/linyi0604/MachineLearning
代码:
- from sklearn.datasets import load_boston
- from sklearn.cross_validation import train_test_split
- from sklearn.preprocessing import StandardScaler
- from sklearn.ensemble import RandomForestRegressor, ExtraTreesRegressor, GradientBoostingRegressor
- from sklearn.metrics import r2_score, mean_squared_error, mean_absolute_error
- import numpy as np
- '''
- 随机森林回归
- 极端随机森林回归
- 梯度提升回归
- 通常集成模型能够取得非常好的表现
- '''
- # 1 准备数据
- # 读取波士顿地区房价信息
- boston = load_boston()
- # 查看数据描述
- # print(boston.DESCR) # 共506条波士顿地区房价信息,每条13项数值特征描述和目标房价
- # 查看数据的差异情况
- # print("最大房价:", np.max(boston.target)) # 50
- # print("最小房价:",np.min(boston.target)) # 5
- # print("平均房价:", np.mean(boston.target)) # 22.532806324110677
- x = boston.data
- y = boston.target
- # 2 分割训练数据和测试数据
- # 随机采样25%作为测试 75%作为训练
- x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.25, random_state=33)
- # 3 训练数据和测试数据进行标准化处理
- ss_x = StandardScaler()
- x_train = ss_x.fit_transform(x_train)
- x_test = ss_x.transform(x_test)
- ss_y = StandardScaler()
- y_train = ss_y.fit_transform(y_train.reshape(-1, 1))
- y_test = ss_y.transform(y_test.reshape(-1, 1))
- # 4 三种集成回归模型进行训练和预测
- # 随机森林回归
- rfr = RandomForestRegressor()
- # 训练
- rfr.fit(x_train, y_train)
- # 预测 保存预测结果
- rfr_y_predict = rfr.predict(x_test)
- # 极端随机森林回归
- etr = ExtraTreesRegressor()
- # 训练
- etr.fit(x_train, y_train)
- # 预测 保存预测结果
- etr_y_predict = rfr.predict(x_test)
- # 梯度提升回归
- gbr = GradientBoostingRegressor()
- # 训练
- gbr.fit(x_train, y_train)
- # 预测 保存预测结果
- gbr_y_predict = rfr.predict(x_test)
- # 5 模型评估
- # 随机森林回归模型评估
- print("随机森林回归的默认评估值为:", rfr.score(x_test, y_test))
- print("随机森林回归的R_squared值为:", r2_score(y_test, rfr_y_predict))
- print("随机森林回归的均方误差为:", mean_squared_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(rfr_y_predict)))
- print("随机森林回归的平均绝对误差为:", mean_absolute_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(rfr_y_predict)))
- # 极端随机森林回归模型评估
- print("极端随机森林回归的默认评估值为:", etr.score(x_test, y_test))
- print("极端随机森林回归的R_squared值为:", r2_score(y_test, gbr_y_predict))
- print("极端随机森林回归的均方误差为:", mean_squared_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(gbr_y_predict)))
- print("极端随机森林回归的平均绝对误差为:", mean_absolute_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(gbr_y_predict)))
- # 梯度提升回归模型评估
- print("梯度提升回归回归的默认评估值为:", gbr.score(x_test, y_test))
- print("梯度提升回归回归的R_squared值为:", r2_score(y_test, etr_y_predict))
- print("梯度提升回归回归的均方误差为:", mean_squared_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(etr_y_predict)))
- print("梯度提升回归回归的平均绝对误差为:", mean_absolute_error(ss_y.inverse_transform(y_test),
- ss_y.inverse_transform(etr_y_predict)))
- '''
- 随机森林回归的默认评估值为: 0.8391590262557747
- 随机森林回归的R_squared值为: 0.8391590262557747
- 随机森林回归的均方误差为: 12.471817322834646
- 随机森林回归的平均绝对误差为: 2.4255118110236227
- 极端随机森林回归的默认评估值为: 0.783339502805047
- 极端随机森林回归的R_squared值为: 0.8391590262557747
- 极端随机森林回归的均方误差为: 12.471817322834646
- 极端随机森林回归的平均绝对误差为: 2.4255118110236227
- GradientBoostingRegressor回归的默认评估值为: 0.8431187344932869
- GradientBoostingRegressor回归的R_squared值为: 0.8391590262557747
- GradientBoostingRegressor回归的均方误差为: 12.471817322834646
- GradientBoostingRegressor回归的平均绝对误差为: 2.4255118110236227
- '''
机器学习之路:python 集成回归模型 随机森林回归RandomForestRegressor 极端随机森林回归ExtraTreesRegressor GradientBoostingRegressor回归 预测波士顿房价的更多相关文章
- 机器学习之路: python 线性回归LinearRegression, 随机参数回归SGDRegressor 预测波士顿房价
python3学习使用api 线性回归,和 随机参数回归 git: https://github.com/linyi0604/MachineLearning from sklearn.datasets ...
- 机器学习之路:python k近邻回归 预测波士顿房价
python3 学习机器学习api 使用两种k近邻回归模型 分别是 平均k近邻回归 和 距离加权k近邻回归 进行预测 git: https://github.com/linyi0604/Machine ...
- 机器学习之路: python 回归树 DecisionTreeRegressor 预测波士顿房价
python3 学习api的使用 git: https://github.com/linyi0604/MachineLearning 代码: from sklearn.datasets import ...
- 机器学习之路: python k近邻分类器 KNeighborsClassifier 鸢尾花分类预测
使用python语言 学习k近邻分类器的api 欢迎来到我的git查看源代码: https://github.com/linyi0604/MachineLearning from sklearn.da ...
- 机器学习之路: python 决策树分类DecisionTreeClassifier 预测泰坦尼克号乘客是否幸存
使用python3 学习了决策树分类器的api 涉及到 特征的提取,数据类型保留,分类类型抽取出来新的类型 需要网上下载数据集,我把他们下载到了本地, 可以到我的git下载代码和数据集: https: ...
- 机器学习之路--Python
常用数据结构 1.list 列表 有序集合 classmates = ['Michael', 'Bob', 'Tracy'] len(classmates) classmates[0] len(cla ...
- 吴裕雄 python 机器学习——集成学习AdaBoost算法回归模型
import numpy as np import matplotlib.pyplot as plt from sklearn import datasets,ensemble from sklear ...
- Poisson回归模型
Poisson回归模型也是用来分析列联表和分类数据的一种方法,它实际上也是对数线性模型的一种,不同点是对数线性模型假定频数分布为多项式分布,而泊松回归模型假定频数分布为泊松分布. 首先我们来认识一下泊 ...
- 吴裕雄 python 机器学习——集成学习随机森林RandomForestRegressor回归模型
import numpy as np import matplotlib.pyplot as plt from sklearn import datasets,ensemble from sklear ...
随机推荐
- 微服务深入浅出(7)-- 网关路由Zuul
Zuul用于构建边界服务,致力于动态路由,过滤,监控,弹性伸缩和安全等方向. 1.Zuul+Ribbon+Eureka结合,可以实现智能路由和负载均衡 2.网关将所有服务的API接口统一聚合统一暴露 ...
- transparent 透明效果
background-color:transparent;就是把背景色设置为透明. 实际上background默认的颜色就是透明的属性.所以写和不写都是一样的 span{ width: 0; heig ...
- LCD时序中设计到的VSPW/VBPD/VFPD/HSPW/HBPD/HFPD总结【转】
转自:https://blog.csdn.net/u011603302/article/details/50732406 下面是我在网上摘录的一些关于LCD信号所需时钟的一些介绍, 描述方式一: 来自 ...
- django Rest Framework----GenericAPIView 通用视图 GenericAPIView源码分析
一.GenericAPIView GenericAPIView扩展了APIView,为标准列表和详细视图添加了常见的行为. 提供的每个具体通用视图都是一个GenericAPIView或多个mixin类 ...
- Jenkins+Ant+TestNG+Testlink自动化构建集成
这段时间折腾自动化测试,之前都是在Eclipse工程里面手工执行自动化测试脚本,调用Testlink API执行测试用例,目前搭建Jenkins自动化构建测试的方式,实现持续构建,执行自动化测试. 硬 ...
- 使用postman做接口测试(二)
参考大神总结:https://www.cnblogs.com/Skyyj/p/6856728.html 二,下边的东西工作中实际要用到了 1, postman安装 chrome浏览器打开chrome: ...
- mysql -> 事务&事务锁_09
事务的特性 redo undo 锁的隔离级别
- centos 升级linux内核
=============================================== 2018/1/14_第1次修改 ccb_warlock == ...
- 30 C? Go? Cgo!
C? Go? Cgo! 17 March 2011 Introduction Cgo lets Go packages call C code. Given a Go source file writ ...
- python网络编程-paramiko
python基础学习日志day8-paramiko 一:简介 Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作 现有这样的需求:需要使用windows客户端,远程连 ...