问题描述
我使用了卷积定理来有效地计算卷积。假设有两个实信号s1
,每个信号s2
的长度N
。然后我可以从
import numpy as np
import numpy.fft as fft
size = len(s1)
fft_size = int(2 ** np.ceil(np.log2(2 * size - 1))) #The size for the FFT algorithm
S1 = fft.rfft(s1, fft_size) #Take FTs
S2 = fft.rfft(s2, fft_size)
convolution = fft.irfft(S1 * S2) #Take IFT
但是,如果我有k
单曲,则fft_size
必须修改为阅读
fft_size = int(2 ** np.ceil(np.log2(k * size - 1)))
为了避免圆形重叠。
不幸的是,我不知道k
先验。一种选择是选择最大值k_max
,但如果不是绝对必要,我宁愿不必使用大量内存,并且我宁愿在每次 k 变化时都不要再次评估 FT。
问题
是否可以执行以下操作之一
- 根据需要对信号进行 FFT
k=1
和“傅立叶空间中的零填充”? - 防止 FFT 中的循环环绕?