3

我希望创建一个函数,该函数可以在 .wav 文件上在 5 秒内创建淡入/淡出功能。

我在 MATLAB 论坛上找到了这段代码,但似乎实现有点错误,尽管有正确的想法。它适用于 300 毫秒的 .WAV 文件,具有 10 毫秒的淡入/淡出:

tenmssamples = length(soundfile)*10/300;
fade1 = linspace(0,1,tenmssamples);
fadedsound = soundfile .* ...
  [fade1, ones(1,length(soundfile)-2*tenmssamples), fliplr(fade1)];


tenmssamples = length(soundfile)*10/300;
fade2 = sin(linspace(0,2*pi/4,tenmssamples));
fadedsound2 = soundfile .* ...
  [fade2, ones(1,length(soundfile)-2*tenmssamples), fliplr(fade2)];

通过尝试使用 linspace 对递增函数读取的波形的前 10 个样本进行缩放,我可以看到他在尝试做什么,但我试图修补和修改它,但我无法让它工作。

请问有人有什么建议吗?谢谢你。

4

1 回答 1

5

我不确定您遇到的问题是什么,但我会这样做:

Fs = 1000; % sampling rate of signal
FADE_LEN = 5; % 5 second fade

sig = randn(15.*Fs,1); % generate 15 s signal

fade_samples = round(FADE_LEN.*Fs); % figure out how many samples fade is over
fade_scale = linspace(0,1,fade_samples)'; % create fade

sig_faded = sig;
sig_faded(1:fade_samples) = sig(1:fade_samples).*fade_scale; % apply fade

subplot(211)
plot(sig)
subplot(212)
plot(sig_faded)

当然,您可以将 linspace 替换为 sigmoid 之类的其他东西,并使用相同的想法进行淡出...

编辑:做淡出,试试

sig_faded(end-fade_samples+1:end) = sig(end-fade_samples+1:end).*fade_scale(end:-1:1);
于 2010-08-18T16:56:34.190 回答