Mid_term1
Dependencies: MMA8451Q SLCD mbed
Fork of ACC_LCD_341_MID by
Revision 4:f17af9f983dc, committed 2014-10-06
- Comitter:
- sphasim
- Date:
- Mon Oct 06 07:44:11 2014 +0000
- Parent:
- 3:0e7f46de6d17
- Commit message:
- Part 1
Changed in this revision
acc_341.cpp | Show annotated file Show diff for this revision Revisions of this file |
diff -r 0e7f46de6d17 -r f17af9f983dc acc_341.cpp --- a/acc_341.cpp Mon Oct 06 07:16:01 2014 +0000 +++ b/acc_341.cpp Mon Oct 06 07:44:11 2014 +0000 @@ -1,23 +1,10 @@ /* Test of the accelerometer, digital I/O, on-board LCD screen. - RED: When absolute horizontal - GREEN : When absolute vertical - BLINKY: When in intermediate state - - Author: Siphamandla Simelane - Date: 10/6/2014 - */ - -#include "mbed.h" -#include "MMA8451Q.h"/* - Test of the accelerometer, digital I/O, on-board LCD screen. - MISSION - LED RED: absolute horizontal - LED GREEN : absolute vertical - Should Blink: in intermediate state + RED: Until absolute vertical is reached + GREEN: Until absolute horizontal is reached Author: Siphamandla P. Simelane - Date: 10/7/2014 + Date: 10/6/2014 */ #include "mbed.h" @@ -47,8 +34,8 @@ #define LCDLEN 10 #define LOW_POINT 0.0 #define LOW_LIMIT 0.1 -#define HIGH_LIMIT 1.05 -#define BLINKTIME 0.5// milliseconds +#define HIGH_LIMIT 1.1 +#define BLINKTIME 0.2// milliseconds enum orientStates {INTERMEDIATE, LANDSCAPE, PORTRAIT}; // define the states @@ -76,151 +63,6 @@ } return my_x; -} - -// Print using LCD screen -void LCDMess(char *lMess, float dWait){ - slcd.Home(); - slcd.clear(); - slcd.printf(lMess); - wait(dWait); -} - - -int main() { - float xAcc; - float yAcc; - float vector; - float angle; - char lcdData[LCDLEN]; //buffer needs places dor decimal pt and colon - orientStates PGMState = INTERMEDIATE; - Timer LEDTimer; // time till next PWM values is to change. - int ledState = LEDON; - int timeToChangeDF = BLINKTIME; - // set up timer for next step of Duty Factor timing - LEDTimer.start(); - LEDTimer.reset(); - - #ifdef PRINTDBUG - pc.printf(PROGNAME); - #endif - - // main loop forever - while(true) { - switch (PGMState){ - case INTERMEDIATE: - //Get accelerometer data - tilt angles minus offset for zero mark. - xAcc = abs(acc.getAccX()); - yAcc = abs(acc.getAccY()); - - // Calulate vector sum and angle of x and y reading. - vector = sqrt_newt(pow(xAcc,2) + pow(yAcc,2)); - angle = atan(yAcc / xAcc)* 180 / PI; - - - #ifdef PRINTDBUG - pc.printf("xAcc = %f\r\n", xAcc); - pc.printf("yAcc = %f\r\n", yAcc); - pc.printf("vector = %f\r\n", vector); - pc.printf("Angle = %f\r\n", angle); - #endif - sprintf (lcdData,"%4.3f", yAcc); - LCDMess(lcdData, DATATIME); - - - // Define the landscape and portrait position using x and y readings - if(yAcc < LOW_LIMIT && xAcc > LOW_POINT && xAcc < HIGH_LIMIT){ - PGMState = PORTRAIT; - } else if (xAcc < LOW_LIMIT && yAcc > LOW_POINT && yAcc < HIGH_LIMIT){ - PGMState = LANDSCAPE; - } else { - // Blink the LED if in this state - ledState = ! ledState; - if (LEDTimer.read_ms() > timeToChangeDF){ // check for timer time out transtion - redLed.write(ledState); - greenLed.write(ledState); - LEDTimer.reset(); - PGMState = INTERMEDIATE; - } - } - break; - - case PORTRAIT: - // Green led ON and red OFF - redLed.write(LEDON); - greenLed.write(LEDOFF); - PGMState = INTERMEDIATE; // go idle state - break; - - case LANDSCAPE: - // Green led OFF and red ON - redLed.write(LEDOFF); - greenLed.write(LEDON); - PGMState = INTERMEDIATE; // go idle state - break; - - default: - PGMState = INTERMEDIATE; // go idle state - break; - - } // end state machine - } -} -#include "SLCD.h" -#include "math.h" - -// Configure Accelerometer/Magnetometer: -#if defined (TARGET_KL25Z) || defined (TARGET_KL46Z) - PinName const SDA = PTE25; // Data pins for the accelerometer/magnetometer. - PinName const SCL = PTE24; // DO NOT CHANGE -#elif defined (TARGET_KL05Z) - PinName const SDA = PTB4; - PinName const SCL = PTB3; -#else - #error TARGET NOT DEFINED -#endif - -#define MMA8451_I2C_ADDRESS (0x1d<<1) - -#define PI 3.14159265 -#define DATATIME 0.150 -#define PROGNAME "ACCLCD341VB\r/n" -#define PRINTDBUG -#define LEDON false -#define LEDOFF true -#define LCDLEN 10 -#define LOW_POINT 0.0 -#define LOW_LIMIT 0.125 -#define HIGH_LIMIT 1.1 -#define ONTIME 1.0 -#define BLINKTIME 0.1// milliseconds - - -enum orientStates {INTERMEDIATE, LANDSCAPE, PORTRAIT}; // define the states -PwmOut greenLed(LED_GREEN); -PwmOut redLed(LED_RED); -SLCD slcd; //define LCD display - -MMA8451Q acc(SDA, SCL, MMA8451_I2C_ADDRESS); -Serial pc(USBTX, USBRX); - -float sqrt_newt(float arg) { - int i = 0; - float X1 = 0.0; - int intMax = 20; - int epsilon = 1e-7; - float my_x = float(arg/2.0); - int delta = 1; - for(i=0; i<intMax; i++){ - X1 = 0.5*(my_x + (arg/my_x)); - delta = abs(X1-my_x); - if (delta < epsilon) - break; - else - my_x = X1; - } - return my_x; - // return (sqrt(arg)); } @@ -239,14 +81,8 @@ float vector; float angle; char lcdData[LCDLEN]; //buffer needs places dor decimal pt and colon - orientStates PGMState = INTERMEDIATE; - Timer LEDTimer; // time till next PWM values is to change. - int ledState = LEDON; - int timeToChangeDF = BLINKTIME; - // set up timer for next step of Duty Factor timing - LEDTimer.start(); - LEDTimer.reset(); - + orientStates PGMState = INTERMEDIATE; + #ifdef PRINTDBUG pc.printf(PROGNAME); #endif @@ -261,8 +97,7 @@ // Calulate vector sum and angle of x and y reading. vector = sqrt_newt(pow(xAcc,2) + pow(yAcc,2)); - angle = atan(yAcc / xAcc)* 180 / PI; - + angle = atan(yAcc / xAcc)* 180 / PI; #ifdef PRINTDBUG pc.printf("xAcc = %f\r\n", xAcc); @@ -270,38 +105,30 @@ pc.printf("vector = %f\r\n", vector); pc.printf("Angle = %f\r\n", angle); #endif - sprintf (lcdData,"%4.3f", yAcc); - LCDMess(lcdData, DATATIME); - + sprintf (lcdData,"%4.3f", vector); + LCDMess(lcdData, DATATIME); // Define the landscape and portrait position using x and y readings if(yAcc < LOW_LIMIT && xAcc > LOW_POINT && xAcc < HIGH_LIMIT){ PGMState = PORTRAIT; } else if (xAcc < LOW_LIMIT && yAcc > LOW_POINT && yAcc < HIGH_LIMIT){ PGMState = LANDSCAPE; - } else { - // Blink the LED if in this state - ledState = ! ledState; - if (LEDTimer.read_ms() > timeToChangeDF){ // check for timer time out transtion - redLed.write(ledState); - greenLed.write(ledState); - LEDTimer.reset(); - PGMState = INTERMEDIATE; - } - } + } else { + PGMState = INTERMEDIATE; + } break; case PORTRAIT: // Green led ON and red OFF redLed.write(LEDON); - greenLed.write(LEDOFF); + greenLed.write(LEDOFF); PGMState = INTERMEDIATE; // go idle state - break; + break; case LANDSCAPE: // Green led OFF and red ON redLed.write(LEDOFF); - greenLed.write(LEDON); + greenLed.write(LEDON); PGMState = INTERMEDIATE; // go idle state break;