Cat hungry.png
Здравствуйте! Собираем деньги на перевод материалов по электронике(https://www.allaboutcircuits.com/education/). Реквизиты указаны здесь.

Arduino:Примеры/fft adc

Материал из Онлайн справочника
Перейти к: навигация, поиск

Перевод: Максим Кузьмин (Cubewriter)
Перевел 2686 статей для сайта.

Контакты:

Проверка/Оформление/Редактирование: Мякишев Е.А.


Применение БПФ на данных от АЦП и отправка результата посредством write()[1]

Это скетч для библиотеки FFT, который при помощи платы Arduino считывает данные с АЦП (аналогово-цифрового преобразователя), а затем обрабатывает их при помощи алгоритма БПФ (быстрое преобразование Фурье).

Для передачи данных по последовательному порту используется функция write().

Код

  1.  
  2. /*
  3. Применение БПФ на данных от АЦП и отправка результата через write()
  4.  
  5. Создан пользователем guest на openmusiclabs.com
  6. Дата создания – 18 августа 2012 года.
  7. Скетч предназначен для тестирования библиотеки FFT.
  8.  
  9. Он берет данные у adc0 (0—ой аналоговый контакт), а затем 
  10. обрабатывает их при помощи БПФ. Данные отправляются 
  11. по последовательному порту на скорости 115,2 килобит.
  12. Для визуализации данных есть специальный патч на PureData.
  13. */
  14.  
  15. #define LOG_OUT 1 // включаем функцию для логарифмического формата
  16. #define FFT_N 256 // задаем количество выходных отсчетов на 256
  17.  
  18. #include <FFT.h> // подключаем библиотеку
  19.  
  20. void setup() {
  21.   Serial.begin(115200); // запускаем последовательный порт
  22.   TIMSK0 = 0; // выключаем timer0, чтобы уменьшить джиттер
  23.   ADCSRA = 0xe5; // задаем для АЦП автономный режим работы
  24.   ADMUX = 0x40; // используем adc0
  25.   DIDR0 = 0x01; // выключаем цифровой вход для adc0
  26. }
  27.  
  28. void loop() {
  29.   while(1) { // уменьшаем джиттер
  30.     cli();  // на Arduino 1.0 со снижением хорошо справляются прерывания UDRE
  31.     for (int i = 0 ; i < 512 ; i += 2) { // сохраняем 256 отчетов
  32.       while(!(ADCSRA & 0x10)); // ждем, когда АЦП будет готов
  33.       ADCSRA = 0xf5; // перезапускаем АЦП
  34.       byte m = ADCL; // считываем данные АЦП
  35.       byte j = ADCH;
  36.       int k = (j << 8) | m; // конвертируем в данные типа int
  37.       k -= 0x0200; // конвертируем в данные типа int со знаком
  38.       k <<= 6; // конвертируем в 16-битные данные типа int со знаком
  39.       fft_input[i] = k; // сохраняем действительные значения в четные отсчеты
  40.       fft_input[i+1] = 0; // задаем нечетным отсчетам значение «0»
  41.     }
  42.     fft_window(); // функция-окно, повышающая частотное разрешение 
  43.     fft_reorder(); // реорганизовываем данные перед запуском БПФ
  44.     fft_run(); // обрабатываем данные в БПФ
  45.     fft_mag_log(); // извлекаем данные, обработанные БПФ
  46.     sei();
  47.     Serial.write(255); // отсылаем стартовый байт
  48.     Serial.write(fft_log_out, 128); // отсылаем данные
  49.   }
  50. }

См.также

Внешние ссылки

  1. wiki.openmusiclabs.com - fft_adc.pde