This repository was archived by the owner on Sep 24, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathModelCode.ino
More file actions
73 lines (67 loc) · 4.16 KB
/
ModelCode.ino
File metadata and controls
73 lines (67 loc) · 4.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//-----------------------------------------------------------------------\\
// Программа по чтению информации с датчиков (гироскопа и ИК-дальномера) \\
// и формированию по ним команд для сервоприводов. \\
// Программа выполнена для статьи: \\
// "Разработка подсистемы управления гибким крылом беспилотного \\
// летательного аппарата на базе аэрошюта". \\
// Ссылка на статью: \\
// Автор программы: ElMigele \\
//-----------------------------------------------------------------------\\
// Библиотеки
#include <Servo.h> // Библиотека для работы с сервоприводом
#include <Wire.h> // Библиотека для работы I²C
#include <TroykaIMU.h> // Библиотека для работы с модулями IMU
// доступна для скачивания:
// https://github.com/amperka/Troyka-IMU
// Создание объектов для работы
Servo servo1; // ... с сервоприводом, связанным с гироскопом
Servo servo2; // ... с сервоприводом, связанным с дальномером
Gyroscope gyro; // ... с гироскопом
// Пины подключения
int RangeFinderPin = 0; // ... дальномера
int ServoPin1 = 6; // ... сервопривода-1
int ServoPin2 = 9; // ... сервопривода-2
// Переменные для данных с гироскопа и дальномера
int ang, dist;
int oldAng = 0;
void setup() {
Serial.begin(9600); // Установка скорости общения с компьютером
servo1.attach(ServoPin1); // Прикрепление сервопривода к пину
servo1.write(0); // Установление значения сервопривода в 0
servo2.attach(ServoPin2); // ...
servo2.write(0); // ...
gyro.begin(); // Инициализация гироскопа
gyro.setRange(RANGE_500DPS);// Устанавливаем чувствительность гироскопа
// 250dps — по умолчанию, 500dps, 2000dps
}
void loop() {
// Гироскоп
ang = gyro.readDegPerSecZ(); // Чтение угла с гироскопа по
// оси Z в градусах в секунду
// (по другим осям не работаем)
oldAng = oldAng + ang;
int res = map(oldAng, -180, 180, 0, 255);
Serial.print("Ang: ");
Serial.print(oldAng);
Serial.print("\t\t");
Serial.print("Sr1: ");
Serial.print(res);
Serial.print("\t\t");
servo1.write(res); // Поворот сервопривода на угол,
// задаваемый гироскопом
// Дальномер
int oldDist = dist;
dist = analogRead(RangeFinderPin); // Чтение расстояния с дальномера
int pos = map(dist, 0, 200, 0, 255); // Интерпретация расстояния
// (диапазон [0, 200]) в угол
// поворота сервопривода
// (диапазон [0, 255])
Serial.print("Pos: ");
Serial.print(dist);
Serial.print("\t\t");
Serial.print("Sr2: ");
Serial.println(pos);
servo2.write(pos); // Поворот сервопривода на угол,
// задаваемый ИК-дальномером
delay(1000);
}