波士顿房价数据集——预测房价

文章目录

      • 1.数据集及问题简介
      • 2.加载数据集并探索数据
      • 3.准备输入的数据
      • 4.构建网络并编译网络
      • 6.从训练集中留出验证集(K折验证法),初步训练模型
      • 7.根据训练数据,重新训练模型并测试
      • 8.画出训练数据
      • 9.调参完成后,在所有训练集上训练生产模型
      • 总结

1.数据集及问题简介

20 世纪70 年代中期波士顿郊区房屋价格数据集,它包含的数据点相对较少,只有506 个,分为404 个训练样本和102 个测试样本。输入数据的每个特征(比如犯罪率)都有不同的取值范围。例如,有些特性是比例,取值范围为0-1;有的取值范围为1-12;还有的取值范围为0~100,等等。

我们将要预测当时该地区房屋价格的中位数,这是一个回归问题。

分类问题,其目标是预测输入数据点所对应的单一离散的标签。另一种常见的机器学习问题是回归问题,它预测一个连续值而不是离散的标签,例如,根据气象数据预测明天的气温,或者根据软件说明书预测完成软件项目所需要的时间。

2.加载数据集并探索数据

from keras.datasets import boston_housing(train_data, train_targets), (test_data, test_targets) = boston_housing.load_data()print(train_data.shape) # (404, 13)
print(test_data.shape) #(102, 13)
print(train_targets) #array([ 15.2, 42.3, 50. ... 19.4, 19.4, 29.1])#【房价大都在 10000~50000 美元】

简单了解各属性的意义:

import pandas as pdtrain = pd.DataFrame(train_data)
train.columns=['crim','zn','indus','chas','nox','rm','age','dis','rad','tax','ptratio','b','lstat']
train.columns=['人均犯罪','用地','非商业地','河','环保指标','房间数','老房子比例','dis','交通便利','税率','教师学生比','黑人比','低收入房东比']
train

在这里插入图片描述

3.准备输入的数据

将取值范围差异很大的数据输入到神经网络中,这是有问题的。网络可能会自动适应这种取值范围不同的数据,但学习肯定变得更加困难。对于这种数据,普遍采用的最佳实践是对每个特征做标准化,即对于输入数据的每个特征(输入数据矩阵中的列),减去特征平均值,再除以标准差,这样得到的特征平均值为0,标准差为1。用Numpy 可以很容易实现标准化。

#【1】求每一列的平均值
mean = train_data.mean(axis=0) 
#【2】减去平均值
train_data -= mean
#【3】求每一列的标准差
std = train_data.std(axis=0)
#【4】除以标准差
train_data /= stdtest_data -= mean
test_data /= std

注意,用于测试数据标准化的均值和标准差都是在训练数据上计算得到的。在工作流程中,你不能使用在测试数据上计算得到的任何结果,即使是像数据标准化这么简单的事情也不行。

4.构建网络并编译网络

由于样本数量很少,我们将使用一个非常小的网络,其中包含两个隐藏层,每层有64 个单元。一般来说,训练数据越少,过拟合会越严重,而较小的网络可以降低过拟合。

from keras import models
from keras import layersdef build_model():model = models.Sequential()model.add(layers.Dense(64, activation='relu', input_shape=(train_data.shape[1],)))model.add(layers.Dense(64, activation='relu'))model.add(layers.Dense(1))model.compile(optimizer='rmsprop', loss='mse', metrics=['mae'])return model

网络的最后一层只有一个单元,没有激活,是一个线性层。这是标量回归(标量回归是预测单一连续值的回归)的典型设置。添加激活函数将会限制输出范围。例如,如果向最后一层添加sigmoid 激活函数,网络只能学会预测0~1 范围内的值。这里最后一层是纯线性的,所以网络可以学会预测任意范围内的值。

注意,编译网络用的是mse 损失函数,即均方误差(MSE,mean squared error),预测值与目标值之差的平方。这是回归问题常用的损失函数。在训练过程中还监控一个新指标:平均绝对误差(MAE,mean absolute error)。它是预测值与目标值之差的绝对值。比如,如果这个问题的MAE 等于0.5,就表示你预测的房价与实际价格平均相差500 美元。

6.从训练集中留出验证集(K折验证法),初步训练模型

由于数据点很少,验证集会非常小(比如大约100 个样本)。因此,验证分数可能会有很大波动,这取决于你所选择的验证集和训练集。也就是说,验证集的划分方式可能会造成验证分数上有很大的方差,这样就无法对模型进行可靠的评估。

在这种情况下,最佳做法是使用K 折交叉验证。这种方法将可用数据划分为K个分区(K 通常取4 或5),实例化K 个相同的模型,将每个模型在K-1 个分区上训练,并在剩下的一个分区上进行评估。模型的验证分数等于K 个验证分数的平均值。

在这里插入图片描述

这种方法的代码实现很简单。

import numpy as npk = 4 # 4折
num_val_samples = len(train_data) // k  #分成4份,每份的数据大小
num_epochs = 100
all_scores = []
for i in range(k):print('processing fold #', i)#【1】准备验证集val_data = train_data[i * num_val_samples: (i + 1) * num_val_samples]val_targets = train_targets[i * num_val_samples: (i + 1) * num_val_samples]#【2】准备训练集partial_train_data = np.concatenate([train_data[:i * num_val_samples],train_data[(i + 1) * num_val_samples:]],axis=0)partial_train_targets = np.concatenate([train_targets[:i * num_val_samples],train_targets[(i + 1) * num_val_samples:]],axis=0)#【3】创建模型实例model = build_model()#【4】训练模型 (in silent mode, verbose=0)model.fit(partial_train_data, partial_train_targets,epochs=num_epochs, batch_size=1, verbose=0)#【5】在验证集上验证val_mse, val_mae = model.evaluate(val_data, val_targets, verbose=0)#【6】保存每一次训练的MAE误差all_scores.append(val_mae)print(all_scores) #[1.9296772480010986, 2.4259424209594727, 2.429856300354004, 2.5913355350494385]
print(np.mean(all_scores)) # 2.3837935992396706

每次运行模型得到的验证分数有很大差异,从1.9到2.6不等。平均分数(2.38)是比单一分数更可靠的指标——这就是K 折交叉验证的关键。在这个例子中,预测的房价与实际价格平均相差2380美元,考虑到实际价格范围在10000~50000 美元,这一差别还是很大的。

7.根据训练数据,重新训练模型并测试

我们让训练时间更长一点,达到500 个轮次。为了记录模型在每轮的表现,我们需要修改训练循环,以保存每轮的验证分数记录。

from keras import backend as K# Some memory clean-up
K.clear_session()num_epochs = 500
all_mae_histories = []
for i in range(k):print('processing fold #', i)val_data = train_data[i * num_val_samples: (i + 1) * num_val_samples]val_targets = train_targets[i * num_val_samples: (i + 1) * num_val_samples]partial_train_data = np.concatenate([train_data[:i * num_val_samples],  train_data[(i + 1) * num_val_samples:]],axis=0)partial_train_targets = np.concatenate([train_targets[:i * num_val_samples],train_targets[(i + 1) * num_val_samples:]],axis=0)model = build_model()history = model.fit(partial_train_data, partial_train_targets,validation_data=(val_data, val_targets),epochs=num_epochs, batch_size=1, verbose=0)mae_history = history.history['val_mae']all_mae_histories.append(mae_history)average_mae_history = [np.mean([x[i] for x in all_mae_histories]) for i in range(num_epochs)]

在这里插入图片描述

8.画出训练数据

import matplotlib.pyplot as plt
plt.plot(range(1, len(average_mae_history) + 1), average_mae_history)
plt.xlabel('Epochs')
plt.ylabel('Validation MAE')
plt.show()

因为纵轴的范围较大,且数据方差相对较大,所以难以看清这张图的规律。我们来重新绘制一张图。

  • 删除前 10 个数据点,因为它们的取值范围与曲线上的其他点不同。
  • 将每个数据点替换为前面数据点的指数移动平均值,以得到光滑的曲线。
def smooth_curve(points, factor=0.9):smoothed_points = []for point in points:if smoothed_points:previous = smoothed_points[-1]smoothed_points.append(previous * factor + point * (1 - factor))else:smoothed_points.append(point)return smoothed_pointssmooth_mae_history = smooth_curve(average_mae_history[10:])plt.plot(range(1, len(smooth_mae_history) + 1), smooth_mae_history)
plt.xlabel('Epochs')
plt.ylabel('Validation MAE')
plt.show()

在这里插入图片描述

从上图可以看出,验证MAE 在80 轮后不再显著降低,之后就开始过拟合。

9.调参完成后,在所有训练集上训练生产模型

# Get a fresh, compiled model.
model = build_model()
# Train it on the entirety of the data.
model.fit(train_data, train_targets,epochs=80, batch_size=16, verbose=0)
test_mse_score, test_mae_score = model.evaluate(test_data, test_targets)print(test_mae_score) #2.7805774211883545

我们预测的房价还是和实际价格相差约2780美元。

总结

  • 回归问题使用的损失函数与分类问题不同。回归常用的损失函数是均方误差(MSE)。
  • 同样,回归问题使用的评估指标也与分类问题不同。显而易见,精度的概念不适用于回归问题。常见的回归指标是平均绝对误差(MAE)。
  • 如果输入数据的特征具有不同的取值范围,应该先进行预处理,对每个特征单独进行
    缩放。
  • 如果可用的数据很少,使用 K折验证可以可靠地评估模型。
  • 如果可用的训练数据很少,最好使用隐藏层较少(通常只有一到两个)的小型网络,以避免严重的过拟合。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/14162.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Boston波士顿房价数据下载

下载地址:https://archive.ics.uci.edu/ml/machine-learning-databases/housing/housing.data 打开方式: 直接用excel可以打开,转存为csv等 模型训练 from sklearn.linear_model import Lasso from sklearn.preprocessing import Standard…

利用波士顿房价数据集实现房价预测

文章目录 一、 观察波士顿房价数据并加载数据集1、加载数据集 二、 特征选择三、 模型选择四、 模型训练和测试1、 训练模型2、打印线性方程参数3、模型预测4、 计算mae、mse5、 画出学习曲线 五、 模型性能评估和优化1、 模型优化,考虑用二项式和三项式优化2、 划分…

预测房价(Python)

构建神经网络/深度学习模型的基本步骤 深度学习模型具有一定的通用性,使得深度学习的门槛降低,这是深度学习得以重新占据计算机领域一席之地的重要原因,深度学习均可以从下述五个步骤来完成模型的构建和训练。 def load_data():# 从文件导入…

香港的房价真的那么贵吗?用数据挖掘真相!

作者 | 挖数 来源 | 挖数(公众号id:washu66) 香港位于广东深圳的南边,面积是1106平方公里,比中国的四大一线城市都小。 不仅面积小,其人口密度也大,香港每平方公里的人口数比四大一线城市都多。…

波士顿房价数据集

数据集 Keras中常见的集成数据集波士顿房价数据集1. 加载数据集2. 访问数据集3. 数据可视化 Keras是一个高层的神经网络和深度学习库,可以快速搭建神经网络,易于调试和从扩展,是TensorFlow的官方API,内置了常用的公共数据集&#…

ChatGTP全景图 | 背景+技术篇

引言:人类以为的丰功伟绩,不过是开端的开端……我们在未来100年取得的技术进步,将远超我们从控制火种到发明车轮以来所取得的一切成就。——By Sam Altman 说明:ChatGPT发布后,我第一时间体验了它的对话、翻译、编程、…

考研成功上岸提前学Python,轻松拿到大厂实习offer!

23考研即将尘埃落定,首先要恭喜上岸的同学呀~ 关于上岸后到底要不要学Python、读研怎么找实习等相关问题,其实之前也聊过,但是大家可能还没有意识到Python给读研带来什么样的正面影响,蛋糕给大家看看往期Python学员的反馈&#x…

在当下互联网行情下,2023年程序员的工作真的很难找

前言 年后,听到有几位同事有离职的想法,有的已经在开始找工作了。,这个行业的工资就是靠跳槽来加速增长的,不过经过了这几个月的面试、复试的经历,几位前期提出离职的同事渐渐改变了想法,他们发现放开后的…

重磅!大湾区大学,官宣招生!

来源:大湾区大学 编辑整理 :双一流高教 3月23日,大湾区大学(筹)发布招生信息,该校将和南方科技大学联合招收30名硕士研究生。通知显示,这批学生的学籍属于南科大,第一年在南科大培养…

2022硅谷大厂的大!失!败!AiDA时尚设计师助手;2023热门IT技能预告;Uber送货机器人;GitHub今日热榜 | ShowMeAI资讯日报

👀日报合辑 | 🎡AI应用与工具大全 | 🔔公众号资料下载 | 🍩韩信子 📢 『抖音』2022抖音热点数据报告,共度温暖岁末 抖音热点联合巨量算数,发布了《2022抖音热点数据报告》,盘点了20…

Datawhale优秀作者,入选名单!

Datawhale团队 公示:Datawhale优秀作者,2023.01-03 优秀作者公示 入选奖 1. 陈敬 中国移动云能力中心 机器学习技术:多任务学习综述! 2. 滕飞 浙江大学研究生 浙大学长分享,第二次打数据挖掘赛,雪浪算力…

24考研网盘群来了…免费进…

简介 免费分享考研网课资源,考研资料、考研资讯、考研真题、分享考研英语\考研政治\考研数学\考研复试\考研调剂信息等一系列资源,助你一战成硕。 百度网盘群 2024考研 微信公众号:考研保研直通车,坚持方便、省时的原则&#xff…

考研人导航上线啦

科大学长开发的考研人导航上线啦 ,可以帮助考研学生更高效的获取最新考研复试信息和备考资料 考研人导航官网:https://kaoyan.ahy2.top

从事架构师岗位快2年了,聊一聊我对架构的一些感受和看法

从事架构师岗位快2年了,聊一聊我和ChatGPT对架构的一些感受和看法 职位不分高低,但求每天都能有新的进步,永远向着更高的目标前进。 文章目录 踏上新的征程架构是什么?架构师到底是干什么的?你的终极目标又是什么&…

ChatGPT的出现,让我们必须思考未来孩子的职业

最近这段时间,大家都在谈论ChatGPT,谈论最多的大概就是它将来会淘汰哪些行业?多少人会因此而失业? 作为父母,我们除了关心自己的发展,当然还关心孩子的未来。 尤其是现在的人工智能发展如此迅速&#xff0c…

chatgpt赋能Python-python影评分析

介绍 Python是一种流行的编程语言,它被广泛应用于各种领域,包括数据分析领域。在电影业,Python也被用于进行影评分析。通过分析影评数据,我们可以了解到观众对于不同电影的看法和评价,从而更好地了解市场需求和趋势。…

GPT、科技、人类的生产、知识与未来(上)

本文将继续结合GPT探讨人工智能技术升级可能对人类社会带来的影响。主要还是侧重历史、社会、文化、经济、政治等角度。 问题的提出:ChatGPT等工具会提高人的工作效率和产出。但它会让人类使用者自身变得更“聪明”,还是“更笨”?更“强”&am…

ChatGPT初尝试——合并Excel表格【AI版】

ChatGPT真的能提升生产力吗?【AI版】 无意间的刷到的视频一、提需求二、ChatGPT用Python编写代码三、意外的解释四、ChatGPT改用Java编写代码五、GPT第二次生成Java代码尾巴 无意间的刷到的视频 晚上在家刷视频,突然看到一个在讲关于AI编程的视频&#…

AI 3.0快速阅读后的思考

AI3.0阅读思考 梳理 几大技术词汇: 卷积神经网络CNN:权重和值之积的和深度神经网络DNN工具:深度指层数,深度学习强化学习符号人工智能亚符号人工智能,感知机,亚符号,从数据中学习机器学习对博…

HTTP的缓存机制是什么?

💂 个人网站:【海拥】【游戏大全】【神级源码资源网】🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】💅 寻找学习交流、摸鱼划水的小伙伴,请点击【摸鱼学习交流群】 目录 前言HTTP缓存机制简介H…