我试图通过RTL-SDR获得特定频率的功率。我正在调整我在网上找到的FFT示例。这里的缩写代码(删除了多余的东西):
import matplotlib.mlab as mlab
import rtlsdr
NFFT=1024
dwell = 0.016
sample_rate = 2.4e6
offset = 200e3
freq = 100e6
sdr = rtlsdr.RtlSdr(0)
sdr.set_sample_rate(sample_rate)
sdr.set_manual_gain_enabled(1)
sdr.set_gain(22.9)
sdr.freq_correction = 0
numsamples = next_2_to_pow(int(dwell * sample_rate))
freq = freq - offset # avoid dc spike
sdr.set_center_freq(freq)
samples = sdr.read_samples(numsamples)
powers, freqs = mlab.psd(samples, NFFT=NFFT, Fs=sample_rate/1e6, window=hamming(NFFT))
bin_offset = int(offset / (sample_rate / NFFT))
freq = int(freq + offset)
pwr = float( "{:.2f}".format(10 * math.log10( powers[ int(len(powers)/2) + bin_offset ] )) )
这根本行不通。即使我注入信号,频率处的功率也保持不变(本底噪声水平)。
我有两个关于为什么这不起作用的理论。 1)RTL-SDR返回I / Q数据,这种方法没有考虑到(?)2)我对FFT的理解根本不足以正确执行。
这是什么?我该如何解决?
答案 0 :(得分:1)
您是否尝试过使用rtl_power然后只在输出中选择正确的bin?这是rtl_sdr套件的一个相对新近的补充。在C中,而不是Python。 https://github.com/osmocom/rtl-sdr