Контроллер для кордовых электричек

Маркс

в общем, ошибка в том, что если просто подождать несколько минут,
то при записи данных из программатора в таймер вылезает ошибка.
причина в накапливающихся “данных” в буфере приема, по сути помех.

VitalikV

А как эти помехи туда попадают? В принципе мы подключились, считали , и отключились,редактируем, подключаемся и записываем, записали отключились. Или как то работает не так?

Второй вариант не хранить в программаторе ничего, а просто на нем отображать вводимые данные.

Маркс
VitalikV:

А как эти помехи туда попадают?

да х его з, этого я тоже пока не понимаю,
есть еще предположение, что в какой то момент в буфере приема таймера “зависает” байт или несколько,
сейчас буду прикручивать Софт сериал и смотреть что читает таймер от программатора.
Сегодня пол дня дома, буду ковырять дальше.

VitalikV:

Или как то работает не так?

Примерно так, но физического отключения нет. Хотя на этапе корректировки вполне можно отключиться.

В общем есть мысль, чистить буферы перед началом обмена.
Но я же инициирую обмен со стороны программатора,

  • отправляю команду на чтение,
  • жду подтверждение,
  • передаю данные,
  • передаю контрольную сумму,
  • жду ответ от программатора о получении пакета
  • таймер присылает ответ - CRC ERROR.

Т.е. он принимает пакет, принимает переданную CRC сравнивает и видит ошибку приема.
Ни хрена не понимаю.
Если бы данных было мало, программатор бы не получил ответа и была ба ошибка тайм аута T/O ERROR

Маркс

В общем прикручу USB-UART на свободные ноги и буду смотреть,
что конкретно принимает таймер от программатора

Маркс

Источник ошибки обмена установлен и удален.
В архивах исправленные версия программатора и программы таймера
Programmer_v1.zip
Timer_for_Plane_v6.1_wo_Gyro.zip
Временные параметры пока ограничены 1800 секунд или 30 минут (так исторически сложилось)

Маркс

Следующим номером нашей программы “вкрячивание” MPU6050
выглядеть будет примерно так
ая кросс плата
J3 и J4 точки подключения модуля MPU6050
вот такого

ZY MPU-6050

Маркс

есть необходимость проверить гувернер на оборотах выше 9000,
на днях протравлю и распаяю новую кросс-плату, а старую, без гироскопа,
готов отправить в любую точку России почтой для тестирования
у меня просто нет мотора для тестирования на таких оборотах

vittek

Приветствую. Готов протестить ваш сетап по полной программе, главное чтобы был получен правильный результат.

Маркс

Для этого нужно иметь

Два последних, это программатор, что бы можно было менять настройки без подключения таймера к компьютеру.

vittek

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

Маркс
vittek:

у нас ничего нет, но при необходимости всё можем заказать.

настройки можно и с компа поменять ), а потом прошить Ардуинку.
но для программирования Pro Mini потребуется еще USB-UART преобразователь.
хотя, прошить можно и с помощью UNO.

VitalikV

Заказал, жду детальки, соберу отпишусь по результатам.

RandomJ

А схема сборки всего этого в кучу в каком файлике лежит?

RandomJ

mini, USB2UART, nano, UNO+LCD_keypad_sheld и GY-521 есть в наличии.

Маркс

Доброе утро всем.
Нет никакой особой схемы сборки.
LCD+KEY штатно ставится на UNO
кросс плата (это ее рисунок)

штатно ставится на Pro Mini, четыре угловые пины как раз по углам Pro Mini
К J1 присоединяются провода от фаз мотора
К J2 регулятор оборотов.
На новой версии кросс платы добавлен светодиод, кнопка и разъем для подключения внешней кнопки
Выглядит все это примерно так

Пяти пиновый разъем на Pro Mini для подключения программатора/
Через него же подключается USB-UART для прошивки

В выходные протестирую MPU-6050 и сделаю новую кросс-плату.

Маркс

провел предварительный тест MPU-6050, в общем нужно предусмотреть калибровку гироскопа.

без калибровки, данные плывут сильно, с калибровкой, тоже плывут, но намного медленнее.
в идеале гироскоп надо будет калибровать перед каждым вылетом.
но в принципе хватит и одной калибровки на день.
при калибровке гироскоп должен находится горизонтально и неподвижно
от нескольких секунд до десятков, это как повезет.

Маркс

Теперь по обработке изменения угла.
Вот статья от Гайвера
alexgyver.ru/arduino-mpu6050/?ysclid=lnnlcbtk8a954…
Получить данные от гироскопа получится не чаще 100 раз в секунду,
само получение данных и их “интерпретация” в теле программы занимает не меньше 2 мс.
кроме того, есть еще основная программа гувернера,
а значит корректировку по данным гироскопа получится делать не чаще 50 раз в секунду,
а лучше сделать 20-30 раз в секунду, что бы программа не “спотыкалась” об прерывания.

Вопрос, этого достаточно.
Скорее всего и расчет текущего значения оборотов программой гувернера стоит синхронизировать
с получением данных от гироскопа.

RandomJ

Модель в среднем пролетает 20…25 метров за секунду., плюс инерция модели на изменение тяги двигателя, от этого отталкиваться.

VitalikV

На данном этапе, частота обработки нам не так важна, к задержкам газа можно привыкнуть. Куда важнее правильно обработать положение модели.

Да и с калибровкой вопрос, модель на шасси не стоит ровно, а слегка мордой вверх, иногда и не слегка. Как ловить уровень горизонта? Да и модель в полете, тоже никогда не находится четко по горизонту, она только движется относительно ему.

Так же при полете на ноже, угол атаки носа модели равен нулю, но при этом модель находится на вершине сферы и газу надо бы добавить. Обработка нужна по нескольким осям. И эти оси вращаются вместе с моделью.

Маркс
VitalikV:

На данном этапе, частота обработки нам не так важна, к задержкам газа можно привыкнуть. Куда важнее правильно обработать положение модели.

это как раз сейчас самый главный вопрос )),
работу программы гувернера надо синхронизировать с работой гироскопа.
надо понять, как правильно это сделать.
опрос гироскопа программа может делать не чаще 100 раз в секунду,
при этом каждый опрос приводит к блокированию основного цикла программы на 2 мс.
т.е. 2 мс программа что то “перетирает” с модулем гироскопа.