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

Сжатие последовательности импульсов для экономии места


Tokes

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

Здравствуйте!
Делаю приёмник команд с ИК пультов, который не заточен под определённый протокол. То есть он ловит длительности сигналов, преобразует их в последовательности единиц и нулей и всё это дело хотелось бы сохранять в EEPROM. Использую маленькую старенькую 2313А, а памяти у неё там не много совсем. Если использовать решение в лоб - сохранять эти последовательности прямо в EEPROM - места едва хватит на две-четыре кнопки пульта. Хотелось бы хотя б восемь. Я предполагаю, что есть определённые алгоритмы сжатия, но не знаю, как подступить к этому вопросу. В одном из пультов последовательность команды передаётся в 72 битах (стартовые отбрасываются автоматически). Как сделать так, чтобы эту последовательность сжать, скажем, в пару байт? Что почитать на эту тему? Спасибо.

1.jpg

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

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

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

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

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

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

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

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

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

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

2 часа назад, Tokes сказал:

В одном из пультов последовательность команды передаётся в 72 битах (стартовые отбрасываются автоматически). Как сделать так, чтобы эту последовательность сжать, скажем, в пару байт?

Никак. Невозможно из 72-х "палочек" сделать 16, не потеряв информацию остальных 56-и.

Всё пройдет в этом мире: и слава, и богатство. И если ты вовремя не поделишься своим достоянием с другом, после твоей смерти оно достанется врагу.(с)Омар Хайям

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

Ну как же? Я тут взглянул на простой RLE и уже прикинул, что будет несколько экономичнее выглядеть ситуация. Остальные пока не смотрел подробно.

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

Я рассчитываю на то, что смогу принимать, запоминать и использовать команды с любого пульта ИК ДУ, кроме самых экзотических, где сверхкороткие или сверхдлинные импульсы.

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

Проще. Но вопрос стоял не в том, какой контроллер выбрать или как подключить внешнюю память, а в том, как сэкономить немного энергонезависимой памяти. 

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

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

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

Tokes, имхо, вы не с того конца ищите! Большинство алгоритмов сжатия достаточно сложны, чтобы крутить их на МК, тем более на ATtiny2313! Там просто не хватит памяти - как Flash, так и SRAM... К тому же, большинство компрессоров без потерь (Лемпель-Зив, к примеру) дают удовлетворительный результат только с относительно большими объемами данных, т.к. они ищут цепочки БАЙТ (а не отдельных БИТОВ), и кодируют их... Ими хорошо жать тексты, битмапы и т.п., а при сжатии очень маленьких файлов результат может быть даже обратным! А вот про сжатие отдельных битов, чтобы из восьми байт сделать два - такого я, извините, не слыхал... :D Кто такое придумает - тому Нобелевку дадут сразу же! ;)

Я советую Вам присмотреться к другой возможности - все AVR-ки имеют функцию selfy-prog, т.е. возможность обращаться к собственной flash-памяти, и писать туда любые данные (читать тоже можно). Почему бы не "запрятать" эти коды на флешку Вашего МК? Памяти у него аж 2 кб, я думаю, что свободное место должно остаться! "Сверху" - прошивка, а "вниз" пусть эта прошивка пихает все, что Вашей душе угодно! А EEPROM можно еще для чего-нибудь приспособить... Флешка у МК гарантированно выдерживает около 10 000 циклов записи...

Или, как Вам тут уже советовали, присмотритесь к I2C EEPROM-микросхемам - там есть модели на 4 кб и более - хватит, что называется, "за глаза и за уши"!

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

Если не пытаться "впихнуть невпихуемое", то есть охватить все телевизоры на свете, а остановиться на одном протоколе,например RC-5, то для запоминания кнопки достаточно одного байта. Ибо в пакете 14 бит, причём информацию несут только последние 6 бит. Остальные для любого телевизора одинаковые (читай стандарт).

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

@Prozac , мысль дельная, попробую. Ещё не работал с такой возможностью.

@oldmao , в первом посте написано - не под конкретный протокол. Я не стремлюсь охватить все телевизоры на свете. Я говорю про большинство бытовых пультов. А большинство укладывается в десяток протоколов. 

И тут было два варианта - либо делать автоопределение протокола, либо считывать длительности пауз и импульсов и формировать битовую последовательность. Я выбрал последнее, т.к. даже если будут изменены условия старта, стопа и т.п., всё равно последовательность можно будет распознать и запомнить. Даже с манчестером эта штука проканает, алгоритм сам определяет все возможные комбинации (до четырех на данный момент), при этом явно выбивающиеся длительности (как, например, в первом посте стартовые) игнорируются. Ещё хочу реализовать возможность запоминания двух последовательностей для одной кнопки, как флаг Т в RC-5. 

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

3 часа назад, Tokes сказал:

большинство укладывается в десяток протоколов

Назовите хотя бы пять! Мне в жизни только три телевизионных протокола встречались...

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

Ну вот опять. Я вам про бытовые, вы мне - про телевизионные.

http://www.sbprojects.com

Там меню есть, в нём список протоколов, и есть пункт "остальные протоколы". Читайте, ознакамливайтесь :)

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

Так непонятна ваша изначальная задумка. Про телевизор было упомянуто во втором же вашем посте, поэтому и подумал, что речь про универсальный пульт для телевизоров. Сделать один универсальный пульт для всего? Так они уже существуют в продаже, и недорого. Мне вот захотелось вместо двух пультов (от телевизора и спутникового ресивера) иметь один, сваял на ATtiny13A. Всего шесть кнопок: Громкость +/-, Каналы +/-, Выкл (одновременно ТВ и ресивер), Sleep-таймер телевизора. Команды сначала прочитал, потом зашил их жёстко в программу (обучение-то пульта мне не нужно). Полтора года назад вместо спутникового ресивера поставил DVB-T2 приставку, команды в программе поправил.
Вообще для большого количества команд можно любую EEPROM 24Схх, использовать, благо их бесплатно найти не проблема, их в бытовухе полно, от телевизоров до картриджей принтеров и планок памяти.

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

Алгоритм, позволяющий принимать коды с практически любых (скажем, порядка 90%) пультов ДУ, давным давно разработан, влезает не только в attiny2313, но даже в attiny13. Более того, существует несколько разновидностей алгоритма.

Мой детально и подробно описан в моей же статье на моём же сайте: http://arv.radioliga.com/content/view/219/43/ Мой алгоритм достаточно просто превратить в асинхронный, что так все любят, т.е. по прерываниям, хотя мне больше нравится исходный его вид :) Вот пример практического утрамбовывания этого алгоритма в attiny13 (сообщение на форуме, отправная точка проекта - первое сообщение в теме)

Альтернативы поищите сами, они есть. 

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

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

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

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

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

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

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

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

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

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

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

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

    • @READART Конкретно с LOGO не сталкивался, но у всех других, с кем сталкивался, программа всегда лежала во флеше. Да и хранить именно програмный код в энегозависимой памяти просто нелогично. Ионистор, скорее, может использоваться для отработки отключения питания, что-бы программа штатно могла завершиться, сохранив свое состояние.
    • А тема офигенно интересная. Рассуждать логически, в варианте А в среднем проводнике тока вообще практически нет и он нафиг не нужен. Во втором варианте по этим двум проводникам фигачит полный ток туда и обратно. Если хорошо свить, то по помехам одно...нно, только омические потери.  Дальше однозначного понимания у меня тоже нет. Я не выдающийся математик, мне нужен эксперимент. Например попробовать разорвать средний провод. Посмотреть куда подключены остальные цепи. Возможно у БЖТ асимметрия. Посмотреть как идут крайние провода обмотки, возможно раздвоенный средний компенсировал помеху от крайних.  ......  Не надо в подушку плакать, просто не нужно лезть с сегнетоэлектрикой в (калашный) звуковой ряд.
    • Да схема самая обычная, без всяких пиэфси . Вот примерная.  Но блочок все равно не заработал, при превышении нагрузки 50 ватт происходит перекос плечей и выброс. В одной клетке 50 вольт. Получается на одном плече 200 на другом 150.
    • @1960sae "Собирал когда то такой конструктор, запустился сразу....". блин. не могу управится с ним. все проверил. нашел пробитый конденсатор, поменял. питание от адаптера сделал 7,3в. регулятор четко 5,05 в держит. на ногах пика питание есть, на всех ногах тоже какая то напруга есть. ниче не греется, транзы холодные. но не работает и все. когда щупами проверял по выводам пика моргнули индикаторы один раз и все. осцилла нет. ума не приложу, интернет рою. пока нифига не смог победить. что смущает: по схеме (я выше здесь выложил) 8 резисторов (на индикаторы идут) по 220 ом, а в наборе они по 1 кОм (я их впаял).  может по прошивке другая частота запуска прописана, может с кварцем что не так. опыта не хватает, конечно, сообразить, куда рыть. буду перебором
    • Кто сказал? Откуда такие знания? Опишите механизм появления искаженного звука. Точно не надо.
    • Здравствуйте. Чтобы не открывать новую тему по примитивному вопросу. На фото выше справа вверху стоит ионистор. На этой плате никаких элементов памяти я не вижу, поэтому скорее всего питание с ионистора подается вверх - на плату с МК.   Правильно ли я понимаю, что ионистор нужен для хранения текущего времени, а рабочая программа хранится в eeprom или flash на плате с МК (или в кишках самого МК)? Вопрос связан с тем, что прежде чем чинить эту LOGO, надо знать, сохранилась ли в нем программа. А чтобы узнать, сохранилась ли в нем программа, надо иметь соответствующую приблуду. Приблуду можно сотворить и самому, но если программа все-таки хранится в sram с питанием от ионистора, то никакого смысла делать приблуду нет, как и чинить LOGO. Просьба просветить, кто в курсе месте хранения рабочей программы в siemens logo. LOGO само собой старый: 6ED1052-1MD00-OBA5  
×
×
  • Создать...