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

语音频谱语音信号处理之(四)梅尔频率倒谱系数(MFCC)

今天一直在查找语音频谱之类的问题,今天正好有机会和大家共享一下.

    语音信号处置之(四)梅尔频率倒谱系数(MFCC)

    zouxy09@qq.com

    http://blog.csdn.net/zouxy09

     

           这学期有《语音信号处置》这门课,快考试了,所以也要了解了解相干的知识点。呵呵,平常没怎么听课,现在只能抱佛脚了。顺便也总结总结,好让自己的知识架构清晰点,也和大家分享下。上面总结的是第四个知识点:MFCC。因为花的时间不多,所以可能会有不少说的不妥的地方,还望大家指正。谢谢。

     

          在任意一个Automatic speech recognition 系统中,第一步就是提取特征。换句话说,我们需要把音频信号中拥有辨识性的成份提掏出来,然后把其他的乱七八糟的信息扔掉,例如背景噪声啊,情感啊等等。

    语音和频谱

          搞清语音是怎么发生的对于我们理解语音有很大帮助。人通过声道发生声音,声道的shape(形状?)决议了收回怎样的声音。声道的shape包括舌头,牙齿等。如果我们可以准确的知道这个形状,那么我们就能够对发生的音素phoneme进行准确的描述。声道的形状在语音短时功率谱的包络中显示出来。而MFCCs就是一种准确描述这个包络的一种特征。

           MFCCs(Mel Frequency Cepstral Coefficents)是一种在主动语音和谈话人识别中广泛使用的特征。它是在1980年由Davis和Mermelstein搞出来的。从那时起。在语音识别领域,MFCCs在人工特征方面可谓是出类拔萃,桂林一枝,从未被超越啊(至于说Deep Learning的特征学习那是后话了)。

           好,到这里,我们提到了一个很重要的关键词:声道的形状,然后知道它很重要,还知道它可以在语音短时功率谱的包络中显示出来。哎,那什么是功率谱?什么是包络?什么是MFCCs?它为什么有效?如何失掉?上面咱们渐渐道来。

     

    一、声谱图(Spectrogram

             我们处置的是语音信号,那么如何去描述它很重要。因为不同的描述方式放映它不同的信息。那怎样的描述方式才利于我们视察,利于我们理解呢?这里我们先来了解一个叫声谱图的东西。

    语音和频谱

           这里,这段语音被分为很多帧,每帧语音都对应于一个频谱(通过短时FFT盘算),频谱表现频率与能量的关系。在现实使用中,频谱图有三种,即线性振幅谱、对数振幅谱、自功率谱(对数振幅谱中各谱线的振幅都作了对数盘算,所以其纵坐标的单位是dB(分贝)。这个变换的目的是使那些振幅较低的成份相对高振幅成份得以拉高,以便视察掩饰在低幅噪声中的周期信号)。

      语音和频谱

           我们先将其中一帧语音的频谱通过坐标表现出来,如上图左。现在我们将左边的频谱旋转90度。失掉中间的图。然后把这些幅度映射到一个灰度级表现(也可以理解为将连续的幅度量化为256个量化值?),0表现黑,255表现白色。幅度值越大,相应的区域越黑。这样就失掉了最右侧的图。那为什么要这样呢?为的是增加时间这个维度,这样就能够显示一段语音而不是一帧语音的频谱,而且可以直观的看到静态和动态的信息。长处稍后呈上。

             这样我们会失掉一个随着时间变化的频谱图,这个就是描述语音信号的spectrogram声谱图。

    语音和频谱

          下图是一段语音的声谱图,很黑的地方就是频谱图中的峰值(共振峰formants)。

    语音和频谱

          那我们为什么要在声谱图中表现语音呢?

          首先,音素(Phones)的属性可以更好的在这里头视察出来。另外,通过视察共振峰和它们的改变可以更好的识别声音。隐马尔科夫模型(Hidden Markov Models)就是隐含地对声谱图进行建模以达到好的识别性能。还有一个作用就是它可以直观的评估TTS系统(text to speech)的好坏,直接比较合成的语音和自然的语音声谱图的匹配度便可。

     

    二、倒谱分析(Cepstrum Analysis

           上面是一个语音的频谱图。峰值就表现语音的主要频率成份,我们把这些峰值称为共振峰(formants),而共振峰就是携带了声音的辨识属性(就是个人身份证一样)。所以它特别重要。用它就能够识别不同的声音。

    语音和频谱

            既然它那么重要,那我们就是需要把它提掏出来!我们要提取的不仅仅是共振峰的位置,还得提取它们改变的进程。所以我们提取的是频谱的包络(Spectral Envelope)。这包络就是一条连接这些共振峰点的平滑曲线。

    语音和频谱

          我们可以这么理解,将原始的频谱由两部分组成:包络和频谱的细节。这里用到的是对数频谱,所以单位是dB。那现在我们需要把这两部分分离开,这样我们就能够失掉包络了。

    语音和频谱

          那怎么把他们分离开呢?也就是,怎么在给定log X[k]的基础上,求得log H[k] log E[k]以满意log X[k] = log H[k] + log E[k]呢?

          为了达到这个目标,我们需要Play a Mathematical Trick。这个Trick是什么呢?就是对频谱做FFT。在频谱上做傅里叶变换就相当于逆傅里叶变换Inverse FFT (IFFT)。需要注意的一点是,我们是在频谱的对数域上面处置的,这也属于Trick的一部分。这时候,在对数频谱上面做IFFT就相当于在一个伪频率(pseudo-frequency)坐标轴上面描述信号。

    语音和频谱

             由上面这个图我们可以看到,包络是主要是低频成份(这时候需要改变思维,这时候的横轴就不要看成是频率了,咱们可以看成时间),我们把它看成是一个每秒4个周期的正弦信号。这样我们在伪坐标轴上面的4Hz的地方给它一个峰值。而频谱的细节部分主要是高频。我们把它看成是一个每秒100个周期的正弦信号。这样我们在伪坐标轴上面的100Hz的地方给它一个峰值。

             把它俩叠加起来就是原来的频谱信号了。

    语音和频谱

          在现实中咱们已知道log X[k],所以我们可以失掉了x[k]。那么由图可以知道,h[k]x[k]的低频部分,那么我们将x[k]通过一个低通滤波器就能够失掉h[k]了!没错,到这里咱们就能够将它们分离开了,失掉了我们想要的h[k],也就是频谱的包络。

    每日一道理
曾经辉煌过,曾经凋零过,这可是你至死不渝的生活吗?我亲爱的母亲—大自然。多少次,我伏在地上,去聆听你沉重的脉搏声;多少次,我伫立在山前,去感受那松涛千年的浩瀚。你的豪壮,足以让中华民族腾飞;你的无私,谱写了一曲曲感人至深的千古壮曲。

           x[k]现实上就是倒谱Cepstrum(这个是一个新造出来的词,把频谱的单词spectrum的后面四个字母次序倒过来就是倒谱的单词了)。而我们所关心的h[k]就是倒谱的低频部分。h[k]描述了频谱的包络,它在语音识别中被广泛用于描述特征。

          那现在总结下倒谱分析,它现实上是这样一个进程:

    1)将原语音信号经过傅里叶变换失掉频谱:X[k]=H[k]E[k]

    只斟酌幅度就是:|X[k] |=|H[k]||E[k] |

    2)我们在双方取对数:log||X[k] ||= log ||H[k] ||+ log ||E[k] ||

    3)再在双方取逆傅里叶变换失掉:x[k]=h[k]+e[k]

           这现实上有个专业的名字叫做同态信号处置。它的目的是将非线性问题转化为线性问题的处置方法。对应上面,原来的语音信号现实上是一个卷性信号(声道相当于一个线性时不变系统,声音的发生可以理解为一个激励通过这个系统),第一步通过卷积将其变成了乘性信号(时域的卷积相当于频域的乘积)。第二步通过取对数将乘性信号转化为加性信号,第三步进行逆变换,使其恢复为卷性信号。这时候,虽然前后均是时域序列,但它们所处的离散时域明显不同,所以后者称为倒谱频域。

          总结下,倒谱(cepstrum)就是一种信号的傅里叶变换经对数运算后再进行傅里叶反变换失掉的谱。它的盘算进程如下:

    语音和频谱

     

    三、Mel频率分析(Mel-Frequency Analysis 

             好了,到这里,我们先看看我们刚才做了什么?给我们一段语音,我们可以失掉了它的频谱包络(连接所有共振峰值点的平滑曲线)了。但是,对于人类听觉感知的试验表明,人类听觉的感知只聚焦在某些特定的区域,而不是全部频谱包络。

             Mel频率分析就是基于人类听觉感知试验的。试验视察发明人耳就像一个滤波器组一样,它只存眷某些特定的频率分量(人的听觉对频率是有选择性的)。也就说,它只让某些频率的信号通过,而压根就直接疏忽它不想感知的某些频率信号。但是这些滤波器在频率坐标轴上却不是同一分布的,在低频区域有很多的滤波器,他们分布比较麋集,但在高频区域,滤波器的数目就变得比较少,分布很稀少。

    语音和频谱

           人的听觉系统是一个特别的非线性系统,它响应不同频率信号的灵敏度是不同的。在语音特征的提取上,人类听觉系统做得非常好,它不仅能提掏出语义信息, 而且能提掏出谈话人的个人特征,这些都是现有的语音识别系统所望尘莫及的。如果在语音识别系统中能模拟人类听觉感知处置特色,就有可能进步语音的识别率。

            梅尔频率倒谱系数(Mel Frequency Cepstrum Coefficient, MFCC)斟酌到了人类的听觉特征,先将线性频谱映射到基于听觉感知的Mel非线性频谱中,然后转换到倒谱上。

            将一般频率转化到Mel频率的公式是:
 语音和频谱
      由下图可以看到,它可以将不同一的频率转化为同一的频率,也就是同一的滤波器组。

    语音和频谱

          在Mel频域内,人对音调的感知度为线性关系。举例来说,如果两段语音的Mel频率相差两倍,则人耳听起来两者的音调也相差两倍。

 

    四、Mel频率倒谱系数(Mel-Frequency Cepstral Coefficients 

           我们将频谱通过一组Mel滤波器就失掉Mel频谱。公式表述就是:log X[k] = log (Mel-Spectrum)。这时候我们在log X[k]上进行倒谱分析:

    1)取对数:log X[k] = log H[k] + log E[k]

    2)进行逆变换:x[k] = h[k] + e[k]

          在Mel频谱上面取得的倒谱系数h[k]就称为Mel频率倒谱系数,简称MFCC

    语音和频谱

             现在咱们来总结下提取MFCC特征的进程:(具体的数学进程网上太多了,这里就不想贴了)

    1)先对语音进行预减轻、分帧和加窗;

    2)对每个短时分析窗,通过FFT失掉对应的频谱;

    3)将上面的频谱通过Mel滤波器组失掉Mel频谱;

    4)在Mel频谱上面进行倒谱分析(取对数,做逆变换,现实逆变换一般是通过DCT离散余弦变换来实现,取DCT后的第2个到第13个系数作为MFCC系数),取得Mel频率倒谱系数MFCC,这个MFCC就是这帧语音的特征;

    语音和频谱

           这时候,语音就能够通过一系列的倒谱向量来描述了,每个向量就是每帧的MFCC特征向量。

    语音和频谱

         这样就能够通过这些倒谱向量对语音分类器进行训练和识别了。

     

    五、参考文献

    [1]这里头还有一个比较好的教程:

    http://practicalcryptography.com/miscellaneous/machine-learning/guide-mel-frequency-cepstral-coefficients-mfccs/

    [2]本文主要参考:cmu的教程:

     http://www.speech.cs.cmu.edu/15-492/slides/03_mfcc.pdf

    [3] C library for computing Mel Frequency Cepstral Coefficients (MFCC)

    http://code.google.com/p/libmfcc/

文章结束给大家分享下程序员的一些笑话语录: 自行车
一个程序员骑着一个很漂亮的自行车到了公司,另一个程序员看到了他,问 到,“你是从哪搞到的这么漂亮的车的?”
骑车的那个程序员说, “我刚从那边过来, 有一个漂亮的姑娘骑着这个车过来, 并停在我跟前,把衣服全脱了,然后对我说,‘你想要什么都可以’”。
另一个程序员马上说到, “你绝对做了一个正确的选择, 因为那姑娘的衣服你 并不一定穿得了”。

--------------------------------- 原创文章 By
语音和频谱
---------------------------------

转载于:https://www.cnblogs.com/jiangu66/p/3153514.html

相关文章:

  • apache+php+mysql的分布安装
  • Lvs+keepalived+nginx+php的session 保持的算法
  • [免費軟體] 用15個「免費正版軟體」取代盜版軟體! (狂省10萬元!)
  • 【算法】算法的艺术(二)
  • 泛型回顾
  • 离线缓存
  • 字符串的提取
  • MySql数据库恢复(*frm)文件
  • Flex Fonts
  • Java菜鸟学习笔记(4)--常见编译运行错误汇集(不断更新)
  • XHTML--1
  • 如何快速去掉.svn文件夹?
  • js英雄对战小游戏 看看你的人品
  • mongodb在PHP下的应用学习笔记
  • 最长公共子序列问题(不连续)
  • 「译」Node.js Streams 基础
  • Angular数据绑定机制
  • Brief introduction of how to 'Call, Apply and Bind'
  • C++入门教程(10):for 语句
  • JavaScript 基础知识 - 入门篇(一)
  • Java超时控制的实现
  • Js基础知识(四) - js运行原理与机制
  • Netty源码解析1-Buffer
  • Selenium实战教程系列(二)---元素定位
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • yii2中session跨域名的问题
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 动态魔术使用DBMS_SQL
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 如何设计一个比特币钱包服务
  • 如何在GitHub上创建个人博客
  • 王永庆:技术创新改变教育未来
  • 学习笔记TF060:图像语音结合,看图说话
  • 再谈express与koa的对比
  • C# - 为值类型重定义相等性
  • JavaScript 新语法详解:Class 的私有属性与私有方法 ...
  • LIGO、Virgo第三轮探测告捷,同时探测到一对黑洞合并产生的引力波事件 ...
  • PostgreSQL 快速给指定表每个字段创建索引 - 1
  • #前后端分离# 头条发布系统
  • $.ajax()方法详解
  • $.extend({},旧的,新的);合并对象,后面的覆盖前面的
  • (Repost) Getting Genode with TrustZone on the i.MX
  • (八)Flask之app.route装饰器函数的参数
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (四)库存超卖案例实战——优化redis分布式锁
  • (学习日记)2024.02.29:UCOSIII第二节
  • (已解决)vue+element-ui实现个人中心,仿照原神
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • **python多态
  • .NET Compact Framework 多线程环境下的UI异步刷新
  • .NetCore项目nginx发布
  • .NET高级面试指南专题十一【 设计模式介绍,为什么要用设计模式】
  • .NET设计模式(8):适配器模式(Adapter Pattern)
  • .net通用权限框架B/S (三)--MODEL层(2)
  • @entity 不限字节长度的类型_一文读懂Redis常见对象类型的底层数据结构