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

 
 
 
Reply to this topicStart new topic
> Поддержание постоянной скорости вывода данных при переменной скорости ввода, как реализовать?
drum1987
сообщение Mar 16 2010, 10:03
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 255
Регистрация: 3-02-09
Из: Омск
Пользователь №: 44 323



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

При реализации демодулятора столкнулся с проблемой того, что размер выходного буфера изменяется(в зависимости от разности тактовых частот приемника и передатчика) и не равен размеру входного. Сейчас сделал так: большой буфер в который циклически пишется столько отсчетов сколько приходит с демодулятора, а считывается всегда фиксированное число(равное размеру буфера вывода на устройство индикации). Проблема в том, что при тактовой частоте передатчика большей чем у приемника записывается всегда больше чем считывается и запись "догоняет" чтение на второй круг и начинается шлейф ошибок...

Ткните пожалуйста на то как люди делают в мире rolleyes.gif
Go to the top of the page
 
+Quote Post
Andron_
сообщение Mar 16 2010, 10:10
Сообщение #2


.NET developer
***

Группа: Свой
Сообщений: 218
Регистрация: 20-10-07
Из: Новосибирск
Пользователь №: 31 532



это из разряда загадок "впихнуть невпихуемое"?
Go to the top of the page
 
+Quote Post
drum1987
сообщение Mar 16 2010, 10:24
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 255
Регистрация: 3-02-09
Из: Омск
Пользователь №: 44 323



Цитата(Andron_ @ Mar 16 2010, 17:10) *
это из разряда загадок "впихнуть невпихуемое"?

Цель не как вы говорите "впихнуть невпихуемое", а минимизировать блочные ошибки...ясен пень что избежать их не получится(конечно если нет безконечного буфера laughing.gif )

Хочется узнать как это реализовывали люди, которые с такой проблемой сталкивались.
Go to the top of the page
 
+Quote Post
des00
сообщение Mar 16 2010, 12:34
Сообщение #4


Вечный ламер
******

Группа: Модераторы
Сообщений: 7 248
Регистрация: 18-03-05
Из: Томск
Пользователь №: 3 453



Цитата(drum1987 @ Mar 16 2010, 04:03) *
Проблема в том, что при тактовой частоте передатчика большей чем у приемника записывается всегда больше чем считывается и запись "догоняет" чтение на второй круг и начинается шлейф ошибок...

вам нужен цифровой или аналоговый гаситель джиттера %)


--------------------
Go to the top of the page
 
+Quote Post
fontp
сообщение Mar 16 2010, 13:05
Сообщение #5


Эксперт
*****

Группа: Свой
Сообщений: 1 467
Регистрация: 25-06-04
Пользователь №: 183



Цитата(drum1987 @ Mar 16 2010, 13:03) *
Проблема в том, что при тактовой частоте передатчика большей чем у приемника записывается всегда больше чем считывается и запись "догоняет" чтение на второй круг и начинается шлейф ошибок...


Считывайте всегда на немного повышеной скорости (на максимальной для ввода). Тогда данных будет всегда только немного не хватать, вставите там что-нибудь rolleyes.gif
В противном случае нужно строить "джиттер-буффер" и подстраивать частоту
Go to the top of the page
 
+Quote Post
RCray
сообщение Apr 12 2010, 13:06
Сообщение #6


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

Группа: Свой
Сообщений: 170
Регистрация: 14-09-05
Из: Suwon
Пользователь №: 8 548



а по какому принципу здесь строится джиттер буфер? чем он отличается от приведённой здесь буферизации?
Go to the top of the page
 
+Quote Post
fontp
сообщение Apr 12 2010, 14:48
Сообщение #7


Эксперт
*****

Группа: Свой
Сообщений: 1 467
Регистрация: 25-06-04
Пользователь №: 183



Цитата(RCray @ Apr 12 2010, 17:21) *
а по какому принципу здесь строится джиттер буфер? чем он отличается от приведённой здесь буферизации?


здесь это где? и что здесь приведено?

Джиттер буфер строится с подстройкой частоты - в аналоговом случае нужно подстраивать частоту АЦП так, чтобы добиться постоянного заполнения буфера (например наполовину) , а в цифровом варианте нужно делать ресамплинг. В любом случае нужно выравнивать частоты приемника и передатчика. Система автоподстройки.

Просто вставлять интерполированые значения - это ещё не есть джиттер буфер. Но часто так и делают и это как-то работает. Если не контролировать расстройку частоты, то и интерполяция возможна только кривая - повтором по ближайшему соседу.
Go to the top of the page
 
+Quote Post
des00
сообщение Apr 13 2010, 01:36
Сообщение #8


Вечный ламер
******

Группа: Модераторы
Сообщений: 7 248
Регистрация: 18-03-05
Из: Томск
Пользователь №: 3 453



Цитата(fontp @ Apr 12 2010, 09:03) *
Джиттер буфер строится с подстройкой частоты - в аналоговом случае нужно подстраивать частоту АЦП так, чтобы добиться постоянного заполнения буфера (например наполовину) , а в цифровом варианте нужно делать ресамплинг. В любом случае нужно выравнивать частоты приемника и передатчика. Система автоподстройки.

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

2 RCray
как делается в цифре посмотрите на интеловские микросхемы для синхронных каналов, в аналоге проще. Буфер удерживаемый в середине, сторона записи на грязном клоке, сторона чтения на чистом. Ошибка указателей идет в петлю подстройки ГУНа чистого клока. Для стандартных синхронных каналов петля делается узкой (10 - 20Гц). Достоинства таких приемников широкая петля захвата тактовой (в цифре) + малый джиттер выходных данных %)

Но все эти методы по сути переводят джиттер в вандер. Тут главное в маски по джиттеру уложиться %)


--------------------
Go to the top of the page
 
+Quote Post
DMax
сообщение Apr 19 2010, 09:34
Сообщение #9


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

Группа: Свой
Сообщений: 161
Регистрация: 19-01-08
Из: Питер
Пользователь №: 34 234



Цитата(drum1987 @ Mar 16 2010, 13:18) *
Доброго времени суток.

При реализации демодулятора столкнулся с проблемой того, что размер выходного буфера изменяется(в зависимости от разности тактовых частот приемника и передатчика) и не равен размеру входного. Сейчас сделал так: большой буфер в который циклически пишется столько отсчетов сколько приходит с демодулятора, а считывается всегда фиксированное число(равное размеру буфера вывода на устройство индикации). Проблема в том, что при тактовой частоте передатчика большей чем у приемника записывается всегда больше чем считывается и запись "догоняет" чтение на второй круг и начинается шлейф ошибок...

Ткните пожалуйста на то как люди делают в мире rolleyes.gif


Делайте событийно-ориентированную систему: выходной буфер - объект, генерирующий событие "полон на половину", а то, что вычитывает из выходного буфера, ожидает это событие. Конкретная реализация уже зависит от того, какое окружение у вашей программы - здесь могу быть как глобальные флаги в качестве событий, если у вас нет операционки, а могут быть разные нити и какие-то синхронизационные примитивы (кондвары и мутексы, например), если у вас есть операционка. Правда, скорость вывода будет не постоянной, а по мере накопления. Постоянную скорость вывода здесь не сделать по определению.
Go to the top of the page
 
+Quote Post
RCray
сообщение Apr 30 2010, 08:42
Сообщение #10


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

Группа: Свой
Сообщений: 170
Регистрация: 14-09-05
Из: Suwon
Пользователь №: 8 548



des00 и fontp, спасибо за ликбез.
Go to the top of the page
 
+Quote Post
drum1987
сообщение May 4 2010, 08:54
Сообщение #11


Местный
***

Группа: Участник
Сообщений: 255
Регистрация: 3-02-09
Из: Омск
Пользователь №: 44 323



Цитата(DMax @ Apr 19 2010, 16:34) *
Делайте событийно-ориентированную систему: выходной буфер - объект, генерирующий событие "полон на половину", а то, что вычитывает из выходного буфера, ожидает это событие. Конкретная реализация уже зависит от того, какое окружение у вашей программы - здесь могу быть как глобальные флаги в качестве событий, если у вас нет операционки, а могут быть разные нити и какие-то синхронизационные примитивы (кондвары и мутексы, например), если у вас есть операционка. Правда, скорость вывода будет не постоянной, а по мере накопления. Постоянную скорость вывода здесь не сделать по определению.

В принцыпе так я и сделал. Спасибо за ответ.
Go to the top of the page
 
+Quote Post

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

 


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


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