Periodogram of a square wave

2 visualizaciones (últimos 30 días)
Gianmarco Lavacca
Gianmarco Lavacca el 30 de Mayo de 2023
Comentada: Gianmarco Lavacca el 11 de Sept. de 2023
Hi everyone, I'm doing a DSP project where I need to extract the THD and SNDR of a Sigma-Delta DPWM.
I'm using the MATLAB function "periodogram" on the output to do it, but it returns bad results because the output wave is a square wave and not a sine wave (which amplifies the error). How can I work around that and get the correct periodogram of a square wave?
Thank you very much!
  6 comentarios
Mathieu NOE
Mathieu NOE el 31 de Mayo de 2023
I don't have accss to this publication
maybe you can take contact with the authors to further discuss that topic
Gianmarco Lavacca
Gianmarco Lavacca el 31 de Mayo de 2023
Editada: Gianmarco Lavacca el 31 de Mayo de 2023
I don't really have the time to do that, the deadline is fairly near. I'll just own up to it in the report. Thank you very much for your help though. I'll leave the question open in case someone has suggestions.

Iniciar sesión para comentar.

Respuesta aceptada

akshatsood
akshatsood el 4 de Sept. de 2023
Editada: akshatsood el 6 de Sept. de 2023
Hi Gianmarco,
I understand that you working on a Sigma-Delta DPWM. As stated in the question, you have used periodogram on the output square wave, yet it renders bad results. As per my understanding, you can leverage the fft function to compute the Fourier transform of the square wave and then calculate the power spectral density from the Fourier coefficients.
I have assumed a random data to discuss the workaround. Here is the code snippet for you reference
frequency = 10;
duration = 1;
samplingRate = 1000;
% generating square wave
t = 0:(1/samplingRate):(duration-1/samplingRate);
squareWave = square(2*pi*frequency*t);
N = length(squareWave);
Y = fft(squareWave); % computing Fourier transform
% determinging the power spectral density (PSD)
psd = (abs(Y).^2)/N;
f = samplingRate*(0:(N/2))/N; % frequency vector
% plot the square wave and the periodogram
tiledlayout(2,1);
nexttile;
plot(t,squareWave);
ylabel('Amplitude');
title('Square Wave');
grid on;
nexttile;
plot(f, 10*log10(psd(1:N/2+1)));
xlabel('Frequency (Hz)');
ylabel('Power Spectral Density (dB/Hz)');
title('Periodogram of Square Wave');
grid on;
I believe that, following this approach would be helpful in supressing the errors and acheiving a satisfactory result for the periodogram of the square wave.
Have a look at the documentation page for fft function for better understanding
I hope this helps.
  1 comentario
Gianmarco Lavacca
Gianmarco Lavacca el 11 de Sept. de 2023
Thank you very much. The exam is done and gone, but i'm sure your answer will help somebody else.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Spectral Measurements en Help Center y File Exchange.

Productos


Versión

R2021b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by