数组太大,无法在matlab中进行除法,但不能在python中进行除法

2024-06-01 04:03:56 发布

您现在位置:Python中文网/ 问答频道 /正文

我的问题是在Matlab中数组太大。数组数据来自音频文件。我想得到脉冲响应。你知道吗

我首先对原始和录制的音频进行FFT。然后按原始记录的划分。最后进行逆FFT得到脉冲响应。那是我计划要做的,但我被困在部门的一部分。你知道吗

一直使用Matlab,我发现一个python code可以做得很好。我把代码重写成Matlab,问题又来了。代码不完整,但足以说明问题所在。你知道吗

希望得到更多的建议和批评。谢谢

计划执行,但失败,因此继续执行下一个代码

[y_sweep,Fs] = audioread('sweep.wav');
[y_rec,Fs] = audioread('edit_rec_sweep_laptop_1.2.wav');
fft_y1 = abs(fft(y_rec(:,1)));
fft_y2 = abs(fft(y_rec(:,2)));
fft_x = abs(fft(y_sweep));
fft_h1 = fft_y1/fft_x;
% fft_h2 = fft_y2/fft_x;
% fft_h = [fft_h1,fft_h2];
% h1 = ifft(fft1_h);

从python“翻译”了代码,但仍然失败,因此来到这里

[a,fs] = audioread('sweep.wav'); % sweep
[b,fs] = audioread('rec.wav'); % rec

a = pad(a,fs*50,fs*10);
b = pad(b,fs*50,fs*10);
[m,n] = size(b);
h = zeros(m,n); 

for chan = 1:2
    b1 = b(:,1);
    ffta = abs(fft(a));
    fftb = abs(fft(b1));
    ffth = fftb / ffta;
end

pad.m函数(从python翻译而来,但应该是正确的)

function y = pad(data, t_full, t_pre)
[row_dim,col_dim] = size(data);
t_post = t_full - row_dim - t_pre;
if t_post > 0
    if col_dim == 1
        y = [zeros(t_pre,1);data;zeros(t_post,1)];
%         width = [t_pre,t_post];
    else
        y1 = [zeros(t_pre,1);data(:,1);zeros(t_post,1)];
        y2 = [zeros(t_pre,1);data(:,2);zeros(t_post,1)];
        y = [y1,y2];
%         width = [[t_pre,t_post],[0,0]];
    end 
else
    if col_dim == 1
        y = [zeros(t_pre,1);data(t_full - t_pre:end,1)];
%         width = [t_pre,0];
    else
        y = [zeros(t_pre,1);data(t_full - t_pre:end,1)];
%         width = [[t_pre,0],[0,0]];
    end
end

end

错误

Error using  \ 
Requested 4800000x4800000 (171661.4GB) array exceeds
maximum array size preference. Creation of arrays
greater than this limit may take a long time and
cause MATLAB to become unresponsive. See array size
limit or preference panel for more information.

Error in impulseresponse (line 13)
    ffth = fftb / ffta;

Tags: 代码fftdatazerosabspostprefs
1条回答
网友
1楼 · 发布于 2024-06-01 04:03:56

正斜杠在MATLAB中是^{}的简写形式。用于求解线性矩阵方程组。我想你想要的是^{},用./表示。你知道吗

  • 只有当b是标量时,c = a/b才等价于标准除法。

  • c = a./b是按元素划分的,其中a的每个元素都被b的相应元素划分。你知道吗

    [1 2 3] ./ [2 4 9]
    >> ans = [0.5, 0.5, 0.3333]
    

所以“计划要做”代码的最后一行变成

fft_h1 = fft_y1 ./ fft_x;

相关问题 更多 >