Проект "Трикоптер" — различия между версиями

Материал из Department of Theoretical and Applied Mechanics
Перейти к: навигация, поиск
Строка 2: Строка 2:
  
 
== Участники ==
 
== Участники ==
 +
 
* [[Веренинов Игорь]]  
 
* [[Веренинов Игорь]]  
 
* [[Верховых Михаил]]
 
* [[Верховых Михаил]]
Строка 7: Строка 8:
 
* [[Пшенов Антон]]
 
* [[Пшенов Антон]]
  
= Трикоптер v1.0=
+
== Трикоптер v1.0 ==
  
== Оборудование ==
+
=== Оборудование ===
 
*Платформа сборки: Arduino
 
*Платформа сборки: Arduino
 
*Гироскопы: Melexis MLX90609 типа MEMS, 300 deg/sec
 
*Гироскопы: Melexis MLX90609 типа MEMS, 300 deg/sec
Строка 17: Строка 18:
 
*Двигатели: 200Вт 1000kv бесколлекторные
 
*Двигатели: 200Вт 1000kv бесколлекторные
  
+
=== Рама ===
== Рама ==
 
  
<gallery widths=330px heights=300px perrow = 2>
+
<gallery widths=300px heights=210px perrow = 2>
 
Файл:Cptr1.JPG|Самое начало проекта, установлен только один мотор
 
Файл:Cptr1.JPG|Самое начало проекта, установлен только один мотор
 
Файл:Cptr3.JPG|Поворотный механизм
 
Файл:Cptr3.JPG|Поворотный механизм
Строка 27: Строка 27:
 
</gallery>
 
</gallery>
  
 +
=== Структурная схема ===
  
== Структурная схема ==
+
[[Файл:3copter_scheme.jpg‎]]
  
[[Файл:3copter_scheme.jpg‎]]
+
=== Программирование ===
  
== Программирование ==
 
 
Программирование осуществлялось на языке/диалекте Wiring-C++ в среде Arduino.
 
Программирование осуществлялось на языке/диалекте Wiring-C++ в среде Arduino.
 
Первым делом надо было просто заставить коптер полететь, поэтому алгоритмы обработки датчиков и управления предельно простые.
 
Первым делом надо было просто заставить коптер полететь, поэтому алгоритмы обработки датчиков и управления предельно простые.
  
=== вычисление угловой скорости ===
+
==== Вычисление угловой скорости ====
  
 
В этом проекте использованы три гироскопа MLX90609 , они имеют аналоговые выходы для данных о угловой скорости и встроенный температурный датчик для устранения дрифта.
 
В этом проекте использованы три гироскопа MLX90609 , они имеют аналоговые выходы для данных о угловой скорости и встроенный температурный датчик для устранения дрифта.
 
Микроконтроллер получает от гироскопа значения в диапазоне 0-1024, затем с учетом чувствительности 300 градусов в секунду производит расчет угловой скорости. Кроме того вычитается байес - значение которое показывает сенсор при отсутствии вращения. Таким образом окончательная формула выглядит так:
 
Микроконтроллер получает от гироскопа значения в диапазоне 0-1024, затем с учетом чувствительности 300 градусов в секунду производит расчет угловой скорости. Кроме того вычитается байес - значение которое показывает сенсор при отсутствии вращения. Таким образом окончательная формула выглядит так:
 
 
  
 
   for( int i=0; i<3; i++)
 
   for( int i=0; i<3; i++)
Строка 54: Строка 52:
 
  }
 
  }
  
 +
Использование оверсэмплинга, то есть многократного повторного чтения входа, позволяет увеличить разрешение на бит.
  
Использование оверсэмплинга, тоесть многократного повторного чтения входа, позволяет увеличить разрешение  на бит.
+
==== Задание угловой скорости ====
 
 
=== задание угловой скорости ===
 
  
 
На данном этапе, управление аппаратом организовано посредством задания угловой скорости вокруг каждой оси с пульта управления.  Данные о положении джойстиков кодируются и передаются на приемник,  находящийся на коптере. Микроконтроллер получает информацию с приемника и  приводит ее к формату удобному для вычисления.
 
На данном этапе, управление аппаратом организовано посредством задания угловой скорости вокруг каждой оси с пульта управления.  Данные о положении джойстиков кодируются и передаются на приемник,  находящийся на коптере. Микроконтроллер получает информацию с приемника и  приводит ее к формату удобному для вычисления.
Строка 63: Строка 60:
 
[[Файл:futaba.JPG‎|400px]]
 
[[Файл:futaba.JPG‎|400px]]
  
=== ПИД-регулятор ===
+
==== ПИД-регулятор ====
  
 
В каноническом виде уравнение ПИД-регулятора выглядит так:
 
В каноническом виде уравнение ПИД-регулятора выглядит так:
Строка 70: Строка 67:
  
 
Программная реализация. Входом регулятора служит разность желаемой и текущей угловых скоростей.
 
Программная реализация. Входом регулятора служит разность желаемой и текущей угловых скоростей.
 
  
 
       error = RCToDeg(RC[i+1]) - omega[i];
 
       error = RCToDeg(RC[i+1]) - omega[i];
Строка 79: Строка 75:
 
       axisPID = Pgain*error + Dgain*Dpart + Igain*Ipart;  
 
       axisPID = Pgain*error + Dgain*Dpart + Igain*Ipart;  
 
      
 
      
 
+
== Трикоптер v1.1 ==
 
 
=трикоптер v1.1=
 
  
 
После отладки алгоритма и тестовых полетов, рама коптера пришла в полную негодность, появились трещины и люфты. Для продолжения работы понадобился новый трикоптер. Версия 1.1 почти в два раза больше первой, лучи подросли до 30см, увеличилась и площадка под электронику .Новые шасси должны хорошо аммортизировать жесткие посадки и обеспечивать более стабильный взлет. Электроника осталась прежней.
 
После отладки алгоритма и тестовых полетов, рама коптера пришла в полную негодность, появились трещины и люфты. Для продолжения работы понадобился новый трикоптер. Версия 1.1 почти в два раза больше первой, лучи подросли до 30см, увеличилась и площадка под электронику .Новые шасси должны хорошо аммортизировать жесткие посадки и обеспечивать более стабильный взлет. Электроника осталась прежней.
  
<gallery widths=330px heights=300px perrow = 2>
+
<gallery widths=300px heights=210px perrow = 2>
 
Файл:wiring.JPG|Рама собрана, начинается разводка проводов
 
Файл:wiring.JPG|Рама собрана, начинается разводка проводов
 
Файл:wiring1.JPG|Почти вся электроника  на своих местах
 
Файл:wiring1.JPG|Почти вся электроника  на своих местах
Строка 92: Строка 86:
 
</gallery>
 
</gallery>
  
=создание адаптивного регулятора=
+
== Создание адаптивного регулятора ==
 +
 
 +
=== Моделирование ===
  
==моделирование==
 
 
Важной задачей для разработки эффективной системы управления является создание модели коптера. На ней можно провести  все испытания, не подвергая при этом опасности реальный аппарат.  
 
Важной задачей для разработки эффективной системы управления является создание модели коптера. На ней можно провести  все испытания, не подвергая при этом опасности реальный аппарат.  
 
Модель была запрограммирована в среде SIMULINK, управлять ей можно, как и настоящим коптером  - при помощи пульта.
 
Модель была запрограммирована в среде SIMULINK, управлять ей можно, как и настоящим коптером  - при помощи пульта.
Строка 100: Строка 95:
  
 
Программа пока работает не очень точно, это связано с тем что не вводились параметры реального аппарата.
 
Программа пока работает не очень точно, это связано с тем что не вводились параметры реального аппарата.
==регулятор==
 
здесь будет про фази-пид
 
  
==алгоритм оптимизации==
+
=== Регулятор ===
 +
 
 +
''Здесь будет про фази-ПИД...''
 +
 
 +
=== Алгоритм оптимизации ===
  
 
Алгоритм swarm был написан [[Пшенов Антон|Антоном Пшеновым]].
 
Алгоритм swarm был написан [[Пшенов Антон|Антоном Пшеновым]].
  
= Результаты =
+
== Результаты ==
 +
 
 
# Данный проект был представлен на международной конференции школьников [http://www.school.ioffe.ru/readings/2011/meeting.html Сахаровские Чтения 2011], где удостоился специального диплома "за успешное продвижение в работе над перспективной темой".
 
# Данный проект был представлен на международной конференции школьников [http://www.school.ioffe.ru/readings/2011/meeting.html Сахаровские Чтения 2011], где удостоился специального диплома "за успешное продвижение в работе над перспективной темой".
 
# 15 Июня 2011г. трикоптер, совершил свой [http://www.youtube.com/watch?v=5WGxiVSGcUY&feature=player_embedded первый полет]
 
# 15 Июня 2011г. трикоптер, совершил свой [http://www.youtube.com/watch?v=5WGxiVSGcUY&feature=player_embedded первый полет]
Строка 118: Строка 116:
  
 
== Планы ==
 
== Планы ==
В дальнейшем планируется создать адаптивный (самонастраивающийся) PID-регулятор.
+
 
 +
В дальнейшем планируется создать адаптивный (самонастраивающийся) ПИД-регулятор.
  
 
== Публикации по теме проекта ==
 
== Публикации по теме проекта ==
 +
 
*  Веренинов И.А., Кузькин В.А. Разработка математической модели и прототипа трикоптера // Сборник трудов конференции "Неделя науки СПбГПУ",    2011 [направлено в печать] ([[Медиа: Vereninov_2011_SW_05.pdf |prerint_v.01]], [[Медиа: Vereninov_2011_SW_04.pdf | prerint_v.02]])
 
*  Веренинов И.А., Кузькин В.А. Разработка математической модели и прототипа трикоптера // Сборник трудов конференции "Неделя науки СПбГПУ",    2011 [направлено в печать] ([[Медиа: Vereninov_2011_SW_05.pdf |prerint_v.01]], [[Медиа: Vereninov_2011_SW_04.pdf | prerint_v.02]])
 +
  
 
[[Category: Студенческие проекты]]
 
[[Category: Студенческие проекты]]
 
[[Category: Проект "Трикоптер"]]
 
[[Category: Проект "Трикоптер"]]

Версия 16:38, 25 декабря 2011

Проект, осуществляемый Клубом технического творчества при поддержке кафедры "Теоретическая Механика".

Участники

Трикоптер v1.0

Оборудование

  • Платформа сборки: Arduino
  • Гироскопы: Melexis MLX90609 типа MEMS, 300 deg/sec
  • Радиолинк: Spektrum DSM2 FHSS-технология. Аппаратура все время меняет частоту передачи, обеспечивая надежную связь в радиусе до 1км.
  • Серво поворотного механизма: Hitec HS-81MG , с металлическим редуктором.
  • Аккумулятор: Li-Po 2.2Ah 25C 11.1V
  • Двигатели: 200Вт 1000kv бесколлекторные

Рама



Структурная схема

3copter scheme.jpg

Программирование

Программирование осуществлялось на языке/диалекте Wiring-C++ в среде Arduino. Первым делом надо было просто заставить коптер полететь, поэтому алгоритмы обработки датчиков и управления предельно простые.

Вычисление угловой скорости

В этом проекте использованы три гироскопа MLX90609 , они имеют аналоговые выходы для данных о угловой скорости и встроенный температурный датчик для устранения дрифта. Микроконтроллер получает от гироскопа значения в диапазоне 0-1024, затем с учетом чувствительности 300 градусов в секунду производит расчет угловой скорости. Кроме того вычитается байес - значение которое показывает сенсор при отсутствии вращения. Таким образом окончательная формула выглядит так:

 for( int i=0; i<3; i++)
 {
   float tmp=0;
     for(int j=0;j<10;j++)
     {
         tmp+=analogRead(pin[i]);// oversampling
     }
  tmp/=10.0;
  omega[i]=(tmp-bias[i])*gain[i]; 
}

Использование оверсэмплинга, то есть многократного повторного чтения входа, позволяет увеличить разрешение на бит.

Задание угловой скорости

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

Futaba.JPG

ПИД-регулятор

В каноническом виде уравнение ПИД-регулятора выглядит так:

[math]u(t) = P + I + D = K_p\,{e(t)} + K_i\int\limits_{0}^{t}{e(\tau)}\,{d\tau} + K_d\frac{de}{dt}[/math]

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

     error = RCToDeg(RC[i+1]) - omega[i];
     Ipart+= error*Dt;
     Ipart= constrain(Ipart,-20,20); 
     Dpart = (omega - oldomega)/float(Dt);
     oldomega =omega;
     axisPID = Pgain*error + Dgain*Dpart + Igain*Ipart; 
   

Трикоптер v1.1

После отладки алгоритма и тестовых полетов, рама коптера пришла в полную негодность, появились трещины и люфты. Для продолжения работы понадобился новый трикоптер. Версия 1.1 почти в два раза больше первой, лучи подросли до 30см, увеличилась и площадка под электронику .Новые шасси должны хорошо аммортизировать жесткие посадки и обеспечивать более стабильный взлет. Электроника осталась прежней.



Создание адаптивного регулятора

Моделирование

Важной задачей для разработки эффективной системы управления является создание модели коптера. На ней можно провести все испытания, не подвергая при этом опасности реальный аппарат. Модель была запрограммирована в среде SIMULINK, управлять ей можно, как и настоящим коптером - при помощи пульта. первые виртуальные полеты

Программа пока работает не очень точно, это связано с тем что не вводились параметры реального аппарата.

Регулятор

Здесь будет про фази-ПИД...

Алгоритм оптимизации

Алгоритм swarm был написан Антоном Пшеновым.

Результаты

  1. Данный проект был представлен на международной конференции школьников Сахаровские Чтения 2011, где удостоился специального диплома "за успешное продвижение в работе над перспективной темой".
  2. 15 Июня 2011г. трикоптер, совершил свой первый полет
  3. Первые фотографии с борта


Планы

В дальнейшем планируется создать адаптивный (самонастраивающийся) ПИД-регулятор.

Публикации по теме проекта

  • Веренинов И.А., Кузькин В.А. Разработка математической модели и прототипа трикоптера // Сборник трудов конференции "Неделя науки СПбГПУ", 2011 [направлено в печать] (prerint_v.01, prerint_v.02)