Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: HIDScope MODSERIAL QEI biquadFilter mbed
Fork of a_pid_kal_end_def by
main.cpp@8:cd0cb71b69f2, 2016-10-21 (annotated)
- Committer:
- daniQQue
- Date:
- Fri Oct 21 13:50:48 2016 +0000
- Revision:
- 8:cd0cb71b69f2
- Parent:
- 7:42d0e38196f1
- Child:
- 9:464c447ce82d
motor draait op biceps, zonder juiste filter;
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| daniQQue | 0:34c739fcc3e0 | 1 | //libraries | 
| daniQQue | 0:34c739fcc3e0 | 2 | #include "mbed.h" | 
| daniQQue | 0:34c739fcc3e0 | 3 | #include "HIDScope.h" | 
| daniQQue | 4:7d9ca9c1dcce | 4 | #include "biquadFilter.h" | 
| daniQQue | 0:34c739fcc3e0 | 5 | |
| daniQQue | 0:34c739fcc3e0 | 6 | //Define objects | 
| daniQQue | 0:34c739fcc3e0 | 7 | AnalogIn emg0( A0 ); //analog in to get EMG in to c++ | 
| daniQQue | 0:34c739fcc3e0 | 8 | Ticker sample_timer; //ticker | 
| daniQQue | 8:cd0cb71b69f2 | 9 | HIDScope scope( 3); //open 3 channels in hidscope | 
| daniQQue | 8:cd0cb71b69f2 | 10 | DigitalOut richting_motor1(D4); //motor1 direction output | 
| daniQQue | 8:cd0cb71b69f2 | 11 | PwmOut pwm_motor1(D5); //motor1 velocity output | 
| daniQQue | 0:34c739fcc3e0 | 12 | DigitalOut led(LED_GREEN); | 
| daniQQue | 0:34c739fcc3e0 | 13 | |
| daniQQue | 0:34c739fcc3e0 | 14 | //define variables | 
| daniQQue | 0:34c739fcc3e0 | 15 | double emg_0_value; | 
| daniQQue | 4:7d9ca9c1dcce | 16 | double emg_gefilterd; | 
| daniQQue | 7:42d0e38196f1 | 17 | double emg_abs; | 
| daniQQue | 7:42d0e38196f1 | 18 | int onoffsignal=0; | 
| daniQQue | 7:42d0e38196f1 | 19 | double cut_off_value=0.05; //gespecifeerd door floortje | 
| daniQQue | 5:688b1b5530d8 | 20 | |
| daniQQue | 5:688b1b5530d8 | 21 | biquadFilter filterhigh1(-1.1430, 0.4128, 0.6389, -1.2779, 0.6389); | 
| daniQQue | 0:34c739fcc3e0 | 22 | |
| daniQQue | 8:cd0cb71b69f2 | 23 | |
| daniQQue | 0:34c739fcc3e0 | 24 | void filter(){ | 
| daniQQue | 0:34c739fcc3e0 | 25 | emg_0_value=emg0.read(); //read the emg value from the elektrodes | 
| daniQQue | 5:688b1b5530d8 | 26 | emg_gefilterd= filterhigh1.step(emg_0_value); | 
| daniQQue | 6:83358367e413 | 27 | emg_abs=abs(emg_gefilterd); | 
| daniQQue | 0:34c739fcc3e0 | 28 | led=!led; | 
| daniQQue | 7:42d0e38196f1 | 29 | |
| daniQQue | 7:42d0e38196f1 | 30 | if (emg_abs>cut_off_value) | 
| daniQQue | 7:42d0e38196f1 | 31 | {onoffsignal=1;} | 
| daniQQue | 7:42d0e38196f1 | 32 | |
| daniQQue | 7:42d0e38196f1 | 33 | else | 
| daniQQue | 7:42d0e38196f1 | 34 | {onoffsignal=0;} | 
| daniQQue | 7:42d0e38196f1 | 35 | |
| daniQQue | 0:34c739fcc3e0 | 36 | //send signals to scope | 
| daniQQue | 1:30d46f7e5150 | 37 | scope.set(0, emg_0_value ); //set emg signal to scope in channel 1 | 
| daniQQue | 4:7d9ca9c1dcce | 38 | scope.set(1, emg_gefilterd ); | 
| daniQQue | 7:42d0e38196f1 | 39 | scope.set(2, onoffsignal); | 
| daniQQue | 0:34c739fcc3e0 | 40 | scope.send(); //send all the signals to the scope | 
| daniQQue | 0:34c739fcc3e0 | 41 | } | 
| daniQQue | 0:34c739fcc3e0 | 42 | |
| daniQQue | 0:34c739fcc3e0 | 43 | //program | 
| daniQQue | 0:34c739fcc3e0 | 44 | |
| daniQQue | 0:34c739fcc3e0 | 45 | int main() | 
| daniQQue | 0:34c739fcc3e0 | 46 | { | 
| daniQQue | 0:34c739fcc3e0 | 47 | sample_timer.attach(&filter, 0.001); //continously execute the EMG reader and filter, it ensures that filter and sampling is executed every 1/frequency seconds | 
| daniQQue | 4:7d9ca9c1dcce | 48 | |
| daniQQue | 0:34c739fcc3e0 | 49 | //endless loop | 
| daniQQue | 0:34c739fcc3e0 | 50 | |
| daniQQue | 0:34c739fcc3e0 | 51 | while(1) | 
| daniQQue | 8:cd0cb71b69f2 | 52 | { | 
| daniQQue | 8:cd0cb71b69f2 | 53 | if (onoffsignal==1) | 
| daniQQue | 8:cd0cb71b69f2 | 54 | { | 
| daniQQue | 8:cd0cb71b69f2 | 55 | richting_motor1 = 0; //motordirection (ccw) | 
| daniQQue | 8:cd0cb71b69f2 | 56 | pwm_motor1 = 1; //motorspeed 1 | 
| daniQQue | 8:cd0cb71b69f2 | 57 | |
| daniQQue | 8:cd0cb71b69f2 | 58 | } | 
| daniQQue | 8:cd0cb71b69f2 | 59 | else if(onoffsignal==0) | 
| daniQQue | 8:cd0cb71b69f2 | 60 | { | 
| daniQQue | 8:cd0cb71b69f2 | 61 | richting_motor1 = 0; //motordirection (ccw) | 
| daniQQue | 8:cd0cb71b69f2 | 62 | pwm_motor1 = 0; //motorspeed 0 | 
| daniQQue | 8:cd0cb71b69f2 | 63 | |
| daniQQue | 8:cd0cb71b69f2 | 64 | } | 
| daniQQue | 8:cd0cb71b69f2 | 65 | |
| daniQQue | 8:cd0cb71b69f2 | 66 | } | 
| daniQQue | 0:34c739fcc3e0 | 67 | |
| daniQQue | 0:34c739fcc3e0 | 68 | } | 
