Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

А по аппаратной реализации с контролем прошлого состояния..

Отправлено POV (217.150.45.109) 20 июля 2010, г. 11:10
В ответ на: Дык, может попроще обработчик сделать?... отправлено POV 20 июля 2010, г. 11:05

гемморно на тригеррах. Много получится всего, уж лучше на ПЛИСине. Реализация банальнейшая:

-- определение момента изменения состояния энкодера
front = ((lst_lir0.q XOR lir0) OR (lst_lir1.q XOR lir1));

-- Сохранение прошлого состояния энкодера и тактирование счётчика
lst_lir[].d = lir[];
lst_lir[].clk = front;
cnt_lir.clock = !front;

-- устанавливем направление на весь такт
cnt_lir.updown = DFF(twrd, enbl AND empty,,);
code[3..2] = lst_lir[1..0].q; code[1..0] = lir[1..0];
TABLE
code[] => twrd, enbl;
0 => X, 0;
1 => 0, 1;
2 => 1, 1;
3 => X, 0;
4 => 1, 1;
5 => X, 0;
6 => X, 0;
7 => 0, 1;
8 => 0, 1;
9 => X, 0;
10 => X, 0;
11 => 1, 1;
12 => X, 0;
13 => 1, 1;
14 => 0, 1;
15 => X, 0;
END TABLE;


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 63:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru