-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEMG.ino
104 lines (77 loc) · 3.3 KB
/
EMG.ino
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
int EMG_sensor_1 = A0; // Pino para ler os dados do primeiro sensor
int EMG_sensor_2 = A1; // Pino para ler os dados do segundo sensor
int EMG_sensor_3 = A2; // Pino para ler os dados do terceiro sensor
int EMG_sensor_4 = A3; // Pino para ler os dados do quarto sensor
int PWM_MOTOR_1 = 3; // Pino para escrever no primeiro motor
int PWM_MOTOR_2 = 11; // Pino para escrever no primeiro motor
int PWM_MOTOR_3 = 10; // Pino para escrever no primeiro motor
int PWM_MOTOR_4 = 9; // Pino para escrever no primeiro motor
int EMG_pure1 = 0; // Variável para armazenar os valores lidos do primeiro sensor
int EMG_pure2 = 0; // Variável para armazenar os valores lidos do primeiro sensor
int EMG_pure3 = 0; // Variável para armazenar os valores lidos do primeiro sensor
int EMG_pure4 = 0; // Variável para armazenar os valores lidos do primeiro sensor
long EMG_filter_1 = 0; // Variável para armazenar os valores filtrados do primeiro sensor
long EMG_filter_2 = 0; // Variável para armazenar os valores filtrados no segundo sensor
long EMG_filter_3 = 0; // Variável para armazenar os valores filtrados no terceiro sensor
long EMG_filter_4 = 0; // Variável para armazenar os valores filtrados no quarto sensor
int PWM_8BITS = 0; // Variável para escrever no PWM do primeiro motor
// Parâmetros para a média móvel
int amostras = 50; // Quantidade de amostras para realizar a média móvel
int numbers[50]; // Vetor para guardar amostras do primeiro sensor
long moving_average(int EMG_filter); // Protótipo da função de média móvel
void setup() {
Serial.begin(115200); // Iniciando a UART
}
void loop() {
amostras = 50;
PWM_8BITS = 0;
EMG_pure1 = analogRead(EMG_sensor_1); // Lendo os dados do sensor
EMG_filter_1 = moving_average(EMG_pure1);
PWM_8BITS = (EMG_filter_1 >> 2);
analogWrite(PWM_MOTOR_1, PWM_8BITS);
amostras = 50;
PWM_8BITS = 0;
EMG_pure2 = analogRead(EMG_sensor_2); // Lendo os dados do sensor
EMG_filter_2 = moving_average(EMG_pure2);
PWM_8BITS = (EMG_filter_2 >> 2);
analogWrite(PWM_MOTOR_2, PWM_8BITS);
amostras = 50;
PWM_8BITS = 0;
EMG_pure3 = analogRead(EMG_sensor_3); // Lendo os dados do sensor
EMG_filter_3 = moving_average(EMG_pure3);
PWM_8BITS = (EMG_filter_3 >> 2);
analogWrite(PWM_MOTOR_3, PWM_8BITS);
amostras = 50;
PWM_8BITS = 0;
EMG_pure4 = analogRead(EMG_sensor_4); // Lendo os dados do sensor
EMG_filter_4 = moving_average(EMG_pure4);
PWM_8BITS = (EMG_filter_4 >> 4);
analogWrite(PWM_MOTOR_4, PWM_8BITS);
Serial.print(EMG_filter_1); // Enviando os dados pela serial do sinal filtrado do primeiro sensor
Serial.print(","); // Caracter de divisão de dados
Serial.print(EMG_filter_2); // Enviando os dados pela serial do sinal filtrado do segundo sensor
Serial.print(",");
Serial.print(EMG_filter_3);
Serial.print(",");
Serial.println(EMG_filter_4);
//delay(100);
}
long moving_average(int EMG_pure)
{
for(int i = amostras-1; i > 0; i-- )
{
numbers[i] = numbers[i-1];
}
long average = 0;
numbers[0] = EMG_pure;
for(int i = 0; i < amostras; i++){
average = average + numbers[i];
}
/*
for(int i = 0; i < amostras; i++)
{
numbers[i] = 0;
}
*/
return (average/amostras);
}