ВходНаше всё Теги codebook 无线电组件 Поиск Опросы Закон Понедельник
25 ноября
800227
Dingo (07.12.2017 06:39 - 06:45, просмотров: 1419)
Дали старый проект поковыряться. Любопытный способ упаковки данных 12бит => 8бит. Перекликается с кодами Элиаса. Данные с AD7892 со знаком пакуются в 8 бит со знаком. Результирующий байт делится на знак и два поля - группу порядка(экспоненты?) и собственно наиболее значащие биты: s eee bbbb eee кодирует количество "ведущих" нулей перед первой единицей как (MAX - n). Саму единицу хранить необходимости нет. Для положительных получается примерно так:
 SAMPLE RAW         BYTE

s1xx xx.. .... => s111 xxxx
s01x xxx. .... => s110 xxxx
s001 xxxx .... => s101 xxxx
s000 1xxx x... => s100 xxxx
s000 01xx xx.. => s011 xxxx
s000 001x xxx. => s010 xxxx
s000 0001 xxxx => s001 xxxx
Последняя строка любопытна тем, что число переходит в само себя, то есть используется не 4 бита, а 5. При этом погрешность восстановленного сигнала не превышает 6%, а поскольку кодер сделан на ПЗУ, то табличку дополнительно поправили, чтобы ещё уменьшить погрешности. Можно ещё сравнить с флоатом, затрамбованным в 8 бит, но здесь экспонента всегда положительная.
image