john72 Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Добрый день! Недавно начал изучать ПЛИС. Необходима ваша помощь в написании устройства, принцип которого схож с работой кнопки и D триггера. Нажатие на кнопку без фиксации - на выходе сего устройства - логическая 1, при отпускании кнопки, 1 удерживается. При повторном нажатии на кнопку - логический 0 на выходе устройства. И т.д. Типа кнопки on/off. Или реализовывать внутри плис это все на D триггере? Спасибо всем откликнувшимся. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
tcoder Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Больше на Т-триггер похоже... 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
20% скидка на весь каталог электронных компонентов в ТМ Электроникс!Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!Перейти на страницу акции Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849
Vascom Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 (изменено) Да, реализуй просто на триггере, который по приходу фронта от кнопки будет менять своё значение на противоположное. Изменено 29 ноября, 2013 пользователем Vascom 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>> Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161
tcoder Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 И про дребезг механических контактов самое время подумать. А то если кнопка сильно дребезжит может получиться многократное переключение, аки очередь, и ещё неизвестно в каком состояни оно будет после прекращения дребезга. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Vascom Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Да не, если длительность нажатия кнопки хотя бы в 100-1000 раз больше тактовой частоты, то дребезга в этом случае можно не бояться, всё устаканится. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
tcoder Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 (изменено) Аа, так это если D-триггер использовать. Я что-то про Т-триггер говорю - ведь именно он в первом посте описан. Хотя я что-то не совсем понимаю, какой толк тут от D-триггера. Если инверсный выход триггера подключен на вход D, а сигнал синхронизации берётся с кнопки - то причём тут частота.... разве что перед входом C поставить И, в который заведены кнопка и тактовая частота... Изменено 29 ноября, 2013 пользователем tcoder 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Vascom Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 (изменено) В общем как-то так мне это видится: Асинхронный. Сигнал кнопки является тактовым для триггера. reg out = 0; always @(posedge knob) out <= ~out; Синхронный. Сигнал кнопки лишь управляющий, при наличии другого тактового сигнала: wire knob; reg out = 0; reg knob_d = 0; always@(posedge clk) knob_d <= knob; //задерживаем сигнал от кнопки на один такт assign knob_edge = (knob^knob_d) & knob; //выделяем фронт и спад сигнала кнопки, и оставляем только фронт always @(posedge clk) if(knob_edge) out <= ~out; //переключаем выходной регистр по наличию фронта Изменено 29 ноября, 2013 пользователем Vascom 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
tcoder Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Во, асинхронный по-любому будет дребезжать вместе с кнопкой. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Vascom Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Согласен. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
john72 Опубликовано 29 ноября, 2013 Автор Поделиться Опубликовано 29 ноября, 2013 про дребезг думал, что-то буду придумывать. здесь есть материал на подобную тему http://www.fpga4fun.com/Debouncer.html http://www.labfor.ru/guidance/digital-leso2/debounce . Можно соорудить блок перед триггером. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Vascom Опубликовано 29 ноября, 2013 Поделиться Опубликовано 29 ноября, 2013 Ну а чем второй вариант не подходит? Там дребезга не будет. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
john72 Опубликовано 29 ноября, 2013 Автор Поделиться Опубликовано 29 ноября, 2013 наверное, всем подходит 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
john72 Опубликовано 29 ноября, 2013 Автор Поделиться Опубликовано 29 ноября, 2013 В общем как-то так мне это видится: Асинхронный. Сигнал кнопки является тактовым для триггера. reg out = 0; always @(posedge knob) out <= ~out; Синхронный. Сигнал кнопки лишь управляющий, при наличии другого тактового сигнала: wire knob; reg out = 0; reg knob_d = 0; always@(posedge clk) knob_d <= knob; //задерживаем сигнал от кнопки на один такт assign knob_edge = (knob^knob_d) & knob; //выделяем фронт и спад сигнала кнопки, и оставляем только фронт always @(posedge clk) if(knob_edge) out <= ~out; //переключаем выходной регистр по наличию фронта спасибо, не смог я скомпилировать объект, Quartus выдал 4 ошибки 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Vascom Опубликовано 4 декабря, 2013 Поделиться Опубликовано 4 декабря, 2013 Что за ошибки? Ну исправь их. Это я так, по быстрому на коленке написал, чтобы понятно было. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
tcoder Опубликовано 4 декабря, 2013 Поделиться Опубликовано 4 декабря, 2013 Это я так, по быстрому на коленке написал, чтобы понятно было. За последний год ситуация изменилась. Теперь нужно не помогать, а уже готовые рабочие проекты выдавать. Если вдруг не заработает, обязательно обидятся, а в худшем случае ещё и нахамят. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Рекомендуемые сообщения
Присоединяйтесь к обсуждению
Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.