for_20211114
Dependencies: HEPTA_SENSOR mbed HEPTA_EPS HEPTA_COM HEPTA_CDH
main.cpp
- Committer:
- heptasat2021
- Date:
- 2021-11-14
- Revision:
- 28:80d6576011e1
- Parent:
- 27:ecdf196153cd
- Child:
- 29:3d7a0b3a1b8a
File content as of revision 28:80d6576011e1:
#include "mbed.h" #include "HEPTA_CDH.h" #include "HEPTA_EPS.h" DigitalOut cond[]={LED1,LED2,LED3,LED4}; Serial gs(USBTX,USBRX); // for ground station HEPTA_CDH cdh(p5, p6, p7, p8, "sd"); HEPTA_EPS eps(p16,p26); Timer sattime; int rcmd = 0,cmdflag = 0; //command variable //getting command and flag void commandget() { rcmd=gs.getc(); cmdflag = 1; } //interrupting void receive(int rcmd, int cmdflag) { gs.attach(commandget,Serial::RxIrq); } //initialzing void initialize() { rcmd = 0; cmdflag = 0; cond[0] = 0; } int main() { gs.baud(9600); gs.printf("From Sat : Operation Start...\r\n"); int flag = 0; // condition float btvol,temp; //Voltage, Temerature sattime.start(); receive(rcmd,cmdflag); //interupting by ground station command for(int i = 0; i < 100; i++) { //Sensing and Transmitting HK data eps.vol(&btvol); temp = 28.5; gs.printf("HEPTASAT::Condition = %d, Time = %f [s], batVol = %.2f [V],Temp = %.2f [C]\r\n",flag,sattime.read(),btvol,temp); //Condition cond[0] = 1; //Power Saving Mode if(btvol <= 3.5) { eps.shut_down_regulator(); flag = 1; } else { eps.turn_on_regulator(); flag = 0; } if(flag == 1) { gs.printf("Power saving mode ON\r\n"); } //Contents of command if (cmdflag == 1) { if (rcmd == 'a') { for(int j=0;j<5;j++){ gs.printf("HEPTASAT::Hello World!\r\n"); cond[0] = 0; wait(1); cond[0] = 1; } } initialize(); } } sattime.stop(); gs.printf("From Sat : Operation Stop...\r\n"); }