news 2026/6/6 11:45:02

打开Matlab先给自己整杯咖啡,咱们今天要玩点有意思的语音信号处理。先从硬盘里拽个wav文件进来,我习惯用audioread直接怼

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打开Matlab先给自己整杯咖啡,咱们今天要玩点有意思的语音信号处理。先从硬盘里拽个wav文件进来,我习惯用audioread直接怼

Matlab语音信号去噪程序,使用低通巴特沃斯滤波器。 1、读取一段歌曲的信号,绘制时域频域图,并播放。 2、添加正弦噪声; 3、设计巴特沃斯低通滤波器; 4、使用滤波器去除噪声,并画出时域频域图,播放,与原始信对比,发现去噪效果很好; 5、对信号添加高斯白噪声; 6、去除高斯白噪声,并播放,发现去噪效果还可以,但不如正弦噪声去噪效果好(这是肯定的,因为高斯白噪声是随机噪声,不可能完全去除的)。 注:另自己按公式编写了DFT与IDFT函数,与Matlab自带fft函数运行结果一样。

[raw, fs] = audioread('周杰伦_晴天.wav'); soundsc(raw(1:fs*3,1), fs); % 播放前3秒单声道 t = (0:length(raw)-1)/fs; subplot(211); plot(t, raw); title('原唱时域:杰伦在唱歌');

这时候频谱图必须安排上,但咱不用现成的fft,自己写的DFT函数得拿出来秀。注意看这个三重循环,虽然效率被Matlab自带的fft吊打,但自己写的用着就是爽:

function X = myDFT(x) N = length(x); X = zeros(1,N); for k = 0:N-1 for n = 0:N-1 X(k+1) = X(k+1) + x(n+1)*exp(-1j*2*pi*k*n/N); end end end

频谱画出来长这样:

freq = linspace(0, fs, length(raw)); raw_fft = myDFT(raw(:,1)); subplot(212); plot(freq, abs(raw_fft)); title('杰伦歌声的频谱,高频在抖腿');

接下来搞事情——加个800Hz的正弦噪声。注意这里的相位随机扰动,纯属防止波形太完美:

noise = 0.3*sin(2*pi*800*t' + randn*pi); noisy_sig = raw(:,1) + noise(1:length(raw)); soundsc(noisy_sig, fs); % 能听到持续蜂鸣声

该巴特沃斯出场了!设计个6阶低通,截止频率设500Hz比较稳妥。看这个butter函数的返回值,直接搞出传输函数的分子分母:

order = 6; cutoff = 500/(fs/2); [b,a] = butter(order, cutoff, 'low'); filtered_sig = filtfilt(b, a, noisy_sig);

滤波后频谱明显看到800Hz那个刺头被削了。但别急,先检查群延迟——用filtfilt搞零相位滤波才是正确姿势,不然音乐变鬼畜就翻车了。

Matlab语音信号去噪程序,使用低通巴特沃斯滤波器。 1、读取一段歌曲的信号,绘制时域频域图,并播放。 2、添加正弦噪声; 3、设计巴特沃斯低通滤波器; 4、使用滤波器去除噪声,并画出时域频域图,播放,与原始信对比,发现去噪效果很好; 5、对信号添加高斯白噪声; 6、去除高斯白噪声,并播放,发现去噪效果还可以,但不如正弦噪声去噪效果好(这是肯定的,因为高斯白噪声是随机噪声,不可能完全去除的)。 注:另自己按公式编写了DFT与IDFT函数,与Matlab自带fft函数运行结果一样。

到高斯白噪声环节得换打法,这里直接randn伺候:

gauss_noise = 0.2*randn(size(raw(:,1))); gauss_sig = raw(:,1) + gauss_noise;

这时候低通滤波器有点力不从心了,毕竟白噪声全频段搞事情。不过还是能救回点人声:

gauss_filtered = filtfilt(b,a,gauss_sig); soundsc(gauss_filtered, fs); % 能听但带点闷罐声

最后验证自写IDFT的正确性,拿滤波后的信号反向操作:

recovered = real(myIDFT(myDFT(filtered_sig))); err = max(abs(recovered - filtered_sig)); % 误差小于1e-10稳了

实测发现正弦噪声消除效果堪比降噪耳机,但高斯噪声就像雨天擦玻璃——总有点糊。不过自己从头撸DFT的过程倒是治好了我的代码洁癖,原来矩阵运算还能这么暴力美学。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 12:02:13

零基础掌握screen指令连接开发板的方法

以下是对您提供的博文内容进行 深度润色与重构后的专业级技术文章 。全文已彻底去除AI痕迹,采用真实工程师口吻撰写,结构更自然、逻辑更连贯、语言更具实操感和教学性;同时强化了“为什么这样配置”“踩过哪些坑”“怎么一眼定位问题”的一…

作者头像 李华
网站建设 2026/6/6 8:07:39

3步掌握LizzieYzy:围棋AI分析工具的实战进阶指南

3步掌握LizzieYzy:围棋AI分析工具的实战进阶指南 【免费下载链接】lizzieyzy LizzieYzy - GUI for Game of Go 项目地址: https://gitcode.com/gh_mirrors/li/lizzieyzy LizzieYzy作为一款专业的围棋AI分析工具,集成了Katago、LeelaZero等顶级围棋…

作者头像 李华
网站建设 2026/6/1 19:11:12

ChatGLM-6B实战入门:开源双语大模型保姆级部署与多轮对话配置

ChatGLM-6B实战入门:开源双语大模型保姆级部署与多轮对话配置 你是不是也试过下载大模型时卡在“正在下载权重”半小时不动?或者好不容易跑起来,一问中文就乱码,一调参数就报错?别急,这次我们不讲原理、不…

作者头像 李华
网站建设 2026/5/21 11:12:04

GLM-4v-9b业务场景:客服工单截图问题分类与优先级判断

GLM-4v-9b业务场景:客服工单截图问题分类与优先级判断 1. 这个模型能帮你解决什么实际问题? 你有没有遇到过这样的情况:每天收到上百张客服工单截图,有的是App崩溃报错,有的是支付失败弹窗,有的是用户上传…

作者头像 李华
网站建设 2026/5/23 6:13:29

为什么推荐新手用PyTorch-2.x-Universal-Dev?亲测告诉你

为什么推荐新手用PyTorch-2.x-Universal-Dev?亲测告诉你 1. 新手学深度学习,最怕什么? 不是数学公式推导不够深,也不是算法原理理解不透——而是环境配不起来。 我清楚记得第一次在本地跑通一个PyTorch训练脚本时的场景&#x…

作者头像 李华
网站建设 2026/6/4 22:15:05

Zotero Duplicates Merger:让你的文献库告别重复烦恼

Zotero Duplicates Merger:让你的文献库告别重复烦恼 【免费下载链接】ZoteroDuplicatesMerger A zotero plugin to automatically merge duplicate items 项目地址: https://gitcode.com/gh_mirrors/zo/ZoteroDuplicatesMerger 你是否也曾在整理文献时&…

作者头像 李华