LRS модуль Expert RC 433 MHz
На дальность влияет передача 8 или 9 бит , вот и вся разница…
Вы это серьезно ? Сами пробовали или просто так - поддержать разговор ?
Вы это серьезно ? Сами пробовали или просто так - поддержать разговор ?
Саш, ну чел верно написал!
Данных больше?- больше, а передавать надо по времени также?- также, значит скорость нужно больше?-больше. а чем выше скорость тем ниже чувствительность избирательность итд- и результат- дальность.
Ну это при каких объемах информации и при каких расстояниях ?
Никто же на 600 км не собирается летать (даже теоретически) ?
Просто давайте сравним с той же Futaba - разрешение 1024, расстояние тоже не маленькое ! А с бустером - так и подстать LRS.
Данных больше?- больше, а передавать надо по времени также?- также, значит скорость нужно больше?-больше
А сжимать данные не пробывали?
8 байт сжимать?
8 байт сжимать?
Да, если Вам дорог каждый бит. Посмотрите хотя-бы PCM протоколы, как там делается увеличение чиcла каналов или разрядности без уменьшения времени отклика.
Если интересны методы сжатия, могу поделится опытом, но для этого нужно знать хотя-бы структуру Вашего пакета, что как я помню - строжайшая коммерческая тайна. 😃
причем тут структура пакета, Вы скажите как сжать, а уж как передать я придумаю
а почему бы просто не применить чтото типа ADPCM?
в центре хода сервы сделать больше значений, а по краям более дискретно.
причем тут структура пакета
Нужно знать, может ли пакет быть переменной длины, как Вы кодируте биты (я имею в виду размазывание по спектру, если оно есть), и метод скремблирования данных (если используется)?
В приближенном виде, хотя бы так: в номинале 2 байта, два канала, в сумме 16 бит. В четном пакете передаем полный 1 канал, и 4 бита разницы 2-го, в нечетном - наоборот. В итоге посылаем уже 12 бит за раз.
Если использовать какой-нибудь law типа мю или альфа и предсказание след. положения (пример - звуковой кодек ADPCM, который работает даже на ATmega), получим сжатие еще больше. Реально ведь ни один пилот не сможет перекладывать ручки туда-сюда каждые 20 мс. Зато можно увеличить таким образом разрядность мелких перемещений на 20% бесплятно 😉 (до 1024 положений, как во фхутабе)
8 бит реально дерготня, даже “на куске пены с метровыми зазорами”, и сервы постоянно жужжат из-за ошибок квантования.
ничего такого нет,если очень грубо- каждый пакет 8 байт(по байту не канал) +срс (не считая всяких преамбл и служебки)
Еще простейщая идея - разделить каналы на полноценно аналогове (4-6) и псевдо дискретные (все равно в FPV половина команд управляюще, на 2-8 положений). Первые кодировать 12-ю битами остальные 3-мя.
В приближенном виде
Я исходил изначально что связи почти нет, т.е. любой пришедший пакет в приёмник сможет им полностью рулить.
Хотел бы этим дальше и руководствоваться. Все эти алгоритмы работают только если связь уверенная и потерь нет.
ничего такого нет,
А битстаффинг хотя бы есть? Плохо себе представляю как можно долго удерживать битовую синхронизацию на вырожденных данных (типа все нули)?
“Первые кодировать 12-ю битами остальные 3-мя.”
Идея хорошо подходит для ФПВ. ну или сделать настраиваемыми какие каналы псевдодискретные.
Все равно телеметрия иглов (2 тумблера), фишка - это все дискретные каналы… по идее полноценных нужно 4-5 всего то.
Дима, прокоментируй плиз эту идею.
в принципе да, тока не 12 а 10 максимум бит -заглаза.
тогда хотим 😃 на 10 бит первых 5 каналов согласны, остальные 3 бит дискретные будут за глаза.
Если что подправить потом кому нибудь прошивку на ±1 полноценный канал это раз плюнуть, зато общий объем передаваемых данных даже меньше будет чем все каналы по 8 бит а выигрыш налицо.
Только надо сразу как-то защититься чтобы при потерях связи эти дискретные каналы не прыгали и не переключали телеметрию!
тогда хотим на 10 бит первых 5 каналов согласны
точно. и еще останется битов под простенькую коррекцию ошибок.
и еще останется битов под простенькую коррекцию ошибок.
Для пакета длиной порядка 100 бит, длина корректирующего кода Рида-Соломона = log2(N)+1, то есть 8 бит. Позволяет исправлять одиночные ошибки. Но на каналах с BER > 10-3 практически бесполезен.
на 10 бит первых 5 каналов согласны
на газ и рудер зачем например 10 бит? я бы понял на трекер чтоб камера плавно шла
по поводу канала газа согласен, можно и 8 бит оставить, а руддер я бы всеже сделал 9-10 бит. и 2 канала на трекер. и того надо 6 пропорциональных выходит.
плюс еще надо като учесть, что могут быть аппы в которых первые управляющие каналы (THR ELEV RUD AIL) не первые по очереди.
Может сразу имеет смысл заложить возможность настройки разрядности каналов в пределах заданного количества бит.