02/07/15

Dependencies:   mbed

Dependents:   TabbedGUIMbed

Committer:
aidanPJG
Date:
Thu Jul 16 14:01:24 2015 +0000
Revision:
52:d21fc7266b66
Parent:
51:210353276e06
Child:
53:10f4f519ba69
variable number of pins. have to change it in code, going to make it adaptable form the parameter ;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
aidanPJG 22:34bc2f2f5b09 1 #include "mbed.h"
aidanPJG 22:34bc2f2f5b09 2 #include <time.h>
aidanPJG 22:34bc2f2f5b09 3 #include <string>
aidanPJG 22:34bc2f2f5b09 4 #include <iostream>
aidanPJG 39:3527578e78dd 5 #include "Distance.h"
aidanPJG 31:bea1117f14fb 6
aidanPJG 52:d21fc7266b66 7 void printArray(double array[20], int timesArray[20]);
aidanPJG 51:210353276e06 8 void data(int sensor_number, int time, double speed);
aidanPJG 38:da262dc4f90a 9
aidanPJG 19:a3edf2c547e1 10 //mbed pins
aidanPJG 26:4289549b2d21 11 extern Serial pc; //defines the communication between MBed and pc
aidanPJG 47:1dc3b5f7bf4a 12 int NoOfPins = 3; //for how many sensors there are
aidanPJG 52:d21fc7266b66 13 DigitalIn sensor[20] = {p5,p6,p7,p8,p9,p10,p11,p12,p13,p14,p15,p16,p17,p18,p19,p20,p21,p22,p23,p24} ; //array of sensors.
aidanPJG 31:bea1117f14fb 14
aidanPJG 31:bea1117f14fb 15
aidanPJG 19:a3edf2c547e1 16 //c++ variables
aidanPJG 26:4289549b2d21 17 time_t sensor_time ; //time at which sensor is broken
aidanPJG 44:3b45ec49bc44 18 int timeDiff; //time between 2 sensors - not used right now
aidanPJG 44:3b45ec49bc44 19 float speed;
aidanPJG 52:d21fc7266b66 20 int times[20]; //array the size of #pins
aidanPJG 52:d21fc7266b66 21 double speeds[20]; //array of speeds
aidanPJG 52:d21fc7266b66 22
aidanPJG 52:d21fc7266b66 23
aidanPJG 52:d21fc7266b66 24
aidanPJG 50:d794595c6868 25 int calculate(double distance)
aidanPJG 22:34bc2f2f5b09 26 {
aidanPJG 22:34bc2f2f5b09 27 pc.printf("new program \n"); //alert user of initialisation
aidanPJG 38:da262dc4f90a 28
aidanPJG 30:ab3a436e8968 29 int i = 0;
aidanPJG 52:d21fc7266b66 30 while( i < NoOfPins)
aidanPJG 25:bab86a12e9ad 31 {
aidanPJG 30:ab3a436e8968 32 while(!sensor[i])
aidanPJG 22:34bc2f2f5b09 33 {
aidanPJG 30:ab3a436e8968 34 if(sensor[i + 1]) {
aidanPJG 30:ab3a436e8968 35 sensor_time = time(NULL);
aidanPJG 30:ab3a436e8968 36 i++;
aidanPJG 30:ab3a436e8968 37 } //error checking incase next one is done
aidanPJG 22:34bc2f2f5b09 38 }
aidanPJG 33:929f1755664b 39 sensor_time = time(NULL); //gets current time
aidanPJG 39:3527578e78dd 40 pc.printf("\n sensor %d : %d \t", i,sensor_time);
aidanPJG 31:bea1117f14fb 41 times[i] = sensor_time; //adds sensor times to array for logging.
aidanPJG 33:929f1755664b 42 if ( i > 0) { //to ensure it is not the first one
aidanPJG 33:929f1755664b 43 timeDiff = difftime(times[i], times[i-1]); //calculates the time difference
aidanPJG 39:3527578e78dd 44 pc.printf(" timediff: %d s \t", timeDiff);
aidanPJG 33:929f1755664b 45 speed = distance / timeDiff;
aidanPJG 39:3527578e78dd 46 pc.printf(" speed : %f m/s ", speed);
aidanPJG 44:3b45ec49bc44 47 speeds[i] = speed;
aidanPJG 32:792c4239a738 48 }
aidanPJG 30:ab3a436e8968 49 i++;
aidanPJG 30:ab3a436e8968 50 }
aidanPJG 32:792c4239a738 51 pc.printf(" \n Calculate completed \n"); //alert to let user know it completed
aidanPJG 50:d794595c6868 52 printArray(speeds, times);
aidanPJG 38:da262dc4f90a 53
aidanPJG 22:34bc2f2f5b09 54 }
aidanPJG 30:ab3a436e8968 55
aidanPJG 52:d21fc7266b66 56 void printArray(double array[20], int timesArray[20])
aidanPJG 38:da262dc4f90a 57 {
aidanPJG 52:d21fc7266b66 58 for (int i = 0; i < NoOfPins ; i++) //printing module for array
aidanPJG 38:da262dc4f90a 59 {
aidanPJG 50:d794595c6868 60 pc.printf(" Sensor : %d Time %d Speed %f \n", i,times[i],speeds[i]);
aidanPJG 50:d794595c6868 61 // pc.printf(" %d : %d \t", i,times[i]);
aidanPJG 38:da262dc4f90a 62 }
aidanPJG 52:d21fc7266b66 63 for (int i = 0; i < NoOfPins ; i++) //printing to Datalog
aidanPJG 44:3b45ec49bc44 64 {
aidanPJG 51:210353276e06 65 data( i,times[i],speeds[i]);
aidanPJG 44:3b45ec49bc44 66 }
aidanPJG 38:da262dc4f90a 67
aidanPJG 38:da262dc4f90a 68 }