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

 
 
> Преобразовать асинхронный битовый поток в манчестер и обратно
sergvks
сообщение Apr 3 2009, 06:45
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 251
Регистрация: 26-07-05
Пользователь №: 7 117



Имеется девайс на str911 в функционал которого надо добавить преобразователь асинхронного битового потока в манчестер и обратно, всё бы ничего, но в исходном потоке нет никаких синхро-последовательностей и может идти подряд до 30 нулей или единиц, да ещё и частота 19200 может плавать +-0.5%.
Посоветуйте c какой стороны лучше зайти ?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 4)
MrYuran
сообщение Apr 3 2009, 07:00
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(sergvks @ Apr 3 2009, 10:45) *
всё бы ничего, но в исходном потоке нет никаких синхро-последовательностей и может идти подряд до 30 нулей или единиц, да ещё и частота 19200 может плавать +-0.5%.

По фронтам подстраивать тактовую частоту. Вроде +/-0,5% на 30 символов не так уж и страшно. А с манчестером тогда вообще без проблем. XOR-им дата с синком и получаем M-II.

Кстати, 19200 настолько маленькая скорость, что можно делать всё что угодно.
Например, счётчик-делитель с переменным коэффициентом деления.
Если полученный синк отстаёт от фронта входного сигнала, уменьшаем коэффициент деления. Опережает - увеличивает.
Нужно только подобрать оптимальные величины, чтобы максимально быстро входить в синхронизм.
Можно вообще по фронту счётчик сбрасывать.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
sergvks
сообщение Apr 3 2009, 07:45
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 251
Регистрация: 26-07-05
Пользователь №: 7 117



Цитата(MrYuran @ Apr 3 2009, 11:00) *
По фронтам подстраивать тактовую частоту. Вроде +/-0,5% на 30 символов не так уж и страшно. А с манчестером тогда вообще без проблем. XOR-им дата с синком и получаем M-II.

Тут ещё один момент, как это не парадоксально, но в моём случае M-II идёт по проводам, а этот сплошной битовый поток по радиоканалу и приходит он на арм с компаратора. Поэтому тут ещё стоит задача при преобразовании не увеличить количество ошибок, т.е. уровень чувствительности приёмника должен остаться тем же.
Go to the top of the page
 
+Quote Post
scifi
сообщение Apr 3 2009, 10:45
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(sergvks @ Apr 3 2009, 10:45) *
всё бы ничего, но в исходном потоке нет никаких синхро-последовательностей и может идти подряд до 30 нулей или единиц, да ещё и частота 19200 может плавать +-0.5%.
Посоветуйте c какой стороны лучше зайти ?

Вроде бы эта задача называется Clock And Data Recovery. Зайдите на сайты к Analog и Maxim, посмотрите на микросхемы, реализующие эту функцию (ADN2812, MAX3872, ..., - там есть хорошее описание принципа действия). Потом сделайте то же самое, но программным путём.
Go to the top of the page
 
+Quote Post
Nick Nickl's
сообщение Apr 3 2009, 13:58
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 62
Регистрация: 5-05-06
Из: Геленджик
Пользователь №: 16 811



На прошлой неделе реализовал прием и передачу по аналоговому радиотракту с использованием msp430, для удобства синхронизации использовал не обычный манчестер а его модификацию (их на самом деле их много) которая делает одну смену фазы на единицу и две смены фазы для передачи нуля. В этом случае проблем с синхронизацией вобще не стало. Можно начинать с любого места как будет поймана первая единица вы синхронизируетесь и далее уже можно использовать плавную подстройку фазы.
Go to the top of the page
 
+Quote Post

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

 


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


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