草庐IT

使用matlab进行回声处理(三重回声)-数字信号处理课设

渴望学习 2023-04-22 原文

 一、系统设计要求

1.录制一段声音信号,作为原音频信号,生成频域与时域图形,观察与分析其时域 与频域图形。

2.对该音频信号进行时域处理,并且实现对该声音信号添加第一层回声。

3.对该音频信号再继续一次进行时域处理,实现对该声音信号添加第二层回声。

4.将三段音频信号进行合成,比较该声音信号与原音频信号时域和频域的差别, 保存合成的音频。

5.对该声音信号进行时域或者频域处理,消除该添加回声的语音信号的回声。

6.比较原始声音信号与去除回声后的声音信号的频域和时域差别,并通过人耳辨 别原音频,加入回声的音频和去除回声的音频三段音频的区别。

二、系统设计方案

第一步:用 getaudiodata()函数录制一段音频生成并观察其时域和频域图形,再对其 时域频域进行处理。

第二步:添加回声。通过补零矩阵增加回声,且分别将原音频分别进行衰减系数为 0.6 倍和 0.4 倍的缩放,而后将三段音频结合在一起,使得得到音频有一层原声,两层 回声,且从原声到回声一层比一层音量小,得到处理后的声音信号就是有回声的声音 信号,绘制并观察有回声的声音信号的频域时域图形。

第三步:通过 z 域分析得到转换公式,对修改后声音信号时域进行处理。将添加的 回声消除,得到消除回声音频,再次绘制并观察新的声音信号的时域频域图形。

第四步:将三个时域频域图形进行对比,并把三段音频分别播放,用人耳进行区分 其差距

 三、代码实现

1.录制音频代码:

%%%录制音频
clear all
clc
fs=44100;
music=audiorecorder(fs,16,1);
disp('请输入空格并回车开始采集原始信号')
in=input('');
%创建一个保存音频信息的对象,它包含采样率,时间和录制的音频信息等等。
%44100表示采样为44100Hz
%16为用16bits存储,2为两通道即立体声(也可以改为1即单声道)。
recordblocking(music,7);
%开始录制,此时对着麦克风说话即可,录制时间为7秒。
myspeech=getaudiodata(music,'int16');
%得到数字矩阵存储的刚录制的音频信号。
plot(myspeech);
%% save file
filename='myspeech.wav';
audiowrite(filename,myspeech,fs);

2.对录制音频进行采集处理:

%%%%对音频采集处理
clear
[x,fs] = audioread('myspeech.wav');%音乐信号
%输出频率
fs
%音乐语音信号分声道处理
x1=x(:,1);

3.画出录制音频信号时域频域波形图

%画音乐信号时域图
n1=length(x1);%length取音乐数列长度即元素个数
figure(1);
subplot(2,1,1);
t1=(0:(n1-1))/fs;
plot(t1,x1);
axis([0,5,-1,1]);%%设置坐标轴范围
xlabel('时间t');
ylabel('幅度');
title('原音频音乐信号时域波形');
X1=fft(x1,n1);
subplot(2,1,2);
f3=0:fs/n1:fs*(n1-1)/n1;
plot(f3,abs(X1));
axis([0,44100,0,6000]);
xlabel('频率f');
ylabel('幅度');
title('原音频音乐信号频谱波形');

 

4.增加回音(这里我加了两重回音)

% %音乐信号的回音
x11=x1;%截取部分
x11=x11';%因为输出为一列所以要转置成一行
geshu=length(x11);
N2 = 20000;
int0=zeros(1,N2);%1行20000列的零矩阵
temp1=[x11,int0,int0];%原始声音
temp2=[int0,0.6*x11,int0];%第一层的回声是原始0.6倍
temp3=[int0,int0,0.4*x11];%第二层的回声是原始0.4倍
hui=temp1+temp2+temp3;%三重声音相加实现回声
N=length(hui);  %回音序列的长度
% sound(hui,fs);%播放回音音乐

5.画出回声波形,并保存回声为音频文件

%%%画回声波形
figure(2);
subplot(2,1,1);
t1=(0:(N-1))/fs;
plot(t1,hui);
axis([0,4.5,-1,1]);
xlabel('时间');
ylabel('幅度');
title('音频回声信号时域波形');
X2=fft(hui,N);
subplot(2,1,2);
f3=0:fs/N:fs*(N-1)/N;
plot(f3,abs(X2));
axis([0,44100,0,6000]);
xlabel('频率f');
ylabel('幅度');
title('音频回声信号频谱波形');
audiowrite('音频回声.wav',hui,fs);%保存回声整体为声音文件

 

6.消除回声

%%消除回声
% N = 20000;
chang=N2+geshu;
L = length(hui);
y = zeros(1, L);%与回声长度相同的零序列
for  k = 1:L
    if  k>N2 && k<=chang              %%%消除第一层回声
        y(k) = hui(k) - 0.6*x11(k-N2);
   else
        y(k) = hui(k);
    end
    if k>2*N2                      %%%消除第二层回声
        y(k)=y(k)-0.4*x11(k-2*N2);
    end
end
N3 = length(y);
audiowrite('消除回声.wav',y,fs);%%保存为消除回声音频文件

四、展望

       本项目在日后的学习中,应对其进行用户体验感以及完善其功能的更新,设计 GUI 界面使得整个系统操作更加便捷,采用多线程的方式进行编程,增加整个系统能够完 成的功能,后续将更新出既能导入本身存在的音频,又可以重新录制音频进行增加回 声,消除回声以及绘制相关音频信号的时域频域波形图的功能,同时可以设定相关的 回声信号衰减系数,自定义的完成回声信号的添加使用,并将这些功能在 GUI 界面上 体现出来,使得用户体验感更好,操作更加便捷,将项目发挥的更好。

有关使用matlab进行回声处理(三重回声)-数字信号处理课设的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - 在 Ruby 中使用匿名模块 - 2

    假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

  6. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  7. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  8. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  9. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  10. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

随机推荐