Dependencies:   mbed HIDScope biquadFilter

main.cpp

Committer:
hidde1104
Date:
2019-10-16
Revision:
24:2637e0160301
Parent:
23:4c66541f00d3
Child:
25:10be3ac71e2f

File content as of revision 24:2637e0160301:

#include "mbed.h"
#include "HIDScope.h"
#include "BiQuad.h"
#include "algorithm"
Serial pc(USBTX, USBRX);
InterruptIn but1(PTC6);

BiQuad bq1 (0.881889334678067,  -1.76377866935613,   0.8818893346780671,  -1.77069673005903,   0.797707797506027);

BiQuad bq2 (0.000198358203463849,    0.000396716406927699,    0.000198358203463849, -1.96262073248799,   0.963423352820821);


BiQuadChain bqc;


//Define objects
AnalogIn    emg0( A0 );
AnalogIn    emg1( A1 );

Ticker      sample_timer;
Ticker      calibrate_emg_timer;
HIDScope    scope( 3 );
DigitalOut  led1(LED1);
DigitalOut  led2(LED2);
DigitalOut  led3(LED3);

/** Sample function
 * this function samples the emg and sends it to HIDScope
 **/
 
 /*
 double sample_max = 0.0f;
 double sample_min = 1.0f;
 int o = 0;
 
    float emg0_value = emg0.read(); 
    float emg1_value = emg1.read();
 
    float filter_value = fabs(bq2.step(fabs(bq1.step(emg0_value - emg1_value))));
 */

const int length = 1000;
int i = 0;
int j = 0;

float filter_value;
float filter_value_2;
float emg0_value;
float emg1_value;

float emg_mean_array[length] = { };
float emg_mean;

float filter_max = 0;

void sample()
{
    /* Set the sampled emg values in channel 0 (the first channel) and 1 (the second channel) in the 'HIDScope' instance named 'scope' */
    emg0_value = emg0.read(); 
    emg1_value = emg1.read();
    
    //double filter_value = bqc.step(emg1_value);
    //filter_value = fabs(bq2.step(fabs(bq1.step(emg0_value - emg1_value))));
    //float filter_value = fabs(bq2.step(fabs(bq1.step(emg0_value))));                            //alleen emg0 geeft een betere baseline dan emg0 - emg1
    
    
    /*
    if (filter_value > sample_max) {
        sample_max = filter_value;
        }
    if (filter_value < sample_min) {
        sample_min = filter_value;
        }
        
      
    //filter_value = filter_value/sample_max;  
    
    filter_value = filter_value-((sample_max+sample_min)/2);
    filter_value = filter_value/(sample_max-sample_min);
    */ 
    
    
    //filter_value = filter_value - filter_mean;
    //filter_value = filter_value/filter_max;
    
    //but1.mode(PullUp); 
    //but1.rise(&calibrate);
    
    
    scope.set(0, emg0.read() );
    scope.set(1, emg1.read() );
    /* Repeat the step above if required for more channels of required (channel 0 up to 5 = 6 channels) 
    *  Ensure that enough channels are available (HIDScope scope( 2 ))
    *  Finally, send all channels to the PC at once */
    scope.send();
    /* To indicate that the function is working, the LED is toggled */
    led2 = !led2;
}





float emg0_value_2;
float emg1_value_2;
float emg_mean_corr;

void sample_2() {                                                               // mean corrected emg waarden die worden gebruikt voor de eerste instantie van filter_value.
    emg0_value_2 = emg0.read();
    emg1_value_2 = emg1.read();
    
    emg_mean_corr = (emg0_value_2-emg1_value_2)-emg_mean;
    
    filter_value = fabs(bq2.step(fabs(bq1.step(emg_mean_corr))));
    scope.set(2, filter_value); 
    }
    



float filter_array[length] = { };

void calibration_preparation() {
        while (i < length) {
        sample();
        filter_array [i] = filter_value;
        i++;
        }
        
    
    int filter_max = 0;
    int m;
    for (m = 0 ; m < length ; m++);

        if (filter_array[m] > filter_max) {
            filter_max = filter_array[m];
            }
}





void emg_mean_function() {
    while (j < length) {
        sample();
        emg_mean_array[i] = emg0_value - emg1_value;
        j++;
        }
    float emg_sum = 0;
    for (int n = 0; n < length; n++) {
        emg_sum += emg_mean_array[n];
        }
        emg_mean = emg_sum/length;
}
    



void sample_3() {
    
    filter_value_2 = filter_value/filter_max;
    
    scope.set(2, filter_value_2 );
}

int main()
{   

    pc.baud(115200);

    /**Attach the 'sample' function to the timer 'sample_timer'.
    * this ensures that 'sample' is executed every... 0.002 seconds = 500 Hz
    */
    
    
    emg_mean_function();
    sample_2();
    
    
    

    sample_timer.attach(&sample_3, 0.001);
    /*empty loop, sample() is executed periodically*/
    //pc.printf("The value of sample_min is %f\n\r",sample_min);
    //pc.printf("The value of sample_max is %f\n\r",sample_max); 
    while(1) {
        }
}