ASR(Automatic Speech Recognition)调研,当前sota的架构

news2024/9/22 1:32:35

asr概览英文纯享版:an overview of transducer models for asr

本文主要讲述nvidiaopenai的模型架构,应为他们两家霸榜huggingface leader board
小白也能阅读了解一下当前sota的asr架构是什么样的

在这里插入图片描述
评测指标

  • Word Error Rate (WER):错词率,值越小代表识别效果越好
  • Real Time Factor (RTF):实时反馈,值越小代表模型识别的越快

Nvidia的asr模型

以前是基于Conformer模型,现在是基于原先模型优化后的Fast-Conformer,可以4x节省显存以及3x提高计算速率
Conformer是Transformer的一个变体,在自注意力层间堆叠卷积神经网络层

在这里插入图片描述

原文档摘录:This paper’s thesis is that by interleaving Convolutional Neural Networks layers in between the self-attention layers in transformers

一、Canary 金丝雀

这是一个 encoder-decoder模型,encoder模型是Fast-Conformer,decoder是transformer

加入了concatenated tokenizer ,提供对输出标记空间的明确控制,有助于优化模型性能

不支持中文,模型许可不能商用

原文档摘录: The model weights are distributed under a research-friendly non-commercial CC BY-NC 4.0 license

架构参考文献

  • Fast Conformer with Linearly Scalable Attention for Efficient Speech Recognition
  • Unified Model for Code-Switching Speech Recognition and Language Identification Based on Concatenates Tokenizer

二、Parakeet 鹦鹉

也是encoder-decoder模型,语音长度支持11小时,显卡要求A100 GPU 80G

encoder是Fast-Conformer,decoder是RNNT或CTC(CTC在RTF的表现更好,快4~6倍)

  • CTC(Connectionist Temporal Classification)连续时间分类
    在这里插入图片描述

    • 概念: CTC 是一种特别为序列预测任务设计的训练和解码方法,它能够处理输入和输出序列长度不一致的问题。这在语音识别中尤其有用,因为输入的语音长度和输出的文本长度通常是不匹配的。
    • 原理: CTC 引入了一个特殊的空白标签(通常表示为 “blank” 或 “-”),用于处理不需要输出字符的时间步。它通过这个空白标签来桥接输入和输出之间的时间对齐问题,并允许模型学习在何时输出一个字符以及何时保持沉默。
    • 优点: 不需要对齐,只需要语音以及其对应的文本序列
    • 缺点: 条件独立,token之间没有上下文关联;需要一个额外训练的语言模型来纠正语义错误。
      • 例如输出I have for apples ,应该是four,由于条件独立没有上下文交互,所以无法确定是for 还是four
  • RNNT(Recurrent Neural Network Transducer)循环神经网络转录器,Transducer == RNNT 不同称呼但是指的是同一个东西(我之前还疑惑了很久,后来发现是同一个东西)

在这里插入图片描述

  • 概念: 处理输入输出序列长度不匹配的问题

  • 原理: 编码器(encoder)、预测器(Predictor)和联合网络(Joiner)。编码器处理输入的声音特征,预测器处理已生成的文本序列,而联合网络将编码器和解码器的输出结合起来,生成最终的输出概率分布。

  • 优点: 在没有明确时间对齐指导的情况下,进行更为动态的解码,适用于需要实时反馈的应用场景。有上下文依赖,根据上一个输入预测下一个输出

在encoder中,加入了Limited Context Attention (LCA) and Global Token (GT)

  • LCA:不考虑整个输入序列,只关注部分的序列;减少计算负担,提高处理速度,并可能帮助模型更专注于当前最相关的信息片段。
  • GT: 是一种机制,通过引入一个或多个特殊的标记(tokens),这些标记被训练用来捕捉整个输入序列的全局状态或特征。这些标记在模型的每个处理步骤中都会被更新,以反映序列的整体上下文。

不支持中文可以微调可以商用

You can fine-tune Parakeet models for other languages on your own datasets. Below are some helpful tutorials:

  • Finetuning on data in NeMo manifest format: ASR CTC language finetuning tutorial
  • Finetuning on data in Hugging Face datasets format: ASR with Transducer Models using HF Datasets tutorial.

相同模型在不同的推理设备下有不同的RTF(real-time factor)值

架构参考文献

  • Fast Conformer with Linearly Scalable Attention for Efficient Speech Recognition
  • End-to-End ASR Architecture for Long-Form Audio Transcription

三、Parakeet-TDT

TDT (Token-and-Duration Transducer),这是一个新的训练架构,能提高准确率和速度

之前的架构: Transducers (AKA RNNTs if only using Recurrent Neural Networks and their variants).

在这里插入图片描述

  • encoder处理音频
  • decoder处理已经预测出的文本
  • joiner结合encoder和decoder的输出来预测每一个音频片段(frame,是一个基本单位)

joiner通常将语音切片成40~80毫秒,但是说一个单词的平均时间是400毫秒,这就导致在片段中的一些数据不会与任何文本输出相关联,这里用空白符_表示,删除空白符才能得到完整的句子

_ _ _ _ NVIDIA _ _ _ _ is _ _ _ a _ _ great _ _ _ _ _ place _ _ _ _ to work _ _ _

TDT架构多加了一个概率输出
在这里插入图片描述

  • token概率 P T ( v ∣ t , u ) P_T(v|t,u) PT(vt,u) ,是当前frame中预测token的概率
  • 持续时间概率 P D ( d ∣ t , u ) P_D(d|t,u) PD(dt,u),是在预测下一个token之前,当前token持续的frame数量

预测的输出如下

frame 1:  predict token=_,      duration=4 
frame 5:  predict token=NVIDIA, duration=5 
frame 10: predict token=is,     duration=4 
frame 14: predict token=a,      duration=3 
frame 17: predict token=great,  duration=6 
frame 23: predict token=place,  duration=5 
frame 28: predict token=to,     duration=1 
frame 29: predict token=work,   duration=4 
frame 33: reach the end of audio, recognition completed.

将预测frame的步数从33次减少到8次。

参考文献

  • Efficient Sequence Transduction by Jointly Predicting Tokens and Durations

OpenAI的asr模型

whisper

输入:切分成30s的chunk,转换成Log-Mel Spectrogram(声谱)输入encoder

输出:文字

seq2seq的transformer架构

在这里插入图片描述

输入:切分成30s的chunk,转换成Log-Mel Spectrogram(声谱)输入encoder

输出:文字

seq2seq的transformer架构

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1982713.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于使用QListView向模型插入第一条数据的相关问题

在使用QListView的时候,看着它的四个尖角不爽,想着让它变成圆角矩形吗,但麻烦就接踵而至了。。。 在向其中插入第一条数据的时候发现,你插入的一条数据它存在边界超过QListView的现象。如下图所示: 这就令人头大了&am…

JavaEE 图书管理系统

基于阿里巴巴的fastjson框架搭建的JavaEE版本的图书管理系统,项目架构如下: fastjson包的阿里云下载镜像如下: Central Repository: com/alibaba/fastjson2/fastjson2/2.0.8 运行效果: Bean Book.java package Bean;public c…

2024华数杯大学生数学建模竞赛(C题)数学建模完整思路+完整代码全解全析

你是否在寻找数学建模比赛的突破点?数学建模进阶思路! 作为经验丰富的数学建模团队,我们将为你带来2024华数杯数学建模竞赛(C题)的全面解析。这个解决方案包不仅包括完整的代码实现,还有详尽的建模过程和解…

按照指定格式打印pprint()

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 按照指定格式打印 pprint() [太阳]选择题 根据给定的Python代码,哪个选项是正确的? from pprint import pprint data { name: A, age: 30, hobbies:…

Vue项目学习(项目的开发流程)(2)

1、vue项目的默认首页和入口文件 2、两种书写的方式是表达一样的意思——>el:指定当前Vue实例挂载到哪个区域里 3、如果属性值和属性名一致,冒号和后面可以省略不写 (所以有两种写法) 4、以".vue"文件结尾的文件在项…

3个步骤上⼿Midjourney表情包教程,并上传到微信实现变现!

羡慕别⼈设计的表情包,有趣⼜好玩~也想拥有⾃⼰的个性表情包,可是⾯对复杂的设计流程,却不知从何开始?现在⽤Midjourney,你就可以轻松制作,各种⻛格的表情包,变钱赚钱,这些⽅法分享给 你~ 通⽤公式: 我们⽤表情包魔法公式,加⼊你想要的风格,⽐如漫画、卡通、插画、…

rpc框架怎么使用

这是我们提供RPC的服务类: class MprpcApplication { public:static void Init(int argc, char **argv);static MprpcApplication& GetInstance();static MprpcConfig& GetConfig(); private:static MprpcConfig m_config;MprpcApplication(){}MprpcApplica…

cuda逐步优化实现reduce sum 操作

归约是一种常见的数据并行原语,它将数组中的元素通过某种二元操作(如加法)合并成一个单一的值。通过逐步展示不同的CUDA实现版本,来演示重要的优化策略。 由于规约的算术操作很简单,对算力要求不高,因此我们…

文件上传和下载

要想实现文件上传和下载,其实只需要下述代码即可: 文件上传和下载 import cn.hutool.core.io.FileUtil; import cn.hutool.core.util.StrUtil; import com.example.common.Result; import org.springframework.web.bind.annotation.*; import org.sprin…

SQL注入sqli-labs-master关卡二

第二关如下: 查看页面与第一关差不多的样子,再查看PHP源码,与第一关差不多只是其中的查询处有不同。(查看源码是为了更好的判断出该页面有什么漏洞)其中没有单引号所以不用添加单引号去闭合去逃离单引号,说…

【生成式AI-一-生成式AI到底在说什么】

成式AI到底在说什么 什么是生成式人工智能生成式人工智能、机器学习、深度学习的关系chat-gpt 到底是如何实现对话的? 今天主要来看到底生成式AI是什么,语言模型是如何实现生成这个功能的? 什么是生成式人工智能 现在人工智能能做的事情很多…

pxe环境下的无人值守自动安装

0. 环境部署前的准备 1.rhel7的主机 2.开启主机图形 3.配置网络可用 4.关闭vmware dhcp功能 5.关闭防火墙以及selinux getenforce要为disable状态 grubby --update-kernel ALL --args selinux0 systemctl disable --now firewalld 1.kickstart自动安装脚本制作 我们想要…

SQL注入之webshell上传

首先webshell上传就是利用MySQL的文件读写注入而实现,要想上传webshell就得了解文件读写注入的原理。文件读写注入就是利用文件的读写权限进行注入,它可以写一句话木马,也可以读取文件系统的敏感信息。 文件读写注入的条件: 1.高版本的MYSQ…

Axure导入ElementUI元件库——提升原型设计效率与质量

在快速迭代的互联网产品开发过程中,高质量的原型设计是确保项目顺利进行的关键一步。Axure RP,作为一款强大的原型设计工具,以其丰富的交互功能和易用的界面设计,深受设计师和开发者的喜爱。而ElementUI,作为一套为开发…

Ubuntu配置carla docker环境

前言: 本文只在以下设备成功运行, 其他设备不保证能成功, 可以参考在自己设备进行配置 环境 ubuntu 20.04carla 0.9.15gpu 3060(notebook) 安装显卡驱动&nvidia-container-toolkit 显卡驱动 安装完成系统后直接在’软件和更新->附加驱动’直接选择470(proprietary…

工程化实践:工程配置化设计

文内项目 Github:XIAOJUSURVEY 配置化是很灵活且很常见的使用,那XIAOJUSURVEY里有哪些地方应用到了呢? 基础模板​ 问卷模板​ 在创建问卷时,我们提供了多种问卷类型选择,例如普通问卷、投票、报名、NPS等。 为了实…

安卓碎片Fragment

文章目录 Fragment的简单用法动态添加Fragment在Fragment中实现返回栈碎片与活动之间的通信 Fragment是一种可以嵌入在Activity当中的UI片段,它能让程序更加合理和充分地利用大屏幕的空间。 Fragment的简单用法 先建一个空的项目,然后创建两个fragment文…

单片机振荡电路晶振不起振原因分析与解决方法

晶发电子专注17年晶振生产,晶振产品包括石英晶体谐振器、振荡器、贴片晶振、32.768Khz时钟晶振、有源晶振、无源晶振等,产品性能稳定,品质过硬,价格好,交期快.国产晶振品牌您值得信赖的晶振供应商。 晶振在单片机系统中扮演着至关重要的角色,它为单片机提…

大模型分不清 9.9 与 9.11 谁大,那 Embedding 模型呢?

这是我今天在维也纳举行的 ICML 会议上被问到的问题。 在茶歇期间,一位 Jina 用户向我提出了一个源自 LLM 社区最近讨论的问题。他问我们 Jina Embeddings 能不能判断 9.11 比 9.9 更小,很多大模型在这个小问题上翻了车。 我说:“老实说&am…

Flink 实时数仓(七)【DWS 层搭建(一)流量域汇总表创建】

前言 今天开始 DWS 层的搭建,不知不觉又是周一,都忘了昨天是周末,近两年对我来说,周六日晚上八九点能打一小会篮球就算一周的休息了。不得不说自己真的是天生打工体质,每天不管多累,晚上十二点睡&#xff0…