深度学习详解之初试机器学习

作者:tzc_fly 时间:2022-07-04 18:00:13 

机器学习可应用在各个方面,本篇将在系统性进入机器学习方向前,初步认识机器学习,利用线性回归预测波士顿房价;

原理简介

利用线性回归最简单的形式预测房价,只需要把它当做是一次线性函数y=kx+b即可。我要做的就是利用已有数据,去学习得到这条直线,有了这条直线,则对于某个特征x(比如住宅平均房间数)的任意取值,都可以找到直线上对应的房价y,也就是模型的预测值。
从上面的问题看出,这应该是一个有监督学习中的回归问题,待学习的参数为实数k和实数b(因为就只有一个特征x),从样本集合sample中取出一对数据(xi,yi),xi代入kx+b得到输出y^i,MSE可以衡量预测输出与样本标注的接近程度,所以把MSE作为这个问题的损失函数,对于共m mm个样本的集合,损失函数计算为:J(k,b)=1i=1∑m(yi−yi)2

一般需要遍历数据集迭代多次,才能得到一个较好的结果

波士顿房价数据集

房价预测的实现将基于sklearn(scikit-learn),sklearn中有多种数据集:

  • 自带的小数据集(packaged dataset):sklearn.datasets.load_<name>

  • 可在线下载的数据集(Downloaded Dataset):sklearn.datasets.fetch_<name>

  • 自定义生成的数据集(Generated Dataset):sklearn.datasets.make_<name>

首先从sklearn的数据集获取内置数据集中的即波士顿房价数据:


from sklearn.datasets import load_boston

导入其他功能包和模块,导入线性回归模型:


# 使用sklearn 中的 train_test_split 划分数据集
from sklearn.model_selection import train_test_split
# 使用 sklearn 中的线性回归模型进行预测
from sklearn.linear_model import LinearRegression
# 使用 matplotlib 中的 pyplot 进行可视化
import matplotlib.pyplot as plt

加载数据集:


# 加载波士顿房价数据集,返回特征X和标签y
X, y = load_boston(return_X_y=True)
X.shape # (506, 13)
y.shape # (506,)

取出一个特征作为x:


# 只取第6列特征(方便可视化):住宅平均房间数
# 注意切片区间左闭右开
X = X[:,5:6]

划分为训练集和测试集,测试集取20%:


X_train, X_test, y_train, y_test = train_test_split(X,y,test_size=0.2, random_state=2020)

使用到sklearn.model_selection.train_test_split,函数形式为:


train_test_split(train_data, train_target, test_size, random_state,shuffle)
  • test_size:浮点数,在0 ~ 1之间,表示测试样本占比

  • random_state:随机种子,种子不同,每次调用时采样的样本不同;种子相同,每次调用时采样一致

  • shuffle = True,打乱样本数据的顺序

严格来说,对于有监督学习的数据集应分为训练集,验证集,测试集;训练集和验证集有标注,测试集没有标注,泛化能力在验证集上进行检验

划分后的训练数据:


X_train.shape # (404, 1)
y_train.shape # (404,)

建立线性回归模型

在sklearn下,机器学习建模非常方便:

  1. 实例化模型,输入合适的超参数会使模型性能提升

  2. 输入数据训练

  3. 验证模型

建立线性回归模型如下:


# 创建线性回归对象
regr = LinearRegression()
# 使用训练集训练模型
regr.fit(X_train, y_train)
# 在测试集上进行预测
y_pred = regr.predict(X_test)

注意到模型直到接收到训练数据,才最终确定具体形式,比如发现输入数据是(404,1),才确定线性回归形式为kx+b,而不是kx+cx+b


# 画测试数据散点图
plt.scatter(X_test, y_test,  color='blue')
# 画线性回归模型对测试数据的拟合曲线
plt.plot(X_test, y_pred, color='red')
# 显示绘图结果
plt.show()

深度学习详解之初试机器学习

打印模型参数有(注意区分参数和超参数):


# 打印斜率和截距
print('斜率:{}, 截距:{}'.format(regr.coef_,regr.intercept_))

结果为:

 斜率:[9.11163398], 截距:-34.47557789280662

来源:https://blog.csdn.net/qq_40943760/article/details/111701345

标签:机器学习
0
投稿

猜你喜欢

  • PHP实现ASCII码与字符串相互转换的方法

    2023-09-09 13:27:05
  • 微软:跑分速度不是IE8的开发重点

    2008-09-12 12:10:00
  • MYSQL教程:my.cnf缓存优化

    2009-07-30 08:58:00
  • 获取CSDN文章内容并转换为markdown文本的python

    2021-04-05 08:32:15
  • pytorch下的unsqueeze和squeeze的用法说明

    2023-07-16 14:01:41
  • SQL server使用自定义函数以及游标

    2011-11-03 17:26:27
  • 使用C#配合ArcGIS Engine进行地理信息系统开发

    2023-06-25 16:35:01
  • 解析smarty模板中类似for的功能实现

    2023-11-15 12:53:40
  • 跨平台、多浏览器页面测试

    2008-06-24 11:54:00
  • 为什么定位会被float和clear影响!

    2008-11-10 11:06:00
  • 解决django的template中如果无法引用MEDIA_URL问题

    2023-06-12 15:09:07
  • 通过python实现弹窗广告拦截过程详解

    2022-04-12 09:21:31
  • 如何恢复/修复SQL Server的MDF文件

    2008-11-24 15:30:00
  • Python matplotlib 绘制双Y轴曲线图的示例代码

    2023-04-14 11:07:27
  • 面包屑设计

    2009-07-07 11:17:00
  • django ManyToManyField多对多关系的实例详解

    2023-08-11 20:21:01
  • JS重现80后儿时经典拼板(模板)游戏

    2011-09-11 18:36:46
  • Python 递归式实现二叉树前序,中序,后序遍历

    2022-09-22 17:38:32
  • Python中对字典的几个处理方法分享

    2021-03-13 05:48:57
  • Python3获取cookie常用三种方案

    2022-10-20 02:56:19
  • asp之家 网络编程 m.aspxhome.com