sdr.plot.periodogram(x: ArrayLike, sample_rate: float | None = None, window: str | ArrayLike = 'hann', length: int | None = None, overlap: int | None = None, fft: int | None = None, detrend: 'constant' | 'linear' | False = False, average: 'mean' | 'median' = 'mean', x_axis: 'auto' | 'one-sided' | 'two-sided' | 'log' = 'auto', y_axis: 'linear' | 'log' = 'log', **kwargs)

Plots the estimated power spectral density \(P_{xx}\) of a time-domain signal \(x[n]\) using Welch’s method.

Note

This function uses scipy.signal.welch() to estimate the power spectral density of the time-domain signal.

Parameters:
x: ArrayLike

The time-domain signal \(x[n]\).

sample_rate: float | None = None

The sample rate \(f_s\) of the signal in samples/s. If None, the x-axis will be labeled as “Normalized Frequency”.

window: str | ArrayLike = 'hann'

The windowing function to use. This can be a string or a vector of length length.

length: int | None = None

The length of each segment in samples. If None, the length is set to 256.

overlap: int | None = None

The number of samples to overlap between segments. If None, the overlap is set to length // 2.

fft: int | None = None

The number of points to use in the FFT. If None, the FFT length is set to length.

detrend: 'constant' | 'linear' | False = False

The type of detrending to apply. Options are to remove the mean or a linear trend from each segment.

average: 'mean' | 'median' = 'mean'

The type of averaging to use. Options are to average the periodograms using the mean or median.

x_axis: 'auto' | 'one-sided' | 'two-sided' | 'log' = 'auto'

The x-axis scaling. Options are to display a one-sided spectrum, a two-sided spectrum, or one-sided spectrum with a logarithmic frequency axis. The default is "auto" which selects "one-sided" for real-valued signals and "two-sided" for complex-valued signals.

y_axis: 'linear' | 'log' = 'log'

The y-axis scaling. Options are to display a linear or logarithmic power spectral density.

**kwargs

Additional keyword arguments to pass to matplotlib.pyplot.plot().