ASR项目实战-架构设计

这篇具有很好参考价值的文章主要介绍了ASR项目实战-架构设计。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一般而言,业务诉求作为架构设计的输入。

需求清单

对于语音识别产品而言,需满足的需求,举例如下:

功能需求

  • 文件转写。
    • 长文件转写,时长大于60秒,小于X小时,X可以指定为5。
    • 短文件转写,时长小于60秒。
  • 实时语音识别。
    • 长语音识别,时长大于60秒,小于Y小时,Y可以指定为5。
    • 短语音识别,时长小于60秒。
  • 支持多个语种。
  • 其它功能需求,比如:
    • 前处理
      • 支持多种音频文件格式。
      • 支持多种采样率和位深。
      • 支持去回声和抗噪。
      • 支持在音频文件中处理多个声道。
    • 中间处理
      • 支持VAD。
      • 支持区分音频文件中的多个讲话人。
      • 支持输出文本对应的时间偏移。
      • 支持使用热词提高字准率。
    • 后处理
      • 支持输出标点符号。
      • 支持输出拼音类语言的大、小写。
      • 支持数字、符号的归一化处理。

非功能需求

  • 集成多个合作伙伴。
    • 云云对接,即将请求转发给合作伙伴开放在公网的API服务,通过公网API访问的形式集成其语音识别能力。
    • 集成软件包,即将合作伙伴的语音识别服务部署在相同的机房内,通过内网API访问的方式集成其语音识别能力。
    • 集成算法库,集成合作伙伴的语音识别能力。
    • 集成算法模型,基于相同的算法库,合作伙伴提供模型,进而集成其语音识别能力。
  • 控制并发路数。
    • 通过接口接入的基础设施,限制并发TPS。
    • 基于当前可用的并发路数,限制可以接入的请求数量。
    • 基于各个应用的业务推广情况,定义并发路数的最低、最高配额,保证基本的并发路数。
    • 基于各个应用的业务实际情况,定义调用量的最高配额,控制调用量。
  • 支持扩容。
    • 通过扩容硬件的方式,增加服务能力。
    • 针对某具体应用的实际情况,通过扩容,满足其业务诉求。
    • 针对某具体业务场景的实际情况,通过扩容,满足其业务诉求。

技术指标

  • 文件转写场景下的时延类指标,比如
    • 转写比,即端到端处理时长与语音文件时长的比值。这个指标不是越小越好,需结合投入的硬件成本综合考虑,定义符合预期的指标目标值。
  • 语音识别场景下的时延类指标,比如
    • 首字时延
    • 尾字时延
    • 蹦字时延
  • 模型文件的大小,影响如下:
    • 决定了软件包版本构建的时间、安装服务的时间、启动服务的时间,是影响版本交付效率的直观因素。
    • 模型文件占用的空间越大,则加载模型后,进程占用的内存空间则越大。这对硬件规格和技术方案、部署方案有直接的影响。
  • 一定载荷下可提供的并发路数。

运营类需求

  • 支持记录具体应用使用语音识别服务的业务调用量。
  • 支持基于调用量,对具体应用进行计费。

运维类需求

  • 提供日志,比如:
    • 提供业务调试日志。
    • 提供接口访问日志。
  • 提供监控能力。
    • 提供对基础设施的监控,比如CPU使用率、内存使用率、硬盘使用率等,以及必要的告警。
    • 提供对业务组件的监控,比如进程是否存在,进程的CPU、内存使用率等,以及必要的告警。
    • 提供对关键业务指标的监控,比如当前各服务实例在用、可用的并发路数,各业务可用、在用的并发路数等。

安全类需求

  • 在云服务API层面增加保护,比如:
    • 提供鉴权能力。
    • 提供参数校验能力。
    • 抵御DOS攻击的能力。
  • 对用户数据的管理,包括但不限于:
    • 使用安全通道传输用户数据。
    • 使用加密方式保存用户数据。
    • 允许用户删除数据。
    • 允许用户指定数据的保存周期。
    • 用户未提供数据保存周期时,系统支持自动删除。

架构方案

基于前述举例列出的需求,整体方案中包括如下组件:

  • 业务类组件
    • 接入网关
    • 安全网关
    • 业务网关
    • 算法服务
  • 支撑类组件
    • 运维服务
    • 运营服务
    • 开发者服务

接入网关

主要职责有:

  • 对外提供安全协议的请求通道,比如HTTPS。
  • 限制业务请求的速率。
  • 基于协议规则的请求流控。

安全网关

主要的职责是对外部发来的请求进行鉴权,拦截非法请求。
当鉴权通过时,补充必要的数据字段,比如应用标识等。

业务网关

主要的职责有:

  • 对请求消息中的字段,进行校验,从而拦截非法请求。
  • 依据请求消息,依据一定的业务规则,选择合适的算法服务来提供服务。
  • 依据一定的业务规则,从指定的算法服务的集群中,挑选一个实例来提供服务。
  • 记录业务调用量。
  • 记录计费数据。
  • 记录必要的运维数据。
  • 记录必要的调试日志。
  • 基于业务规则的请求流控。

算法服务

算法服务,提供语音识别的基本能力。
依据与合作伙伴的协作方式,算法服务包含如下类型:

  • 云云集成,请求转发至合作伙伴开放在公网的API服务。
  • 软件包集成,合作伙伴的软件包和自有的组件部署在相同的基础设施上,算法服务与其通过内网API的方式集成。
  • 算法库集成,使用JNI方式,算法服务集成合作伙伴提供的算法库文件。
  • 算法模型集成,算法服务集成模型,提供服务。

运维管理服务

主要职责是供运维人员管理、分析业务系统运行情况,包含的内容比较广,比如:

  • 软件仓库
  • 部署管理
  • 配置管理
  • 运维数据管理
    • 采集系统
    • 离线监控系统
    • 在线监控系统
    • 告警系统

运营服务

主要职责是供产品、运营人员分析业务运行现状,比如:

  • 运营数据管理
    • 采集系统
    • 报表系统
    • 告警系统

开发者服务

主要职责是供开发者管理业务的运行情况,比如:

  • 订阅服务
  • 计费报表

技术决策点

划分业务组件中各个组件的职责时,存在一些决策点,对设计方案存在影响,因此需要深入考虑。
语音识别过程可以划分为前、中、后三阶段的处理操作,依据前述架构方案,结合业务场景,需要思考这三个阶段在分别哪个业务组件上交付。

关于前处理

对于实时语音识别,假如使用手机作为录音设备,则可以限定录制时使用的音频文件格式、采样频率、位深、声道的数量,去回声和搞噪可以交给录音设备来完成,因此不涉及复杂的前处理。

对于文件转写,则无法限定音频数据文件的录制设备、文件格式、采样频率、位深、声道数量、录制环境等,因此需要支持前处理。相关的前处理特性,可能的实现位置有业务网关或者算法服务。

假如前处理在业务网关组件上实现,则下载文件、提取音频时长、记录计费数据、记录计量数据、基于业务规则的请求流控等可以一并实现。前处理的音频文件,需要将上传至公共存储,由算法服务下载。
本方案的优点:

  • 在业务网关层面可以实现文件有效性的检查,避免将非法文件传递至算法服务,浪费算法服务器的算力。
  • 在业务网关层面实现基于业务规则的请求流控,提前拦截非法请求,避免浪费算法服务的算力。

本方案的缺点:

  • 业务网关和算法服务需要通过存储服务来传递音频文件,算法服务多了一次下载文件的操作。

假如前处理在算法服务上实现,业务网关组件只需转发请求,而下载文件、提取音频时长、记录计费数据、记录计量数据、基于业务规则的请求流控等特性均需要在算法服务来实现。
本方案的优点:

  • 只涉及一次下载文件的操作。

本方案的缺点:

  • 算法服务组件的数量比较多,假如音频文件保存在公网的存储服务上,则均需要开放外网访问权限。
  • 对于文件有效性的检查延迟到了算法服务组件,恶意的请求可能会占用算法服务的算力资源。
  • 基于业务规则的请求流控延迟到了算法服务组件,同样占用了算法服务的算力资源。

关于提取音频文件中音频数据的时长,处理音频文件中多个声道,目前比较简单的方案是使用开源软件FFmpeg来实现。但这款软件存在一些问题,比如:

  • License非商业友好。
  • 处理音频文件时,比较消耗CPU。
  • 为支持某些特定的音频格式时,需要增加一些额外的编码、解码库,编译FFmpeg的过程比较曲折。此外,音频格式涉及到的开源软件,其License可能非商业友好。此外,部分项目的代码比较旧,长期无人维护,遇到问题时会比较尴尬。
  • 偶尔会不稳定,对音频文件执行操作时会失败,但事后使用相同的音频文件重现问题时,发现问题无法复现。

关于后处理

语音识别的结果中没有标点符号,作为书面形式阅读时会增加很多障碍,不同的句读可能会产生不同的理解,从而出现不必要的歧义。对于中文而言,这个现象尤其严重。因此为了提升可读性,需要在语音识别输出的结果进行处理,增加必要的标点符号,比如句号、逗号、探号、问号等。

对于拼音类语言,比如英语、法语等,相同的单词在不同场景下,其大小写形式可能会不同,比如the Presidentthe president,前者指代现总统,而后者仅为泛指。为了提升可读性,需要对语音识别输出的结果进行处理,增加合理的大、小写形式。

对于数字、单位等词汇,语音识别的结果中均表示为文字,与通常使用的书面表达形式不同,阅读体验比较差,因此有必要依据一定的规则或者场景将其还原为常见的表达形式,改善阅读体验。

针对上述三个特性,决策点有:文章来源地址https://www.toymoban.com/news/detail-764560.html

  • 实现方案,使用机器学习模型实现,还是使用代码基于一定的规则来实现。
  • 实现位置,在业务网关实现,还是在算法服务实现。

到了这里,关于ASR项目实战-架构设计的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ASR项目实战-产品分析

    分析Google、讯飞、百度、阿里、QQ、搜狗等大厂的ASR服务,可以罗列出一款ASR服务所需要具备的能力。 ASR云服务产品,从用户体验、时效性、音频时长,可以划分为如下几类: 实时短音频转写,可以用于支撑输入法、搜索、导航等场景。 实时长音频转写,可以用于支撑视频

    2024年02月04日
    浏览(47)
  • ASR项目实战-数据

    使用机器学习方法来训练模型,使用训练得到的模型来预测语音数据,进而得到识别的结果文本,这是实现语音识别产品的一般思路。 本文着重介绍通用语音识别产品对于数据的诉求。 相关要求,如下: 地域,需要覆盖使用人群所在的地域,且数据的比例适中。 口音,需要

    2024年02月04日
    浏览(43)
  • ASR项目实战-决策点

    针对语音识别的产品,分别记录设计、开发过程中的决策点。 对于实时语音识别来说,客户端和服务端之间实时交换语音数据和识别的结果。 客户端在启动识别时,即开始发送语音数据,期望在等待较短的时间后,即收到最初的识别结果。第一段语音数据和第一个识别结果

    2024年02月04日
    浏览(54)
  • ASR项目实战-后处理

    本文深入探讨后处理环节。 在本环节要处理的重要特性有分词、断句、标点符号、大小写、数字等的格式归一等。 和NLP、搜索等场景下的分词含义不同。对于拼音类的语言,比如英语、法语等,句子由多个单词组成,语音输出的结果,需要按需在各个单词之间补充或者去掉

    2024年02月04日
    浏览(39)
  • ASR项目实战-构建Kaldi

    软件清单如下: bzip2 python3 automake libtool cmake gcc g++ gfortran git subversion 不同平台安装软件的方式不同,比如可以使用 yum 或者 apt-get 等。 软件清单如下: Libunwind glog OpenFST OpenBLAS Kaldi 按照一定的规则,将下载后的文件放在指定目录,如下是样例 build.sh 的内容,如下为样例:

    2024年02月04日
    浏览(42)
  • ASR项目实战-前处理

    本文深入探讨前处理环节。 首先介绍一些基本的名词,比如 文件名后缀 文件格式 音频格式 采样率和位深 常见的音频文件,比如 .wav 、 .mp3 、 .m4a 、 .wma 等,这些都代表什么? 仅仅是这类音频文件的后缀而已,不一定和音频文件的编码、音频数据的编码相关。 举例说明:

    2024年02月04日
    浏览(47)
  • ASR项目实战-交付团队的分工

    对于通常的软件项目,参与角色,比如可以有用户,消费者,产品团队,研发团队(研发团队包括开发和测试),运营团队,运维团队,管理团队。 通常认为,用户,负责购买服务的群体,而消费者,负责使用业务的群体。这两个群体,不在本文的讨论范围之内,因此后续的

    2024年02月04日
    浏览(36)
  • ASR项目实战-交付过程中遇到的内核崩溃问题

    当前参与交付的语音识别产品服务,算法模块基于经典的Kaldi,算法中的一部分运行在GPU之上。 算法团队采用的是声学模型+语言模型的1-pass方案。这个方案的特点在于,语言模型数据文件(HCLG文件)的大小,和训练语料的丰富程度正相关,即语言文本的语料越多,经过训练

    2024年02月03日
    浏览(71)
  • ASR项目实战-交付过程中遇到的疑似内存泄漏问题

    基于Kaldi实现语音识别时,需要引入一款名为OpenFST的开源软件,本文中提到的内存问题,即和这款软件相关。 考虑到过程比较曲折,内容相对比较长,因此先说结论。 在做长时间的语音识别时,集成了Kaldi和OpenFST的进程将会占用远超出预期的内存,这个现象可能和OpenFST、

    2024年02月03日
    浏览(64)
  • ASR项目实战-任务队列在文件转写特性中的应用

    转写时长超出60秒的语音文件,业界的竞品通常会使用创建异步转写任务的方式来提供支持。 一个简单、直接的实现方案,即: 网关服务接收到来自客户的转写请求时,将任务信息持久化至任务队列中。 由算法服务的实例从任务队列中提取任务,并执行转写操作。 待执行完

    2024年02月04日
    浏览(63)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包