matlab wav格式音频去除人声

matlab wav格式音频去除人声(原理自查)

先设立Hbs带阻函数(matlab2018a为例)

这里写图片描述
这里写图片描述
这里写图片描述
选择右上view可以查看函数效果如下
这里写图片描述
应用函数
这里写图片描述
这里写图片描述

代码块

代码块语法遵循标准markdown代码,例如:

function xinhaochuli(Hbs)
%clear; %Hbs需要调用不能使用clear
close all; 
clc;
[x,fs]=audioread('林俊杰 - 可惜没如果.wav'); % 将 WAV 文件转换成变量,最好用wav格式mp3格式影响较大
sound(x,fs);
pause
x1=x(:,1); % 抽取第 1 声道
x2=x(:,2); % 抽取第 2 声道

n=length(x1);
X1=fft(x1,n);     %快速傅里叶变换
figure(1)
subplot(4,1,1);
plot(x1);  
xlabel('时间');
ylabel('幅度');
title('初始信号左波形');   %绘出时域波
grid on;
subplot(4,1,2);                         %绘出频域频谱
plot(abs(fftshift(X1)));
title('初始信号左频谱');
xlabel('频率');
ylabel('幅度');
grid on;
n=length(x2);   %画出加噪之后,其时域频域
X2=fft(x2,n);
subplot(4,1,3)
plot(x2);
title('初始信号右波形')
xlabel('时间');
ylabel('幅度');
grid on;
subplot(4,1,4)
plot(abs(fftshift(X2)));
xlabel('频率');
ylabel('幅度');
title('初始信号右频谱');
grid;
pause;

NewLeft=x1-x2;
NewRight=x1-x2;

n=length(NewLeft);
NEWLEFT=fft(NewLeft,n);     %快速傅里叶变换
figure(2)
subplot(4,1,1);
plot(NewLeft);  
xlabel('时间');
ylabel('幅度');
title('声道相减后信号左波形');   %绘出时域波
grid on;
subplot(4,1,2);                         %绘出频域频谱
plot(abs(fftshift(NEWLEFT)));
title('声道相减后信号左频谱');
xlabel('频率');
ylabel('幅度');
grid on;
n=length(NewLeft);   %声道相减之后,其时域频域
NEWRIGHT=fft(NewRight,n);
subplot(4,1,3)
plot(NewRight);
title('声道相减后信号右波形')
xlabel('时间');
ylabel('幅度');
grid on;
subplot(4,1,4)
plot(abs(fftshift(NEWRIGHT)));
xlabel('频率');
ylabel('幅度');
title('声道相减后信号右频谱');
grid on;
pause;

New=NewLeft+NewRight; % 两路单声道列向量矩阵变量合并
%New(:,1)=NewLeft;
%New(:,2)=NewRight;
n=length(New);   
NEW=fft(New,n);
figure(3);
subplot(2,1,1)
plot(New);
title('两路单声道列向量矩阵变量合并信号波形')
xlabel('时间');
ylabel('幅度');
grid on;
subplot(2,1,2)
plot(abs(fftshift(NEW)));
xlabel('频率');
ylabel('幅度');
title('两路单声道列向量矩阵变量合并信号频谱');
grid on;
sound(New,fs)
pause

BandstopNew=filter(Hbs,New);%Hbs滤波函数 y为滤波输入
n=length(BandstopNew);   %滤去人声一般80hz到700hz之后,其时域频域(在Hbs中可以自己改)
BANDSTOPNEW=fft(BandstopNew,n);
figure(4);
subplot(2,1,1)
plot(BandstopNew);
title('滤去人声一般80hz到700hz之后信号波形')
xlabel('时间');
ylabel('幅度');
grid on;
subplot(2,1,2)
plot(abs(fftshift(BANDSTOPNEW)));
xlabel('频率');
ylabel('幅度');
title('声道相减后信号频谱');
grid on;
sound(BandstopNew,fs)

end

效果

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

参考资料

https://blog.csdn.net/miao0967020148/article/details/54906628
https://blog.csdn.net/qq_17287777/article/details/79292278
https://blog.csdn.net/zouyu409709312/article/details/51330909

DONE

  • 14
    点赞
  • 133
    收藏
    觉得还不错? 一键收藏
  • 24
    评论
如果您下载了本程序,但是该程序存在问题无法运行,那么您可以选择退款或者寻求我们的帮助(如果找我们帮助的话,是需要追加额外费用的)。另外,您不会使用资源的话(这种情况不支持退款),也可以找我们帮助(需要追加额外费用) MATLAB(Matrix Laboratory)是一款由美国MathWorks公司开发的高性能商业数学软件,它集成了高级技术计算语言、交互式环境以及丰富的工具箱,被广泛应用于工程计算、数据分析、算法开发和科学可视化等领域。MATLAB的核心功能包括: 1. **数值计算**:支持大规模矩阵和数组运算,对线性代数、微积分、概率统计等数学问题提供高效解决方案。 2. **编程环境**:提供了易于使用的脚本编写与函数定义界面,支持面向对象编程,并可通过M文件实现模块化程序设计。 3. **数据可视化**:内置强大的二维和三维图形绘制功能,能够创建高质量的数据图表,便于数据分析和结果展示。 4. **工具箱扩展**:MathWorks为MATLAB提供了众多领域的专业工具箱,如信号处理、图像处理、通信系统、控制系统、机器学习、深度学习、量化金融、优化算法等,极大地扩展了MATLAB的应用范围。 5. **Simulink仿真**:作为MATLAB的重要组成部分,Simulink是一个动态系统建模、仿真和基于模型的设计环境,特别适用于多域物理系统和嵌入式系统的模拟和实时测试。 6. **集成能力**:MATLAB可以与其他编程语言(如C、C++、Java、Python等)及外部应用程序进行数据交换和联合开发,也可以调用硬件接口进行实时实验和控制。 7. **交互式工作空间**:用户可以在命令窗口中直接输入表达式并立即得到结果,这种交互式的特性使得快速原型设计和调试变得极为便利。 总之,MATLAB是科学家、工程师和技术人员进行科研、教育和工业应用不可或缺的强大工具之一,尤其在需要大量数值计算和复杂系统建模的场景下发挥着重要作用。
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值