A Weather station designed to read the values of temperature and pressure from the sensor (BMP180), data displayed via a nokia N5110 display.

Dependencies:   BMP180 N5110 PowerControl mbed

Barometer.h

Committer:
amiraseman
Date:
2015-05-09
Revision:
23:a0ce9fa869c2
Child:
26:c0d8d2f68406

File content as of revision 23:a0ce9fa869c2:

/**

@file Barometer.h
@brief Header file containing member functions and variables
@author Amir M. Asemanpayeh
@date May 2015

@brief Header file - Contains Global Variables, GPIO and Pins and Function prototypes

*/


#include "mbed.h"
#include "N5110.h"
#include "BMP180.h"
#include "PowerControl/PowerControl.h"
#include "PowerControl/EthernetPowerControl.h"

/**
@namespace bmp180
@brief A I2C instance to interact with the BMP sensor \n SDA, SCL
*/
BMP180 bmp180(p28,p27);


/**
@namespace lcd
@brief A serial data protocol to operate with a master/slave relationship to interact with the lcd \n VCC,SCE,RST,D/C,MOSI,SCLK,LED
*/
N5110 lcd(p7,p8,p9,p10,p11,p13,p26);


/**
@namespace leds
@brief GPIO bus output for status LEDs
*/
BusOut leds(LED4,LED3,LED2,LED1);


/**
@namespace serial
@brief A USB Virtual Serial Port to print out messages to a host PC terminal
*/
Serial serial(USBTX,USBRX);


/**
@namespace local
@brief A local file system declared to store data files
*/
LocalFileSystem local("local");


/**
@namespace button1
@brief An Interrupt on digital pushbutton1 input p16
*/
InterruptIn button1(p16);


/**
@namespace button2
@brief An Interrupt on digital pushbutton2 input p17
*/
InterruptIn button2(p17);


/**
@namespace button3
@brief An Interrupt on digital pushbutton3 input p15
*/
InterruptIn button3 (p15);


/**
@namespace button4
@brief An Interrupt on digital pushbutton4 input p18
*/
InterruptIn button4 (p18);


/**
@namespace redLED
@brief A PwmOut interface is used to control the frequency and mark-space ratio of a led (The red LED)
*/
PwmOut redLED(p24);//red


/**
@namespace yellowLED
@brief A PwmOut interface is used to control the frequency and mark-space ratio of a led (The yellow LED)
*/
PwmOut yellowLED(p23);//yellow


/**
@namespace greenLED
@brief A PwmOut interface is used to control the frequency and mark-space ratio of a led (The green LED)
*/
PwmOut greenLED(p22);


/**
@namespace buzzer
@brief A PwmOut interface is used to control the frequency and mark-space ratio of a buzzer
pulse train
*/
PwmOut buzzer(p21);


/**
@namespace timer
@brief Create ticker object for temperature and pressure readings
*/
Ticker timer;


/**
@namespace dataLoggerTimer
@brief a ticker object for the data logger functions
*/
Ticker dataLoggerTimer ;


/**
@namespace powerSaverTimeout
@brief create a timeout object for the poweerSaver function
*/
Timeout powerSaverTimeout;

/**
@namespace debounce
@brief create a debounce timer object to implement a debounce counter to avoid multiple interrupts.
*/
Timer debounce;


int timerFlag = 1; /*!< Flag for tempesrature pressure reading ISR */
int tickerFlag = 0 ;  /*!<Flag to show the minutes passed */
int button1Flag = 0; /*!< Flag set in button1Pressed ISR */
int button2Flag = 0 ; /*!<Flag set in button2Pressed ISR  */
int button3Flag = 0 ; /*!< Flag set in button3Pressed ISR  */
int button4Flag = 0 ; /*!< Flag set in button4Pressed ISR */
int unitFlag = 1 ; /*!< Flag set in the unitSettings function, indicates the units picked by user */
int powerSaverFlag = 0 ; /*!<Flag set in the powerSettings function when the powerSaver is switched on */
int lcdPowerFlag = 1 ; /*!< Flag set in the savePower function to indicate the status of the LCD (ON or OFF) */
int dataLoggerFlag = 0 ; /*!< Flag set by user in the dataLoggerSetting function to turn on the logger */
int runLoggerFlag = 0 ;  /*!< Fag set when the logger is switched on, allows user to navigate to this option in the main menu */
int alarmClockFlag = 0 ; /*!< Flag set in the AlarmClock function, indicates if the alarm clock has been turned on */
int thresholdAlarmFlag = 0 ; /*!<Flag set in the thresholdAlarmmenu function,indicates if the thresholds are set */

int UNIXdate=0;   /*!<An integer to store the value of UNIX time calculated by mktime function */
int currentTime ;/*!<An integer to store the UNIX value of the current time */
int powerSaverTime = 60;    /*!<An integer to set the initial value of the power saver ticker */
int dataLoggerTime = 60;    /*!<An integer used to set the initial value of the data logger ticker */

float temperature;  /*!<A float value to store the value of the temperature recieved from the sensor */
float pressure; /*!<A float value to store the value of the pressure recieved from the sensor */
float averageTemperature ;  /*!<A float value to store the average value of temperature readingsn taken over a period of time */
float averagePressure ; /*!<A float value to store the average value of pressure readings over a period of time */
float minTemperature ;  /*!<A float value to save the minimum value of temperature readings */
float maxTemperature ;  /*!<A float value to store the maximum value of temperature readings */
float minPressure;  /*!<A float value to store the minimum value of pressure readings */
float maxPressure;  /*!<A float value to store the maximum value of pressure readings */




float arrayT[83] ; /*!<A A float array to store the values of temperature to calculate the average,minimum and maximum values*/
float arrayP[83] ; /*!<A A float array to store the values of pressure to calculate the average,minimum and maximum values*/
float arrayTG[83] ; /*!<A A float array to store the values of temperature to plot the related graph */
float arrayPG[83] ;/*!<A A float array to store the values of pressure to plot the related graph */


char bufferTime[14]; /*!<A A char array (buffer) to store time*/
char bufferDate[14]; /*!<A A char array (buffer) to store date*/
char bufferT[14];/*!<A A char array (buffer) to store the value of temperature in char*/
char bufferP[14];  /*!<A A char array (buffer) to store the value of pressure in char */
// 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



char buffer0[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,0)*/
char buffer1[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,1)*/
char buffer2[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,2)*/
char buffer3[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,3)*/
char buffer4[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,4)*/
char buffer5[14];   /*!<A A char array (buffer) used to display data on the LCD at (0,5)*/



//arrays used to store data to the local file
char timeSent[1000]; /*!<A A char array used to save time staps to the local file */
char dateSent[1000]; /*!<A A char array used to save date stamps the local file */
char temperatureSent[1000]; /*!<A A char array used to save the temperature readings to the local file */
char pressureSent[1000]; /*!<A A char array used to save the pressure readings to the local file */
char temperatureRecieved[1000]; /*!<A A char array used to retrive the saved temperature readings from the local file */
char pressureRecieved[1000]; /*!<A A char array used to retrive the saved pressure readings from the local file  */
char timeRecieved[1000]; /*!<A A char array used to retrive the saved time stamps from the local file  */
char dateRecieved[1000]; /*!<A A char array used to retrive the saved date stamps from the local file */



char * pch; /*!<A A char array used to split the char arrays of temperature values retrived from the local file to the individual temperature strings */
char * pch1; /*!<A A char array used to split the char arrays of pressure values retrived from the local file to the individual pressure strings*/
char * pch2; /*!<A  A char array used to split the char arrays of times retrived from the local file to the individual time strings*/
char * pch3; /*!<A  A char array used to split the char arrays of dates retrived from the local file to the individual date strings*/


int state=0; /*!<A An integer used to navigate through the finite machines (indexes)*/

float frequency[]= {659,554,659,554,659,554,659,554,659,554,659,554}; /*!<A An array of floats with different frequencies for the buzzer*/





struct  State {
    int output;
    char title[14];
    int nextState[2];
};

typedef struct State STyp1; // for the start menu

STyp1 fsmA[4] = {
    {0,"Live Data",{1,3}},
    {1,"Saved Data",{2,0}},
    {2,"Alarms",{3,1}},
    {3,"Settings",{0,2}},
};

typedef struct State STyp2; // for the settings menu

STyp2 fsmB[4] = {
    {0,"Date/Time",{1,3}},
    {1,"Units",{2,0}},
    {2,"Power Saver",{3,1}},
    {3,"Data Logger",{0,2}},
};

typedef struct State STyp3; // for the time/date settings

STyp3 fsmC[5] = {
    {12,"Hour:",{1,4}},
    {0,"Min:",{2,0}},
    {21,"Day:",{3,1}},
    {4,"Month:",{4,2}},
    {2015,"Year:",{0,3}},
};


typedef struct State STyp4; // for the units settings

STyp3 fsmD[4] = {
    {1,"C/mb",{1,3}},
    {2,"C/atm",{2,0}},
    {3,"F/mb",{3,1}},
    {4,"F/atm",{0,2}},
};


typedef struct State STyp5; // for the Power saver settings

STyp5 fsmE[2] = {
    {0,"Off",{1,1}},
    {60,"On",{0,0}},
};


typedef struct State Stype6; // for the alarms menu

Stype6 fsmF[2] = {
    {0,"Thresholds",{1,1}},
    {1,"Alarm Clock", {0,0}},
};

typedef struct State Stype7; // yes or no

Stype7 fsmG[2] = {
    {1,"Yes",{1,1}},
    {0,"No", {0,0}},
};

typedef struct State Stype8; // for the thresholds

Stype8 fsmH[4] = {
    {20,"Min T:",{1,3}},
    {30,"Max T:",{2,0}},
    {1000,"Min P:",{3,1}},
    {1100,"Max P:",{0,2}},
};


/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void button1Pressed();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void button2Pressed();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void button3Pressed();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void button4Pressed();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void timerExpired();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void dataLoggerTimerExpired ();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void tickerExpired ();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void saveToFile(char *data,char *data1,char *data2,char *data3);

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void updateTime();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void display();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void readData();


/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void powerSaverExpired();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void powerSaverCheck();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void liveData();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void loggerData();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void dataLogger();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void forecast();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void thresholdCheck();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void threshold();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void alarmClockCheck();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void alarmClock ();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void alarmsMenu ();

/**
Adds up two integer variables
@param a - integer to add
@param b - integer to add
@returns the sum of a and b
*/
void dataLoggerSetting();

/**
*Third option in the settings menu./n
*Allows the user to turn on the power saving option and set the value of time out /n
*Attaches a timeout to set the powerSaverFlag /n
@param powerSaverFlag - integer used as a flag to indicate if the power saver option is switched on or off
@param state - integer used to navigate through fsm states
*/
void powerSaverSetting();

/**
*Calculates the UNIX time value./n
*Sets the integer values entered by user to the tm structure mebers /n
*Converts the tm structure to time_t /n
@param timeinfo - tm struct sent to mktime function
@param rawtime - fundamental arithmetic type to represent the current time informations
*/
void calculateUNIXTime();

/**
*The second option in the settings menu./n
*Allows the user to change the units /n
@param unitFlag - integer used as a flag to indicate the units set
@param state - integer used to navigate through fsm states
*/
void unitsSetting();


/**
*The first option in the settings menu./n
*Allows the user to enter time and date /n
*Sends the recieved int arrays to the calculateUNIXtime function to calculate the unix time /n
*sets the current time to the calculated unix time.
@param state - integer used to navigate through fsm states
*/
void timeDateSetting();


/**
*The setting menu displayed when the fourth state of fsmA is picked from the main menu /n
*Depends on the state of the finite state machine used for this function, put the related title in the screen buffers /n
*Also copy the bufferTime (buffer used to store time) on the first screen buffer (at the top) /n
*Displays the screen buffers on the LCD/n
*switch statement checks the current state of the fsm (fsmB),
*The related function to each fsm state is executed as when a rising edge from the 4th button interrupts (button 4 is pressed)

*/
void settingsMenu();

/**
*The main menu displayed at the start /n
*Depends on the state of the finite state machine (fsmA) used for this function, put the related title in the screen buffers /n
*Also copy the bufferTime (buffer used to store time) on the first screen buffer (at the top) /n
*Displays the screen buffers on the LCD/n
*switch statement checks the current state of the fsm (fsmA),
*The related function to each fsm state is executed as when a rising edge from the 4th button interrupts (button 4 is pressed)

*/
void startMenu();