ultrasonic distance sensor - time headerfile
Dependencies: N5110 PowerControl SRF02 beep mbed
Fork of Ultrasonicdistancesensor by
Revision 3:bbfabbbc4291, committed 2015-05-11
- Comitter:
- probrania7
- Date:
- Mon May 11 18:47:19 2015 +0000
- Parent:
- 2:184524f95eb1
- Commit message:
- Ultrasonic ver1
Changed in this revision
diff -r 184524f95eb1 -r bbfabbbc4291 datafile.h --- a/datafile.h Thu May 07 16:43:32 2015 +0000 +++ b/datafile.h Mon May 11 18:47:19 2015 +0000 @@ -1,16 +1,23 @@ +/** +@file datafile.h +@function for writing files +*/ LocalFileSystem local("local"); //create local file system -void writeDataToFile(int data); +void writeDataToFile(char* data1); -void writeDataToFile(int data) +void writeDataToFile(char* data1) { //leds = 15; //turn on leds for feedback FILE *fp = fopen("/local/log.csv", "a"); //open 'log.csv' for apending //if the file doesnt exist it is created, if it exists, data is apended to the end - fprintf(fp, "%0.2f C\n",data); //print string to file + fprintf(fp, "%0.2f cm\n",data1); //print string to file + //fprintf(fp, "%0.2f C\n",data2); //print string to file + //fprintf(fp, "%0.2f C\n",data3); //print string to file fclose(fp); //close file //leds = 0; //turn off leds to signify file access has finished -} \ No newline at end of file +} +
diff -r 184524f95eb1 -r bbfabbbc4291 timeMgr.h --- a/timeMgr.h Thu May 07 16:43:32 2015 +0000 +++ b/timeMgr.h Mon May 11 18:47:19 2015 +0000 @@ -1,4 +1,7 @@ -#include "mbed.h" +/** +@file timeManager.h +@brief Header file +*/ Serial serial(USBTX,USBRX); void serialISR(); // ISR that is called when serial data is received void setTime(); // function to set the UNIX time @@ -29,7 +32,6 @@ serial.gets(rxString,16); // set flag setTimeFlag = 1; - } //ISR void timer2Expired() @@ -37,6 +39,7 @@ timer2Flag = 1; } +//if (timer2Flag) void getCurrentTime() { timer2Flag = 0; @@ -46,9 +49,12 @@ // print over serial serial.printf("\n\n\rTime = %s\n",buffer2); } - + + +//if (setTimeFlag) void chkUpdateTime() { // if updated time has been sent setTimeFlag = 0; // clear flag setTime(); // update time -} \ No newline at end of file +} +
diff -r 184524f95eb1 -r bbfabbbc4291 ultrasonic.cpp --- a/ultrasonic.cpp Thu May 07 16:43:32 2015 +0000 +++ b/ultrasonic.cpp Mon May 11 18:47:19 2015 +0000 @@ -1,75 +1,155 @@ -#include "mbed.h" -#include "N5110.h" -#include "beep.h" -#include "SRF02.h" -#include "timeMgr.h" -#include "datafile.h" +/** +@file main.h +@brief @library for interfacing with SRF02 ultrasonic sensor in I2C +@see http://www.robot-electronics.co.uk/htm/srf02tech.htm +@Brief Nokia library provide by Dr. Craig Evans +@Brief Beep library provided by +@programmer Ibrahim H Adam +*/ - +/** +@brief Header files included in the project +*/ +#include "mbed.h" //mbed standared header fle +#include "PowerControl/PowerControl.h" //power saving functions +#include "PowerControl/EthernetPowerControl.h" //power saving functions +#include "N5110.h" //Nokia screen library +#include "beep.h" //beep +#include "SRF02.h" //ultrasonic range finder +#include "timeMgr.h" //time functions +/** +@brief pin connections to Nokia Screen // VCC,SCE,RST,D/C,MOSI,SCLK,LED +*/ N5110 lcd(p7,p8,p9,p10,p11,p13,p26); +/** // Can also power (VCC) directly from VOUT (3.3 V) - // Can give better performance due to current limitation from GPIO pin +@brief pin connection to range finder // SDA, SCL -SRF02 sensor(p28,p27); +*/ +SRF02 sensor(p28,p27); // +Beep beep1(p21); //PWM pin +AnalogIn potIn (p20); -Beep beep1(p21); -AnalogIn potIn (p20); +//LEDs to indicate program execution stage DigitalOut Led1 (p24); DigitalOut Led2 (p14); DigitalOut Led3 (p25); DigitalOut Led4 (p23); -//========================= +/** +@brief buffer arraey of character data type for bufferD +@brief buffer arraey of character data type for bufferE +@brief buffer arraey of character data type for bufferF + +*/ +char bufferD[14]; +char bufferE[14]; +char bufferF[14]; + +/* +@brief Type local file system created for file +@brief function created to take two arguments +@param data 2 +@param data1 + +*/ +LocalFileSystem local("local"); //create local file system +void writeDataToFile(char* (data2), float data); + +/** +@briefInterript buttons created to set flags + +*/ InterruptIn button1 (p17); InterruptIn button2 (p29); InterruptIn button3 (p30); -//=============================== -int button1Flag = 0; -int button2Flag = 0; -int button3Flag = 0; -int msgFlag = 1; + +int position = 0; //position for select statement +int positionB; //first position sampled in distance measurement +int positionA; //second position sampled in distance measurement +int movedDist; //gap moved +void nextPosition(); // +void calculateDist(); //distance calculculation +int nextPosFlag = 0; //flag to capture while loop attention +void nextPos(); // +void getPointA(); +void getPointB(); + +void introMessage(); //into message +void errorHandler(); //not included +void menu(); //menu selection function +void demo(); //demo code supplied with library +void cursorSelect(int, int, int, int); //cursor funnction accepting 4 integer agruments +void beeper(float, float); //beeper function accepting two float arguments +void menuLevel(float); //menu level function accepting a float variable +void startMessage(); //start message function +void displayClock(); //clock function -//function declarations -//========================= -void introMessage(); -void errorHandler(); -void menu(); -void demo(); -void cursorSelect(int, int, int, int); -void beeper(float, float); -void menuLevel(float); -void startMessage(); -void displayClock(); -//==================================== -void distMeasure(); -void saveData(); -void adjustBrightness(float); -void sysClock(); -void startClockMsg(); -void clearRow(); -void snapShot(); -//------------------------ +void distMeasure(); //distance measurement function +void saveData(); //not used +void adjustBrightness(float); //LCD brightness +void sysClock(); //system clock - require setting with refference to EPOCH time +void startClockMsg(); //clock message warning clock need setting +void clearRow(); //clear pixels in selected rw +void proxCheck(); //proximity check function +void dataCapture(); //distance point stamping +void clearRow2(); //clear pixels in selected row + +/* +@brief functions of interrupt service routine +@brief user to set flags to 1 +*/ + void button1Pressed(); void button2Pressed(); void button3Pressed(); +/** +@brief initially setting flags to 0 +@brief to be reverted to 1 from within ISR functions +*/ + +int button1Flag = 0; +int button2Flag = 0; +int button3Flag = 0; +int msgFlag = 1; //introduction message flag + +/** +@brief menu level set to 0 +@brief brighness flag set to 0 +@brief distance flag set to 0 +@brief clock flag set to 0 +setting flags to 0 will cause while loop to ignore underlying programs +*/ int menuLevelFlag = 0; int brightFlag = 0; int distFlag = 0; int clockFlag = 0; - +int dataFlag = 0; -Ticker distTimer; -int dstFlg = 0; +//more flags +int getPointAFlag = 0; +int getPointBFlag = 0; + +Ticker distTimer; //ticker time object created +int dstFlg = 0; //distance flag initialised to 0 + +//distance check function to sef diatance flag void distChk() { dstFlg = 1; } - +/** +@briefclkTimer object of ticker timer +@briefclosk flag set to 0 +@briefcalls fiunction clock check +@briefsets clock flag to 0 +*/ Ticker clkTimer; int clkFlg = 0; void clkChk() @@ -77,76 +157,113 @@ clkFlg = 1; } +/** +@briefvarying buzzer sound with reference to distance + +*/ void buzzerRange(); -int distance; -//-------------------- - -int speedTime; -int soundDist; -int soundSpeed; -int Mspeed; - -//-------------------- - +int distance; //distance variable, global declaration int main() -{ +{ + PHY_PowerDown(); //ethernet powerdown // first need to initialise display lcd.init(); - - // beeper(1000, 0.5); - + serial.attach(&serialISR); // attach serial ISR - timer2.attach(&timer2Expired,1.0); + timer2.attach(&timer2Expired,1.0); //timer 2 triggered every 2 2seconds set_time(1424535031); // initialise time to 1st January 1970 //1424535031 introMessage(); - + startClockMsg(); + /** + @brief buttons 1 triggers on rising edge + @brief button 3 triggers on thre rising edge + */ button1.rise(&button1Pressed); button3.rise(&button3Pressed); -//----------------------------------------------------- + -//----------------------------------------------------- - distTimer.attach(&distChk, 1.0); //call ISR every 5 sec - clkTimer.attach(&clkChk, 1.0); //call ISR every 5 sec while(1) - { - if (msgFlag) + { + + if (msgFlag) //if message flag is set to 1 { - startMessage(); + startMessage(); //while loop will allow start message to tum } - - if (button1Flag) + + if (button1Flag) // check if button flag is set + //the renus the following codes { - msgFlag=0; - menu(); - menuLevelFlag = 1; + msgFlag=0; //setmsgFlag to 0 + menu(); //call menu function + menuLevelFlag = 1; //set menuLevelFunction to 1 } - + /** + @brief if menu level flag is set + @briefset button 1 flag to 0 + @brief call menu level function, + @brief menu level function to be controlled by potentiometer + */ if (menuLevelFlag) { button1Flag =0; menuLevel(potIn); } - + /** + @brief if distance flag is set + @brief set menu level flag to 0 + @brief call diatance measure function, + @brief button 1 rising edge sets distance flag to 0 + */ if (distFlag) { menuLevelFlag = 0; - if (dstFlg) + distMeasure(); + + if(button1) + { + distFlag = 0; + } + } + + /** + @brief if data flag is set + @brief set menu level flag to 0 + @brief call data capture function, + @brief button 1 rising edge sets distance flag to 0 + */ + if (dataFlag) + { + menuLevelFlag = 0; + dataCapture(); + + if(button1) { - dstFlg = 0; - distMeasure(); - - if(button1) - { - distFlag = 0; - } + dataFlag = 0; } - } - + } + /** + @brief if next position flag is set + @brief if rising edge of button 3 is encountered + @brief call next position function, + + */ + if (nextPosFlag) + { + if (button3) + nextPos(); + } + + /** + @brief if brigtness flag is set + @brief set menu level flag to 0 + @brief call adjust brightness function to be controlled by potentiometer, + @brief button 1 rising edge sets brightness flag to flag to 0 + */ if (brightFlag) { menuLevelFlag = 0; @@ -155,29 +272,71 @@ { brightFlag = 0; } - } + /** + @brief if clock flag is set + @brief set menu level flag to 0 + @brief call displayclock function, + @brief button 1 rising edge sets distance flag to 0 + @brief and set timer2Flag to 0 + */ if (clockFlag) { menuLevelFlag = 0; - if (clkFlg) + displayClock(); + if (button1) { - clkFlg = 0; - displayClock(); - if (button1) - { - clockFlag = 0; - } + clockFlag = 0; + timer2Flag = 0; } } - - sleep(); + /** + @brief if timer2 flag is set + @brief set timer2 flag to 0 + @brief call getCurrentTime function, + @brief button 1 rising edge sets distance flag to 0 + */ + if (timer2Flag) + { + timer2Flag = 0; + getCurrentTime(); + } + /** + @brief if setTime flag is set + @brief call chkUpdateTime function, + @brief button 1 rising edge sets distance flag to 0 + */ + if (setTimeFlag) + { + chkUpdateTime(); + } + // function goes to sleep when no activity + sleep(); } } +/** +@brief introductory message + +*/ + void introMessage() { - //introducto text a + /** + @brief LED flash sequence + @brief all LEDs ON + */ + Led1 = 1; + Led2 = 1; + Led3 = 1; + Led4 = 1; + /** + @brief introductory text a + @brief name of project + @brief wait for 1.3 secs + @brief clear screen + */ + lcd.drawLine(4, 0, 79, 0, 1); lcd.printString("Ultrasonic",13,1); lcd.printString("Distance",18,2); @@ -187,7 +346,13 @@ wait(1.3); lcd.clear(); - //introductory text b + /** + @brief introductory text b + @brief university name + @brief wait for 1.3 secs + @brief clear screen + */ + lcd.drawLine(4, 0, 79, 0, 1); lcd.printString("University",13,1); lcd.printString("Of",35,2); @@ -197,7 +362,13 @@ wait(1.3); lcd.clear(); - //introductory text c + /** + @brief introductory text c + @brief programmert's name + @brief wait for 1.3 secs + @brief clear screen + */ + lcd.drawLine(4, 0, 79, 0, 1); lcd.printString("Ibrahim Adam",5,1); lcd.printString("200789110",10,2); @@ -207,7 +378,13 @@ wait(1.3); lcd.clear(); - //introductory text c + /** + @brief introductory text d + @brief module title + @brief wait for 1.3 secs + @brief clear screen + */ + lcd.drawLine(4, 0, 79, 0, 1); lcd.printString("Elec 2645",15,1); lcd.printString("Embedded SYS",8,2); @@ -218,10 +395,14 @@ wait(1.3); lcd.clear(); - - startClockMsg(); } +/** + @brief not included at present moment + @brief a future posibilityt + + */ + void errorHandler() { //end text @@ -233,43 +414,84 @@ lcd.clear(); } +/** + @brief adjust brightness function + @brief takes float argument + @brief checks the range + @brief clear screen + @brief set corresponding brightness + @brief display brightness level on screen + */ + void adjustBrightness(float x) -{ - if ((x >= 0) && (x < 0.2)) { - +{ + if ((x >= 0) && (x < 0.2)) + { + lcd.clear(); lcd.setBrightness(0); lcd.printString("Light 0%",13,1); } - if ((x >= 0.2) && (x < 0.4)) { - + if ((x >= 0.2) && (x < 0.4)) + { + lcd.clear(); lcd.setBrightness(0.25); lcd.printString("Light 25%",13,1); } - if ((x >= 0.4) && (x < 0.6)) { - + if ((x >= 0.4) && (x < 0.6)) + { + lcd.clear(); lcd.setBrightness(0.5); lcd.printString("Light 50%",13,1); } - if ((x >= 0.6) && (x < 0.8)) { - + if ((x >= 0.6) && (x < 0.8)) + { + lcd.clear(); lcd.setBrightness(0.75); lcd.printString("Light 75%",13,1); - } - if (x >= 0.8) { - + if (x >= 0.8) + { + lcd.clear(); lcd.setBrightness(1); lcd.printString("Light 100%",13,1); } - lcd.clear(); - + } +/** + @brief data capture function + @brief display title + @brief call distance measure function + @brief set next positioFlag to 1 + + + */ +void dataCapture() +{ + + lcd.printString("Store Dist",9,0); + + distMeasure(); + nextPosFlag = 1; +} + +/** + @brief set LED sequence + @brief clear screen + @brief display main menu title + @brief draw line at specitied location + @brief print further information on subsquent lines + @brief display brightness level on screen + */ void menu() { + Led1 = 1; + Led2 = 0; + Led3 = 0; + Led4 = 0; lcd.clear(); lcd.printString("-MAIN MENU-",9,0); lcd.drawLine(4, 7, 79, 7, 1); @@ -278,7 +500,13 @@ lcd.printString("brightness",15,3); lcd.printString("SYS Clock",15,4); } - +/** + @brief cursor select definition function + @brief vertical start point, dommension + @brief horizontal start point, dimmension + @brief in all specified point coordinates turn off pixel + + */ void cursorSelect(int xDimm, int xLimm, int yDimm, int yLimm) { int i,j; @@ -303,6 +531,8 @@ lcd.refresh(); } + +/** void demo() { // these are default settings so not strictly needed @@ -387,8 +617,17 @@ lcd.clear(); } -//Interrupt service routines -//=========================== +*/ + +/** +@brief Interrupt service routines +@brief button 1 +@brief button 1 flag st to 1 to get while loop attention +@brief button 2 +@brief button 2 flag st to 2 to get while loop attention +@brief button 3 +@brief button 3 flag st to 3 to get while loop attention +*/ void button1Pressed() { button1Flag = 1; @@ -401,30 +640,52 @@ { button3Flag = 1; } - -//beep sound based on beeper frequency and beeper time -//entered respectively +/** +@brief beep sound based on beeper frequency and beeper time +@brief entered respectively +*/ void beeper(float beeperFreq, float beeperTime) { beep1.beep(beeperFreq,beeperTime); } +/** +@brief menu level function, takes float argument +@brief argument checked against range 0 -1 +@brief corresponding cursor position established +@brief if rising edge of button 2 encountered +@brief clear screen +@brief set distance flag to 1 +@brief set bright flag to 0 +@brief set clock flag to 0 +@brief set data flag to 0 +*/ void menuLevel(float lvl) { if ((lvl >= 0) && (lvl < 0.25)) { cursorSelect(1, 6, 9, 14); if (button2) - { + { + lcd.clear(); distFlag = 1; brightFlag = 0; clockFlag = 0; - } - + dataFlag = 0; + + } } if ((lvl >= 0.25) && (lvl < 0.5)) { cursorSelect(1, 6, 17, 22); + if (button2) + { + lcd.clear(); + dataFlag = 1; + brightFlag = 0; + distFlag =0; + clockFlag = 0; + } } if ((lvl >= 0.5) && (lvl < 0.75)) @@ -432,11 +693,12 @@ cursorSelect(1, 6, 25, 30); if (button2) { + lcd.clear(); brightFlag = 1; distFlag =0; clockFlag = 0; + dataFlag = 0; } - } if ((lvl >= 0.75) && (lvl <= 1)) { @@ -446,62 +708,46 @@ clockFlag = 1; distFlag = 0; brightFlag = 0; + dataFlag = 0; } } - - } +/** +@brief function wo return distance +@brief distance based on speeed of sound and time travelled to and from + +*/ void distMeasure() { - lcd.clear(); + /** + @brief print title Measure + @brief return sensor distance in cms + @brief do proximity check + + */ lcd.printString("Measure",15,0); - - - // read sensor distance in cm and print over serial port - char buffer[14]; // each character is 6 pixels wide, screen is 84 pixels (84/6 = 14) - // so can display a string of a maximum 14 characters in length - // or create formatted strings - ensure they aren't more than 14 characters long - - distance = sensor.getDistanceCm(); - soundDist = distance * 2; - - soundSpeed = 34029; - speedTime = soundDist/soundSpeed; - Mspeed = distance/speedTime; - - //==================================================================================== - /* - float Avg; - float k; - float array[10]; - for (int a = 0;a<10;a++) - { - array[a] = ; - k = k + array[a]; - } - Avg = k/10; - - */ - //==================================================================================== - - int length = sprintf(buffer,"Dist = %2d cm",distance); // print formatted data to buffer - // it is important the format specifier ensures the length will fit in the buffer - + proxCheck(); - - if (length <= 14) { // if string will fit on display - lcd.printString(buffer,0,1); // display on screen - } - + /** + @brief read sensor distance in cm and print over serial port + @brief each character is 6 pixels wide, screen is 84 pixels (84/6 = 14) + @brief so can display a string of a maximum 14 characters in length + @brief or create formatted strings - ensure they aren't more than 14 characters long + */ + char buffer[14]; + /** + @brief print formatted data to buffer + @brief it is important the format specifier ensures the length will fit in the buffer + */ + int length = sprintf(buffer,"Dist = %2d cm",distance); - - serial.printf("Distance = %d cm\n",distance); - serial.printf("\n\n\r %s, %0.2f \n",buffer, length); - - - + if (length <= 14) + { // if string will fit on display + lcd.printString(buffer,0,1); // display on screen + } + } void saveData() @@ -512,105 +758,272 @@ { lcd.printString("System test",30,0); } +/** +@brief start message function +@brief LED session sequence +@brief display subsequent messages + +*/ void startMessage() { + Led1 = 1; + Led2 = 1; + Led3 = 1; + Led4 = 0; lcd.printString("Press",25,2); lcd.printString("Start Button",8,3); //displayClock(); } +/** +@brief displayClock function +@brief clear screen +@brief print title + +@brief check if timer2Flag is on +@brief if yes, get current time +@brief if setTimeflag +@brief check upate time +@brief print contents of buffer to screen +*/ void displayClock() { - //timer2.attach(&timer2Expired,1.0); - //serial.attach(&serialISR); // attach serial ISR + lcd.clear(); lcd.printString("-SYS CLOCK-",9,0); - if (timer2Flag) { + if (timer2Flag) + { getCurrentTime(); } - if (setTimeFlag) { + if (setTimeFlag) + { chkUpdateTime(); } lcd.printString(buffer2,4,2); // display on screen } +/*buzzer function +@brief + +*/ void buzzerRange() { - { beeper(400,distance); } } - +/** +@brief start clock message function +@brief LED session sequence +@brief if no time displayed +@brief display clock +@brief print title on screen +@brief clear and print in succession +*/ void startClockMsg() { + Led1 = 1; + Led2 = 1; + Led3 = 0; + Led4 = 0; if(time(NULL)) { displayClock(); lcd.printString("Set Clock",15,0); - wait(0.1); + wait(0.3); clearRow(); - wait(0.1); + wait(0.3); lcd.printString("Set Clock",15,0); - wait(0.1); + wait(0.3); clearRow(); - wait(0.1); + wait(0.3); lcd.printString("Set Clock",15,0); - wait(0.1); + wait(0.3); clearRow(); wait(0.3); lcd.printString("Set Clock",15,0); - wait(0.1); - clearRow(); - wait(0.1); - lcd.printString("Set Clock",15,0); - wait(1); - lcd.clear(); - } else { + wait(1.3); + + } + else + { + //diplay clock displayClock(); lcd.printString("Clock Set",15,0); - wait(1.3); + wait(1.3); } + lcd.clear(); } +//clear selected row void clearRow() { - int i,j; - //clear selecton column - for(j = 0; j < 7; j++) - + for (int j = 0; j <8; j++) { + for(int i = 0; i < 84; i++) + { + lcd.clearPixel(i,j); + } + } +} - for (i = 0; i < 83; i++) - { - lcd.clearPixel(i,j); - } - } - lcd.refresh(); - wait(0.2); -} +/** +@brief check range of distance +@brief assign a particular buzzing frequency -void snapShot() +*/ +void proxCheck() { - Timer A; - A.start(); - if (A.read_ms()==3000) + if ((distance>=20) && (distance <50)) { - beeper(1000, 0.1); - beeper(1000, 0.1); - beeper(1000, 0.1); - beeper(1000, 0.5); - - if (button3) - { - beeper(1000,0.5); - - } + beeper(1000, 0.2); + + } + + if ((distance >= 10) && (distance < 20)) + { + beeper(3000, 0.2); + } + + if (distance < 10) + { + beeper(4000, 0.2); + } } +/** +@brief next position function +@brief if position is greater than3 default to 0 +@brief switch statement uses position value +@brief getPointA - first sampled distance +@brief getPointB - second sampled distance +@brief calculate dist subtract to get difference +*/ +void nextPos() +{ + + if (position > 3) + { + position = 0; + } + switch (position) + { + case 0: + //lcd.clear(); + //lcd.printString("Point A",9,1); + getPointA(); + //wait(1); + break; + + case 1: + //lcd.clear(); + //lcd.printString("Point B",9,1); + getPointB(); + //wait(1); + break; + + case 2: + //lcd.clear(); + lcd.printString("Dist ",9,1); + calculateDist(); + //wait(1); + break; + case 3: + + // + // writeDataToFile(bufferE, positionA); + //writeDataToFile(bufferF, positionB); + + //lcd.printString(bufferC,0,2); + + positionA = 0; + positionB = 0; + lcd.clear(); + break; + } + //clearRow2(); + position = position + 1; + +} +/** +@brief point A is assigned value from distance returned value +*/ +void getPointA() +{ + //positionA = 0; + positionA = distance; + + + int lengthE = sprintf(bufferE,"Org = %2d cm",positionA); + if (lengthE <= 14) + { + lcd.printString(bufferE,0,2); + } +} +/** +@brief point B is assigned value from distance returned value +*/ +void getPointB() +{ + // positionB = 0; + positionB = distance; + + + int lengthF = sprintf(bufferF,"Dest = %2d cm",positionB); + if (lengthF <= 14) + { + lcd.printString(bufferF,0,3); + } +} +/** +@brief calculate seperation distance +*/ +void calculateDist() +{ + movedDist = positionB - positionA; + + int lengthD = sprintf(bufferD,"Dist = %2d cm",movedDist); + if (lengthD <= 14) + { + lcd.printString(bufferD,0,4); + //writeDataToFile(bufferD, movedDist); + } +} +//clears specific row +void clearRow2() +{ + for(int ir = 0; ir < 84; ir ++) + { + for(int jr = 8; jr < 16; jr ++) + { + lcd.clear(); + } + } +} +/** +@brief writing to flash memory +@brief opening file, type FILE , +@brief print string to file +@brief close file +*/ +void writeDataToFile(char* (data2), float data) +{ + //leds = 15; //turn on leds for feedback + FILE *fp = fopen("/local/log.csv", "a"); //open 'log.csv' for apending + + //if the file doesnt exist it is created, if it exists, data is apended to the end + fprintf(fp, "%s, %0.2f C\n", data2, data); //print string to file + + fclose(fp); //close file + + // leds = 0; //turn off leds to signify file access has finished + +} + +
diff -r 184524f95eb1 -r bbfabbbc4291 ultrasonic.h --- a/ultrasonic.h Thu May 07 16:43:32 2015 +0000 +++ b/ultrasonic.h Mon May 11 18:47:19 2015 +0000 @@ -1,9 +1,16 @@ - - - +/** + @file ultrasonic.h + */ void introMessage() { - + /* + @brief introductory routine block texts + @brief name of project + @brief name of university + @brief name of programmer + @brief module title + */ + //introductory text a lcd.drawLine(4, 0, 79, 0, 1); lcd.printString("Ultrasonic",13,1);