Important changes to forums and questions
All forums and questions are now archived. To start a new conversation or read the latest updates go to forums.mbed.com.
8 years, 4 months ago.
when I call the function StartRun(), it does not recognize wait for 1 sec and counts in us?
Timer
// The startRun function when called does not perform same. The controller is not recognizing wait(1) adn counts in micro seconds I cannot find the reason. it should do the same whhen called again by interrupt. #include "mbed.h" #include "TextLCD.h" TextLCD lcd(A0, A1, A2, A3, A4, A5); DigitalOut switchengine(D2); DigitalIn pin_up(D10); DigitalIn pin_down(D9); InterruptIn pin_start(D11); DigitalIn pin_delay(D12); InterruptIn Pin_rain(D3); DigitalIn pin_mainpower(D6); Timer timer; int Quarters; void displayUpdate(); void startRun() ; void startRun1() ; void callstart(); void timerf(); void pumpoff(); bool status ; float delay; int i; int d; float del; int s; int m; float reverse= 0.0; float h; float tim; int begin; void rainsense(); time_t seconds = time(NULL); //called when 15min has passed void startRun1() { //engine should be running status = false; lcd.cls(); lcd.locate(3,0); lcd.printf("PUMP START"); wait(1); displayUpdate(); } void pumpoff() { switchengine=0; status = true; //update display lcd.cls(); lcd.locate(3,0); lcd.printf("PUMP OFF!"); lcd.locate(0,1); lcd.printf("Ran T:%1.2f Hr",i*0.25); pin_start.rise(&timerf); pin_start.fall(&callstart); Pin_rain.rise(&rainsense); } void rainsense() { switchengine=0; lcd.cls(); lcd.locate(0,0); lcd.printf("%s",ctime(&seconds)); lcd.locate(0,1); lcd.printf("Rantime:%1.2f Hr ",reverse); while(1) { switchengine=0; } } void timerf() { timer.reset(); timer.start(); begin = timer.read(); } void callstart() { int end = timer.read(); timer.stop(); int t = end - begin; if(status==true) { if(t==2) { displayUpdate(); } } } void displayUpdate() { //engine should be running if (i==0) { pumpoff(); } else { switchengine=1; if(i<4) { m = i*2; s = 60; while(m > 0) { wait(1); lcd.cls(); lcd.locate(3,0); lcd.printf("Time= %d min ",i*2); lcd.locate(2,1); lcd.printf(" %d min %d",m-1, s); s--; if(s==0) { m--; s = 60; } if(m==0) { pumpoff(); } Pin_rain.rise(&rainsense); } } else { s = 60; h = i*0.25; while(h > 0) { wait(1); if(h<1.1) { lcd.cls(); lcd.locate(0,0); lcd.printf("Time= %1.2f Hr ",i*0.25); lcd.locate(1,1); lcd.printf(" %1.1f min %d",(h-0.01)*100, s); } else { lcd.cls(); lcd.locate(0,0); lcd.printf("Time =%1.2f Hr ",i*0.25); lcd.locate(1,1); lcd.printf(" %1.2f Hr %d",h-0.01, s); } s--; if(s==0) { h= h-0.01; reverse = reverse+0.01; s = 60; } if(h==0) { pumpoff(); } Pin_rain.rise(&rainsense); } } } } //update the display and start/stop the engine // init and start the run void startRun() { status = false; lcd.cls(); lcd.locate(3,0); lcd.printf("PUMP START"); wait(1); lcd.cls(); displayUpdate(); } int main() { pin_up.mode(PullDown); pin_down.mode(PullDown); pin_start.mode(PullDown); pin_delay.mode(PullDown); pin_mainpower.mode(PullDown); set_time(1458986114); if(pin_mainpower == 1){ lcd.cls(); lcd.locate(3,0); lcd.printf("SET TIME"); }else{ lcd.cls(); lcd.locate(2,0); lcd.printf("Pump Off"); lcd.locate(0,1); lcd.printf("No MainPower"); } do{ while(pin_delay==1) { d++; wait(0.3); if (d>100) d=100; if(d<4) { del = d ; lcd.cls(); lcd.locate(1,0); lcd.printf("Delay= %1.2f mn", del*15); } else { del = d ; lcd.cls(); lcd.locate(1,0); lcd.printf("Delay= %1.2f Hr", del*15/60); } } if(pin_up==1) { i++; wait(0.1); if (i>200) i=200; tim = i; if(i<4) { lcd.cls(); lcd.locate(1,0); lcd.printf("Time= %1.2f mn", tim*15); } else { lcd.cls(); lcd.locate(1,0); lcd.printf("Time= %1.2f Hr", tim*15/60); } } else if(pin_down==1){ i--; wait(0.1); if( i<0) i=0; tim = i; if(i<4) { lcd.cls(); lcd.locate(1,0); lcd.printf("Time= %1.2f mn", tim*15); } else { lcd.cls(); lcd.locate(1,0); lcd.printf("Time= %1.2f Hr",tim*15/60); } } } while(pin_start==0); if(i==0) { { lcd.cls(); lcd.locate(3,0); lcd.printf("Error!!!"); lcd.locate(1,1); lcd.printf("Time not set"); wait(3); } } tim = Quarters; //Initial selected number of quarters if(d>0) { int sec = 60; int min = d*15; float hr = d*0.25; while(min>0) { sec--; if(sec==0) { min--; sec = 60; } if(min==0) { d=0; Pin_rain.rise(&rainsense); } if(min<60) { lcd.cls(); lcd.locate(0,0); lcd.printf("Delay= %1.1f min",del*15); lcd.locate(2,1); lcd.printf("%d min %d",min-1, sec); wait(1); } else { lcd.cls(); lcd.locate(0,0); lcd.printf("Delay= %1.1f Hr",(del*15)/60); lcd.locate(2,1); lcd.printf("%1.2f Hr %d",hr-0.01, sec); wait(1); } } } startRun(); // call to (re)start engine run)&& status == true if(runtimeleft == 0 ) while(1); // just wait for keypress */ }
Question relating to:
1 Answer
8 years, 4 months ago.
You should write a small routine to prove to yourself that the "wait(xx)" function does in fact wait xxx seconds. Blink the led with the blinky routine or something similar. Then if that works..what could it be? It seems that TextLCD is probably inheriting the Serial class which is a buffered print as of a few releases ago. Perhaps try having it inherit RawSerial instead and see if the problem persists?