信号相移90° Python
时间: 2023-08-27 21:06:36 浏览: 301
在Python中实现信号相移90°可以使用numpy库中的函数来实现。首先,你需要生成原始信号,可以使用numpy的cos函数生成一个余弦信号序列。然后,通过调整相位角来实现相移。相位角可以通过将原始相位角加上π/2来实现90°的相移。最后,你可以使用matplotlib库来绘制相移后的信号。
以下是一个示例代码:
```python
import numpy as np
import matplotlib.pyplot as plt
fs = 2000 # 采样频率
N = 40 # 信号长度
n = np.arange(N) # 样点序列
f0 = 100 # 初始频率
ph1 = -np.pi/3 # 初始相角
# 生成原始信号
x = np.cos(2*np.pi*f0*n/fs+ph1)
# 相移90°
ph2 = ph1 + np.pi/2
x_shifted = np.cos(2*np.pi*f0*n/fs+ph2)
# 绘制原始信号和相移后的信号
plt.figure()
plt.plot(n, x, 'r', label='Original Signal')
plt.plot(n, x_shifted, 'b', label='Shifted Signal')
plt.xlabel('Sample')
plt.ylabel('Amplitude')
plt.legend()
plt.show()
```
这段代码首先生成了一个长度为N的样点序列n,然后使用cos函数生成了原始信号x。接着,通过将原始相位角ph1加上π/2得到相移后的相位角ph2,然后使用相移后的相位角生成相移后的信号x_shifted。最后,使用matplotlib库绘制了原始信号和相移后的信号的图像。
希望这个示例代码能够帮助到你实现信号相移90°。
#### 引用[.reference_title]
- *1* [Verilog实现---时钟信号的90°相移](https://blog.csdn.net/qq_42446721/article/details/121843271)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* *3* [信号相角位移量的计算与信号位移计算-附Matlab代码](https://blog.csdn.net/m0_70745318/article/details/128216498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文