De sensorcontroller van het TLS2 project.

Dependencies:   mbed

main.cpp

Committer:
RichardHoekstra
Date:
2016-11-14
Revision:
2:4c5952cf26d0
Parent:
1:c9fae063e6f3
Child:
3:8e50fc7b82b7

File content as of revision 2:4c5952cf26d0:

#include "mbed.h"


/* De sensor controller heeft de volgende taken
    1. Sensoren uitlezen
        1. De frequentie moet per sensor aanpasbaar zijn.
    2. Reageren op I2C data requests
    3. Indien mogelijk meerdere samples nemen van de hoogste prioriteit sensor
    
    De volgende 'dingen' moeten kunnen worden ingesteld
        1. 'Hoofd'sensor
        2. Sample rate _per_ sensor
        3. Moving Average van 'Hoofd'sensor
*/


void i2c_request(){
    //To be written    
}

        
float sensorVal[3] = {0}; 
//Index 0: druksensor waarde
//Index 1: flowsensor waarde
//Index 2: temperatuursenor waarde
#define druksensor 0
#define flowsensor 1
#define tempsensor 2

bool pressure_is_main = true; //Determine the most important sensor as in, on which value is the motor controller regulating
bool smoothing = true; //Determine to activate the moving average         


//In: nieuwe waarde en hoeveel samples er worden gebruikt
//Out: moving average van x elementen
//Explanation:  deze functie 'smooth' de waardes die binnenkomen van
//              bijvoorbeeld de druksensor. Zoals een condensator,
//              de smoothing factor kan worden ingesteld door de hoeveelheid 
//              samples in de moving average aan te passen.
//              Met maximaal 100 samples.
float calc_moving_average(float val, int samples = 10){
    static float sample_arr[100] = {0}; //[0] is the newest
    float moving_average = 0;
    if(samples > 0 && samples < 100){ //Sanity check
        //Put the new val into the sample_arr and push out the oldest one
        for(int i=samples-1; i>0; i--){
            //[9]<-[8]<-[7]
            sample_arr[i] = sample_arr[i-1];
        }
        sample_arr[0] = val;
        //Calculate the moving average
        for(int i=0; i<samples; i++){
            moving_average += sample_arr[i];
        }
        return moving_average/(float)samples;
    } else {
        return 3.1415926; //Improv error code 
    }
}

int main() {
    //Pins
    AnalogIn drukSensor(A0);
    AnalogIn flowSensor(A1);
    AnalogIn tempSensor(A2);
    
    //Sample time
    int tick_ms_druksensor    = 10,     //100 Hz
        tick_ms_flowsensor    = 10,     //100 Hz
        tick_ms_tempsensor    = 1000;   //1 Hz 

    //mbed ondersteund onneindig veel timers
    Timer   t_druk,
            t_flow,
            t_temp;

    t_druk.start();
    t_flow.start();
    t_temp.start();
    while(1) {
        if(t_druk.read_ms() >= tick_ms_druksensor){
            //Lees de druksensor uit            
            if(pressure_is_main == true && smoothing == true){
                calc_moving_average(drukSensor.read());
            } else {
                sensorVal[druksensor] = drukSensor.read();   
            }
            t_druk.reset(); 
        }
        if(t_flow.read_ms() >= tick_ms_flowsensor){
            //Lees de flowsensor uit
            if(pressure_is_main == false && smoothing == true){
                calc_moving_average(flowSensor.read());
            } else {
                sensorVal[flowsensor] = flowSensor.read();
            }
            t_flow.reset();    
        }
        if(t_temp.read_ms() >= tick_ms_tempsensor){
            //Lees de temperatuursensor uit 
            sensorVal[tempsensor] = tempSensor.read();
            t_temp.reset();   
        }
    }
}