这篇文章主要介绍“matlab怎么实现辨别男女声”,在日常操作中,相信很多人在matlab怎么实现辨别男女声问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”matlab怎么实现辨别男女声”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
function man_or_woman(file) [x,fs]=audioread(file); % 读入声音文件 %======时域图像====== 随着时间声音赋值震荡图 data=x(:,1); %取单声道 n=0:length(x)-1; %建立一个信号等长的序列 time=n/fs; %建立时间序列,作为横坐标 figure(1); %图1:时域波形图 plot(time,data); %作图 title('音频信号时域图') %标题 xlabel('时间/s'); %标注横坐标 ylabel('幅值'); %标注纵坐标 grid on; %打开网格线 %=======频域图====== N=length(data); %取信号矩阵的长度 Y1=fft(data,N); %N点傅里叶变换 mag=abs(Y1); %取模 f=n*fs/N; %频率序列 figure(2); %图2:频谱图 plot(f(1:fix(N/2)),mag(1:fix(N/2))); title('音频信号fft频谱图');%标题 xlabel('频率/Hz'); %标注横坐标 ylabel('幅度'); %标注纵坐标 grid on; %打开网格线 %======基音频率提取====== [~,index]=max(data); % 返回最大值 最大值索引 timewin=floor(0.015*fs); xwin=data(index-timewin:index+timewin); [y,~]=xcov(xwin); ylen=length(y); halflen=(ylen+1)/2 +30; yy=y(halflen: ylen); [~,maxindex] = max(yy); fmax=fs/(maxindex+30); disp([file,'基音频率为 ', num2str(fmax), ' Hz']) %======通过基音频率判断男女声====== if fmax<200; disp([file,' 是男声文件']); else disp([file,' 是女声文件']); end;
到此,关于“matlab怎么实现辨别男女声”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。