Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Тогда так.

Отправлено leon 15 февраля 2008 г. 17:37
В ответ на: Всё к этому, похоже, и свелось. Реализация подойдет только целочисленная, пока непонятно, как будут влиять ошибки округления. Кстати, отправлено Леонид Иванович 15 февраля 2008 г. 02:48



//// ПРОГРАММНЫЙ АНАЛОГ RC ФИЛЬТРА

// Два варианта:
// с целыми значениями (быстрее)
// с действительными значениями (Понятнее)

#define INT_KOEFF 16
#define FLOAT_KOEFF 20.0
int int_RC; // В INT_KOEFF большее от read_adc значения
float float_RC;

void calc_RC (void)
{
int tmp;

tmp = read_adc(ADC_IN);
float_RC += (tmp - float_RC) / FLOAT_KOEFF;
int_RC += tmp - ((int_RC + INT_KOEFF/2) >> 4); // Деление на 16 сдвигом
}


//// ОПРЕДЕЛЕНИЕ СКОЛЬЗЯЩЕГО СРЕДНЕГО

#define ARRAY_SIZE 20
#define ADC_IN 2

// В кольцевом массиве содержаться отдельные значения
int Array[ARRAY_SIZE];

// Индекс элемента массива, в котор будет записано очередное значение
signed char index;

// Значение суммы отдельных значений, Правильное значение бывает только
// после суммирования ARRAY_SIZE значений
int summ;

// Скользящее значение суммы ARRAY_SIZE отдельных значений, всегда правильное значение
int skolz_summ;

// Скользящее среднее ARRAY_SIZE отдельных значений, всегда правильное значение
int skolz_sred;

void calc_skolz_sred (void)
{
int tmp;

tmp = read_adc(ADC_IN);
summ += tmp; // вычисляем временную сумму

// находим очередное значение индекса
if (--index < 0) {
index = ARRAY_SIZE - 1; // Закольцовываем
skolz_summ = summ; // Юстируем скольз сумму
summ = 0;
} else {
// К правильному значению суммы последних ARRAY_SIZE отдельных значений
// прибавляем самое свежее и вычитаем самое старое
skolz_summ += tmp - Array[index];
}

// заменяем самое старое значение самым свежим
Array[index] = tmp;
// вычисляем скользящее среднее
skolz_sred = skolz_summ / ARRAY_SIZE;
}



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
сколько миллиампер в одном ампере ?:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru