Удалите гул на 60 Гц из сигнала

Переменный ток в Соединенных Штатах и нескольких других странах колеблется на частоте 60 Гц. Те колебания часто повреждают измерения и имеют, чтобы быть вычтенными.

Изучите напряжение разомкнутого контура через вход аналогового инструмента в присутствии шума линии электропередачи на 60 Гц. Напряжение производится на уровне 1 кГц.

load openloop60hertz, openLoop = openLoopVoltage;

Fs = 1000;
t = (0:length(openLoop)-1)/Fs;

plot(t,openLoop)
ylabel('Voltage (V)')
xlabel('Time (s)')
title('Open-Loop Voltage with 60 Hz Noise')
grid

Figure contains an axes object. The axes object with title Open-Loop Voltage with 60 Hz Noise contains an object of type line.

Устраните шум на 60 Гц с помощью фильтра метки Баттерворта. Используйте designfilt спроектировать фильтр. Ширина метки задана интервалом частоты на 59 - 61 Гц. Фильтр удаляет, по крайней мере, половину степени частотных составляющих, находящихся в том диапазоне.

d = designfilt('bandstopiir','FilterOrder',2, ...
               'HalfPowerFrequency1',59,'HalfPowerFrequency2',61, ...
               'DesignMethod','butter','SampleRate',Fs);

Постройте частотную характеристику фильтра. Обратите внимание на то, что этот фильтр метки обеспечивает до 45 дБ затухания.

fvtool(d,'Fs',Fs)

Figure Filter Visualization Tool - Magnitude Response (dB) contains an axes object and other objects of type uitoolbar, uimenu. The axes object with title Magnitude Response (dB) contains 2 objects of type line.

Отфильтруйте сигнал с filtfilt компенсировать задержку фильтра. Отметьте, как колебания значительно уменьшаются.

buttLoop = filtfilt(d,openLoop);

plot(t,openLoop,t,buttLoop)
ylabel('Voltage (V)')
xlabel('Time (s)')
title('Open-Loop Voltage')
legend('Unfiltered','Filtered')
grid

Figure contains an axes object. The axes object with title Open-Loop Voltage contains 2 objects of type line. These objects represent Unfiltered, Filtered.

Используйте периодограмму, чтобы видеть, что "скачок" на уровне 60 Гц был устранен.

[popen,fopen] = periodogram(openLoop,[],[],Fs);
[pbutt,fbutt] = periodogram(buttLoop,[],[],Fs);

plot(fopen,20*log10(abs(popen)),fbutt,20*log10(abs(pbutt)),'--')
ylabel('Power/frequency (dB/Hz)')
xlabel('Frequency (Hz)')
title('Power Spectrum')
legend('Unfiltered','Filtered')
grid

Figure contains an axes object. The axes object with title Power Spectrum contains 2 objects of type line. These objects represent Unfiltered, Filtered.

Смотрите также

| | |

Похожие темы

Для просмотра документации необходимо авторизоваться на сайте