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

Changes state in PIN-A1 times larger.

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
fiasgardone



Joined: 19 Jan 2010
Posts: 71

View user's profile Send private message

Changes state in PIN-A1 times larger.
PostPosted: Mon Apr 01, 2013 4:05 am     Reply with quote

Hii!

I have a program here that I have not gotten a positive result I intend to do!

It is the next program to low want to do the following as soon as I turn on the PIC.

For two days in Pin_A1 does nothing.
After two days Pin_A1 desire that the switching state is five by five hours, or 5 hours in the high state (1) and then 5 hours at low state (0) and changing state is 5 in 5 h during 10 days, after 10 days the state is Pin_A1 shut down until the PIC, is in this part of the code that I do not have any idea of ​​making this state change and it's been a week to research, test, and so far no have a positive outcome!

I would like the staff to take a look at the code to be able to give help how should I resolve this problem.

Time does not have to be very precise so I'm using TIMER1.

The part that I doubt this checked, if someone has a better idea I want to do is welcome
I thank


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

int16 segundos=0;
int8 intt=0;

#int_TIMER1
void timer1_isr(void)
{
set_timer1(3036);
++intt;
  if(intt>=10)
  {
  Segundos++;
  intt=0;
  }
   if(segundos==3600)
    {
    hora=hora +1;
    Segundos=0;
    }
   If (hora==24)
    {
    Day=day+1;
    hora =0;
    }
}
void main(void)
{
setup_timer_1(T1_INTERNAL | T1_DIV_BY_8);
enable_interrupts(INT_TIMER1);
enable_interrupts(GLOBAL);

while(true)
{
while(day<=2);

//***Here in this part where I have problem in making the code//****

output_toggle(PIN_A1);

}wihle( day<10)
output_low(PIN_A1);
//**********************************************************
}
}
}
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Mon Apr 01, 2013 5:19 am     Reply with quote

Start at the beginning.
Your timing.
Now first, do a search in the forum, for why setting a timer 'to' a value is always going to be _very_ inaccurate. Why accept such inaccuracy if you don't have to?.
You have timer2, unused, so go for an accurate timing.
Then, why fiddle around with days, hours etc.. Just work in seconds.
You want times of 172800 seconds, then states of 18000 seconds repeated for a period of 864000 seconds.
So:
Code:

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

#define FIVE_HOURS 18000
#define DAY 86400
int32 clock1=DAY*2; //first period
int32 clock2=0;
#define TICKS_PER_SECOND 125

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

void main(void)
{
    enum {FIRST_WAIT,FLASHING,STOP} main_state=FIRST;
    enum {IDLE, PIN_ON} flash_state=IDLE;
    setup_timer_2(T2_DIV_BY_16,249,10); //125 interrupts/second
    enable_interrupts(INT_TIMER2);
    enable_interrupts(GLOBAL);
    while(true)
    {
        switch (main_state) {
        case FIRST:
            //here we just wait A1 off
            output_low(PIN_A1);
            if (clock1==0)
            {
               //state has ended
               //set clock to 10 days
               clock1=DAY*10;
               main_state++;
            }
            break;
        case FLASHING:
            //Here we want to flash the output every 5 hours
            switch (flash_state) {
            case IDLE:
                //first position - start flasher
                clock2=FIVE_HOURS;
                flash_state++; //move to flash pin
                output_high(PIN_A1);
                break;
            case PIN_ON:
                if (clock2==0)
                {
                    //time has finished
                    clock2=FIVE_HOURS;
                    output_toggle(PIN_A1);
                 }
                 break;
             } //end of 'flash' switch
             //now check for the ten day timer
             if (clock1==0)
             {
                 output_low(PIN_A1);
                 main_state++;
                 flash_state-IDLE;
             }
             break;
        case STOP;
             //Stopped - do nothing forever....
             break;
        } //end of main switch
    } //end of while loop
}


Unchecked. Just typed in.
However the point is to think of the different 'jobs' and treat each separately.

Wait for 2 days
Flash for 10 days
Stop

Then only the middle one needs do much, just flashing the output every five hours.

Just two 'state machines' inside one another controlled by two timers.

Best Wishes
fiasgardone



Joined: 19 Jan 2010
Posts: 71

View user's profile Send private message

PostPosted: Mon Apr 01, 2013 1:30 pm     Reply with quote

hello Ttelmah !!

Thanks for helping, is undoubtedly a great help and very important to me, so I'm studying the code and understand the logic programming.

When compiled the code appeared some errors I was seeing then where was the error and made the correction.

What is not yet understood this was the variables "" main_state "" and "" flash_state "" along with "enum", if I can explain how it works, I've never worked with "enum" although I've seen its function

I'll test the code in phortboard and then post the result here

thank you very much
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Mon Apr 01, 2013 1:37 pm     Reply with quote

As I said 'untested'. Probably several typing errors.
Think of enum's as a way of using names instead of numbers. Rather like having a pair of defines for a boolean, as (say)
#define ON 0
#define OFF 1

Nice thing is that since the enum is a variable, and the values have names, the values will exist in a debugger. In higher level languages, they are also type safe, and unlike a define, can't accidentally be redefined.

Best Wishes
fiasgardone



Joined: 19 Jan 2010
Posts: 71

View user's profile Send private message

PostPosted: Mon Apr 01, 2013 1:48 pm     Reply with quote

Ttelmah wrote:
As I said 'untested'. Probably several typing errors.
Think of enum's as a way of using names instead of numbers. Rather like having a pair of defines for a boolean, as (say)
#define ON 0
#define OFF 1

Nice thing is that since the enum is a variable, and the values have names, the values will exist in a debugger. In higher level languages, they are also type safe, and unlike a define, can't accidentally be redefined.

Best Wishes


Hii! Ttelmah

Thanks for clarifying.

One more doubt, and these variables do not have to be declared before used, for example at the beginning of the program?
thank you
temtronic



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

View user's profile Send private message

PostPosted: Mon Apr 01, 2013 2:30 pm     Reply with quote

as a 'helpful hint' when coding for long intervals....
...test using seconds and not hours or days !!!

ie: if the real world time is 5 hours, test using 5 seconds

Yeah, kinda obvious,but........

hth
jay
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
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