人工智能应用工程师技能提升系列1、——TensorFlow2

简介: 人工智能应用工程师技能提升系列1、——TensorFlow2



tensorflow2介绍

这里先说一下选择使用tensorflow2讲解的原因,在对比一下同类型的一个优势。由于我们这个系列的目标是学习,大家使用的都是win系统的电脑,故而这里选择tensorflow2方便得多。当前最新的版本是2.15

官网(偶尔打不开): https://www.tensorflow.org/

中文网站: https://tensorflow.google.cn

可以在学习这个下拉菜单中找到官方给的可成内容,对应的还有API啥的,很方便。

TensorFlow与TensorFlow 2的主要区别体现在以下几个方面:

1. 计算图执行模式:TensorFlow 1.x主要使用静态计算图,需要先构建计算图,然后通过Session执行。而TensorFlow 2.x默认使用Eager Execution(即动态图执行模式),这使得操作更加直观和易于调试,开发效率更高。同时,TensorFlow 2.x也支持通过`tf.function`将动态图代码转化为静态图模式,兼顾运行效率。

2. API简化:相比于TensorFlow 1.x,TensorFlow 2.x删除了许多旧的API,并对一些API进行了合并和简化。例如,TensorFlow 2.x中,Keras被确立为官方的高级API,使得模型的构建和训练更加简洁明了。

3. 兼容性:虽然TensorFlow 2.x进行了许多改进,但它仍然需要考虑与TensorFlow 1.x的兼容性。为此,TensorFlow 2.x提供了一个兼容模块`tf.compat.v1`,使得大部分TensorFlow 1.x的代码可以在TensorFlow 2.x中运行。

总的来说,TensorFlow 2.x在易用性、开发效率和运行效率方面都进行了显著的改进,同时保持了与TensorFlow 1.x的兼容性。这使得开发者可以更方便地进行深度学习相关的工作。所以本课程内容选择的是TensorFlow2进行具体的操作讲解。

tensorflow2优势对比PyTorch

TensorFlow 2与PyTorch是两个流行的深度学习框架,它们都有各自的优势。以下是对TensorFlow 2与PyTorch的优势的详细描述:

TensorFlow 2的优势:

1. 工业级部署:移动端和嵌入式部署: TensorFlow在移动端和嵌入式设备上的部署能力优于PyTorch,对于Android或iOS平台,只需要很小的工作量。

高性能服务器端部署: TensorFlow Serving可以轻松地进行热插拔模型,而不会使服务失效,这在高性能服务器端部署时是一个显著优点。

2. 静态计算图优化:尽管TensorFlow 2默认使用动态图执行模式,但它仍然支持静态计算图的优化。对于一些需要高性能的场景,静态计算图可以提供更快的执行速度。

3. 广泛的社区支持和生态系统:TensorFlow作为一个较早的深度学习框架,拥有庞大的社区和丰富的生态系统,包括许多预训练模型、工具和库。

PyTorch的优势:

1. 动态计算图:PyTorch使用动态计算图,这意味着在构建神经网络时可以使用常见的Python语句(如if、while、for-loop),从而使网络构建过程更加直观和易于调试。

2. 易于使用的API:PyTorch的API设计非常直观,易于上手。它更加符合人类的思考过程,方便查看、修改中间变量的值。

3. 强大的GPU加速支持:PyTorch对GPU的支持非常出色,能够充分利用GPU进行加速计算。

TensorFlow 2和PyTorch各有优势,选择哪个框架取决于您的具体需求。如果您更关注工业级部署、静态计算图优化和广泛的生态系统支持,TensorFlow 2可能是更好的选择。而如果您更看重直观的动态计算图、易于使用的API和强大的GPU支持,那么PyTorch可能更适合您。

工具使用

这里使用的是【PyCharm Community Edition 2023.1.4】,社区版本免费用啊,用于学习绝对OK,python版本是3.9。

安装tensrflow

pip install tensorflow

或者直接在代码中

import tensorflow

ALT+回车,直接会出现安装提示,回车即可。

安装需要一些时间。

版本校验——tensorflow2

必须是这个版本,一定不能是1的,所以我们需要单独输出看看。

import tensorflow as tf
tf.__version__

直接运行可以看到对应的版本显示:

tensorflow常量constant

import tensorflow as tf
a = tf.constant([2, 3])
b = tf.constant([2, 4])
# 对象内容
print(a + b)
# 直接输出numpy结果。
print((a + b).numpy())

tensorflow基础数学计算

这里使用的时候例如下面是整数类型就都得是整数类型,不能出现浮点数什么的。

import tensorflow as tf
a = tf.constant([7, 22])
b = tf.constant([21.2, 55.7])
# 均值对象
print(tf.reduce_mean(a))
# 均值结果·整数值
print(tf.reduce_mean(a).numpy)
print(tf.reduce_mean(b).numpy)

平方计算

这里需要注意匹配数据类型。

import tensorflow as tf
a = tf.constant([7, 22])  # 不匹配
b = tf.constant([21.2, 55.7])  # 不匹配
# 外部计算均值·内部计算平方项·需要类型匹配
print(tf.reduce_mean(tf.square(b - a)))

最终效果:

tensorflow变量Variable

import tensorflow as tf
result = tf.Variable(666.666)
# 对象
print(result)
# 结果
print(result.numpy)

可以直接查看到结果,这里的numpy是函数,需要添加一对小括号。

API文档

点击打开文档可以直接查阅:All symbols in TensorFlow 2  |  TensorFlow v2.14.0

tensorflow2测试——构建一个线性模型

根据100个随机样本找出合适的w与b值,使得y=wx+b;

大致操作过程:

  1. 读取数据
  2. 构造一个线性模型 y=wx+b
  3. 构造损失函数
  4. 最小化方差(训练)
  5. 性能评估

csv文件快速生成:

=RANDBETWEEN(100000,999999)/1000000

=RANDBETWEEN(400000,599999)/100000

基本分析

import tensorflow as tf
import pandas as pd
import matplotlib.pyplot as plt
# 读取数据
# 直接获取二维数组·方便索引缩着切分
data = pd.read_csv("tensorflow_test_info.csv").values
# 样本特征·第一列的值
x = data[:, 0]
# 目标值·第二列的值
y = data[:, 1]
# 构造线性模型y=wx+b
# 我们计算分析的是浮点数,所以加上.0
w = tf.Variable(-6.0)
b = tf.Variable(6.0)
def model(x, w, b):
    """模型函数"""
    return w * x + b
# 视图呈现
plt.figure(figsize=(10, 5))
plt.axis([-0.01, 1.2, 1, 10])
plt.scatter(x, y)
plt.plot(x, model(x, w, b).numpy(), color='red')
plt.legend(['predicted_y', 'target_y'])
plt.show()

效果图:

构造损失函数

def loss(predicted_y, target_y):
    """损失函数"""
    return tf.reduce_mean(tf.square(predicted_y - target_y))

最小化方差优化

with tf.GradientTape() as t:
    """最小化方差优化"""
    dw, dd = t.gradient(loss((model(x, w, b), y), [w, b]))

训练效果

训练100遍效果:

训练1000遍最终结果:

视频效果:

tensorflow2测试——构建一个线性模型——训练效果

总结

最后从效果上看还是OK的,数据我准备的一般,没有成线性,毕竟是随机搞的,如果有兴趣的话可以做一个更贴近的随机数线性数据效果会更好的呢。

相关实践学习
部署Stable Diffusion玩转AI绘画(GPU云服务器)
本实验通过在ECS上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。
相关文章
|
2天前
|
机器学习/深度学习 人工智能 搜索推荐
探索人工智能在医疗诊断中的应用与挑战
本文深入探讨了人工智能(AI)技术在医疗诊断领域的应用及其面临的挑战。通过分析AI技术如何提高疾病诊断的准确性和效率,以及在处理大数据、实现个性化治疗方面的潜力,我们展示了AI技术带来的革命性变化。同时,文章也指出了AI在医疗实践中的伦理问题、数据隐私保护、以及跨学科合作的必要性等挑战,为读者提供了一个全面而深入的视角,理解AI技术在现代医疗中的角色与影响。
15 6
|
2天前
|
机器学习/深度学习 人工智能 算法
探索人工智能在医疗诊断中的应用
【5月更文挑战第85天】 随着人工智能技术的快速发展,其在医疗领域的应用已经取得了显著的成果。特别是在医疗诊断方面,人工智能不仅提高了诊断的准确性和效率,还为医生提供了更多的辅助信息,帮助他们做出更好的决策。本文将介绍人工智能在医疗诊断中的应用,并探讨其未来的发展趋势。
|
1天前
|
机器学习/深度学习 人工智能 算法
人工智能在医疗诊断中的应用与挑战
随着科技的不断进步,人工智能(AI)技术已广泛应用于各个领域,其中医疗领域尤为显著。AI技术在医疗诊断中的运用不仅提高了诊断的准确性和效率,还为医生提供了辅助决策的支持。然而,AI技术在医疗诊断中也面临着数据隐私、算法偏见等挑战。本文将探讨AI在医疗诊断中的应用及其所面临的挑战,并提出相应的对策建议。 【7月更文挑战第26天】
|
1天前
|
机器学习/深度学习 人工智能 算法
人工智能在医疗诊断中的应用与挑战
随着技术的进步,人工智能(AI)已成为现代医疗领域不可或缺的一部分。本文将探讨AI如何改变医疗诊断领域,包括其在提高准确性、降低成本和增强患者体验方面的潜力。同时,我们也将讨论实施AI技术时遇到的一些挑战,比如数据隐私、算法偏见和医疗专业人士的接受度问题。
|
2天前
|
机器学习/深度学习 人工智能 搜索推荐
探索未来:人工智能在日常生活中的应用与影响
本文将深度探讨人工智能(AI)如何在我们的日常生活中扮演着越来越重要的角色,从智能家居到个性化医疗、从教育辅助到职场变革。我们将通过具体案例和最新统计数据,分析AI技术带来的便利与挑战,并对其未来发展进行预测。 【7月更文挑战第25天】
|
2天前
|
数据采集 人工智能 算法
探索人工智能在医疗诊断中的应用
随着人工智能技术的飞速发展,其在医疗领域的应用日益广泛。本文将深入探讨人工智能如何在医疗诊断中发挥作用,通过数据分析、模式识别等技术手段提高诊断的准确性和效率。同时,文章也将分析人工智能在医疗诊断中面临的挑战和未来的发展方向。
|
1天前
|
机器学习/深度学习 人工智能 监控
|
1天前
|
机器学习/深度学习 人工智能 搜索推荐
人工智能在医疗领域的应用:重塑医疗服务的未来
【7月更文挑战第26天】人工智能正在深刻改变医疗领域,为医疗服务的提升和医学研究的推动注入了新的活力。随着技术的不断进步和应用范围的扩大,我们有理由相信,在不久的将来,人工智能将为我们带来更加精准、高效的医疗服务,让人类健康事业更加繁荣昌盛。作为开发者和医疗工作者,我们应当积极拥抱这一变革,共同推动人工智能在医疗领域的广泛应用和发展。
|
2天前
|
机器学习/深度学习 人工智能 算法
探索人工智能在医疗诊断中的应用
随着人工智能技术的迅猛发展,其在医疗领域的应用也日益广泛。本文将深入探讨人工智能在医疗诊断中的具体应用,包括图像识别、病理分析、基因组学研究等方面。通过对比传统医疗诊断方法与AI辅助诊断的优势,揭示AI技术如何提高诊断的准确性和效率,同时指出当前面临的挑战和未来的发展方向。
6 0
|
3天前
|
机器学习/深度学习 人工智能 算法
人工智能在医疗诊断中的应用与挑战
随着人工智能技术的飞速发展,其在医疗领域的应用日益广泛。本文旨在探讨人工智能在医疗诊断中的具体应用,分析其带来的优势与面临的挑战,并对未来发展趋势进行展望。通过对比传统诊断方法与AI辅助诊断的差异,揭示AI技术提高诊断效率和准确性的潜力。同时,指出数据隐私、算法偏见等伦理法律问题,以及技术实施过程中的障碍。最后,展望人工智能与医疗健康领域的深度融合,为未来医疗行业的发展提供参考。

热门文章

最新文章