#coding=utf8
# 从sklearn.datasets导入波士顿房价数据读取器。
from sklearn.datasets import load_boston
# 从sklearn.model_selection中导入train_test_split用于数据分割。
from sklearn.model_selection import train_test_split
# 导入numpy并重命名为np。
import numpy as np
# 从sklearn.preprocessing导入数据标准化模块。
from sklearn.preprocessing import StandardScaler

# 从读取房价数据存储在变量boston中。
boston = load_boston()
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)

# 分别初始化对特征和目标值的标准化器。
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)
y_test = ss_y.transform(y_test)

# 从sklearn.linear_model导入LinearRegression。
from sklearn.linear_model import LinearRegression

# 使用默认配置初始化线性回归器LinearRegression。
lr = LinearRegression()
# 使用训练数据进行参数估计。
lr.fit(X_train, y_train)
# 对测试数据进行回归预测。
lr_y_predict = lr.predict(X_test)
# 使用LinearRegression模型自带的评估模块,并输出评估结果。
print 'The value of default measurement of LinearRegression is', lr.score(X_test, y_test)

# 从sklearn.metrics依次导入r2_score、mean_squared_error以及mean_absoluate_error用于回归性能的评估。
from sklearn.metrics import r2_score, mean_squared_error, mean_absolute_error

# 使用r2_score模块,并输出评估结果。
print 'The value of R-squared of LinearRegression is', r2_score(y_test, lr_y_predict)

# 使用mean_squared_error模块,并输出评估结果。
print 'The mean squared error of LinearRegression is', mean_squared_error(ss_y.inverse_transform(y_test), ss_y.inverse_transform(lr_y_predict))

# 使用mean_absolute_error模块,并输出评估结果。
print 'The mean absoluate error of LinearRegression is', mean_absolute_error(ss_y.inverse_transform(y_test), ss_y.inverse_transform(lr_y_predict))

# 从sklearn.linear_model导入SGDRegressor。
from sklearn.linear_model import SGDRegressor

# 使用默认配置初始化线性回归器SGDRegressor。
sgdr = SGDRegressor()
# 使用训练数据进行参数估计。
sgdr.fit(X_train, y_train)
# 对测试数据进行回归预测。
sgdr_y_predict = sgdr.predict(X_test)
# 使用SGDRegressor模型自带的评估模块,并输出评估结果。
print 'The value of default measurement of SGDRegressor is', sgdr.score(X_test, y_test)

# 使用r2_score模块,并输出评估结果。
print 'The value of R-squared of SGDRegressor is', r2_score(y_test, sgdr_y_predict)

# 使用mean_squared_error模块,并输出评估结果。
print 'The mean squared error of SGDRegressor is', mean_squared_error(ss_y.inverse_transform(y_test), ss_y.inverse_transform(sgdr_y_predict))

# 使用mean_absolute_error模块,并输出评估结果。
print 'The mean absoluate error of SGDRegressor is', mean_absolute_error(ss_y.inverse_transform(y_test), ss_y.inverse_transform(sgdr_y_predict))

类似:

最新文章

  1. HTML5 学习笔记(二)——HTML5新增属性与表单元素
  2. POJ3321Apple Tree[树转序列 BIT]
  3. 在WebBrowser中通过模拟键盘鼠标操控网页中的文件上传控件(转)
  4. Intellij IDEA 快捷键(Mac)
  5. SQL语句技巧_索引的优化_慢查询日志开启_root密码的破解
  6. CLR via C# 混合线程同步构造
  7. POJ2528+线段树
  8. Flink Program Guide (2) -- 综述 (DataStream API编程指导 -- For Java)
  9. ajax基础入门
  10. 超过lua上帝的语言
  11. idea控制台输出乱码
  12. .net平台的rabbitmq使用封装
  13. $MarkDown$ 中使用$ \LaTeX$ 数学式
  14. 迭代法与开根号求值(letcode 69)
  15. 翻译:JVM虚拟机规范1.7中的运行时常量池部分(二)
  16. java多线程快速入门(十九)
  17. 一个友盟BUG的思考和分析:Invalid update
  18. js Location
  19. IRGAN:A Minimax Game for Unifying Generative and Discriminative Information Retrieval Models
  20. Here we take a closer look at the Jordans Unveil

热门文章

  1. PHP概率,抽奖
  2. STL_算法_04_算术和生成算法
  3. C语言位域解析&符号位扩展规则
  4. Activity生命周期之我见
  5. Longest Repeating Character Replacement
  6. MyBatis3-基于注解的示例
  7. Linux crontab定时执行任务 命令格式与详细例子(转)
  8. Android设计模式之工厂模式
  9. Android之侧滑菜单DrawerLayout的使用
  10. Mysql批量导入约束报错