Перейти к содержанию

Кнопка С Фиксацией, Реализация На Плис


john72

Рекомендуемые сообщения

Добрый день!

Недавно начал изучать ПЛИС. Необходима ваша помощь в написании устройства, принцип которого схож с работой кнопки и D триггера. Нажатие на кнопку без фиксации - на выходе сего устройства - логическая 1, при отпускании кнопки, 1 удерживается. При повторном нажатии на кнопку - логический 0 на выходе устройства. И т.д. Типа кнопки on/off. Или реализовывать внутри плис это все на D триггере?

Спасибо всем откликнувшимся.

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Да, реализуй просто на триггере, который по приходу фронта от кнопки будет менять своё значение на противоположное.

Изменено пользователем Vascom
Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

И про дребезг механических контактов самое время подумать. А то если кнопка сильно дребезжит может получиться многократное переключение, аки очередь, и ещё неизвестно в каком состояни оно будет после прекращения дребезга.

Ссылка на комментарий
Поделиться на другие сайты

Да не, если длительность нажатия кнопки хотя бы в 100-1000 раз больше тактовой частоты, то дребезга в этом случае можно не бояться, всё устаканится.

Ссылка на комментарий
Поделиться на другие сайты

Аа, так это если D-триггер использовать. Я что-то про Т-триггер говорю - ведь именно он в первом посте описан.

Хотя я что-то не совсем понимаю, какой толк тут от D-триггера. Если инверсный выход триггера подключен на вход D, а сигнал синхронизации берётся с кнопки - то причём тут частота.... разве что перед входом C поставить И, в который заведены кнопка и тактовая частота...

Изменено пользователем tcoder
Ссылка на комментарий
Поделиться на другие сайты

В общем как-то так мне это видится:

Асинхронный. Сигнал кнопки является тактовым для триггера.

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; //переключаем выходной регистр по наличию фронта

Изменено пользователем Vascom
Ссылка на комментарий
Поделиться на другие сайты

про дребезг думал, что-то буду придумывать. здесь есть материал на подобную тему http://www.fpga4fun.com/Debouncer.html http://www.labfor.ru/guidance/digital-leso2/debounce .

Можно соорудить блок перед триггером.

Ссылка на комментарий
Поделиться на другие сайты

В общем как-то так мне это видится:

Асинхронный. Сигнал кнопки является тактовым для триггера.

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 ошибки

Ссылка на комментарий
Поделиться на другие сайты

Это я так, по быстрому на коленке написал, чтобы понятно было.

За последний год ситуация изменилась. Теперь нужно не помогать, а уже готовые рабочие проекты выдавать. Если вдруг не заработает, обязательно обидятся, а в худшем случае ещё и нахамят.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Ну вот, пока готовил эскиз, на все вопросы ответили :-) Действительно, в 3D моделях DipTrace нет (или не нашёл) модели корпуса ТО220 с распайкой с нижней стороны и креплением к радиатору - по этому и получился такой 3D-портрет платы. Задуманная конструкция выглядит примерно так:  По факту, для наладки, сейчас подключаю транзисторы, закрепленные на радиаторе, проводами.
    • Чтобы потом не допиливать паровоз до истребителя. Заводские варианты схемотехники куда более предсказуемы. Из "вольностей" в первую очередь как-то решать проблему коммутации, подходящий переключатель для режимов искать история долгая и грустная. Что-то там с реле. На диапазоны 6п4н вроде же ?  пг2 хрен найдёшь, п2г тугое неудобство(  Рассыпушный ацп делать, боже упаси. Ну разве что был грешен, побаловался когда-то пнч-ацп. С 1108пп1 и 155 серией
    • Но зачем повторять 1в1? Там дана просто топология   Но не совсем же с нуля. Маловероятно, что вы найдете расширение диапазона 7135 до 200мВ по тому же методу, что это реализовано в В7-38, тем не менее, это вполне реализуемо. А вот до 20мВ я спустить диапазон не смог Что-то предусилитель интегратора отказывается вести себя хорошо   Для сравнения, та же точка (вход интегратора) при 200мв пределе, усиление х10   Ну и 2В Госпаде боже лтц2400, на этой штуке можно и 6 разрядник собрать, лютый АЦП, какие 4.5 разряда Цена на него сейчас конечно негуманная кстати.
    • Что то не нашёл примеров такой реализации замены. С нуля целесообразность подобного действа под вопросом. Тут мои полномочия всё) Как бы почему смотрю на hm8011-3, возможность реализации +/- норм настольного мультиметра без всякой там жести в виде кодинга и микро-мелких современных элементов. Для калибровки валяется где-то в1-12 и прецизионных резисторов если моих не хватит, есть где заказать.  На данный момент разве что качественного файла нет, пытался там всякими улучшайками чего сделать, увы. Пойду через впн лазить по уголочкам всяким, вдруг всплывёт чего. ------------- 8012, 80c32 + 27c512. Чертежи плат есть, осталось hex раздобыть 
    • Вот на этом фото? Я думал  тут радиатор будет под ними, и они к нему "пузом" будут прикручиваться, а дырочки - для отвёртки. У @asng60 транзисторы в наружную сторону "мордой" смотрят. "Пузом" на плату ложатся. Плата так разведена. Вот и непонятно, как их "пузом" к радиатору прикручивать.
    • Что касаемо модели Парафина, я бы порекомендовал товарищу Джексону проверить ток покоя выходного каскада, это первым делом, и вторым делом- проверить модель ОУ. Ибо в ОМ нет никаких оу а в парафине- есть. 
×
×
  • Создать...