学习语音识别有些时间了。老板要求我们基于Kaldi搭一个语音识别系统,在设备上通过MIC讲话,连着设备的PC的console上就能基本实时显示出讲话的内容。由于我们都是小白,刚开始可以要求低些,就用传统的GMM-HMM,能实现孤立词识别就算达标了,后面随着这方面能力的提高,再做更难一点的。任务下达后我根据之前对kaldi的简单理解把模块分成了三部分:数据准备和MFCC、GMM-HMM、解码网络创建和解码,由三个人每人负责一部分学习,掌握基本原理,搞清楚有哪些事情要做。在其他两个同学先挑了模块后就由我来负责解码网络构建和解码部分了。

我们三个学习了kaldi两三个星期后感觉下来kaldi不是很容易上手,主要原因有四。一是我们都是新手,语音识别领域的一些概念和套路还没完全搞清楚。二是kaldi的文档偏少,不利于代码的理解。三是kaldi是算法和工具的集合,语音识别的整个流程是靠很多复杂的shell和Perl脚本把这些工具串起来实现的,不易读。四是kaldi是用C++实现的,而我们先前主要是用C开发软件(芯片公司的软件工程师多数都是在底层用C开发软件)。我们克服了这些困难,理出了每个模块有哪些事情要做,也搞清楚了软件实现分训练和识别两大部分,有些模块在训练和识别中都有,比如MFCC,而有些模块只在训练中有。训练是给识别做准备的,训练得到声学模型、字典和语言模型,并基于WFST将这三个合并成一个大的解码网络用于识别中。真正运行起来的语音识别系统只有识别部分的软件在运行。

具体到我负责的解码,主要有两大部分组成,一是生成解码网络,二是基于解码网络解码。这里面的重中之重就是WFST(加权的有限状态转换器)。WFST属于半环代数理论。我是学控制出身,读本科时学了高数、矩阵、概率论等,读研究生时对矩阵进行了更深入的学习(控制学科对矩阵的要求较高),其他数学分支都没学过,半环代数理论显然是新东西。由于相关基础没有,学习起来不是很轻松,网上也说这学科对学数学和计算机理论的人学起来轻松些。现阶段我们只是搭语音识别系统,不需要深入研究算法,再加上时间也不允许(老板给我们定下了dealline),就仅仅了解了WFST的基本原理,后面就通过具体的例子来熟悉脚本和代码流程。Kaldi里有两种类型的解码器:offline 和 online。yesno就是最简单的offline解码器的例子,通过运行这个例子基本搞清楚了相关脚本和函数的意思。因为我们要搭的是在线实时系统,offline的参考性不大,也就没太关注,转而去看kaldi里的online decoder了。kaldi里的online decoder有两个版本:online(老版本) 和online2(新版本)。官网推荐用online2(基于例子RM(resource management)),并且声称要逐渐把老版本online废弃掉。但是现在RM的语料库无法从网络上下载到,所以例子RM就无法运行,只能去用老版本的online了。还好好多使用者说还是老版本的online好用,总算给我吃了一颗定心丸。看了相关的博客,都是基于kaldi里的唯一的中文识别的例子thchs30来做在线解码的。根据博客的指导,先下语料库,做各种训练得到解码网络等。再下载portaudio,使能从PC的MIC上采集到语音数据。最后改写脚本运行,这样一个在线解码的例子就跑起来了,PC的console上实时显示出了说的文字。在代码里加些log跟踪一下,也就搞清楚了在线解码时软件实现的机制和各种调用过程。

就这样解码相关的除了算法外其他的基本都搞清楚了。按照惯例,要做PPT给组内同学讲,让大家共同提高。我就根据自己的理解做了语音识别解码器相关的内容(一些图片还是借用了各种文档和博客里的,再此表示感谢,就不一一列出了)。下面就是我做的PPT的内容,给有需要的朋友看看。如果有错误,烦请指出,非常感谢!

基于WFST的语音识别解码器的更多相关文章

  1. 基于android的语音识别

    1.注册账户,添加应用 2.针对android平台的选择应用,下载SDK 3.将SDK的libs下文件拷贝到工程的libs目录下 4.添加用户权限 <uses-permission androi ...

  2. 三个小白是如何在三个月内搭一个基于kaldi的嵌入式在线语音识别系统的

    前面的博客里说过最近几个月我从传统语音(语音通信)切到了智能语音(语音识别).刚开始是学语音识别领域的基础知识,学了后把自己学到的写了PPT给组内同学做了presentation(语音识别传统方法(G ...

  3. 最简单的基于FFmpeg的移动端例子:IOS 视频解码器-保存

    ===================================================== 最简单的基于FFmpeg的移动端例子系列文章列表: 最简单的基于FFmpeg的移动端例子:A ...

  4. 最简单的基于FFmpeg的解码器-纯净版(不包含libavformat)

    ===================================================== 最简单的基于FFmpeg的视频播放器系列文章列表: 100行代码实现最简单的基于FFMPEG ...

  5. 最简单的基于FFmpeg的移动端样例:Android 视频解码器-单个库版

    ===================================================== 最简单的基于FFmpeg的移动端样例系列文章列表: 最简单的基于FFmpeg的移动端样例:A ...

  6. 最简单的基于FFmpeg的移动端样例:IOS 视频解码器

    ===================================================== 最简单的基于FFmpeg的移动端样例系列文章列表: 最简单的基于FFmpeg的移动端样例:A ...

  7. 最简单的基于FFMPEG+SDL的视频播放器:拆分-解码器和播放器

    ===================================================== 最简单的基于FFmpeg的视频播放器系列文章列表: 100行代码实现最简单的基于FFMPEG ...

  8. 最简单的基于FFmpeg的直播系统开发移动端例子:IOS 视频解码器

    本文记录IOS平台下基于FFmpeg的视频解码器.该示例C语言的源代码来自于<最简单的基于FFMPEG+SDL的视频播放器>.相关的概念就不再重复记录了. 源代码 项目的目录结构如图所示. ...

  9. Atitit 语音识别的技术原理

    Atitit 语音识别的技术原理 1.1. 语音识别技术,也被称为自动语音识别Automatic Speech Recognition,(ASR),2 1.2. 模型目前,主流的大词汇量语音识别系统多 ...

随机推荐

  1. hdu 6397 Character Encoding (生成函数)

    Problem Description In computer science, a character is a letter, a digit, a punctuation mark or som ...

  2. TensorFlow学习笔记——深层神经网络的整理

    维基百科对深度学习的精确定义为“一类通过多层非线性变换对高复杂性数据建模算法的合集”.因为深层神经网络是实现“多层非线性变换”最常用的一种方法,所以在实际中可以认为深度学习就是深度神经网络的代名词.从 ...

  3. 如何让传统ASP.NET网站在Docker中运行

    本文主要描述如何让传统ASP.NET网站在Docker中运行,侧重Docker image 搭建. 使用条件: Docker for windows 用户切换到Windows 容器模式 Windows ...

  4. SpringBoot 使用JPA时解决no session的方法

    1.在application.yml中添加 spring.jpa.open-in-view: true 2.在使用查询的方法添加 @Transactional

  5. 前后端分离后台api接口框架探索

    前言 很久没写文章了,今天有时间,把自己一直以来想说的,写出来,算是一种总结吧!  这篇文章主要说前后端分离模式下(也包括app开发),自己对后台框架和与前端交互的一些理解和看法.     前后端分离 ...

  6. 低版本IE兼容 H5+CSS3 方案

    [主要是针对ie6 7 8对支持和让老浏览器支持html5+css3的一些js脚本] html5shiv.js  // 让IE8及耕地版本的IE识别section,article,nav等html5元 ...

  7. JAVA-SpringMVC 概述及组件介绍

    一.SpringMVC概述 SpringMVC是一个WEB层.控制层框架,主要用来负责与客户端交互,业务逻辑的调用. SpringMVC是Spring家族中的一大组件,Spring整合SpringMV ...

  8. JS鼠标吸粉特效

    HTML <canvas id=canvas></canvas> CSS * { margin: 0; padding: 0; } html { overflow: hidde ...

  9. 入门MySQL——DML语句篇

    前言:  在上篇文章中,主要为大家介绍的是DDL语句的用法,可能细心的同学已经发现了.本篇文章将主要聚焦于DML语句,为大家讲解表数据相关操作. 这里说明下DDL与DML语句的分类,可能有的同学还不太 ...

  10. Kendo-Grid for Vue API and Template

    写此博客的原因:在做项目时前端用的vue,后端用的jfinal.在前端veu中调用了kendo grid插件,但是在官方文档中对kendo grid for vue 的api和template都不太详 ...