CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

24 hours timer
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
ak270



Joined: 22 Jun 2014
Posts: 5

View user's profile Send private message

24 hours timer
PostPosted: Tue Jun 24, 2014 2:09 pm     Reply with quote

Hello
I'm new here, I have searched this forum like a long time, and now I want to start making a few small codes, I made this code, I want 24 in 24 hours PIN_A1 stay in the high state for 5 seconds, and do it 24 in 24 hours until turned off the power!

But this code does not work! This code was made with a sample of this forum!

Please can you check my code and correct me what this poorly done!
thank you very much

compiller Version 4.93

Code:


#include <18F458.h>
 #use delay(clock=20000000)
 #fuses HS,NOWDT,NOLVP

 #define DAY 3600
 int32 clock1=DAY; //first period
 int16 clock2=0;
 
 #define TICKS_PER_SECOND 125

 #int_TIMER2
 void timer2_isr(void)
 {
   static int8 tick=TICKS_PER_SECOND-1;
   if (tick>0)
      --tick;
   else
   {
      tick=TICKS_PER_SECOND-1;
      if (clock1>0)
         --clock1;
     
         }
 }

 void main(void)
 {
    int16 q;
   
    Setup_adc_ports(AN0);
    Setup_adc_ports(ADC_CLOCK_INTERNAL);
   
     setup_timer_2(T2_DIV_BY_16,249,10); //125 interrupts/second
     enable_interrupts(INT_TIMER2);
     enable_interrupts(GLOBAL);
     while(true)
     {
 
      output_low(PIN_A1);
     
           if (clock1==0)
             {
              clock2=DAY*24;
              --clock2;
                }
              if (clock2==0)
              {
              output_high(PIN_A1);
              delay_ms(5000);
              }
       
       
     }   
       
 }
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Tue Jun 24, 2014 2:51 pm     Reply with quote

Quote:
But this code does not work! This code was made with a sample of this forum!

You don't tell us what works and what does not.

Is your PC running at the correct speed?
Can you do a 1 second flasher?
.....................

Why not do a 1s flash every 10s?
That way you won't have to wait so long to see if its working.
Then expand to once per minute/hour.

Mike

EDIT Maybe you could use a buzzer, then you don't have to watch for the flash.
temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Jun 24, 2014 3:24 pm     Reply with quote

also... in the 'code library' there's a real nice software 'real time clock' program you should look at.
It makes it very easy to do what you want...

hth
jay
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Tue Jun 24, 2014 5:24 pm     Reply with quote

Hi,

It seems to me that the OP has a a much more fundamental problem beyond the problems he has with his code. He apparently has no way to get any feedback or troubleshooting information from his code except for sitting back and waiting for LEDs to work as expected. This simple strategy *might* work (I emphasize 'might') for the simplest of programs, but for anything more complex, it's really hopeless and an exercise in frustration. Learn to use the debugger, or dedicate an I/O pin to create a software serial diagnostic port to read messages on your PC. If you plan to do any embedded development long term, you'll be way ahead of the game if you do this!

A couple of things really stand out in your post. They are:

1. You #fuses, and your #use delay are really reversed.
2. Your variable names are really poor. Names like 'Clock1' & 'Clock2' are really meaningless, and don't add anything to your understanding of what's going on with the code. How about 'SecsPerDay' or 'MinsPerHour' or other names that actually make some sense.
3. Your use of 'Setup_adc_ports' is wrong, it also seems unnecessary given your program description (which I could not follow anyway.....)

John
asmboy



Joined: 20 Nov 2007
Posts: 2128
Location: albany ny

View user's profile Send private message AIM Address

PostPosted: Wed Jun 25, 2014 6:59 am     Reply with quote

and out of curiosity
what does your .LST file show for this part of the code ??
Code:

void timer2_isr(void)
 {
   static int8 tick=TICKS_PER_SECOND-1;
   if (tick>0)
      --tick;
   .....
 }
ak270



Joined: 22 Jun 2014
Posts: 5

View user's profile Send private message

PostPosted: Wed Jun 25, 2014 1:11 pm     Reply with quote

Thanks for the comments,!

The problem is that the code is blocked, tried to make a simple code but does not work.
I think that is the problem with Timer2, but do not know where this error! so what I ask your help, although I tried all the ways I know
Any help is welcome

thank you
temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Jun 25, 2014 2:00 pm     Reply with quote

Time to go back to the basics !

Cut code for the simple '1Hz LED' program and CONFIRM an LED does indeed flash at a 1 Hz rate.

That MUST be confirmed before proceeding.....

Then show us your new entire code...
...and explain what does/doesn't 'work'.
hth
jay
ak270



Joined: 22 Jun 2014
Posts: 5

View user's profile Send private message

PostPosted: Thu Jun 26, 2014 12:43 pm     Reply with quote

Hello guys!!

I made this code below for testing with the timer1 to flash the LED 3 seconds and works well.
I tests for longer times and for 24 hours, and even blocks!
What am I doing wrong?
Can help improve this code to tell 24hortas and connect the LED 5 second?
All help is welcome!
Thanks

Code:


#include<18F452.h>

#fuses HS,NOLVP,NOWDT,PUT

#use delay(clock=20M)

int16 data=0;

int16 ints=0;

 
#int_TIMER1

void timer1_isr(void)//100ms timer
{
set_timer1(3036);
  ++ints;
   if(ints>=10)// 1sec
     {
     data++;
     ints=0;
     }

}

void main(void)

{

   setup_timer_1(T1_INTERNAL | T1_DIV_BY_8);

   enable_interrupts(INT_TIMER1);

   enable_interrupts(GLOBAL);

   while(true)

   {

      if(data==3) //3 sec
        {
     
        output_high(PIN_A1);

        delay_ms(5000);
       
          output_low(PIN_A1);
          data=0;
              }
         }
         
    }


Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sat Jun 28, 2014 8:45 am     Reply with quote

Which variable are you changing to create long delays?
What do you mean, when you say "I tests for longer times and for 24 hours, and even blocks! "
Where does the magic number 3036 come from?
Why have you not taken the hint and included some diagnostics to tell you what is going on?

Mike
ak270



Joined: 22 Jun 2014
Posts: 5

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 5:45 am     Reply with quote

Hello Mike thanks for the comment!


Quote:
What do you mean, when you say "I tests for longer times and for 24 hours, and even blocks! "


What I really want is to make the timer1 count 1 second to do a head count after 24 hours put me to the high level (PIN_A1 or any other PIn) for 5 seconds per PIN_XX in low level counting back 24 hours a the PIN_XX at high for 5 seconds, and so continuously until turned off!

Quote:
Where does the magic number 3036 come from?


Fout = Fosc/4/DIV/set_timer1
Exemple 1Hz:
1Hz = 20.000.000 / 4 / 8 / set_timer1 = 625.000 cycles
Maximum number of cycles the timer 1 (16 bits)
2^16 = 65.536

625.000 / 65.536 = 9,53 apox.10 overflow
625.000 / 10 = 62.500

65.356 - 62.500 = 3036 load the timer1 and wait 10 overflow

or
Fosc = 20.000.000 / 4 => cycles = 5.000.000 Hz => T=0.2Us per increment
Div = 8 => 1.6us per increment
Set timer = 3036
65.536 - 3.036 = 62.500 * 1.6uS = 0.1 seg
0.1 * 10 = 1 Seg

Quote:
Which variable are you changing to create long delays?


I modified the code, but I am still having problems with errors in time!


Code:
#include<18F452.h>

#fuses HS,NOLVP,NOWDT,PUT

#use delay(clock=20M)


int16 ints=0;
int32 day=86400;

#int_TIMER1 //100ms timer

void timer1_isr(void)
{
set_timer1(3036);
  ++ints;
   if(ints>=10)//1seg
     {
     ints=0;
     --day;
     }
}

void main(void)

{
   setup_timer_1(T1_INTERNAL | T1_DIV_BY_8);

   enable_interrupts(INT_TIMER1);

   enable_interrupts(GLOBAL);

   while(true)
   {
      if(day==0)
        {
        day=86400;
          output_high(PIN_A1);
          delay_ms(5000);
          output_low(PIN_A1);         
         }
         
    }// end while
         
 }//end main


I know that this code may be better, but as I have yet to start in programming, I posted my questions here, so any help is welcome
I thank all
temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 6:57 am     Reply with quote

you really should look at the code presented here...

http://www.ccsinfo.com/forum/viewtopic.php?t=26177

...

I KNOW it works, and is very,very easy to modify to do what you want.


hth
jay
dyeatman



Joined: 06 Sep 2003
Posts: 1941
Location: Norman, OK

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 8:01 am     Reply with quote

Quote:
I modified the code, but I am still having problems with errors in time!


Quote:
I know that this code may be better, but as I have yet to start in programming,


Are you working in Proteus?
_________________
Google and Forum Search are some of your best tools!!!!
temtronic



Joined: 01 Jul 2010
Posts: 9295
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 8:05 am     Reply with quote

man are 'we' going to look silly when he says yes......

after I've given him the link to a SOLUTION ...

sigh
jay
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 11:04 am     Reply with quote

Yes, I can see where the magic number 3036 comes from.
You are assuming there is no delay in getting into your ISR!

I also want to know if you are using REAL hardware.

Mike
ak270



Joined: 22 Jun 2014
Posts: 5

View user's profile Send private message

PostPosted: Sun Jun 29, 2014 2:48 pm     Reply with quote

Thanks for the help!

Guys, I'm doing tests on Protoboard!

I changed my 18F458 to 18F2550 because the other spoiled, I modified the code for my needs and it works, but I tested the code to PIN_A1 by 2 by 2 minutes (For testing) and makes only 8 in 8 minutes?

Read all posts of the topic and not found the solution, where is the error?

My modified code, to work 2 on 2 minutes (for testing)
help is welcome
I thank all

Code:

 
 #include <18F2550.h>
 #use delay(clock=20000000)
 #fuses HS,NOWDT,NOLVP

 //RTC variables
 #define XTAL_FREQUENCY  20000000
 #define TIMER1_FREQUENCY (XTAL_FREQUENCY / 4)// 1 clock tick = 1 instr. cycle = crystal frequency / 4
 #define prev_second 120
 int32 Ticker;
 int32 Seconds=0;


 void Initialize_RTC(void)
 {
   Ticker = TIMER1_FREQUENCY;                  // initialize clock counter to number of clocks per second
   setup_timer_1( T1_INTERNAL | T1_DIV_BY_1 ); // initialize 16-bit Timer1 to interrupt
                                               // exactly every 65536 clock cycles
                                               // (about 76 times per second)
   enable_interrupts( INT_TIMER1 );            // Start RTC
 }

 #int_TIMER1                               
 void TIMER1_isr()                         
 {
   Ticker -= 65536;                        // Decrement ticker by clocks per interrupt
   if ( Ticker < 65536 )                   // If second has expired
   {  Ticker += TIMER1_FREQUENCY;          //   Increment ticker by clocks per second
      seconds++;                           //   Increment number of seconds
   }

 }

 ////////////////////////////////////////////////////////////////////////////////
 // Example program for using the RTC
 ////////////////////////////////////////////////////////////////////////////////
 void main()
 {
   
   Initialize_RTC();
   enable_interrupts( GLOBAL );

   // loop forever
   while(1)
   {
 
     if (seconds==prev_second )
     {
      seconds=0;
           output_high(PIN_A1);
           delay_ms(5000);
           output_low(PIN_A1);
     } 
   }
 }
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group