реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Фильтрация аналоговых сигналов
KOT9RA
сообщение May 12 2012, 06:45
Сообщение #1





Группа: Новичок
Сообщений: 4
Регистрация: 12-05-12
Пользователь №: 71 797



Доброго времени суток!

мне необходимо отфильтровать аналоговые сигналы методом скользящего среднего! сигнал подается на микроконтроллер. я использую ADUC842. написал программу, но не уверен что правильно реализовал метод скользящего среднего!
вот кусок кода, в котором происходит считывание сигналов преобразование их с помощью АЦП в код, далее код преобразуется в напряжение, и потом идет фильтрация:


ADCRead(3); //читаем порт P1.3 и запускаем АЦП
U21= (ADCDATAL+(ADCDATAH<<8))&0x0FFF; //снимаем код с АЦП
U11= U21/1638; //перевод кода в напряжение (FFF/2,5=1638.4) - для фильтрации
if(q==0)
{
Up1=Un1; //создание предыдущего зн-ия
q=1; //взводим флаг
}
else
{
Un1=Up1*(1-p)+ Un1*p; //фильтрация (р=1/n, где n-количество отсчетов)
Up1=Un1; //создание предыдущего зн-ия
U21=Un1*1638; //перевод обратно в код
}
на сколько я понимаю скользящее среднее используется для фильтрации данных которые заданны массивом. как это реализовать в данном случаи?

помогите пожайлуста! очень нужно!
Go to the top of the page
 
+Quote Post
bav
сообщение May 12 2012, 07:43
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 693
Регистрация: 21-06-05
Из: Санкт-Петербург
Пользователь №: 6 184



примерно так:
while(1)
{
u = ADCRead();

res = (u + du + ddu + dddu)/4;
dddu = ddu;
ddu = du;
du = u;
}


скользящее из 4-х точек
Go to the top of the page
 
+Quote Post
KalashKS
сообщение May 12 2012, 09:04
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 236
Регистрация: 7-02-11
Пользователь №: 62 755



У Вас получился рекурсивный фильтр 1-го порядка. При больших значениях n, если жалко памяти, и если по линейности ФЧХ требований нет, можно использовать его.

Скользящее среднее без весовых коэффициентов, на мой взгляд, лучше сделать так.

if(init_flag==0)
{
for (k=0; k<n; k++)
sample_reg[k] = 0; //инициализация
U_filtered = 0;
init_flag = 1; //взводим флаг
}
else
{
U_filtered = U_filtered + Un1 - sample_reg[sample_reg_pntr]; //фильтрация
sample_reg[sampe_reg_pntr] = Un1;
sample_reg_pntr = (sample_reg_pntr+1) % n;
}
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 18:09
Рейтинг@Mail.ru


Страница сгенерированна за 0.01341 секунд с 7
ELECTRONIX ©2004-2016