UTC时间(年月日时分秒)转GPS时(GPS周和GPS周内秒)

总结一下常用的两种方法:直接转换法和通过中间值儒格日(MJD)的转换方法。

一、直接转换法

直接从UTC时间(年月日时分秒)转到GPS时(GPS周和GPS周内秒),推荐用这种方法,直接转换到秒级别。

//时间转换,将年月日转为GPS周内秒。
double UTCtoGPSsec(int year, int month, int day, int hour, int minute, int second) {
    int DayofYear = 0, DayofMonth = 0;
    int i = 0;
    for (i = 1980; i < year; i++) {
        //判断闰年
        if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0)
            DayofYear += 366;
        else
            DayofYear += 365;
    }
    for (i = 1; i < month; i++) {
        //判断大小月
        if (i == 1 || i == 3 || i == 5 || i == 7 || i == 8 || i == 10 || i == 12)
            DayofMonth += 31;
        else if (i == 4 || i == 6 || i == 9 || i == 11)
            DayofMonth += 30;
        else {
            if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
                DayofMonth += 29;
            else
                DayofMonth += 28;
        }
    }
    // 计算从1980年1月6日到输入日期的天数
    int Day = DayofYear + DayofMonth + day - 6;
    // 计算总秒数
    double totalSeconds = (double)Day * 24 * 60 * 60 + (double)hour * 3600 + (double)minute * 60 + second;
    // 计算GPS周内秒
    double SecofWeek = totalSeconds - (int)(totalSeconds / (7 * 24 * 60 * 60)) * (7 * 24 * 60 * 60);
    return SecofWeek;
}

二、UTC时间(年月日时分秒)转儒格日(MJD)转GPS时(GPS周和GPS周内秒)

通过中间值儒格日(MJD)进行转换。

//时间转换,将年月日转为MJD再转为GPS周内秒。
double TimetoGPSsec(int year, int month, int day, int hour, int minute, int second) {
    const double mjd = cal2mjd(year, month, day, hour, minute, second);
    if (mjd == -1) {
        return -1;
    }

    const double e = mjd - 44244;
    const int week = (int)(e / 7);
    const double GPSsec = (e - week * 7) * 86400;

    return GPSsec;
}

//时间转换,先从当前时间转为MJD,然后再到GPS周内秒
double cal2mjd(int year, int month, int day, int hour, int minute, int second) {
    const double day_fraction = (hour * 3600 + minute * 60 + second) / 86400.0;
    day += day_fraction;

    int y = year + 4800;
    int m = month;

    if (year < 0) {
        printf("Year is wrong\n");
        return -1;
    }

    if (m <= 2) {
        m += 12;
        y -= 1;
    }

    const int e = (int)(30.6 * (m + 1));
    const int a = y / 100;

    int b;
    if (year < 1582 || (year == 1582 && month < 10) || (year == 1582 && month == 10 && day < 15)) {
        b = -38;
    }
    else {
        b = a / 4 - a;
    }

    const int c = (int)(365.25 * y);
    const double jd = b + c + e + day - 32167.5;
    const double mjd = jd - 2400000.5;

    return mjd;
}

当然,这三个也可以来回转换。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 首先需要了解GPS周内的概念。GPSGPS系统使用的一种时间标准,从1980年1月6日开始计算,每的起始时间日零。而周内则是在一时间内,从0开始计算到604800,即一的总数。 如果要将C语言中的GPS周内换成UTC时间,需要使用一些数学和计算方法。首先需要获取当前时间GPS周内,然后将其换成UTC时间,即世界协调换方法如下: 1. 将当前的GPS周内分别换算成总数。 2. 根据GPS的起始时间(1980年1月6日),计算出当前时间距离起始时间的总数。 3. 将当前时间的总数加上起始时间的总数,即可得到UTC时间的总数。 4. 将UTC时间的总换成具体的年、月、日、、分、时间格式。 对于C语言的实现,可以使用time.h头文件中的time函数来获取当前时间,然后进行以上的计算和换。需要注意的是,由于GPS周内是整数类型,计算过程中会涉及到除法、乘法、取模等运算,因此需要注意精度和数据类型换的问题,同还要考虑区的影响。 总之,将C语言的GPS周内换成UTC时间需要一定的数学和计算基础,但实现起来并不难,只需要注意精度和数据类型换即可。 ### 回答2: C语言GPS周内换成UTC是一个常见的时间换问题。GPS周内GPS系统使用的时间表示方式,而UTC是通用的协调世界,用于协调全球各地的时间。 要将C语言中的GPS周内换成UTC,需要知道以下几个关键信息: 1. GPS起始时间GPS起始时间是1980年1月6日00分0。这一点非常重要,因为GPS周内都是从这个时间开始计算的。 2. GPS数和周内数:GPS数是自GPS起始时间以来的第几周内数是当前周内数。 3. UTC起始时间UTC起始时间是1970年1月1日00分0。这是通用的时间表示方式,用于协调全球各地的时间。 有了以上三个关键信息,我们可以采用如下步骤将C语言中的GPS周内换成UTC: 1. 将GPS数和周内换成总数。总数 = GPS数 * 604800 + 周内数。 2. 计算 GPS 起始时间UTC 起始时间之间的数差,即 delta_t = 315964800。 3. UTC时间 = 总数 - delta_t。 例如,如果要将 GPS 时间换成 UTC 时间,假设 GPS 时间为第 2000 周内数为 345678,那么总数 = 2000 * 604800 + 345678 = 1219165178 。然后,delta_t = 315964800 ,所以 UTC 时间 = 1219165178 - 315964800 = 903200378 。最后,将 UTC 时间换成日期和时间表示即可。 总之,C语言中的GPS周内换成UTC需要通过一定的计算和换过程。有了以上关键信息和步骤,我们可以轻松换出UTC时间,并将其换成日期和时间表示。 ### 回答3: C语言是一种广泛应用于嵌入式系统、操作系统、驱动程序等方面的高级编程语言。在GPS系统中,不同的时间格式有着不同的意义,关于GPS周内UTC之间的换,可以使用C语言实现。 GPS周内GPS系统中使用的时间格式,GPS是从1980年1月6日0开始计算的数,而周内周内数,两者结合可以表示一个准确的GPS时间。而UTC则是世界协调,是全球标准的时间,不受地球自的影响。 C语言提供了标准时间库函数,可以用于处理时间相关的操作。通过使用time.h头文件中的函数,我们可以获取当前系统时间,并进行UTCGPS时间格式间的相互换。 对于GPS周内换为UTC时间,我们可以使用以下的算法: 1.计算自1980年1月6日0起的数:gps_seconds = gps_week * 604800 + week_seconds 2.将所得到的数减去18,得到从UTC1970年1月1日0开始算起的数:utc_seconds = gps_seconds - 18 3.使用标准时间库函数convert utc_seconds to tm格式 代码示例: #include <stdio.h> #include <time.h> int main() { time_t gps_seconds = 1234567890; int gps_week = gps_seconds / 604800; int week_seconds = gps_seconds % 604800; time_t utc_seconds = gps_seconds - 18; struct tm * timeinfo_gps, * timeinfo_utc; timeinfo_gps = gmtime(&gps_seconds); timeinfo_utc = gmtime(&utc_seconds); printf("GPS time:week %d, seconds %d\n", gps_week, week_seconds); printf("UTC time:%s\n", asctime(timeinfo_utc)); return 0; } 以上就是C语言GPS周内换成UTC的方法,通过这种方法可以在程序中使用不同的时间格式,并且实现它们之间的相互换,方便程序的开发。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值