dad

Dependencies:   mbed-os FXAS21000 LED_Bar FXOS8700Q

main.cpp

Committer:
mukundy8
Date:
2022-04-26
Revision:
2:d08625231a9f
Parent:
1:7a49fd0692fd
Child:
3:9ab65e6d4cd4

File content as of revision 2:d08625231a9f:

#include "mbed.h"
#include "FXOS8700Q.h"
#include "FXAS21000.h"
#include "hcsr04.h"
    I2C i2c(PTE25, PTE24);
    Serial pc(USBTX,USBRX);
    FXOS8700QAccelerometer acc(i2c, FXOS8700CQ_SLAVE_ADDR1);    // Configured for the FRDM-K64F with onboard sensors
    FXOS8700QMagnetometer mag(i2c, FXOS8700CQ_SLAVE_ADDR1);
    FXAS21000 gyro(D14,D15);
    HCSR04 usensor1(D8,D9);                     //ECHO Pin=D9, TRIG Pin=D8
    HCSR04 usensor2(D7,D6);                     //ECHO Pin=D7, TRIG Pin=D6

    int main(void)
    {
        int num = 0;
        int distance1, distance2;
        float dist_remaining1, dist_percent1, dist_remaining2, dist_percent2;
        char snd[255],rcv[1000];                    //snd: send command to ESP8266
                                            //rcv: receive response from ESP8266

        //Ultrasound Sensor (HC-SR04) #1 Initialization
        int a = 30;
        usensor1.start();
        wait_ms(500);
        
    //Calculating Distance Percentage Remaining for Sensor # 1
        distance1 = usensor1.get_dist_cm();
        dist_remaining1 = a-distance1;
        dist_percent1 = (dist_remaining1/30)*100;
        
    //LED and Tera Term Output
        if (distance1<30 && distance2<30) {
            //RLed = 1;
//            BLed = 1;
//            GLed = 0;
            pc.printf("You are colse!\n\r"); while(1) {
                    pc.putc(pc.getc() + 1);}
            //printf("Percent remaining: %f\r", dist_percent1 && dist_percent2);
        } else {
            //GLed = 1;
//            BLed = 1;
//            RLed = 0;
            pc.printf("You are far!\n\r"); while(1) {
                    pc.putc(pc.getc() + 1);}
            }
        float gyro_data[3];
        motion_data_units_t acc_data, mag_data;
        motion_data_counts_t acc_raw, mag_raw;
        float faX, faY, faZ, fmX, fmY, fmZ, tmp_float;
        int16_t raX, raY, raZ, rmX, rmY, rmZ, tmp_int;
        acc.enable();
        mag.enable();
        DigitalOut Red(LED1);
        Red=1;
        DigitalOut Blue(LED3);
        DigitalOut Green(LED2);
        Blue=1;
        Green=1;
        
        while (true) {
            // counts based results
            acc.getAxis(acc_raw);
            mag.getAxis(mag_raw);
            acc.getX(raX);
            acc.getY(raY);
            acc.getZ(raZ);
            mag.getX(rmX);
            mag.getY(rmY);
            mag.getZ(rmZ);
            // unit based results
            acc.getAxis(acc_data);
            mag.getAxis(mag_data);
            acc.getX(faX);
            acc.getY(faY);
            acc.getZ(faZ);
            mag.getX(fmX);
            mag.getY(fmY);
            mag.getZ(fmZ);
           pc.printf("FXOSQ8700Q ACC: X=%1.4f   Y=%1.4f   Z=%1.4f", acc.getX(faX),acc.getY(faY),acc.getZ(faZ));
           pc.printf("  MAG: X=%4.1f   Y=%4.1f   Z=%4.1f\r\n", mag.getX(fmX),mag.getY(fmY), mag.getZ(fmZ));
           gyro.ReadXYZ(gyro_data);
           pc.printf("FXAS21000  Gyro: X=%6.2f   Y=%6.2f    Z=%6.2f\r\n", gyro_data[0],gyro_data[1], gyro_data[2]);
           
          
           if(abs(acc.getX(faX)) > 1.5 || abs(acc.getZ(faZ)) > 1.3 || abs(acc.getY(faY)) > 0.1)
           {
            
            //Red = 0;
//            Blue = 1;
//            Green = 1;
            pc.printf("Going too fast!\n\r"); while(1) {
            pc.putc(pc.getc() + 1);}

            } 
            
            
            else{
                
                //Red = 1;
//                Green = 0;
//                Blue = 1;
                    pc.printf("You are safe!\n\r"); while(1) {
                    pc.putc(pc.getc() + 1);}
                };
            wait(1.0f);
        }
    }