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

Кольцевой счётчик на D-триггерах.


Father Gregory

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

Кольцевой счётчик на D-триггерах с инверсным динамическим управлением и статической инверстной установкой и сбросом.

(К сожалению, все предложенные мной варианты отклонялись, может быть тут мне  смогут помочь. Спасибо.)

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

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

А выложить "отклоненные варианты" на рассмотрение - слабО?

Просят - не откажи. Не просят - не навязывайся!

Простота хуже воровства.

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

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

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

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

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

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

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

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

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

9 часов назад, Father Gregory сказал:

Кольцевой счётчик

Ну, начнём с того, что этот термин некорректен. Может быть кольцевой сдвигающий регистр. В некоторых малограмотных источниках его иногда действительно называют "кольцевым счётчиком", но это абсолютно безграмотно.

Применительно к счётчику понятие "кольцевой" неприменимо. Хотя все счётчики считают "по кольцу" - с переполнением.

Так что сначала определитесь, что именно нужно сделать.

 

Кольцевой сдвигающий регистр двухразрядный на D-триггерах с инверсным динамическим управлением и статической инверсной установкой и сбросом:

RLC.JPG.23c71f76a506d30b57f4cbbc0278bb45.JPG

Обратите внимание, что на второй регистр сигналы RES и SET заведены на другие входы. Если на все регистры завести одинаково, то будут устанавливаться или все единицы, или все нули, и никакого сдвига кода фактически не будет. Сигналы RES и SETиспользуются для задания начального кода, который потом будет циклически сдвигаться В данном примере начальный код при RES - 01, при SET - 10. Если нужен регистр большей разрядности, просто добавьте в цепочку ещё триггеров, сколько требуется.

Можно управляющие входы не объединять, а на каждый триггер подавать свой сигнал установки и сброса.

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

Есть ещё вариант, использующий кольцевой сдвигающий регистр, - генератор псевдослучайной последовательности (ПСП). В этом сдвиговом регистре сигнал обратной связи (с выхода на вход) модифицируется так, чтобы при сдвиге перебирались все возможные для данного количества разрядов коды, за исключением только одного "запрещённого". Так как перебираются почти все возможные коды (хотя и в псевдослучайном порядке), то этим эта схема, в принципе, похожа на счётчик, но вряд ли в задании имелась в виду она.

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

@Lexter

Сдвиговые регистры. Кольцевые счётчики на D-тригггерах с инверстным динамическим управлением и статической инверстной установкой и сбросом, таблицы переходов.

(в точности задание звучало так)

В любом случае спасибо.

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

@LexterА вы не могли бы помочь с временными диаграммами к этой схеме?

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

@Father Gregory , ну тут уж сами, сами. :)

Рисуете импульс установки RES или SET, появление соответствующего кода на выходах Q, а потом изменения кода по спадам (по задним фронтам) тактового сигнала CLK.

...

Хотя да... Судя по вашей диаграмме к кольцевому сдвиговому с инвертором, строить диаграммы вас не учили.

DIA.thumb.JPG.dc09eb4a53c26227a1c49180a51bdb01.JPG

Обратите внимание, что спад первого импульса CLK не изменил выходы, так как попал на сигнал RES, который устанавливает выход уровнем и имеет приоритет над сигналом CLK. До начала сигнала RES состояние выходов Q не определено, так как неизвестно, что было ранее.

Вот как-то так. Неточности в обозначениях сигналов RES/R,  CLK/C и т.д  поправьте. Делал, естественно, наспех. :)

И ещё: в слове "инверсный" нет буквы "т".

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

Кольцевой счётчик - это название для краткости. Кольцевой регистр, который используется как счётчик.

Когда-то  давно, сделал себе часы на таких кольцевых регистрах, которые до сих пор идут. В основе была именно  эта схема.

Ей не нужен дешифратор при использовании газоразрядных индикаторов. Также можно использовать низковольтные транзисторы типа КТ315 вместо высоковольтных.

Может она чем-то поможет.

:5c628edfb7962_.thumb.jpg.9d2a3ea365618fd5995cc4634e56065f.jpg

 

 

" Вызывает интерес Ваш технический прогресс " ( Л. Филатов )

А, на ругань жалко буквы тратить

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

Заняться нечем, кроме  как лезть в чужую судьбу?

Схема перерисована из первоисточника лет 40 назад, вот скрин , ищите ошибки , высокограмотный Вы наш

5c63035a3c9eb_.jpg.9b63b705fea178180c3b4644cc03de5c.jpg

Изменено пользователем Юный пионер

" Вызывает интерес Ваш технический прогресс " ( Л. Филатов )

А, на ругань жалко буквы тратить

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

13 часа назад, Lexter сказал:

Ну, начнём с того, что этот термин некорректен

спорный вопрос

кольцевой счётчик на D-триггерах очень удобная штука

основное достоинство - синхронная работа всех триггеров по счётному входу и соответственно 

максимальная рабочая частота счёта

есть сложности с дешифрацией результата - но я так понимаю что вопрос не в этом.

самое простое построение - цепочка из последовательно соединённых по D триггеров, 

кроме последнего, с которого инверсный сигнал возвращается на вход первого

но могут быть варианты

можно пустить паровозик и из одного импульса по кругу

для этого используется элемент И-НЕ с количеством входов равным количеству триггеров

в общем элементарная и очень изящная штука.

на приведённом выше рисунке 4 собственно кольцевой счётчик на триггерах собран на элементах

D1.2 - D3.2

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

6 минут назад, next sound сказал:

в общем элементарная и очень изящная штука.

Ещё оказалась и помехоустойчивая. 

Понадобилось сделать электронный счётчик мелких радиодеталей для автомата упаковки в цехе с большим уровнем индустриальных помех.

Применил эту схему, но опасался, что помехи повлияют на её работу и появятся лишние импульсы. Удивительно, но за несколько лет работы ни одного сбоя не было зафиксировано.

Потом сделал себе часы на её основе.;)

" Вызывает интерес Ваш технический прогресс " ( Л. Филатов )

А, на ругань жалко буквы тратить

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

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

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

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

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

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

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

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

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

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

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

    • #include <Wire.h> #include <Oregon_TM.h> #include <BME280I2C.h> //////////////////////////////////////////////////////////////////////////////////////////////////////////// //Скетч для устройства, передающего данные датчика BME280 в формате Oregon Scientific THGN132N //Принципиальная схема прилагается. //Для работы необходима библиотека https://github.com/finitespace/BME280/ //Устройство работает от 3-ех пальчиковых батареек, для экономии электричества заливать скетч нужно через ISP //////////////////////////////////////////////////////////////////////////////////////////////////////////// //Также возможна передача данных в формате - THP (температура, влажность, давление, напряжение батареи) //Пример с приёмником поддерживает расшифоовку THP //////////////////////////////////////////////////////////////////////////////////////////////////////////// # define THGN_SEND 1 // Передавать ли данные в формате THGN132 # define THP_SEND 0 // Передавать ли данные в формате THP # define DEVICE_LOG 1 //Писать ли лог В Serial # define DONE_PIN 15 // вывод сигнала об окончании работы на таймер # define BME_WAIT 10 // Сколько мс ожидать датчик BME # define BATTERY_THR 3.5 // Порог напряжения для выставляения флага разряда батарейки (THGN) ///////////////////////////////////////////////////////////////////////////////////////////////// //Ниблы датчика THP //Во всех полях младшие ниблы идут вперёд!!! // 1-2 - тип (55) // 3 - канал (0-7) // 4-6 - (температура от -100С) * 10. Т.е. +25.1С = 1251 = 4E3h // 7-9 - Влажность *10 Т.е. 25.1% = 251 = 0FBh // 10-12 - (давление от 500ммртст) * 10. Т.е. 765мм = 2650 = A5Ah // 13-15 - данные с АЦП (A0) // 16-17 - CheckSUM // 18-19 - CRC8 (poly 0x07 start 0x00) ///////////////////////////////////////////////////////////////////////////////////////////////// Oregon_TM transmitter(4); BME280I2C bme; bool bme_present = false; float bme_temp(NAN), bme_hum(NAN), bme_pres(NAN); ///////////////////////////////////////////////////////////////////////////////////////////////// void setup() { digitalWrite(DONE_PIN, LOW); pinMode(DONE_PIN, OUTPUT); #ifdef DEVICE_LOG Serial.begin(115200); Serial.println("Waiting for BMEsensor..."); #endif //Обмен данными с BME////////////////////////////////// Wire.begin(); while(!bme.begin()) { if (millis() > BME_WAIT) break; } if (!bme.begin()) { #ifdef DEVICE_LOG Serial.println("No BME sensor found"); #endif bme_present = false; } else { switch(bme.chipModel()) { case BME280::ChipModel_BME280: bme_present = true; bme.read(bme_pres, bme_temp, bme_hum); #ifdef DEVICE_LOG Serial.println("Found BME280 sensor! Success."); Serial.print("Temperature = "); Serial.print(bme_temp, 1); Serial.println("C"); Serial.print("Humidity = "); Serial.print(bme_hum, 1); Serial.println("%"); Serial.print("Pressure = "); Serial.print(bme_pres * 0.75, 1); Serial.println("mmHg"); #endif break; default: #ifdef DEVICE_LOG Serial.println("Found UNKNOWN sensor! Error!"); #endif bme_present = false; } } //Напряжения батареи/////////////////////////////////////////// word battvotage = (word)(((float)(1.1 * 16368) / Vbg()) * 100); #ifdef DEVICE_LOG Serial.print("Battery voltage = "); Serial.println(battvotage,HEX); #endif //Подготовка и отправка данных THGN////////////////////////////////////// transmitter.protocol == 2; if (THGN_SEND) { transmitter.setType(THGN132); transmitter.setChannel(3); transmitter.setBatteryFlag(battvotage < BATTERY_THR); if (bme_present) { if (bme_hum > 98) bme_hum = 98; if (bme_hum < 2) bme_hum = 2; if (bme_temp > 70) bme_temp = 70; if (bme_temp < -50) bme_temp = -50; transmitter.setTemperature(bme_temp); transmitter.setHumidity(bme_hum); transmitter.setComfort(bme_temp, bme_hum); } else { transmitter.setTemperature(-49.9); transmitter.setHumidity(2); transmitter.setComfort(-49.9, 2); } transmitter.SendPacket(); } // Если отправляются оба формата пакетов, межу ними надо выдержать паузу if (THP_SEND && THGN_SEND) delay(100); //Подготовка и отправка данных THP////////////////////////////////////// if (THP_SEND) { transmitter.setType(THP); transmitter.setChannelTHP(1); transmitter.setBatteryTHP( battvotage); if (bme_present) { transmitter.setTemperatureTHP(bme_temp); transmitter.setHumidityTHP(bme_hum); transmitter.setPressureTHP(bme_pres * 0.75); // перевод Pa в mmHg } else { transmitter.setErrorTHP(); } transmitter.SendPacket(); } #ifdef DEVICE_LOG Serial.println(); Serial.print(millis()); Serial.println("ms"); Serial.println(); #endif //Команда на отключение питания digitalWrite(DONE_PIN, HIGH); } ///////////////////////////////////////////////////////////////////////////////////////////////// void loop(){} ///////////////////////////////////////////////////////////////////////////////////////////////// int Vbg() { ADMUX = (1<<REFS0)|(0<<REFS1)|(1<<MUX3)|(1<<MUX2)|(1<<MUX1)|(0<<MUX0); long buffersamp=0; for (int n=0x0; n<=0xff; n++ ) { ADCSRA = 0xc7; while (bit_is_set(ADCSRA,ADSC)); buffersamp += ADC; } buffersamp >>=4; //16368 full scale 14bit ADCSRA &= ~(1 << ADEN); // отключаем АЦП return buffersamp; } Вот код программы. Пробовал по разному и от 5в запитывал и всю систему от 3,3 в. Причем голая ардуинка с таймером работает в нормальном режиме некоторое время, но потом все равно слетает и начинает питать мк постоянно( Причем это происходит всегда через разный промежуток времени.
    • На фото может быть название , характеристики и т.д. И по этому фото я смогу выбрать такой же в инете.. самому мне не собрать..
    • А что даст фотка? Тот же щуп, только чуть крупнее и с проводами питания.
    • Для меня наверное лучше купить готовый.. цель повысить чувствительность до 1 mV.. Наверное на Авто стоит покупать , мне бы фотку какую нить..такого активного щупа..))
    • Так на схемах обозначается подключение к сети 220 В.
    • Привет, радионарод! Вот, решил показать, рассказать и дать попробовать свою придумку, как я внешнюю синхронизацию к "ослику" прикрутил. DSO138 уже не так популярен, но кто-то пользуется, кому-то быть может пригодится. Подробной информации по таким доработкам в сети не встречал, так что делюсь, чем сам измыслился. Собственно, схема. Немного фоточек. С "ослика" не пугайтесь, не умею я делать красивые корпуса с красивыми мордами лица к ним. Двухканального функционального генератора с возможностью двигать фазу у меня нет, поэтому какая-то программа-генератор из Интернетов, звуковая карта и DSO138. Смотрим синус, т.к. меандр из звуковухи никакой. Конечно, видна погрешность в измерениях. Прибор-то - игрушка. Да и генератор не блещет точным сигналом. Полноценного аналога внешней синхронизации (как у аналоговых приборов) не получится, но даже в таком виде эта доработка расширяет функционал осциллографа и дает в некоторых случаях возможность изучать два сигнала. Как пользоваться. Из иных доработок. Как видите, дурацкие ползунковые переключатели заменены на сдвоенные галетники на три положения. Кнопки поставлены большие тактовые 12х12 мм. Подпаяны паралельно, старые удалять не нужно. Светодиод тоже в паралель. Питание батарейное, от аккумулятора старого "умнофона". Полтора ампер-часа, наверное. Плата зарядки, плюс повышайка с фильтрами по питанию. Корпус алюминиевый от "не-знаю-как-правильно-называется", там жесткий диск стоял с парой ветродуйчиков. Гетинакс, оргстекло.   Короче, удачи!
×
×
  • Создать...