Python实现正交相敏检波
时间: 2023-08-27 13:13:45 浏览: 106
以下是一个简单的 Python 实现正交相敏检波的示例代码:
```python
import numpy as np
# 产生输入信号
t = np.arange(0, 1, 0.001) # 时间轴
f = 1000 # 信号频率
x = np.sin(2 * np.pi * f * t)
# 产生本地振荡器
f_lo = 1100 # 本地振荡器频率
lo_cos = np.cos(2 * np.pi * f_lo * t) # 本地振荡器的实部
lo_sin = np.sin(2 * np.pi * f_lo * t) # 本地振荡器的虚部
lo = lo_cos + 1j * lo_sin
# 正交相敏检波
y = x * np.conj(lo)
# 低通滤波
fc = 200 # 截止频率
N = 4 # 滤波器阶数
b, a = signal.butter(N, fc / (f_lo / 2), 'low')
z = signal.filtfilt(b, a, y)
# 绘制波形图
import matplotlib.pyplot as plt
plt.plot(t, x, label='Input signal')
plt.plot(t, np.real(z), label='Output signal')
plt.legend()
plt.xlabel('Time (s)')
plt.ylabel('Amplitude')
plt.show()
```
代码中,我们首先生成了一个频率为 1000Hz 的正弦波作为输入信号,然后产生了一个频率为 1100Hz 的本地振荡器信号,并分别取其实部和虚部,组合成一个复数形式的本地振荡器信号。接着,将输入信号与本地振荡器的共轭相乘,得到正交相敏检波后的信号。最后,使用 `scipy.signal` 库的 `butter` 函数设计了一个低通滤波器,并对正交相敏检波后的信号进行滤波。最后,使用 `matplotlib` 库绘制了输入信号和输出信号的波形图。
阅读全文