TensorFlow工具快速入门教程8-2 线性回归练习基于pandas

简介

波士顿数据集,其中包括以下变量

CRIM城镇人均犯罪率
zn占地面积超过25,000平方尺的住宅用地比例
indus每个城镇非零售业务占的比例。
nox一氧化氮浓度
rm每栋住宅的平均房间数量
age1940年以前建造的自住单位比例
dis到波士顿五个就业中心的加权距离
tax每10,000美元全价物业税率
ptratio城镇的师生比例
medv自住房屋的中位数, 单位为千美元

您将创建三个不同的数据集:

数据集目的形状
Training训练模型并获得权重400,10
Evaluation在看不见的数据上的评估模型性能100,10
Predict使用该模型预测新数据的房屋价值6,10

目标是使用数据集的特征来预测房屋的价值。

在本教程的第二部分中,您将学习如何使用TensorFlow以三种不同的方式导入数据:

  • pandas
  • Numpy
  • 只有TF

他们都提供相同的结果。

您将学习如何使用高级API构建,训练评估线性回归模型。 如果使用的是低级API,则必须手动定义: 损失函数;优化:梯度下降;矩阵乘法;图和张量。这对于初学者来说是乏味且复杂的。

数据集下载:https://itbooks.pipipan.com/fs/18113597-328521226

pandas

Tensorflow目前提供6个预建estimator,其中3个用于分类任务,3个用于回归任务:

  • 回归
    • DNNRegressor
    • LinearRegressor
    • DNNLineaCombinedRegressor
  • 分类
    • DNNClassifier
    • LinearClassifier
    • DNNLineaCombinedClassifier

参考资料

该函数需要两个参数:

  • feature_columns:包含要包含在模型中的变量
  • model_dir:存储图形的路径,保存模型参数等

使用TensorFlow的棘手部分是为模型提供信息。 Tensorflow旨在用于并行计算和非常大的数据集。 由于机器资源的限制,不可能同时为所有数据提供模型。 为此,您需要每次都提供一批。 请注意,我们正在谈论拥有数百万或更多记录的庞大数据集。 如果不添加批处理,最终会出现内存错误。

当模型看到所有数据时,它就完成了一个epoch 。epoch定义了您希望模型查看数据的次数。 最好将此步骤设置为None,并让模型执行迭代次数。

要添加的第二个信息是,如果要在每次迭代之前对数据进行混洗。 在训练期间,重要的是对数据进行混洗,以便模型不会学习数据集的特定模式。 如果模型了解数据的基础模式的细节,则难以概括对未见数据的预测。 这称为overfitting 。 该模型在训练数据上表现良好,但无法正确预测未见数据。

TensorFlow使这两个步骤变得容易。 当数据进入管道时,它知道需要多少观察(批处理)以及是否必须对数据进行混洗。

要指示Tensorflow如何提供模型,可以使用函数pandas_input_fn。 该对象需要5个参数:

  • x:要素数据
  • y:标签数据
  • batch_size:batch。 默认为128
  • num_epoch:纪元的数量,默认为1
  • shuffle:随机播放或不播放数据。 默认情况下,无

评估模型性能的常用方法是:

  • 训练模型
  • 在不同的数据集中评估模型
  • 做预测

代码参见: https://github.com/china-testing/python-api-tesing/blob/master/practices/ts/lr_pd.py

Loss: 1693.105225
count    400.000000
mean      22.625500
std        9.572593
min        5.000000
25%       16.600000
50%       21.400000
75%       25.025000
max       50.000000
Name: medv, dtype: float64
Predictions: [array([35.063747], dtype=float32), array([19.22251], dtype=float32), array([23.879816], dtype=float32), array([34.587215], dtype=float32), array([13.386072], dtype=float32), array([19.621191], dtype=float32)]

后面的Predictions是预测的房子价格。

    原文作者:python人工智能命理
    原文地址: https://www.jianshu.com/p/f5eff5d2db78
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞