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

 
 
 
Reply to this topicStart new topic
> Спектральный анализ на слабых MCU, какой подход использовать
Zelepuk
сообщение Aug 17 2011, 06:03
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Имеется сигнал (основной тон + гармоники). Частота основного тона может меняться от 45 до 50 Гц.
Необходимо произвести расчёт 10-и спектральных составляющих. Использую алгоритм Герцеля так как БПФ требует хранения больших таблиц поварачивающих коэффициентов и слишком затратно.
Но чтобы избавится от растекания требуется окно - от этого никуда не деться.

итак, если используем окно то при изменении частоты основного тона от 45 до 55Гц потребуется искать максимумы и придётся использовать алгоритм Герцеля не для поиска 10 гармоник, а для поиска 44-х. (4 отсчёта вблизи каждого максимума).

Получается этот вариант слишком затартный((

Возможно ли какое-то оптимальное решения для MCU с 4кБ RAM и 120 кБ ROM??

Сообщение отредактировал Zelepuk - Aug 17 2011, 06:06
Go to the top of the page
 
+Quote Post
bahurin
сообщение Aug 17 2011, 08:04
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 240
Регистрация: 20-09-08
Пользователь №: 40 347



Цитата(Zelepuk @ Aug 17 2011, 10:03) *
Возможно ли какое-то оптимальное решения для MCU с 4кБ RAM и 120 кБ ROM??


4k RAM это конечно жестко. Ну как вариант попробовать следить за основной частотой простеньким контуром, и исходя из нее динамически пересчитывать алгоритм Герцеля для того чтобы отказаться от окон и уменьшить растекание.
Go to the top of the page
 
+Quote Post
Zelepuk
сообщение Aug 17 2011, 08:56
Сообщение #3


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



У меня исходная частота дискретизации железная 4096.
Что если делать так:

исходя из значения основной гармоники (узнаётся по переходам через "0" и интерполяцией вблизи нуля) мы преобразуем частоту дискретизации фильтром Фарроу в пределах 1080... 1320Гц (из условия получения 11 гармоник и изменения частоты основного тона 45... 55Гц). Тогда всегда будем иметь в буфере 24 отсчёта. Затем делаем ДПФ на 24 отсчёта для 11 гармоник. В результате получим спетр из 11 гармоник.

Или Герцель будет менее затратным?

Сообщение отредактировал Zelepuk - Aug 17 2011, 09:43
Go to the top of the page
 
+Quote Post
ivan219
сообщение Aug 17 2011, 12:33
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 350
Регистрация: 16-11-08
Пользователь №: 41 680



Вычислительная сложность Герцеля на одну гармонику = N + 2 умножений и 2N сложений ДПФ = N операций с комплексными числами, что равно 2N сложений и 4N умножений + таблица на Sin Cos Герцель более выгоден вычислительная сложность БПФ = N * Log2(N) операций с комплексными числами при определённом значении N и числа гармоник БПФ выгоднее Герцель.

Герцель по сравнению с БПФ выгоден, когда число гармоник K <= Log2(N) т.е. для 11 гармоник N = 2048 будут равноценные объём вычислений при БПФ = 2048 при меньшем БПФ, БПФ выгоднее.

Сообщение отредактировал ivan219 - Aug 17 2011, 12:39
Go to the top of the page
 
+Quote Post
Alexey Lukin
сообщение Aug 17 2011, 14:16
Сообщение #5


Частый гость
**

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



Цитата(Zelepuk @ Aug 17 2011, 10:03) *
итак, если используем окно то при изменении частоты основного тона от 45 до 55Гц потребуется искать максимумы и придётся использовать алгоритм Герцеля не для поиска 10 гармоник, а для поиска 44-х. (4 отсчёта вблизи каждого максимума).

Окно как раз уменьшает число коэффициентов, подлежащих оценке, а не увеличивает.

Если вам неизвестна частота сигнала, то делать поиск придётся в любом случае, для уточнения частот высших гармоник. А если частота примерно известна, то используйте flat-top окно. Тогда достаточно оценить 1 коэффициент на гармонику.
Go to the top of the page
 
+Quote Post
анатолий
сообщение Aug 18 2011, 07:56
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 221
Регистрация: 10-12-05
Из: Украина
Пользователь №: 12 052



Цитата
120 кБ ROM

Если есть такая память,
то лучше не заморачиваться, запомнить в памяти синусоиды, окна и сделать чистый ДПФ.
А Герцеля лучше забыть, т.к. у него ошибки сильно накапливаются.

Я в 1993 делал такую же задачу на чистом і8051 через ДПФ.
И памяти хватало, и точности, и времени.
Точность измерения частоты была 0,1 Гц.
Go to the top of the page
 
+Quote Post
bahurin
сообщение Aug 18 2011, 08:06
Сообщение #7


Местный
***

Группа: Участник
Сообщений: 240
Регистрация: 20-09-08
Пользователь №: 40 347



Цитата(анатолий @ Aug 18 2011, 11:56) *
А Герцеля лучше забыть, т.к. у него ошибки сильно накапливаются.


Не больше чем у любого бих фильтра. Кстати если сравнивать Герцеля и FFT, то в FFT ошибки накапливаются не меньше.
Go to the top of the page
 
+Quote Post
Zelepuk
сообщение Aug 18 2011, 09:17
Сообщение #8


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Цитата(Alexey Lukin @ Aug 17 2011, 18:16) *
Окно как раз уменьшает число коэффициентов, подлежащих оценке, а не увеличивает.

Если вам неизвестна частота сигнала, то делать поиск придётся в любом случае, для уточнения частот высших гармоник. А если частота примерно известна, то используйте flat-top окно. Тогда достаточно оценить 1 коэффициент на гармонику.


Частота сигнала известна с точностью 0,01Гц. Даже при использовании flattop при изменении частоты основного тона в пределах 45... 55 Гц пики гармоник в спектре не всегда будут на одинаково расстоянии друг от друга и придётся искать эти пики в некоторых пределах, что потребует вычисления "лишних" спектральных отсчётов вблизи максимумов.
Go to the top of the page
 
+Quote Post
Alexey Lukin
сообщение Aug 18 2011, 16:14
Сообщение #9


Частый гость
**

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



Если частота известна, никакого поиска пиков не требуется, они фиксированы.
Go to the top of the page
 
+Quote Post

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

 


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


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