Контроллер для кордовых электричек
у нас ничего нет, но при необходимости всё можем заказать.
настройки можно и с компа поменять ), а потом прошить Ардуинку.
но для программирования Pro Mini потребуется еще USB-UART преобразователь.
хотя, прошить можно и с помощью UNO.
Понятно, разберёмся.
Заказал, жду детальки, соберу отпишусь по результатам.
А схема сборки всего этого в кучу в каком файлике лежит?
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 раз в секунду, что бы программа не “спотыкалась” об прерывания.
Вопрос, этого достаточно.
Скорее всего и расчет текущего значения оборотов программой гувернера стоит синхронизировать
с получением данных от гироскопа.
Модель в среднем пролетает 20…25 метров за секунду., плюс инерция модели на изменение тяги двигателя, от этого отталкиваться.
На данном этапе, частота обработки нам не так важна, к задержкам газа можно привыкнуть. Куда важнее правильно обработать положение модели.
Да и с калибровкой вопрос, модель на шасси не стоит ровно, а слегка мордой вверх, иногда и не слегка. Как ловить уровень горизонта? Да и модель в полете, тоже никогда не находится четко по горизонту, она только движется относительно ему.
Так же при полете на ноже, угол атаки носа модели равен нулю, но при этом модель находится на вершине сферы и газу надо бы добавить. Обработка нужна по нескольким осям. И эти оси вращаются вместе с моделью.
На данном этапе, частота обработки нам не так важна, к задержкам газа можно привыкнуть. Куда важнее правильно обработать положение модели.
это как раз сейчас самый главный вопрос )),
работу программы гувернера надо синхронизировать с работой гироскопа.
надо понять, как правильно это сделать.
опрос гироскопа программа может делать не чаще 100 раз в секунду,
при этом каждый опрос приводит к блокированию основного цикла программы на 2 мс.
т.е. 2 мс программа что то “перетирает” с модулем гироскопа.
При этом, на оборотах 10000 прерывания от мотора на Ардуинку приходят с периодом меньше 1 мс.
Я очень надеюсь, что при “терках” с гироскопом библиотека MPU6050 не блокирует прерывания,
это я сегодня вечером или завтра проверю.
Иначе вся идея с гувернером может пойти прахом.
Лучше тогда отказаться от гироскопа, и дальше развивать тему с гувернером, так как если доработать его, то гироскоп не нужен будет. Привязаться к оборотам мотора проще, чем к трем осям гироскопа.
Либо ставим одну ардуину на гувернер, вторую на гироскоп, а третья собирает данные и управляет газом 🤣
идея таймера увеличивать обороты при положительных углах тангажа и крена выше заданных.
ну например - тангаж +30 градусов или крен +30 градусов, обороты увеличиваем на 10 процентов.
при этом задачу держать обороты выполняет гувернер.
сам по себе гувернер самодостаточен, но не всегда )
если прерывания не блокируются, то в принципе никаких трудностей быть не должно.
просто обработки будут разделять время процессора.
сейчас я думаю, как это проверить.
я могу запустить стоковый пример с чтением данных с гироскопа по прерыванию
и наверное использую генератор импульсов для имитации прерываний от мотора.
есть у меня такой девайс, офигительная штука к слову.
а энкодер в осциллограф я так еще и не поставил )
но это мне не помешает посмотреть два сигнала
но что то мне подсказывает, что сегодня я этим точно не займусь.
и это “что то” бутылочка хорошего виски, все таки сегодня мой профессиональный праздник ))
- "день Советской армии и Военно-Морского флота"©
а я все таки кадровый военный (уже в отставке) и начинал служить в далеком 82 как раз в Советской армии )
так что, с праздником, всех причастных к Советской армии и флоту.
Мои поздравления всем нашим воинам!
Что касается гувернера, опрос и корректировку можно сделать реже, так как обороты все же держит регулятор, а при маневрах, даже на двс есть задержка пока он включится. К этому привыкаешь, главное чтобы не было рывков.
А вот положение модели, должно опрашиваться чаще, так как от него зависит добавлять обороты или нет.
Не вынесла душа поэта неопределенности и после пары маленьких и одной большой
пошел ставить эксперимент, стенд показывать смысла большого нет, там осталась таже ардуинка и MPU6050
а вот “картинку” стоит расшифровать.
Генератор выдает на втором канале импульсы с частотой 1 кГц,
которые я подаю на вторую ногу Ардуино, тем самым вызываю срабатывание прерывания isr0,
в скетче в теле прерывания просто инвертируется сигнал на 11 ноге Ардуинки,
результат виден на желтом графике, т.е. на 11 ноге меандр с частотой 1кГц
а вот синий график, это вывод 13 ардуино, он показывает период занятости МК обработкой данных гироскопа.
при этом в программе, это одна строка кода и она блокирует цикл программы.
Вывод, программу оно блокирует, но прерывания все равно проходят ))
Еще чуть чуть и будет целый полетный контроллер для кордовой, а не просто таймер))
Виталий, это основная цель
это я еще “прячу” web-морду таймера на базе ESP32 😄 (это так, что бы распалить воображение)
но там все немного сложнее, web-морда жрет много ресурсов МК
В очередной раз спрошу, почему нельзя взять регулятор с поддержкой blheli?
В нем есть полноценная поддержка гувернера. Нп вертолете прекрасно работает без участия гироскопа.