CV:基于Keras利用CNN主流架构之mini_XCEPTION训练情感分类模型hdf5并保存到指定文件夹下

简介: CV:基于Keras利用CNN主流架构之mini_XCEPTION训练情感分类模型hdf5并保存到指定文件夹下

图示过程

image.png


核心代码

def mini_XCEPTION(input_shape, num_classes, l2_regularization=0.01):

   regularization = l2(l2_regularization)

   # base

   img_input = Input(input_shape)

   x = Conv2D(8, (3, 3), strides=(1, 1), kernel_regularizer=regularization,

                                           use_bias=False)(img_input)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   x = Conv2D(8, (3, 3), strides=(1, 1), kernel_regularizer=regularization,

                                           use_bias=False)(x)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   # module 1

   residual = Conv2D(16, (1, 1), strides=(2, 2),

                     padding='same', use_bias=False)(x)

   residual = BatchNormalization()(residual)

   x = SeparableConv2D(16, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   x = SeparableConv2D(16, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = MaxPooling2D((3, 3), strides=(2, 2), padding='same')(x)

   x = layers.add([x, residual])

   # module 2

   residual = Conv2D(32, (1, 1), strides=(2, 2),

                     padding='same', use_bias=False)(x)

   residual = BatchNormalization()(residual)

   x = SeparableConv2D(32, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   x = SeparableConv2D(32, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = MaxPooling2D((3, 3), strides=(2, 2), padding='same')(x)

   x = layers.add([x, residual])

   # module 3

   residual = Conv2D(64, (1, 1), strides=(2, 2),

                     padding='same', use_bias=False)(x)

   residual = BatchNormalization()(residual)

   x = SeparableConv2D(64, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   x = SeparableConv2D(64, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = MaxPooling2D((3, 3), strides=(2, 2), padding='same')(x)

   x = layers.add([x, residual])

   # module 4

   residual = Conv2D(128, (1, 1), strides=(2, 2),

                     padding='same', use_bias=False)(x)

   residual = BatchNormalization()(residual)

   x = SeparableConv2D(128, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = Activation('relu')(x)

   x = SeparableConv2D(128, (3, 3), padding='same',

                       kernel_regularizer=regularization,

                       use_bias=False)(x)

   x = BatchNormalization()(x)

   x = MaxPooling2D((3, 3), strides=(2, 2), padding='same')(x)

   x = layers.add([x, residual])

   x = Conv2D(num_classes, (3, 3),

           #kernel_regularizer=regularization,

           padding='same')(x)

   x = GlobalAveragePooling2D()(x)

   output = Activation('softmax',name='predictions')(x)

   model = Model(img_input, output)

   return model


相关文章
|
7月前
|
机器学习/深度学习 人工智能 监控
大型动作模型LAM:让企业重复任务实现80%效率提升的AI技术架构与实现方案
大型动作模型(LAMs)作为人工智能新架构,融合神经网络与符号逻辑,实现企业重复任务的自动化处理。通过神经符号集成、动作执行管道、模式学习、任务分解等核心技术,系统可高效解析用户意图并执行复杂操作,显著提升企业运营效率并降低人工成本。其自适应学习能力与上下文感知机制,使自动化流程更智能、灵活,为企业数字化转型提供坚实支撑。
504 0
大型动作模型LAM:让企业重复任务实现80%效率提升的AI技术架构与实现方案
|
8月前
|
存储 BI Shell
Doris基础-架构、数据模型、数据划分
Apache Doris 是一款高性能、实时分析型数据库,基于MPP架构,支持高并发查询与复杂分析。其前身是百度的Palo项目,现为Apache顶级项目。Doris适用于报表分析、数据仓库构建、日志检索等场景,具备存算一体与存算分离两种架构,灵活适应不同业务需求。它提供主键、明细和聚合三种数据模型,便于高效处理更新、存储与统计汇总操作,广泛应用于大数据分析领域。
822 2
|
10月前
|
人工智能 负载均衡 API
长连接网关技术专题(十二):大模型时代多模型AI网关的架构设计与实现
随着 AI 技术快速发展,业务对 AI 能力的渴求日益增长。当 AI 服务面对处理大规模请求和高并发流量时,AI 网关从中扮演着至关重要的角色。AI 服务通常涉及大量的计算任务和设备资源占用,此时需要一个 AI 网关负责协调这些请求来确保系统的稳定性与高效性。因此,与传统微服务架构类似,我们将相关 API 管理的功能(如流量控制、用户鉴权、配额计费、负载均衡、API 路由等)集中放置在 AI 网关层,可以降低系统整体复杂度并提升可维护性。 本文要分享的是B站在大模型时代基于多模型AI的网关架构设计和实践总结,希望能带给你启发。
836 4
|
10月前
|
人工智能 缓存 自然语言处理
Bolt DIY架构揭秘:从模型初始化到响应生成的技术之旅
在使用Bolt DIY或类似的AI对话应用时,你是否曾好奇过从输入提示词到获得回答的整个过程是如何运作的?当你点击发送按钮那一刻,背后究竟发生了什么?本文将揭开这一过程的神秘面纱,深入浅出地解析AI对话系统的核心技术架构。
402 5
|
6月前
|
数据采集 机器学习/深度学习 搜索推荐
MIT新论文:数据即上限,扩散模型的关键能力来自图像统计规律,而非复杂架构
MIT与丰田研究院研究发现,扩散模型的“局部性”并非源于网络架构的精巧设计,而是自然图像统计规律的产物。通过线性模型仅学习像素相关性,即可复现U-Net般的局部敏感模式,揭示数据本身蕴含生成“魔法”。
275 3
MIT新论文:数据即上限,扩散模型的关键能力来自图像统计规律,而非复杂架构
|
6月前
|
机器学习/深度学习 数据采集 并行计算
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
682 2
|
5月前
|
机器学习/深度学习 存储 缓存
115_LLM基础模型架构设计:从Transformer到稀疏注意力
大型语言模型(LLM)的架构设计是其性能的核心决定因素。从2017年Transformer架构的提出,到如今的稀疏注意力和混合专家模型,LLM架构经历了快速的演进。本文将全面探讨LLM基础架构的设计原理,深入分析Transformer的核心机制,详细介绍稀疏注意力、MoE等创新架构,并展望未来架构发展方向。通过数学推导和实践案例,为构建高效、强大的LLM提供全面指导。
|
5月前
|
机器学习/深度学习 自然语言处理 算法
48_动态架构模型:NAS在LLM中的应用
大型语言模型(LLM)在自然语言处理领域的突破性进展,很大程度上归功于其庞大的参数量和复杂的网络架构。然而,随着模型规模的不断增长,计算资源消耗、推理延迟和部署成本等问题日益凸显。如何在保持模型性能的同时,优化模型架构以提高效率,成为2025年大模型研究的核心方向之一。神经架构搜索(Neural Architecture Search, NAS)作为一种自动化的网络设计方法,正在为这一挑战提供创新性解决方案。本文将深入探讨NAS技术如何应用于LLM的架构优化,特别是在层数与维度调整方面的最新进展,并通过代码实现展示简单的NAS实验。
|
7月前
|
机器学习/深度学习 数据采集 运维
基于WOA-CNN-BiLSTM-Attention、CNN-BiLSTM-Attention、WOA-CNN-BiLSTM、CNN-BiLSTM、BiLSTM、CNN6模型单变量时序预测一键对比研究
基于WOA-CNN-BiLSTM-Attention、CNN-BiLSTM-Attention、WOA-CNN-BiLSTM、CNN-BiLSTM、BiLSTM、CNN6模型单变量时序预测一键对比研究
294 7
|
7月前
|
编解码 文字识别 自然语言处理
Dots.ocr:告别复杂多模块架构,1.7B参数单一模型统一处理所有OCR任务22
Dots.ocr 是一款仅1.7B参数的视觉语言模型,正在重塑文档处理技术。它将布局检测、文本识别、阅读顺序理解和数学公式解析等任务统一于单一架构,突破传统OCR多模块流水线的限制。在多项基准测试中,其表现超越大参数模型,展现出“小而精”的实用价值,标志着OCR技术向高效、统一、灵活方向演进。
820 0
Dots.ocr:告别复杂多模块架构,1.7B参数单一模型统一处理所有OCR任务22

热门文章

最新文章