概述
MATLAB计算信号短时平均过零率
MATLAB计算信号短时平均过零率
一、原理:
短时平均过零率表示一帧语音中语音信号波形穿过横轴的次数
二、计算过零率代码
clear all; clc; close all;
filedir=[]; % 设置路径
filename='bluesky3.wav'; % 设置文件名
fle=[filedir filename]; % 构成完整的路径和文件名
[xx,Fs]=audioread(fle); % 读入数据文件
x=detrend(xx); % 消除直流分量
wlen=200; inc=80; % 设置帧长、帧移
win=hanning(wlen); % 窗函数
N=length(x); % 求数据长度
X=enframe(x,win,inc)'; % 分帧
fn=size(X,2); % 获取帧数
zcr1=zeros(1,fn); % 初始化
for i=1:fn
z=X(:,i); % 取得一帧数据
for j=1: (wlen-1); % 在一帧内寻找过零点
if z(j)* z(j+1)< 0 % 判断是否为过零点
zcr1(i)=zcr1(i)+1; % 是过零点,记录1次
end
end
end
time=(0:N-1)/Fs; % 计算时间坐标
frameTime=frame2time(fn,wlen,inc,Fs); % 求出每帧对应的时间
%
最后
以上就是英俊铃铛为你收集整理的音频信号 过零率 matlab,MATLAB计算信号短时平均过零率的全部内容,希望文章能够帮你解决音频信号 过零率 matlab,MATLAB计算信号短时平均过零率所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复