当前位置: 首页 > news >正文

TensorFlow实现回归分析详解

本文使用TensorFlow框架实现了与之前NumPy和PyTorch相同的回归分析任务,通过比较可以更清楚地了解不同框架之间的特点。

1. 代码实现要点

  1. 数据生成:使用NumPy生成相同的训练数据
np.random.seed(100)
x = np.linspace(-1, 1, 100).reshape(100,1)
y = 3*np.power(x, 2) +2+ 0.2*np.random.rand(x.size).reshape(100,1)
  1. TensorFlow特有结构
  • 使用placeholder定义输入节点
  • 显式定义变量Variable
  • 构建静态计算图(需要禁用eager execution)
  1. 训练过程
  • 需要创建Session来执行计算图
  • 使用feed_dict传入数据
  • 更新参数是计算图的一部分

2. 关键修改说明

原始代码有几处需要修正:

  1. 使用tf.compat.v1兼容接口确保TF 2.x可以运行1.x代码
  2. 前向传播中需要使用placeholder x1而不是原始数据x
  3. 计算梯度时需要对loss而不是y-y_pred
  4. 更新参数时需要将操作包含在sess.run

3. 与PyTorch的对比

特性TensorFlow (静态图)PyTorch (动态图)
构图方式先构建完整计算图动态构建,边执行边构建
执行方式需要Session运行直接执行
调试便利性较难调试易于调试
代码结构更声明式更命令式
变量更新是计算图的一部分在计算图外执行

4. 结果分析

经过2000次迭代:

  • 最终损失值:0.0041
  • 权重:2.90(接近目标值3)
  • 偏移量:2.13(接近目标值2)

可视化结果显示了良好的拟合效果,与预期二次函数曲线吻合。

5. 静态图与动态图特点

TensorFlow静态图

  • 优点:优化更好,适合生产部署
  • 缺点:调试较困难,不够直观

PyTorch动态图

  • 优点:交互式,易于调试
  • 缺点:运行时开销略大

6. 完整修正代码

import tensorflow as tf 
import numpy as np
from matplotlib import pyplot as plt# 禁用eager execution以使用静态图
tf.compat.v1.disable_eager_execution() # 生成训练数据
np.random.seed(100) 
x = np.linspace(-1, 1, 100).reshape(100, 1)
y = 3 * np.power(x, 2) + 2 + 0.2 * np.random.rand(x.size).reshape(100, 1)# 创建占位符
x1 = tf.compat.v1.placeholder(tf.float32, shape=(None, 1))
y1 = tf.compat.v1.placeholder(tf.float32, shape=(None, 1))# 创建变量 
w = tf.Variable(tf.random.uniform([1], 0, 1))
b = tf.Variable(tf.zeros([1])) # 前向传播
y_pred = tf.pow(x1, 2) * w + b  # 使用x1而不是x# 损失函数
loss = tf.reduce_mean(tf.square(y1 - y_pred))# 计算梯度
grad_w, grad_b = tf.gradients(loss, [w, b])# 更新参数
learning_rate = 0.01
new_w = w.assign(w - learning_rate * grad_w)
new_b = b.assign(b - learning_rate * grad_b)# 训练模型
with tf.compat.v1.Session() as sess:# 初始化变量sess.run(tf.compat.v1.global_variables_initializer())for step in range(2000):# 运行计算图loss_value, v_w, v_b, _ = sess.run([loss, w, b, [new_w, new_b]],feed_dict={x1: x, y1: y})if step % 200 == 0:print(f"Step {step}: 损失值={loss_value:.4f}, 权重={v_w[0]:.4f}, 偏移量={v_b[0]:.4f}")# 获取最终参数用于绘图final_w, final_b = sess.run([w, b])# 可视化结果plt.figure(figsize=(8, 6))plt.scatter(x, y, label="原始数据")plt.plot(x, final_b + final_w * x**2, 'r-', label="拟合曲线")plt.title("TensorFlow回归分析结果")plt.xlabel("x")plt.ylabel("y")plt.legend()plt.grid(True)plt.show()

7. 扩展建议

  1. 尝试增加迭代次数观察精度变化
  2. 调整学习率观察收敛速度
  3. 尝试使用TensorFlow 2.x的eager execution模式实现相同功能
  4. 添加正则化项防止过拟合
  5. 使用更复杂的模型结构(如增加隐藏层)

通过这个实现,我们可以清楚地看到TensorFlow静态图的工作方式,以及与PyTorch动态图的区别。理解这些差异有助于我们在不同场景下选择合适的框架。

http://www.lryc.cn/news/619405.html

相关文章:

  • PyTorch基础(使用TensorFlow架构)
  • CSS counter-reset 与 counter-increment:用 CSS 实现自动编号的黑科技
  • 【贪心算法】加油站
  • TensorFlow深度学习实战(31)——强化学习仿真库Gymnasium
  • 【IntelliJ IDEA】如何在pom.xml中去除maven中未使用的依赖
  • 七大排序算法全解析:从入门到精通
  • 各种排序算法(一)
  • Java开发环境搭建(WIN+IDEA+Maven)
  • STM32的UART奇偶校验注意
  • C# xml UI格式化字符串
  • IDEA创建一个VUE项目
  • 基于人工智能和物联网融合跌倒监控系统(LW+源码+讲解+部署)
  • CW32L011电机开发板控制教程
  • 分布式与微服务宝典
  • js:13KB或者xxxkb、xxxMB\xxxtb\xxb等多种情况怎么获取后面的单位
  • FluxSelectMultiple 技术设计文档
  • 飞算JavaAI的中间件风暴:Redis + Kafka 全链路实战
  • docker network 与host的区别
  • 数据科学与爬虫技术学习笔记
  • 玩转Docker | 使用Docker部署WordPress网站服务
  • 【车联网kafka】Kafka核心架构与实战经验(第四篇)
  • 猿大师中间件:Chrome网页内嵌PhotoShop微信桌面应用程序
  • Jetson NX Python环境搭建:使用APT轻松安装NumPy, scikit-learn, OpenCV
  • java学习 leetcode 二分查找 图论
  • 图论理论部分
  • 【C++ STL】list详解和模拟
  • Day52--图论--101. 孤岛的总面积(卡码网),102. 沉没孤岛(卡码网),103. 水流问题(卡码网),104. 建造最大岛屿(卡码网)
  • day50 图论基础 卡码网98. 所有可达路径
  • 15-docker的企业级私有仓库之docker-harbor
  • 若依plus SpringCloud [DUBBO] 多模块异常抛出 异常里面包了一层异常