import numpy as np
import matplotlib.pyplot as plt
n = 500
T = 10
dw = 2 * np.pi / T
t = np.linspace(0, T, n)
x = 5 * np.sin(20 * t + np.pi) + 10 * np.sin( 40 * t + np.pi/2)
fftx = np.fft.rfft(x)
freq = np.fft.rfftfreq(n) * n * dw
amps = np.abs(fftx) * 2 / n
angs = np.angle(fftx)
_, ax = plt.subplots(3, 1)
ax[0].plot(t, x)
ax[1].plot(freq, amps)
ax[2].plot(freq, angs)
Я получаю правильные значения для частоты и амплитуды. Но, как видно из графика, значения фазы не верны. Как извлечь правильные значения для фазы из FFT? Что именно я смотрю на фазовом графике?
Я ожидаю около 3,14 и 3,14 / 2 для частот 20 и 40 соответственно.