0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何使用TensorFlow构建机器学习模型

新机器视觉 来源:新机器视觉 2024-01-08 09:25 次阅读

作者 | Kesk 译者 | 张健欣 来源| AI前线

在这篇文章中,我将逐步讲解如何使用 TensorFlow 创建一个简单的机器学习模型。

TensorFlow 是一个由谷歌开发的库,并在 2015 年开源,它能使构建和训练机器学习模型变得简单。

我们接下来要建立的模型将能够自动将公里转换为英里,在本例中,我们将创建一个能够学习如何进行这种转换的模型。我们将向这个模型提供一个 CSV (https://en.wikipedia.org/wiki/Comma-separated_values)文件作为输入,其中有 29 组已经执行过的公里和英里之间的转换,基于这些数据,我们的模型将学会自动进行这种转换。

我们将使用有监督学习算法,因为我们知道数据的输入和输出结果。并使用 Python 作为编程语言。Python 提供了一系列与机器学习相关的方便的库和工具。本例中所有的步骤都是使用 Google Colab 执行的。Google Colab 允许我们在浏览器上零配置地编写和执行 Python 代码。

导入必需的库

我们首先导入在我们的例子中将要使用到的库。

import tensorflow as tf
import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt

我们将导入 TensorFlow 来创建我们的机器学习模型。

我们还将导入 Pandas 库来读取包含有公里和英里转换数据的 CSV 文件。

最后,我们将导入 Seaborn 和 Matlotlib 库绘制不同的结果。

加载样例数据

我们将含有逗号分隔的值的文件(Kilometres-miles.csv)读取到我们的数据帧中。这个文件包含一系列公里和英里值的转换。我们将使用这些数据帧来训练我们的模型。你可以在这个链接(https://drive.google.com/file/d/1m63pJA-zUAA12XOCCBt3Aik9fnjrj_8s/view?usp=sharing)下载这个文件。

要从 Google Colab 读取文件,你可以使用不同的方法。在本例中,我直接将 CSV 文件上传到我的 Google Colab 上的 sample_data 文件夹中,但你可以从一个 URL 中读取文件(比如,从 GitHub)。

上传到 Google Colab 的问题是,数据会在运行时重启时丢失。

数据帧是二维的大小可变的并且各种各样的表格数据。

df  = pd.read_csv('/content/sample_data/Kilometres-miles.csv')
df.info
3c6681b6-adb9-11ee-8b88-92fbcf53809c.png

示例数据信息

绘制数据帧

我们将“searborn”库的“scatterplot”导入并命名为“sns”,然后使用这个库来绘制上述图形。它显示了 X(公里)和 Y(英里)对应关系的图形化表示。

print("Painting the correlations")
#Once we load seaborn into the session, everytime a matplotlib plot is executed, seaborn's default customizations are added
sns.scatterplot(df['Kilometres'], df['Miles'])
plt.show()
3c6d1b02-adb9-11ee-8b88-92fbcf53809c.png

公里和英里的相关性

我们定义数据帧的输入和输出来训练模型:

X(公里)是输入,Y(英里)是输出。

print("Define input(X) and output(Y) variables")
X_train=df['Kilometres']
y_train=df['Miles']
创建神经网络

现在,让我们使用“keras.Sequential”方法来创建一个神经网络,其中依次添加“layers”。每一个层(layer)都具有逐步提取输入数据以获得所需输出的功能。Keras 是一个用 Python 写的库,我们创建神经网络并使用不同的机器学习框架,例如 TensorFlow。

接下来,我们将使用“add”方法向模型添加一个层。

print("Creating the model")
model = tf.keras.Sequential()
model.add(tf.keras.layers.Dense(units=1,input_shape=[1]))
创建神经网络 编译模型

在训练我们的模型之前,我们将在编译步骤中添加一些额外设置。

我们将设置一个优化器和损失函数,它们会测量我们的模型的准确性。Adam 优化是一种基于第一次和第二次矩的自适应预算的随机梯度下降算法。

为此,我们将使用基于平均方差的损失函数,它测量了我们预测的平均方差。

我们的模型的目标是最小化这个函数。

print("Compiling the model")
model.compile(optimizer=tf.keras.optimizers.Adam(1), loss='mean_squared_error')
训练模型

我们将使用“拟合(fit)”方法来训练我们的模型。首先,我们传入独立变量或输入变量(X-Kilometers)和目标变量(Y-Miles)。

另一方面,我们预测 epoch 的数值。在本例中,epoch 值是 250。一个 epoch 就是遍历一遍所提供的完整的 X 和 Y 数据。

如果 epoch 的数值越小,误差就会越大;反过来,epoch 的数值越大,则误差就会越小。

如果 epoch 的数值越大,算法的执行速度就会越慢。

print ("Training the model")
epochs_hist = model.fit(X_train, y_train, epochs = 250)
3c75dc88-adb9-11ee-8b88-92fbcf53809c.png

训练模型的控制台

评估模型

现在,我们评估创建的模型,在该模型中,我们可以观察到损失(Training_loss)随着执行的遍历次数(epoch)的增多而减少,如果训练集数据有意义并且是一个足够大的组,这是合乎逻辑的。

print("Evaluating the model")
print(epochs_hist.history.keys())


#graph
plt.plot(epochs_hist.history['loss'])
plt.title('Evolution of the error associated with the model')
plt.xlabel('Epoch')
plt.ylabel('Training Loss')
plt.legend('Training Loss')
plt.show()

3c81e73a-adb9-11ee-8b88-92fbcf53809c.png

从图中我们可以看出,用 250 次训练模型并没有多大帮助,在第 50 次遍历后,误差并没有减少。因此,训练该算法的最佳遍历数大约是 50。

进行预测

现在我们已经训练了我们的模型,我们可以使用它来进行预测。

在本例中,我们将 100 赋值给模型的输入变量,然后模型会返回预测的英里数:

kilometers = 100
predictedMiles = model.predict([kilometers])
print("The conversion from Kilometres to Miles is as follows: " + str(predictedMiles))

从公里到英里的换算为 62.133785.

检查结果

milesByFormula = kilometers * 0.6214
print("The conversion from kilometers to miles using the mathematical formula is as follows:" + str(milesByFormula))
diference = milesByFormula - predictedMiles
print("Prediction error:" + str(diference))

使用公式从公里到英里的换算值为:62.13999999999999。预测误差为 0.00621414

总 结

通过本例,我们了解了如何使用 TensorFlow 库来创建一个模型,这个模型已经学会自动将公里数转换为英里数,并且误差很小。

TensorFlow 用于执行此过程的数学非常简单。基本上,本例使用线性回归来创建模型,因为输入变量(公里数)和输出变量(英里数)是线性相关的。在机器学习中,过程中最耗时的部分通常是准备数据。

随着时间的推移,我们收获了一些经验,这些经验可以帮助我们选择最适合的算法及其设置,但一般来说,这是一项分析测试并改进的任务。

作者介绍

Kesk,软件工程师,软件爱好者,科幻作家。

审核编辑:汤梓红
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 模型
    +关注

    关注

    1

    文章

    3199

    浏览量

    48784
  • 机器学习
    +关注

    关注

    66

    文章

    8392

    浏览量

    132507
  • python
    +关注

    关注

    56

    文章

    4788

    浏览量

    84542
  • tensorflow
    +关注

    关注

    13

    文章

    329

    浏览量

    60514

原文标题:如何使用TensorFlow构建机器学习模型

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    tensorflow机器学习日志

    tensorflow学习日志(四)机器学习(泛化,过拟合, 数据集,验证集,测试集)
    发表于 04-14 06:32

    labview+yolov4+tensorflow+openvion深度学习

    缺陷检测主要知识点:1Tensorflow-GPU环境的搭建Tensorflow object环境搭建学会如何标注图片如何labview快速通过迁移学习训练自己的模型如何利用labvi
    发表于 05-10 22:33

    labview调用深度学习tensorflow模型非常简单,附上源码和模型

    本帖最后由 wcl86 于 2021-9-9 10:39 编辑 `labview调用深度学习tensorflow模型非常简单,效果如下,附上源码和训练过的模型:[hide][/h
    发表于 06-03 16:38

    Mali GPU支持tensorflow或者caffe等深度学习模型

    Mali GPU 支持tensorflow或者caffe等深度学习模型吗? 好像caffe2go和tensorflow lit可以部署到ARM,但不知道是否支持在GPU运行?我希望把训
    发表于 09-16 14:13

    部署基于嵌入的机器学习模型

    还需要处理模型的更新。模型更新的速度甚至可以非常高,因为模型需要定期地根据最新的数据进行再训练。  本文将描述一种更复杂的机器学习系统的一般
    发表于 11-02 15:09

    谷歌推出开源的量子机器学习TensorFlow Quantum

    谷歌在其官方AI博客宣布推出TensorFlow Quantum(TFQ),这是一个开源的量子机器学习库,可将量子计算与机器学习结合在一起,
    的头像 发表于 03-11 14:25 2454次阅读

    如何才能正确的构建机器学习模型

    组织构建一个可行的、可靠的、敏捷的机器学习模型来简化操作和支持其业务计划需要耐心、准备以及毅力。各种组织都在为各行业中的众多应用实施人工智能项目。这些应用包括预测分析、模式识别系统、自
    发表于 01-11 19:25 14次下载

    使用TensorFlow建立深度学习机器学习网络

    教你使用TensorFlow建立深度学习机器学习网络。
    发表于 03-26 09:44 18次下载

    六个构建机器学习模型需避免的错误

    近年来,机器学习在学术研究领域和实际应用领域得到越来越多的关注。但构建机器学习模型不是一件简单的
    发表于 05-05 16:39 1415次阅读

    轻松入门,高效成长: "TensorFlow 机器学习技能解锁季"

    体系,体验 TensorFlow 的最佳实践模式? 《 TensorFlow 入门实操课程》 带你零基础快速上手 想高效实践机器学习模型部署
    的头像 发表于 11-10 11:35 770次阅读

    机器学习构建ML模型实践

    实践中的机器学习构建 ML 模型
    的头像 发表于 07-05 16:30 691次阅读

    深度学习框架tensorflow介绍

    TensorFlow可以用于各种不同的任务,包括图像和语音识别、自然语言处理和推荐系统等。 TensorFlow提供了一个灵活和强大的平台,可以用于构建和训练各种深度学习
    的头像 发表于 08-17 16:11 2476次阅读

    如何使用Tensorflow保存或加载模型

    TensorFlow是一个广泛使用的开源机器学习库,它提供了丰富的API来构建和训练各种深度学习模型
    的头像 发表于 07-04 13:07 1371次阅读

    keras模型tensorflow session

    和训练深度学习模型。Keras是基于TensorFlow、Theano或CNTK等底层计算框架构建的。TensorFlow是一个开源的
    的头像 发表于 07-05 09:36 495次阅读

    tensorflow简单的模型训练

    在本文中,我们将详细介绍如何使用TensorFlow进行简单的模型训练。TensorFlow是一个开源的机器学习库,广泛用于各种
    的头像 发表于 07-05 09:38 578次阅读