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

GMT to local time

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



Joined: 10 Sep 2003
Posts: 35

View user's profile Send private message

GMT to local time
PostPosted: Wed Mar 07, 2012 9:53 am     Reply with quote

Does some made a routine to calculate the local time from GMT. The GMT is from a GPS receiver.

Basic it is only calculate the minute of year, plus timezone and convert back to date and time.
temtronic



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

View user's profile Send private message

PostPosted: Wed Mar 07, 2012 10:03 am     Reply with quote

Your GPS doesn't have an option to change the time to 'local'?
Ttelmah



Joined: 11 Mar 2010
Posts: 19544

View user's profile Send private message

PostPosted: Wed Mar 07, 2012 10:30 am     Reply with quote

You should already have what is needed.
Key is that you need to calculate the 'offset' between UTC (no longer GMT), and the local time. time.h, has routines to convert a 'time', into a tick count (mktime), and back to a string (ctime). So you just take the UTC time, convert it to a 'tick' count, then add or subtract the offset, and convert it back to a string. If you do a search online, you will find dozens of examples, normally with the 'offset' called something like GMT_OFFSET. All you need to calculate this is the timezone, and a flag for DST.

Best Wishes
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Wed Mar 07, 2012 10:58 am     Reply with quote

If this is a stationary application (home etc), then the above answers work. If this is mobile, you have the added issue of having to periodically figure out which time zone you are in (and if DaylightSavings applies). My older Magellan hand-held gps doesn't know which time zone it is in which surprised me since it knows where it is - I would have thought they would have put that feature in, but nope. So if you are mobile (at least to the extent of crossing time zones), then you will also need to figure out how to determine which time zone you are in before you can correct for it.
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
JamesW



Joined: 23 Apr 2007
Posts: 91
Location: Rochester, England

View user's profile Send private message Visit poster's website

PostPosted: Fri Mar 09, 2012 12:32 pm     Reply with quote

Funnily enough, I am doing exactly the same at the moment.

I have tried the above method, and get some weird results

My data from the satellite is reporting in perfectly, and displaying OK on the terminal - however when converting to ticks using mktime and then back to a string using ctime - I am getting an incorrect date (time is OK).

At the moment I am not introducing an offset into the ticks, to cater for local time. (But when I do - the hours adjust fine!)

It did occur to me, that maybe I needed to add 2000 to the year, as the satellite data is only 2 digits - but this crashed the PIC.

MY RESULTS (CAPTURED FROM HYPERTERMINAL) :
SATELLITE TIME : 18:24:13 09/03/12
SECONDS SINCE EPOCH 8706253
LOCAL TIME : Sat Apr 11 18:24:13 1970



Code:

         if ( (ValidPacket == 1) && (GPS.PosError == 0) )
         {
            printf(DebugPutc, "\r\n SATELLITE TIME : %02u:%02u:%02u %02u/%02u/%02u", GPS.SatelliteHours,
                                                                           GPS.SatelliteMinutes,
                                                                           GPS.SatelliteSeconds,
                                                                           GPS.SatelliteDayOfMonth,
                                                                           GPS.SatelliteMonth,
                                                                           GPS.SatelliteYear);
            // Convert time to local time
            struct_tm tmUTC;

            tmUTC.tm_sec  = GPS.SatelliteSeconds;
            tmUTC.tm_min  = GPS.SatelliteMinutes;
            tmUTC.tm_hour = GPS.SatelliteHours;
            tmUTC.tm_mday = GPS.SatelliteDayOfMonth;
            tmUTC.tm_mon  = GPS.SatelliteMonth;

            //tmUTC.tm_year = ( (unsigned int16) ((unsigned int16) GPS.SatelliteYear + 2000)) ;
            tmUTC.tm_year = (unsigned int16) GPS.SatelliteYear;
            tmUTC.tm_wday = 0;
            tmUTC.tm_yday = 0;
           
            time_t UTCticks = 0;
            UTCticks = mktime(&tmUTC);
           
            signed int32 timediff = ReadRegionTimeDifference();
            GPS.LocalSecondsSinceEpoch = (UTCticks + timediff);
           
            char tbuff[128];
           
            printf(DebugPutc, "\r\n SECONDS SINCE EPOCH %Ld", GPS.LocalSecondsSinceEpoch);
           
            ctime(&GPS.LocalSecondsSinceEpoch, tbuff);
           
            printf(DebugPutc, "\r\n LOCAL TIME : %s", tbuff);
         }


Can anyone offer any useful pointers please?

Cheers

James
Ttelmah



Joined: 11 Mar 2010
Posts: 19544

View user's profile Send private message

PostPosted: Fri Mar 09, 2012 4:32 pm     Reply with quote

The most likely thing is a variable is being destroyed/overwritten.
In C, It is _not_ legal to declare variables in the middle of the code. CCS does not complain about this, and sometimes seems to accept it, but most normally it results in variables that overwrite one another. Variables can be declared in a function, but _must_ be declared at the start of the function section.
Second, it is not legal in CCS, to declare a variable and initialise it from a function in the same line.

Best Wishes
picprogrammer



Joined: 10 Sep 2003
Posts: 35

View user's profile Send private message

PostPosted: Sat Mar 10, 2012 8:41 am     Reply with quote

My own way was the quickest:

Code:


  static int16  month_days[2][13] = { { 0,   0,  31,  59,  90, 120, 151,
                                       181, 212, 243, 273, 304, 334 },
                                    { 0,   0,  31,  60,  91, 121, 152,
                                       182, 213, 244, 274, 305, 335 } };
                   /* cumulative number of days prior to beginning of month */

        daynum = utc_day + month_days[0][utc_month];         
    /* (adjust for leap year) */
        if ( ((utc_year % 4) == 0) &&(((utc_year % 100) != 0) || ((utc_year % 400) == 0) ) && (utc_month > 2) )
           daynum += 1;         
           
         moy= (1440 * (int32)daynum) + (60 * (int32)utcHour) + (int32)utcMinutes;
         moy += ((int16)timezone * 60); // the timezone correction
         daynum = moy /1440;
         minuteleft = moy- (daynum * 1440);
         local_hour   = minuteleft/ 60;         
         local_min = minuteleft - ((int16)local_hour*60);
         
    /* Set the leap year switch */
        if ( ((utc_year % 4) == 0) && ( ((utc_year % 100) != 0) || ((utc_year % 400) == 0) ) )
          leap = 1;
        else
          leap = 0;

     /* Find the month */
        imon = 12;
        while ( daynum <= month_days [leap][imon] )
          --imon;

    /* Set the month and day of month */
        local_month = imon;
        local_day   = daynum - month_days[leap][imon];         


ckielstra



Joined: 18 Mar 2004
Posts: 3680
Location: The Netherlands

View user's profile Send private message

PostPosted: Sun Mar 11, 2012 5:18 am     Reply with quote

Just some minor remarks.

1) You are calculating the leap year correction for number of days with two different methods. Once using two different arrays and once by adding +1.
Both methods are correct, but your code is larger and more difficult to understand because you use two methods.

2) You can save some code space by using a year calculation that is limited to the year span 1901 - 2099. Sufficient for most applications:
Code:
#define IS_LEAP(year) (year%4 == 0)


Here a link to another GPS implementation with time correction in the Code Library: http://www.ccsinfo.com/forum/viewtopic.php?t=45954
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