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

用TensorFlow 2.x和DenseNet121,手把手教你搭建一个数学图形分类器(附完整代码)

基于TensorFlow 2.x与DenseNet121的数学图形分类实战指南在计算机视觉领域数学图形分类是一个极具教育意义的入门项目。不同于常见的猫狗分类或人脸识别几何图形识别任务具有明确的特征边界和规则性结构非常适合初学者理解卷积神经网络的工作原理。本文将带领读者从零开始使用TensorFlow 2.x框架和预训练的DenseNet121模型构建一个能够准确识别圆形、抛物线、正方形和三角形等基本几何图形的分类系统。1. 环境配置与数据准备1.1 开发环境搭建确保已安装Python 3.7和TensorFlow 2.x版本。推荐使用conda创建独立的Python环境conda create -n tf_densenet python3.8 conda activate tf_densenet pip install tensorflow-gpu2.8.0 matplotlib对于GPU加速需要额外配置CUDA和cuDNN。验证TensorFlow是否识别到GPUimport tensorflow as tf print(Num GPUs Available: , len(tf.config.list_physical_devices(GPU)))1.2 数据集组织与加载创建一个规范的目录结构存放数学图形数据集math_shapes/ ├── train/ │ ├── circle/ │ ├── parabola/ │ ├── square/ │ └── triangle/ └── val/ ├── circle/ ├── parabola/ ├── square/ └── triangle/使用tf.keras.preprocessing.image_dataset_from_directory加载数据IMG_SIZE (224, 224) BATCH_SIZE 32 train_ds tf.keras.preprocessing.image_dataset_from_directory( math_shapes/train, validation_split0.2, subsettraining, seed123, image_sizeIMG_SIZE, batch_sizeBATCH_SIZE ) val_ds tf.keras.preprocessing.image_dataset_from_directory( math_shapes/val, validation_split0.2, subsetvalidation, seed123, image_sizeIMG_SIZE, batch_sizeBATCH_SIZE )提示对于小数据集1000样本建议使用cache()和prefetch()优化数据管道性能2. DenseNet121模型原理与迁移学习2.1 DenseNet架构核心思想DenseNetDense Convolutional Network的核心创新在于密集连接机制特征重用每一层都接收前面所有层的特征图作为输入缓解梯度消失通过短接路径增强梯度流动参数效率减少了需要训练的参数数量DenseNet121的具体结构包含初始卷积层7x7卷积stride2密集块4个与过渡层3个交替全局平均池化全连接分类层2.2 迁移学习策略选择针对数学图形分类任务我们采用以下迁移学习方案策略适用场景训练参数数据需求特征提取极小数据集仅分类层1k样本微调顶层中等数据集最后2-3个密集块1k-10k样本完整微调大数据集全部层10k样本对于数学图形分类假设约2k样本推荐微调最后两个密集块base_model tf.keras.applications.DenseNet121( include_topFalse, weightsimagenet, input_shape(224, 224, 3) ) # 冻结前三个密集块 for layer in base_model.layers: if dense_block1 in layer.name or dense_block2 in layer.name: layer.trainable False3. 模型构建与训练优化3.1 自定义模型架构在预训练基座上添加自定义分类头inputs tf.keras.Input(shape(224, 224, 3)) x tf.keras.applications.densenet.preprocess_input(inputs) x base_model(x) x tf.keras.layers.GlobalAveragePooling2D()(x) x tf.keras.layers.Dropout(0.5)(x) outputs tf.keras.layers.Dense(4, activationsoftmax)(x) model tf.keras.Model(inputs, outputs)3.2 学习率调度与早停配置动态学习率和训练早停策略initial_learning_rate 0.001 lr_schedule tf.keras.optimizers.schedules.ExponentialDecay( initial_learning_rate, decay_steps100, decay_rate0.96, staircaseTrue ) early_stopping tf.keras.callbacks.EarlyStopping( monitorval_loss, patience5, restore_best_weightsTrue ) model.compile( optimizertf.keras.optimizers.Adam(learning_ratelr_schedule), losssparse_categorical_crossentropy, metrics[accuracy] )4. 训练过程与性能分析4.1 训练执行与监控启动训练并记录关键指标history model.fit( train_ds, validation_dataval_ds, epochs30, callbacks[early_stopping] )典型的训练过程输出Epoch 1/30 63/63 [] - 45s 600ms/step - loss: 0.8923 - accuracy: 0.7120 - val_loss: 0.4021 - val_accuracy: 0.8625 Epoch 2/30 63/63 [] - 32s 510ms/step - loss: 0.3021 - accuracy: 0.9010 - val_loss: 0.2210 - val_accuracy: 0.9250 ... Epoch 12/30 63/63 [] - 33s 520ms/step - loss: 0.0121 - accuracy: 0.9980 - val_loss: 0.0089 - val_accuracy: 0.99754.2 可视化训练曲线定义训练指标可视化函数def plot_training_metrics(history): acc history.history[accuracy] val_acc history.history[val_accuracy] loss history.history[loss] val_loss history.history[val_loss] plt.figure(figsize(12, 4)) plt.subplot(1, 2, 1) plt.plot(acc, labelTraining Accuracy) plt.plot(val_acc, labelValidation Accuracy) plt.legend() plt.title(Accuracy Curves) plt.subplot(1, 2, 2) plt.plot(loss, labelTraining Loss) plt.plot(val_loss, labelValidation Loss) plt.legend() plt.title(Loss Curves) plt.show() plot_training_metrics(history)4.3 常见问题诊断训练过程中可能遇到的问题及解决方案过拟合迹象增加数据增强旋转、平移、缩放提高Dropout比率0.5→0.7添加L2正则化验证准确率波动大减小批量大小32→16使用更温和的学习率衰减检查数据分布是否均衡训练停滞不前解冻更多底层进行微调尝试不同的优化器如RMSprop检查输入数据预处理是否正确5. 模型部署与推理实践5.1 模型保存与加载推荐使用TensorFlow SavedModel格式保存完整模型model.save(math_shape_classifier, save_formattf)加载模型进行推理loaded_model tf.keras.models.load_model(math_shape_classifier)5.2 单图预测接口创建端到端的预测函数def predict_shape(image_path): img tf.keras.preprocessing.image.load_img( image_path, target_size(224, 224) ) img_array tf.keras.preprocessing.image.img_to_array(img) img_array tf.expand_dims(img_array, 0) pred loaded_model.predict(img_array) class_names [circle, parabola, square, triangle] return class_names[np.argmax(pred)]5.3 性能优化技巧提升推理速度的实用方法量化感知训练converter tf.lite.TFLiteConverter.from_keras_model(model) converter.optimizations [tf.lite.Optimize.DEFAULT] tflite_model converter.convert()GPU加速推理tf.function(experimental_compileTrue) def predict_batch(images): return model(images)批处理优化dataset val_ds.map(lambda x, y: x).batch(64) predictions model.predict(dataset)在实际项目中我们通常会遇到各种边缘情况。例如当输入的图形存在部分遮挡或噪声干扰时可以通过添加测试时的数据增强Test-Time Augmentation来提高鲁棒性def tta_predict(image_path, n_aug5): img load_img(image_path, target_size(224, 224)) img_array img_to_array(img) augmentations [ random_rotation(img_array, rg15), random_shift(img_array, wrg0.1, hrg0.1), random_zoom(img_array, zoom_range0.1) ][:n_aug] predictions [] for aug in augmentations: pred model.predict(np.expand_dims(aug, 0)) predictions.append(pred) return np.mean(predictions, axis0)

相关文章:

用TensorFlow 2.x和DenseNet121,手把手教你搭建一个数学图形分类器(附完整代码)

基于TensorFlow 2.x与DenseNet121的数学图形分类实战指南 在计算机视觉领域,数学图形分类是一个极具教育意义的入门项目。不同于常见的猫狗分类或人脸识别,几何图形识别任务具有明确的特征边界和规则性结构,非常适合初学者理解卷积神经网络的…...

告别臃肿!用Hono在Cloudflare Workers上5分钟搭建一个超轻量API(附完整代码)

边缘计算新选择:用Hono在5分钟内构建高性能API服务 当我们需要快速构建一个轻量级API服务时,传统框架往往显得过于臃肿。Cloudflare Workers作为边缘计算平台,配合Hono这样的微型框架,能实现惊人的部署速度和运行效率。本文将带你…...

AB 触摸屏常用操作步骤及常见问题解决方案

AB 触摸屏常用操作步骤及常见问题解决方案 1:顾客备份的后缀.mer如何打开? 如图导入,即可自动.med文件,在文件处打开即可。2:后缀.mer 如何导入触摸屏? 一:U盘导入 二:ME传输3&#…...

高效PR沟通:提升代码协作效率的关键技巧

1. 为什么PR沟通如此重要?在代码协作开发中,Pull Request(PR)是开发者之间最重要的沟通载体之一。一个典型的PR生命周期中,沟通环节往往占据70%以上的时间成本。根据GitHub官方统计,处理良好的PR沟通能使代…...

C. Partitioning the Array

原题:Problem - C - Codeforces 官方题解:Editorial for Codeforces Round #919 (Div. 2) - Codeforces 收获及反思: 同余推理,如: 判断x,y两数是否可能同余,并找出模数m. 设相同的余数为k, xa*mk, yb*m…...

Ryujinx Switch模拟器:5个简单步骤让您在PC上畅玩任天堂游戏

Ryujinx Switch模拟器:5个简单步骤让您在PC上畅玩任天堂游戏 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 想要在电脑上体验《塞尔达传说:王国之泪》《集合啦…...

RT-Thread下MPU6050的I2C驱动避坑指南:从硬件连接到DMP解算全流程

RT-Thread下MPU6050的I2C驱动避坑指南:从硬件连接到DMP解算全流程 在嵌入式开发领域,姿态传感器已成为无人机、平衡车、VR设备等智能硬件的核心组件。MPU6050作为一款集成6轴运动跟踪的经典传感器,凭借其高性价比和丰富功能,在RT-…...

数据安全治理是什么?数据安全治理有哪些步骤?

近几年,企业因数据安全问题遭受损失的情况越来越频繁。监管罚单、勒索病毒、内部泄露,随便哪一样都能让企业脱层皮。很多公司以为买几个防火墙、装个杀毒软件就万事大吉,结果真出事时才发现根本防不住。因为数据安全并不是简单的技术问题&…...

Python高频交易引擎性能压测全记录:从50μs到8μs的7大关键优化步骤

更多请点击: https://intelliparadigm.com 第一章:Python高频交易引擎性能压测全记录:从50μs到8μs的7大关键优化步骤 在实盘环境模拟中,我们基于 ccxt asyncio 构建的订单路由引擎初始平均延迟为 50.3μs(P99&…...

Python 3.15 WASM编译器首次开源:仅需2条命令生成可嵌入HTML的.pywasm文件,附GitHub Star破万的starter模板

更多请点击: https://intelliparadigm.com 第一章:Python 3.15 WASM 轻量化部署 Python 3.15 正式引入实验性 WASM(WebAssembly)后端支持,允许将纯 Python 模块编译为 .wasm 二进制文件,在浏览器或 WASI 运…...

Docker AI Toolkit 2026兼容性矩阵全曝光(覆盖CUDA 12.4–12.8 / ROCm 6.2 / Apple M4 Ultra),你的硬件在支持列表第几位?

更多请点击: https://intelliparadigm.com 第一章:Docker AI Toolkit 2026 兼容性矩阵全景解析 Docker AI Toolkit 2026 是面向生成式AI工作流深度优化的容器化工具集,其兼容性设计覆盖从边缘设备到超算集群的全栈基础设施。与传统AI镜像不…...

kew快速入门指南:10个命令让你立即开始播放音乐

kew快速入门指南:10个命令让你立即开始播放音乐 【免费下载链接】kew Music for the Shell. 项目地址: https://gitcode.com/gh_mirrors/ke/kew kew是一款专为命令行用户设计的音乐播放器,让你无需离开终端即可享受高品质音乐体验。本文将通过10个…...

如何快速掌握ASP.NET Core MVC:面向开发者的完整实战指南

如何快速掌握ASP.NET Core MVC:面向开发者的完整实战指南 【免费下载链接】Mvc [Archived] ASP.NET Core MVC is a model view controller framework for building dynamic web sites with clean separation of concerns, including the merged MVC, Web API, and W…...

MCP插件生态搭建全链路拆解,覆盖协议注册、能力协商、上下文同步与热重载调试

更多请点击: https://intelliparadigm.com 第一章:MCP插件生态搭建全景概览 MCP(Model Control Protocol)作为新一代模型交互协议,其插件生态是实现大模型能力可扩展、可编排与可治理的核心基础设施。插件并非孤立模块…...

本地部署OpenAI TTS:开源项目openai-edge-tts实战指南

1. 项目概述:当TTS遇见边缘计算最近在折腾一个智能语音项目,需要把文本实时转换成听起来很自然的语音。市面上成熟的云端TTS服务不少,但一涉及到实时性要求高、数据隐私敏感或者网络不稳定的场景,云端方案就显得有些力不从心了。要…...

3个关键场景下彻底清理显卡驱动的专业方案:Display Driver Uninstaller实战指南

3个关键场景下彻底清理显卡驱动的专业方案:Display Driver Uninstaller实战指南 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/disp…...

终极指南:如何使用jq实现模块化JSON处理脚本开发

终极指南:如何使用jq实现模块化JSON处理脚本开发 【免费下载链接】jq Command-line JSON processor 项目地址: https://gitcode.com/GitHub_Trending/jq/jq jq作为一款强大的命令行JSON处理器,能够帮助开发者轻松处理和转换JSON数据。本文将详细介…...

从2.8MB到300KB:Vue ECharts构建优化实战指南

从2.8MB到300KB:Vue ECharts构建优化实战指南 【免费下载链接】vue-echarts Vue.js component for Apache ECharts™. 项目地址: https://gitcode.com/gh_mirrors/vu/vue-echarts 在现代前端开发中,性能优化和构建体积控制直接影响用户体验和加载…...

Cursor智能体开发:智能体评审

智能体评审可在 Cursor 中对你的本地更改进行专门的代码评审。 设置 要配置智能体评审: 打开 Cursor 设置前往 代理找到 智能体评审,并按需配置偏好设置 你可以将其设为在每次智能体任务后自动运行,或者保留为手动并自行触发。 开始评审…...

Ryujinx Switch模拟器终极指南:从零开始畅玩Switch游戏的5个实用场景

Ryujinx Switch模拟器终极指南:从零开始畅玩Switch游戏的5个实用场景 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 想要在电脑上体验Switch游戏的魅力吗?Ryuj…...

如何加入DevDocs合作伙伴计划:打造技术文档生态系统的完整指南

如何加入DevDocs合作伙伴计划:打造技术文档生态系统的完整指南 【免费下载链接】devdocs API Documentation Browser 项目地址: https://gitcode.com/GitHub_Trending/de/devdocs DevDocs作为一款强大的API文档浏览器,致力于为开发者提供集中、高…...

MP4容器结构修复技术:Untrunc项目架构与实现深度解析

MP4容器结构修复技术:Untrunc项目架构与实现深度解析 【免费下载链接】untrunc Restore a truncated mp4/mov. Improved version of ponchio/untrunc 项目地址: https://gitcode.com/gh_mirrors/un/untrunc 1. 技术背景与问题定义 在多媒体数据处理领域&…...

农业IoT设备批量失效真相:3类未声明的硬件依赖让C驱动在国产MCU上静默崩溃(附GCC编译器级修复补丁)

更多请点击: https://intelliparadigm.com 第一章:农业IoT设备批量失效的现场现象与系统级归因 在华北某智慧农场集群中,部署于温棚与大田的 327 台土壤墒情传感器、气象微站及自动灌溉控制器于连续 48 小时内集中离线,平台显示“…...

如何快速掌握弹幕格式转换技巧:DanmakuFactory 完整使用指南

如何快速掌握弹幕格式转换技巧:DanmakuFactory 完整使用指南 【免费下载链接】DanmakuFactory 支持特殊弹幕的xml转ass格式转换工具 项目地址: https://gitcode.com/gh_mirrors/da/DanmakuFactory 还在为B站弹幕在其他播放器上无法显示而烦恼吗?D…...

ngx_free_connection

1 定义 ngx_free_connection 函数 定义在 ./nginx-1.24.0/src/core/ngx_connection.cvoid ngx_free_connection(ngx_connection_t *c) { c->data ngx_cycle->free_connections;ngx_cycle->free_connections c;ngx_cycle->free_connection_n;if (ngx_cycle->fi…...

React TypeScript Cheatsheet:Prettier代码格式化终极集成指南

React TypeScript Cheatsheet:Prettier代码格式化终极集成指南 【免费下载链接】react Cheatsheets for experienced React developers getting started with TypeScript 项目地址: https://gitcode.com/gh_mirrors/reactt/react-typescript-cheatsheet Reac…...

GIF动图批量转换静图工具:功能配置与使用指南

在日常内容运营工作中,处理大量GIF动图并将其转换为静态图片是一个高频需求。无论是电商主图制作、自媒体素材整理还是设计资源归档,批量处理都能显著提升工作效率。本文介绍一款Windows桌面端的GIF批量转换工具,重点说明其功能配置和使用方法…...

STM32CubeMX最新版安装避坑指南:从注册账号到固件包下载,手把手解决网络报错

STM32CubeMX最新版安装避坑指南:从注册账号到固件包下载,手把手解决网络报错 第一次接触STM32开发的朋友们,十有八九会在CubeMX安装环节踩坑。作为ST官方推出的图形化配置工具,CubeMX能大幅降低开发门槛,但它的安装过程…...

Preact版本迁移终极指南:如何实现升级过程的平滑过渡

Preact版本迁移终极指南:如何实现升级过程的平滑过渡 【免费下载链接】preact ⚛️ Fast 3kB React alternative with the same modern API. Components & Virtual DOM. 项目地址: https://gitcode.com/gh_mirrors/pr/preact Preact作为一款仅4kB大小的R…...

Excel/CSV分割工具使用指南

在日常办公中,将大型Excel或CSV文件按需求拆分成多个小文件是一个常见需求。本文介绍一款支持批量处理的表格分割工具,提供4种分割模式,适用于不同场景的数据拆分需求。工具简介这是一款Windows桌面端工具,可以批量将Excel&#x…...