flybrain. передатчик + приемник + автопилот. powered by stm32

smalltim
AlexSneg:

И еще такая мысль. Уж если идти в сторону общей шины, то никак не SBUS.

CAN?

AlexSneg

Реальный CAN требует два пуда обвязки и слой гуталина. Там трансиверы нужны и приемники, если по уму. А если без этого, то все превратиться в банальный 485й. В качестве физики я вижу стандартный UART только делать его надо тупо и в лоб, и на скорости не выше 36к.Тогда на серву достаточно будет мелкой приблуды, замаскированной под стандартный шлейф. AtTiny на 8 ног + кварц + пара кондеров + 2 разъема, ВСЕ!. НО зато все можно будет соединить в звезду. Каждой серве назначаем свой адрес, она сама свою инфу вычитывает. Сделать протокол программирования адреса. Примерно так же и в SBUS сейчас, только там скорость сверхзвуковая и инверсия аппаратная, чтобы враг не догадался. Еще там кривой вариант с детектированием начала фрейма. Только одному это делать - ну его на фиг, если народ подключится и добавит поддержку выработанного совместно протокола, то буду участвовать и к себе поддержку добавлю. Стоимость одной такой приблуды на серву выше 150руб не будет, даже если в розницу все брать, я уже прикинул. Но нам в тиньку нужен программный UART, аппаратного там нет.

smalltim
AlexSneg:

Реальный CAN требует два пуда обвязки и слой гуталина.

www.compel.ru/catalog/interface/can/

Милости просим, драйверы на любой вкус, 1 SOIC8 на девайс. Жрут как кони, но если делать по-взрослому, то извольте мириться с потреблением.
Я у себя CAN интерфейс вывел на разъем доп. функций.

А если подешевле и поближе к народу, то, мне кажется, I2C, и придумывать ничего не надо. И на Тиньке сделать его можно спокойно.

Федор_Иванович

Смысла делать УАРТ (как и И2Ц) для раздачи каналов на сервы нет никакого. Самопальная шина на УАРТе получается малоскоростная, ненадежная при проблемах на узлах, переходник на серву все равно нужен, что с КАНа что с УАРТа. Ну да, с УАРТа немного дешевле, но это почти тупик. Да и И2Ц хороша только внутри одного прибора между блоками, а не между приборами. Не верите - посмотрите на проект Microkopter - сколько там вопросов вызывают регули на И2Ц. Зато когда захотите расширять проект, КАН у вас будет на все случаи жизни. Защищенность от разного потенциала земель, не выходит из строя при ошибках в подключении (некоторые драйверы КАНа до 80 вольт по входу держат), реалтайм арбитраж и уже заранее заложенное сглаживание фронтов для повышения ЭМС. Ни на УАРТе, ни на И2Ц ничего подобного не получить.

AlexSneg

Нарисуйте схему трансивера CAN со всем сопутсвующим прицепом и прослезитесь. Какие напряжения вы там гонять собираетесь? CAN - это 2 провода + земля + питание+трансивер+МК (не слабый причем)+обвес из барахла. I2C - это 2 провода + земля + питание + 1МК + задница в протоколе, который не может быть сам восстановлен. UART - это 1 провод и голая ножка МК + crc16 + земля + питание + 1МК, а дальше вперед и с песней. Футаба работает через UART, ничего не глючит. Нам не нужны большие скорости, чтобы сервами управлять. Нам нужно устройство простое как валенок и дешевое, как туалетная бумага.

smalltim:

Я у себя CAN интерфейс вывел на разъем доп. функций.

А толку? А можешь конкретно сказать, что ты на него планируешь повесить и каким способом хотя бы в теории? Сервы? Как? Преобразователь на каждую серву CAN->PWM ? Подключать доп. устройства? Какие? у тебя же все на одной плате в сборе, чего там еще подключать?

smalltim
AlexSneg:

А толку? А можешь конкретно сказать, что ты на него планируешь повесить и каким способом хотя бы в теории? Сервы? Как? Преобразователь на каждую серву CAN->PWM ? Подключать доп. устройства? Какие? у тебя же все на одной плате в сборе, чего там еще подключать?

Да всякое. Забей.

baychi

Учитывая, что CAN присутствует только в старших типах микроконтроллеров, использоввать его для массовых элемментов РУ: сервы, регули, реле всякие не получится.
Да и все ухищрения физики и протокола на расстояних порядка неск. метров - как из пушки по воробьям.
ИМХО, на моделе достаточно PPM/PWM, UART и I2C для всех видов обмена. Просто и надежно.

Федор_Иванович

Обвязка КАНа проста и недорога. Трансивер в корпусе SO-8 и пара-тройка резисторов. Но с позиции цены шину даже на УАРТе городить не надо, РРМ прост как валенок и не стоит вообще ничего, вполне еще поработает. По поводу “ухищрения физики и протокола на расстояних порядка неск. метров - как из пушки по воробьям” расскажите это сообществу коптероводов, у которых на 30 см шины И2Ц без вдумчивой разводки земель и экранирования постоянно ошибки сыпятся, а при крашах и как следствие КЗ между шиной и питанием процы горят.

smalltim

Я спорить не стал, пусть автор проекта решает, это его проект.
К тому же, проблемы квадров с их регулями на I2C - это, всё-таки, проблемы квадров.

Dikoy
smalltim:

то, мне кажется, I2C, и придумывать ничего не надо. И на Тиньке сделать его можно спокойно.

+1

Федор_Иванович:

Не верите - посмотрите на проект Microkopter - сколько там вопросов вызывают регули на И2Ц.

Ой да ладно!
У меня AVRDragon столько вопросов вызывал, пока не допилил его напильником. По JTAG отказывался шить на кабеле длиньше 10 см. А это таки фирменный девайс.
Кто знает кто и как проектировал ту I2C? Стоят ли там резисторы в линиях на 16-20 ом, какой провод использован для связи? Какие номиналы подтяжки? И т.д. Звон, стоячую волну кто-нить смотрел осциллом?
Нормальный И2Ц на 400 кГц работает на 30 см стабильно. Уменьшаем скорость - увеличиваем дальность. Нам ше надо обеспечить 50 Гц на серву, а это фигня.
Прелесть КАНа в том, что он не теряет протоколы при коллизиях. Но это актуально при многомастерной системе, при одномастерной это такой же 485. Только переменное напряжение высокой частоты в проводах гоняется.

AlexSneg:

UART - это 1 провод и голая ножка МК + crc16 + земля + питание + 1МК, а дальше вперед и с песней.

+1
Обычный TTL UART, это до метра провода. И, в отличие от SPI и I2C, он нечувствителен к звону в линиях. только вероятность ошибки возрастает, теоретическая, т.к. может выпасть один сампл из 16.
Но у СТМ можно настраивать время нарастания сигнала на ногах, этим можно пользоваться.

Федор_Иванович:

у которых на 30 см шины И2Ц без вдумчивой разводки земель и экранирования постоянно ошибки сыпятся, а при крашах и как следствие КЗ между шиной и питанием процы горят.

Как говориться, las manos cresen del culo. Раз даже процы горят.

hav22
AlexSneg:

Небольшая демка того, что на подходе
разрешение 376x220

Выглядит неплохо. Это будет работать на текущей ревизии платы АП или подразумевается новое железо?

SkyWorker
hav22:

Выглядит неплохо. Это будет работать на текущей ревизии платы АП или подразумевается новое железо?

Будет работать на текущей. Осмелюсь ответить за Алексея… 😃

AlexSneg

Никаких новых железок не нужно, работать будет в текущей железке. Это разрешение еще не предел, можно еще раздвинуть, но мне пока памяти жалко.

hav22

Алексей, у меня возник вопрос (скорее на будущее). Не думал ли ты реализовать возможность управления антенным трекером? Например передавать GPS координаты через обратный канал (с самолета на землю) или генерить аудио сигнал с закодированными данными и передавать его через аудио канал AV передатчика для поддержки существующих трекеров типа ImmersionRC или Eagle Tree?

AlexSneg

Сейчас мысли крутятся вокруг схемы будущего треккера со следующими возможностями на плате:

  • три сервы. Две под pan/tilt + 1 под вариант для подстройки поляризации. Наклон самолета относительно горизонта будет известен, соответственно будет информация для переориентации антенны, почему бы ее не использовать. Не факт что будет полезный выхлоп. Если не получится, будет просто запасной сервоканал.
  • автоматический подбор уровня компаратора для декодирования полезного сигнала из видеопотока. Переменных резисторов точно ставить не буду.
  • RFM модуль на прием обратного канала с самолета, для подстраховки пропавшего видео. Кроме того можно будет реализовать управление треккером с пульта самолета. Тогда можно будет поставить 2 направленных антенны - видео + радиоканал. при необходимости организовать радиоканал Пульт-Треккер-Самолет. На пульте антенна обычная, а на треккере направленная
  • видео вход от приемника обычного
  • видеовыход буферизированный (2 штуки)
  • shield разъемы под насадку платы приемника на 5,8ГГц (эта платка уже изготовлена и едет ко мне). Антенну буду цеплять через ВЧ фидер типа RG178. Не факт, что решение будет удачным, но я хочу попробовать.
  • usb разъем для подключения к PC
  • разъем usart/i2c/SPI для расширения типа синего зуба.

опционально:

  • добавить в схему таки к RFM модулю еще и бустер, как в пульте, чтобы можно было прямо с треккера сигнал посылать и сидеть за ноутом, а пульт выключить после взлета

про диверсити пока не очень понятно по криериям переключения и технологии разветвления. Это либо два приемника надо иметь, либо RSSI с видеоприемника. Но можно заложить без проблем вариант с двумя видеовходами для двух приемников и переключаться между ними. Здесь нет проблем.

Вообщем по треккеру принято пока только концептуальное решение, что он будет сделан. Но по плану сейчас

  1. ОСД в массы. Завтра думаю будет новая прошивка на сайте.
  2. Добавление в ОСД экранного меню
  3. Контрольная панель
  4. Передатчик. Платы уже едут ко мне. Думаю в середине февраля начну сборку. К новому сезону хочу иметь уже обновленную аппаратуру.
  5. треккер
hav22:

и передавать его через аудио канал AV передатчика для поддержки существующих трекеров типа ImmersionRC или Eagle Tree?

У меня пробел в познаниях существующих треккеров. 😃 ОК. Аппаратно я заложу возможность вынуть цифровой поток из аудиоканала. Но программную поддержку пока только в список хотелок в самый конец могу добавить.

Syberian

Алекс, синус-косИнус у тебя табличные или процедурные?

AlexSneg

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

AlexSneg

Выложил долгожданные обновления прошивки в разделе download:

  • Перерисовано OSD. Добавлено разрешение экрана 384x220. Переключение между режимами OSD при помощи переменной OSD_Resolution_Mode.
  • Для настройки OSD можно задать режим принудительной зарисовки всех возможных элементов даже без присутствия приемника. См. OSD_Force_Show.
  • Для облегчения понимания где граница экрана, теперь можно засветить бордюры OSD_Show_Outline_Border
  • Для нового разрешения OSD теперь доступен русский язык Set OSD_Lang 1

Подробнее для работы с новым OSD читайте мануал раздел 5.9 Все необходимые нововведения там отражены. Кроме того в мануал добавлено описание работы и настройки миксеров и описание использования S-BUS от Futaba
Текущая версия мануала одним файлом скачать здесь

FlyingBrain_User_Manual_v1.2-160113.pdf

Видео демки пока нет. Вчера ночью все закончил. Может сегодня сделаю вечером, если удастся. Ну может кто-то меня опередит.

Не успел перерисовать вариометр, тоже постараюсь оформить сегодня. Теперь начну рисовать менюшки для управления настройками на экране ОСД

Тут мне справедливо заметили, что я забыл сказать что после перепрошивки автоматом новый режим OSD не включится. Останется старый. Так вот новый надо принудительно включить и сохранить перманентно в конфиге. То есть даем команду Set OSD_Resolution_Mode 1

И еще в догонку. Новые значения координат будут мусорными или нулевыми. Поэтому изначально Reset OSD исправит положение если все элементы ОСД навалились друг на друга с координатами (0,0). Однако не забываем посмотреть и запомнить какое было значение OSD_Comp_Voltage, оно тоже сбрасывается. Его потом восстановить надо будет после Reset OSD.

AlexSneg

Вчера посидел над темой таблетки для цветовых декодеров и борьбы с цветомузыкой на экране.
Вот результат. Сначала самая больная тема - черный фон, затем уже светлый (ну тут оно всегда проще было)
Смотрим на результат, это запись с EasyCap. За качество не пинайте, я до сих пор не могу заставить ноут с хорошим качеством сделать запись. Ну и туба добавляет еще…