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

 
 
> Передискретизация
qwa
сообщение Jun 29 2015, 12:31
Сообщение #1


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

Группа: Участник
Сообщений: 80
Регистрация: 8-02-15
Из: Санкт-Петербург
Пользователь №: 85 020



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

Есть такая задача: дан сигнал с частотой дискретизации A и надо преобразовать эту частоту дискретизации до значения B. Важный аспект здесь то, что изменяется частота дискретизации в нецелое число раз - то есть,сначала в L интерполируем, а потом в M децимируем.

Вопрос: существуют ли какие-нибудь методы,по которым можно найти такое оптимальное отношение L/M, что оно будет с некоторой точностью (3-4 знака после запятой) близко к отношению A/B?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
leeeeha
сообщение Jul 1 2015, 00:51
Сообщение #2





Группа: Новичок
Сообщений: 5
Регистрация: 11-07-12
Пользователь №: 72 705



Есть отличный алгоритм основанный на дереве Штерна-Броко. вот моя реализация.

Код
uint aim = 0.456;
uint guess;
uint max_denominator = 8192;
  uint item_1_p = 0;
  uint item_1_q = 1;
  uint item_2_p = 1;
  uint item_2_q = 2;
  uint item_3_p = 1;
  uint item_3_q = 1;

  while(1){

    guess = (double)item_2_p/ (double)item_2_q;

    if (aim<=guess) {
      item_3_p = item_2_p;
      item_3_q = item_2_q;
    } else{
      item_1_p = item_2_p;
      item_1_q = item_2_q;
    }
    if (item_1_q + item_3_q>max_denominator) break;

    item_2_p = item_1_p + item_3_p;
    item_2_q = item_1_q + item_3_q;
    
  }

По итогу в item_2_p и item_2_q хранятся числитель и знаменатель дроби минимально отличающейся от aim при заданном максимальном знаменателе. Изменяя значения item_1_p item_1_q item_3_p item_3_q задаём границы для поиска решения.
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 30th June 2025 - 01:45
Рейтинг@Mail.ru


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