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

TensorFlow2实战-系列教程15:Resnet实战3

🧡💛💚TensorFlow2实战-系列教程 总目录

有任何问题欢迎在下面留言
本篇文章的代码运行界面均在Jupyter Notebook中进行
本篇文章配套的代码资源已经上传

Resnet实战1
Resnet实战2
Resnet实战3

7、训练脚本train.py解读------配置训练参数

# create modelmodel = get_model()# define loss and optimizerloss_object = tf.keras.losses.SparseCategoricalCrossentropy()optimizer = tf.keras.optimizers.Adam(lr=0.001)train_loss = tf.keras.metrics.Mean(name='train_loss')train_accuracy = tf.keras.metrics.SparseCategoricalAccuracy(name='train_accuracy')valid_loss = tf.keras.metrics.Mean(name='valid_loss')valid_accuracy = tf.keras.metrics.SparseCategoricalAccuracy(name='valid_accuracy')
  1. 前面已经解析了模型的构建
  2. loss_object,多元交叉熵损失函数
  3. optimizer ,Adam优化器,学习率为0.001
  4. train_loss ,返回的是batch的平均损失
  5. train_accuracy ,loss计算方法对应的准确率计算方法
  6. valid_loss 和valid_accuracy 是验证集的平均损失和准确率计算方法

8、训练脚本train.py解读------模型训练

@tf.function
def train_step(images, labels):with tf.GradientTape() as tape:predictions = model(images, training=True)loss = loss_object(y_true=labels, y_pred=predictions)gradients = tape.gradient(loss, model.trainable_variables)optimizer.apply_gradients(grads_and_vars=zip(gradients, model.trainable_variables))train_loss(loss)train_accuracy(labels, predictions)@tf.function
def valid_step(images, labels):predictions = model(images, training=False)v_loss = loss_object(labels, predictions)valid_loss(v_loss)valid_accuracy(labels, predictions)

train_step(images, labels) 函数:

  • @xxx 是python装饰器,所谓装饰器就是一个函数加上了装饰器,被@的这个函数会将加上装饰器的这个函数作为参数传进被@的这个函数,所以@tf.function就是将train_step函数作为参数传给了tf.function函数
  • with tf.GradientTape() as tape:这是一个自动微分的上下文管理器,用于记录在其内部执行的所有操作,以便于后续计算梯度
  • predictions = model(images, training=True):通过模型传递输入图像,得到预测结果。training=True 表示模型在训练模式下运行
  • loss = loss_object(y_true=labels, y_pred=predictions):计算真实标签和预测标签之间的损失。
  • gradients = tape.gradient(loss, model.trainable_variables):计算损失相对于模型可训练变量的梯度。
  • optimizer.apply_gradients(grads_and_vars=zip(gradients, model.trainable_variables)):应用梯度下降算法来更新模型的权重。
  • train_loss(loss)train_accuracy(labels, predictions):更新训练损失和准确率的指标。

valid_step(images, labels) 函数,不需要计算梯度,其他都一样

    for epoch in range(config.EPOCHS):train_loss.reset_states()train_accuracy.reset_states()valid_loss.reset_states()valid_accuracy.reset_states()step = 0for images, labels in train_dataset:step += 1train_step(images, labels)print("Epoch: {}/{}, step: {}/{}, loss: {:.5f}, accuracy: {:.5f}".format(epoch + 1, config.EPOCHS, step, math.ceil(train_count / config.BATCH_SIZE), train_loss.result(), train_accuracy.result()))for valid_images, valid_labels in valid_dataset:valid_step(valid_images, valid_labels)print("Epoch: {}/{}, train loss: {:.5f}, train accuracy: {:.5f}, ""valid loss: {:.5f}, valid accuracy: {:.5f}".format(epoch + 1, config.EPOCHS, train_loss.result(), train_accuracy.result(), valid_loss.result(), valid_accuracy.result()))model.save_weights(filepath=config.save_model_dir, save_format='tf')
  1. 逐个epoch执行训练
  2. 重置训练和验证的损失及准确率计算
  3. step 归0
  4. 训练集一个batch一个batch取数据
  5. step +1
  6. 调用train_step()函数训练当前batch数据
  7. 打印当前batch训练信息
  8. 验证集集一个batch一个batch取数据
  9. 调用valid_step()函数验证当前batch数据
  10. 在训练完成后,保存模型的权重

Resnet实战1
Resnet实战2
Resnet实战3

相关文章:

  • 聊聊PowerJob日志的上报及存储
  • dockerpipwork相关测试过程
  • Faster-Whisper 实时识别电脑语音转文本
  • web应用课——(第四讲:中期项目——拳皇)
  • 【PHP源码】熊猫乐园签到,任务,玩游戏一键完成源代码
  • unittest、nosetest、pytest
  • 【Tomcat与网络4】Tomcat的连接器设计
  • CSC联合培养博士申请亲历|联系外导的详细过程
  • 栈的应用:括号匹配问题_有效的括号
  • 防御保护---防火墙的智能选路
  • 机器学习入门-----sklearn
  • 《幻兽帕鲁》好玩吗?幻兽帕鲁能在Mac上运行吗?
  • torch训练简单例子
  • C语言入门到精通之练习37:输入3个数a,b,c,按大小顺序输出。
  • AES加密原理
  • -------------------- 第二讲-------- 第一节------在此给出链表的基本操作
  • (十五)java多线程之并发集合ArrayBlockingQueue
  • __proto__ 和 prototype的关系
  • 【347天】每日项目总结系列085(2018.01.18)
  • CEF与代理
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • Javascript基础之Array数组API
  • JDK 6和JDK 7中的substring()方法
  • Linux编程学习笔记 | Linux IO学习[1] - 文件IO
  • PHP变量
  • Python_网络编程
  • 仿天猫超市收藏抛物线动画工具库
  • 机器学习中为什么要做归一化normalization
  • 将回调地狱按在地上摩擦的Promise
  • 猫头鹰的深夜翻译:Java 2D Graphics, 简单的仿射变换
  • 前端面试之CSS3新特性
  • 深度解析利用ES6进行Promise封装总结
  • 通过npm或yarn自动生成vue组件
  • 为什么要用IPython/Jupyter?
  • 用mpvue开发微信小程序
  • 7行Python代码的人脸识别
  • ​iOS安全加固方法及实现
  • #QT(串口助手-界面)
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (js)循环条件满足时终止循环
  • (笔试题)分解质因式
  • (三十五)大数据实战——Superset可视化平台搭建
  • (学习日记)2024.02.29:UCOSIII第二节
  • (循环依赖问题)学习spring的第九天
  • (一)Neo4j下载安装以及初次使用
  • (一)插入排序
  • (转)Linux NTP配置详解 (Network Time Protocol)
  • (转)菜鸟学数据库(三)——存储过程
  • (轉)JSON.stringify 语法实例讲解
  • .NET 4.0中使用内存映射文件实现进程通讯
  • .net 反编译_.net反编译的相关问题
  • .NET 设计模式—适配器模式(Adapter Pattern)
  • .Net中间语言BeforeFieldInit