schroeder reverb matlab实现
原理参考:Natural sounding artificial reverberation

combFilter.m:
function output = combFilter(delay, gain, input)
fs = 48000;
delaySample = int32(delayTime * fs / 1000);
B = [1 zeros(1, delaySample - 1)];
A=[1 zeros(1, delaySample - 2) -gain];
output = filter(B, A, input);
end
calcCombGain.m:
function gain = calcCombGain(reverbTime, delayTime)
gain = power(10, -3 * delayTime / reverbTime)
end
allPassFilter.m:
function output = allPassFilter(delay, gain, input)
fs = 48000;
delaySample = int32(delayTime * fs / 1000);
B = [-gain zeros(1, delaySample - 2) 1];
A=[1 zeros(1, delaySample - 2) -gain];
output = filter(B, A, input);
end
reverb.m:
function output = reverb(combDelayTime, combGain, allPassDelayTime, allPassGain, input)
y = zeros(length(input), 4);
combOut = zeros(length(input), 1);
for i = 1:1:4
y(:, i) = combFilter(combDelayTime(i), combGain(i), input);
combOut = combOut + y(:, i);
end
allPassOut1 = allPassFilter(allPassDelayTime(1), allPassGain(1), combOut);
output = allPassFilter(allPassDelayTime(2), allPassGain(2), allPassOut1);
output = output * 0.25 + input;
end
main.m:
clc
clear
T60 = 2000;
combDelayTime = [29.23 37.67 41.49 44.31];
combGain = calcCombGain(T60, combDelayTime);
allPassDelayTime = [5 1.7];
allPassGain = [0.7 0.7];
%input = [1, zeros(48000-1, 1)];
[input fs] = wavread('test.wav');
y = reverb(combDelayTime, combGain, allPassDelayTime, allPassGain, input);
wavwrite(y, fs, 'reverb.wav');
figure(1)
plot(y)
schroeder reverb matlab实现的更多相关文章
- 转载:reverb
https://blog.csdn.net/qiumingjian/article/details/43938687 https://blog.csdn.net/jsjwangmingmin/arti ...
- Matlab 绘制三维立体图(以地质异常体为例)
前言:在地球物理勘探,流体空间分布等多种场景中,定位空间点P(x,y,x)的物理属性值Q,并绘制三维空间分布图,对我们洞察空间场景有十分重要的意义. 1. 三维立体图的基本要件: 全空间网格化 网格节 ...
- Matlab slice方法和包络法绘制三维立体图
前言:在地球物理勘探,流体空间分布等多种场景中,定位空间点P(x,y,x)的物理属性值Q,并绘制三维空间分布图,对我们洞察空间场景有十分重要的意义. 1. 三维立体图的基本要件: 全空间网格化 网格节 ...
- Matlab 高斯_拉普拉斯滤波器处理医学图像
前言:本程序是我去年实现论文算法时所做.主要功能为标记切割肝脏区域.时间有点久,很多细节已经模糊加上代码做了很多注释,因此在博客中不再详述. NOTE: 程序分几大段功能模块,仔细阅读,对解决医学图像 ...
- MATLAB中绘制质点轨迹动图并保存成GIF
工作需要在MATLAB中绘制质点轨迹并保存成GIF以便展示. 绘制质点轨迹动图可用comet和comet3命令,使用例子如下: t = 0:.01:2*pi;x = cos(2*t).*(cos(t) ...
- linux下配置matlab运行环境(MCR)
在安装好的matlab下有MCR(MatlabCompilerRuntime)在matlab2011/toolbox/compiler/deploy/glnxa64下找到MCRInstaller.zi ...
- EMD分析 Matlab 精华总结 附开源工具箱(全)
前言: 本贴写于2016年12与15日,UK.最近在学习EMD(Empirical Mode Decomposition)和HHT(Hilbert-Huang Transform)多分辨信号处理,FQ ...
- Atitit MATLAB 图像处理 经典书籍attilax总结
Atitit MATLAB 图像处理 经典书籍attilax总结 1.1. MATLAB数字图像处理1 1.2. <MATLAB实用教程(第二版)>((美)穆尔 著)[简介_书评_在线阅读 ...
- Atitit MATLAB 图像处理attilax总结
Atitit MATLAB 图像处理attilax总结 1.1. 下载 Matlab7.0官方下载_Matlab2012 v7.0 官方简体中文版-办公软件-系统大全.html1 1.2. Matla ...
随机推荐
- 关于Java8中的Comparator那些事
在前面一篇博文中,对于java中的排序方法进行比较和具体剖析,主要是针对 Comparator接口和 Comparable接口,无论是哪种方式,都需要实现这个接口,并且重写里面的 方法.Java8中对 ...
- install multiple versions of CUDA
https://www.pugetsystems.com/labs/hpc/How-To-Install-CUDA-10-together-with-9-2-on-Ubuntu-18-04-with- ...
- bootstrap-table中时间戳转换为日期格式。
{ field: 'createdTime', title: '创建时间', formatter: function (value, row, index) { return changeDateFo ...
- H5-安卓和ios调用相机和相册
<input v-if="ipshow" type="file" accept="image/*" name="file1& ...
- Git常用命令简记
创建仓库 添加需要版本控制的文件到仓库中 提交到版本库 修改位于顶端的commit的日志 分支管理 版本回退 切换与合并分支 本地版本库与远程关联 克隆 Tag的使用 问题与解决 创建git仓库 gi ...
- 第十周 11.28 psp0
课堂测试总结 学生:马小心 日期:2017.11.28 作业号 日期 过程 估计数据 实际数据 累计数据 时间 ...
- 机器学习作业(二)逻辑回归——Matlab实现
题目太长啦!文档下载[传送门] 第1题 简述:实现逻辑回归. 第1步:加载数据文件: data = load('ex2data1.txt'); X = data(:, [1, 2]); y = dat ...
- centos7重启Mysql命令
执行命令/etc/init.d/mysql restart重启Mysql服务器
- Winform form窗体已弹出框的形式出现并回传值
From2(弹出框)回传数据到From1 Form1(数据接收form): public string Sstr; private void button1_Click(object sender, ...
- Tomcat的使⽤
准备 1.官⽹地址:http://tomcat.apache.org下载. 2.解压文件,并放到指定路径,给该文件授权. chmod -R 755 3.启动和停止 进入到/Users/lucas/Do ...