Changeset 5664 in ntrip


Ignore:
Timestamp:
May 26, 2014, 5:09:28 PM (11 years ago)
Author:
stoecker
Message:

SSR update

Location:
trunk/clock_and_orbit
Files:
8 added
2 edited
1 copied
2 moved

Legend:

Unmodified
Added
Removed
  • trunk/clock_and_orbit/lib/clock_orbit_rtcm.c

    r4981 r5664  
    9090  }
    9191
    92 #define SCALEADDBITS(a, b, c) ADDBITS(a, (int64_t)(b*c))
    93 
    94 /* standard values */
    95 #define T_MESSAGE_NUMBER(a)              ADDBITS(12, a) /* DF002 */
    96 #define T_GPS_SATELLITE_ID(a)            ADDBITS(6, a)  /* DF068 */
    97 #define T_GPS_IODE(a)                    ADDBITS(8, a)  /* DF071 */
    98 #define T_GLONASS_IOD(a)                 ADDBITS(8, a)  /* DF237 */
    99 
    100 /* defined values */
     92#define SCALEADDBITS(a, b, c) ADDBITS(a, (int64_t)(c > 0 ? b*c+0.5 : b*c-0.5))
     93
     94#define MPI         3.141592653589793
     95
     96/* GPS macros also used for other systems when matching! */
     97#define T_MESSAGE_NUMBER(a)              ADDBITS(12, a)     /* DF002 */
     98#define T_GPS_SATELLITE_ID(a)            ADDBITS(6, a)      /* DF068 */
     99#define T_QZSS_SATELLITE_ID(a)           ADDBITS(4, a)      /* DF249 */
     100#define T_GLONASS_SATELLITE_ID(a)        ADDBITS(5, a)
     101
     102#define T_GPS_IODE(a)                    ADDBITS(8, a)      /* DF071 */
     103#define T_GLONASS_IOD(a)                 ADDBITS(8, a)      /* DF237 */
     104#define T_GALILEO_IOD(a)                 ADDBITS(10, a)     /* DF459 */
     105#define T_SBAS_T0MOD(a)                  ADDBITS(9, (a/16)) /* DF468 */
     106#define T_SBAS_IODCRC(a)                 ADDBITS(24, a)     /* DF469 */
     107#define T_BDS_TOEMOD(a)                  ADDBITS(10, (a/8)) /* DF470 */
     108#define T_BDS_IODCRC(a)                  ADDBITS(24, a)     /* DF471 */
     109
    101110#define T_DELTA_RADIAL(a)                SCALEADDBITS(22,    10000.0, a)
    102111#define T_DELTA_ALONG_TRACK(a)           SCALEADDBITS(20,     2500.0, a)
     
    111120#define T_DELTA_CLOCK_C2(a)              SCALEADDBITS(27, 50000000.0, a)
    112121#define T_NO_OF_CODE_BIASES(a)           ADDBITS(5, a)
    113 #define T_GPS_SIGNAL_IDENTIFIER(a)       ADDBITS(5, a)
    114 #define T_GLONASS_SIGNAL_IDENTIFIER(a)   ADDBITS(5, a)
     122#define T_NO_OF_PHASE_BIASES(a)          ADDBITS(5, a)
     123#define T_SIGNAL_IDENTIFIER(a)           ADDBITS(5, a)
    115124#define T_CODE_BIAS(a)                   SCALEADDBITS(14,      100.0, a)
    116 #define T_GLONASS_SATELLITE_ID(a)        ADDBITS(5, a)
     125#define T_YAW_ANGLE(a)                   SCALEADDBITS(9,   256.0/MPI, a)
     126#define T_YAW_RATE(a)                    SCALEADDBITS(8,  8192.0/MPI, a)
     127#define T_PHASE_BIAS(a)                  SCALEADDBITS(20,    10000.0, a)
    117128
    118129#define T_GPS_EPOCH_TIME(a)              ADDBITS(20, a)
     
    120131#define T_NO_OF_SATELLITES(a)            ADDBITS(6, a)
    121132#define T_MULTIPLE_MESSAGE_INDICATOR(a)  ADDBITS(1, a)
     133#define T_DISPERSIVE_BIAS_INDICATOR(a)   ADDBITS(1, a)
     134#define T_MW_CONSISTENCY_INDICATOR(a)    ADDBITS(1, a)
     135#define T_INTEGER_INDICATOR(a)           ADDBITS(1, a)
     136#define T_WIDE_LANE_INDICATOR(a)         ADDBITS(1, a)
     137#define T_DISCONTINUITY_COUNTER(a)       ADDBITS(4, a)
    122138#define T_SSR_URA(a)                     ADDBITS(6, a)
    123139#define T_HR_CLOCK_CORRECTION(a)         SCALEADDBITS(22,    10000.0, a)
     
    127143#define T_SSR_PROVIDER_ID(a)             ADDBITS(16, a)
    128144#define T_SSR_SOLUTION_ID(a)             ADDBITS(4, a)
     145
     146#define T_NO_IONO_LAYERS(a)              ADDBITS(2, a-1)
     147#define T_VTEC_QUALITY_INDICATOR(a)      SCALEADDBITS(9,        20.0, a)
     148#define T_IONO_COEFF(a)                  SCALEADDBITS(16,      200.0, a)
     149#define T_IONO_DEGREE(a)                 ADDBITS(4, a-1)
     150#define T_IONO_ORDER(a)                  ADDBITS(4, a-1)
     151#define T_IONO_HEIGHT(a)                 SCALEADDBITS(8,   1/10000.0, a)
    129152
    130153static double URAToValue(int ura)
     
    152175}
    153176
     177static const enum ClockOrbitType corbase[CLOCKORBIT_SATNUM] =
     178{
     179  COBBASE_GPS, COBBASE_GLONASS, COBBASE_GALILEO, COBBASE_QZSS, COBBASE_SBAS,
     180  COBBASE_BDS
     181};
     182static const enum COR_OFFSETS satoffset[CLOCKORBIT_SATNUM+1] =
     183{
     184  CLOCKORBIT_OFFSETGPS, CLOCKORBIT_OFFSETGLONASS, CLOCKORBIT_OFFSETGALILEO,
     185  CLOCKORBIT_OFFSETQZSS, CLOCKORBIT_OFFSETSBAS, CLOCKORBIT_OFFSETBDS,
     186  CLOCKORBIT_COUNTSAT
     187};
     188
    154189size_t MakeClockOrbit(const struct ClockOrbit *co, enum ClockOrbitType type,
    155190int moremessagesfollow, char *buffer, size_t size)
    156191{
    157   int gpshr=0, gpsur=0, gpsor=0, gpscl=0, gpsco=0, glohr=0, glour=0, gloor=0,
    158   glocl=0, gloco=0, mmi, i;
    159 
     192  unsigned int status[CLOCKORBIT_SATNUM][COBOFS_NUM], i, s;
     193
     194  memset(status, 0, sizeof(status));
    160195  STARTDATA
    161196
    162   if(co->NumberOfGPSSat && co->HRDataSupplied
    163   && (type == COTYPE_AUTO || type == COTYPE_GPSHR))
    164     gpshr = 1;
    165   if(co->NumberOfGPSSat && co->URADataSupplied
    166   && (type == COTYPE_AUTO || type == COTYPE_GPSURA))
    167     gpsur = 1;
    168   if(co->NumberOfGPSSat && co->OrbitDataSupplied
    169   && (type == COTYPE_AUTO || type == COTYPE_GPSORBIT))
    170     gpsor = 1;
    171   if(co->NumberOfGPSSat && co->ClockDataSupplied
    172   && (type == COTYPE_AUTO || type == COTYPE_GPSCLOCK))
    173     gpscl = 1;
    174   if(co->NumberOfGPSSat && co->ClockDataSupplied && co->OrbitDataSupplied
    175   && (type == COTYPE_AUTO || type == COTYPE_GPSCOMBINED)
    176   /*&& co->NumberOfGPSSat <= 28*/)
     197  for(s = 0; s < CLOCKORBIT_SATNUM; ++s)
    177198  {
    178     gpsco = 1; gpsor = 0; gpscl = 0;
    179   }
    180   if(co->NumberOfGLONASSSat && co->HRDataSupplied
    181   && (type == COTYPE_AUTO || type == COTYPE_GLONASSHR))
    182     glohr = 1;
    183   if(co->NumberOfGLONASSSat && co->URADataSupplied
    184   && (type == COTYPE_AUTO || type == COTYPE_GLONASSURA))
    185     glour = 1;
    186   if(co->NumberOfGLONASSSat && co->OrbitDataSupplied
    187   && (type == COTYPE_AUTO || type == COTYPE_GLONASSORBIT))
    188     gloor = 1;
    189   if(co->NumberOfGLONASSSat && co->ClockDataSupplied
    190   && (type == COTYPE_AUTO || type == COTYPE_GLONASSCLOCK))
    191     glocl = 1;
    192   if(co->NumberOfGLONASSSat && co->ClockDataSupplied && co->OrbitDataSupplied
    193   && (type == COTYPE_AUTO || type == COTYPE_GLONASSCOMBINED))
     199    for(i = 0; i < COBOFS_NUM; ++i)
     200    {
     201      if(co->NumberOfSat[s] && (type == COTYPE_AUTO
     202      || type == corbase[s]+i) && (co->Supplied[i] || (i <= COBOFS_CLOCK
     203      && co->Supplied[COBOFS_COMBINED]) || (i == COBOFS_COMBINED
     204      && co->Supplied[COBOFS_ORBIT] && co->Supplied[COBOFS_CLOCK])))
     205      {
     206        status[s][i] = 1;
     207        if(i == COBOFS_COMBINED)
     208        {
     209          status[s][COBOFS_ORBIT] = status[s][COBOFS_CLOCK] = 0;
     210        } /* disable single blocks for combined type */
     211      } /* check for data */
     212    } /* iterate over RTCM data types */
     213  } /* iterate over satellite systems */
     214
     215  for(s = 0; s < CLOCKORBIT_SATNUM; ++s)
    194216  {
    195     gloco = 1; gloor = 0; glocl = 0;
    196   }
    197 
    198   mmi = gpshr+gpsur+gpsor+gpscl+gpsco+glohr+glour+gloor+glocl+gloco; /* required for multimessage */
    199   if(!moremessagesfollow) --mmi;
    200 
    201   if(gpsor)
    202   {
    203     INITBLOCK
    204     T_MESSAGE_NUMBER(COTYPE_GPSORBIT)
    205     T_GPS_EPOCH_TIME(co->GPSEpochTime)
    206     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    207     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    208     --mmi;
    209     T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    210     T_SSR_IOD(co->SSRIOD)
    211     T_SSR_PROVIDER_ID(co->SSRProviderID)
    212     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    213     T_NO_OF_SATELLITES(co->NumberOfGPSSat)
    214     for(i = 0; i < co->NumberOfGPSSat; ++i)
    215     {
    216       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    217       T_GPS_IODE(co->Sat[i].IOD)
    218       T_DELTA_RADIAL(co->Sat[i].Orbit.DeltaRadial)
    219       T_DELTA_ALONG_TRACK(co->Sat[i].Orbit.DeltaAlongTrack)
    220       T_DELTA_CROSS_TRACK(co->Sat[i].Orbit.DeltaCrossTrack)
    221       T_DELTA_DOT_RADIAL(co->Sat[i].Orbit.DotDeltaRadial)
    222       T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack)
    223       T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack)
    224     }
    225     ENDBLOCK
    226   }
    227   if(gpscl)
    228   {
    229     INITBLOCK
    230     T_MESSAGE_NUMBER(COTYPE_GPSCLOCK)
    231     T_GPS_EPOCH_TIME(co->GPSEpochTime)
    232     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    233     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    234     --mmi;
    235     T_SSR_IOD(co->SSRIOD)
    236     T_SSR_PROVIDER_ID(co->SSRProviderID)
    237     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    238     T_NO_OF_SATELLITES(co->NumberOfGPSSat)
    239     for(i = 0; i < co->NumberOfGPSSat; ++i)
    240     {
    241       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    242       T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0)
    243       T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1)
    244       T_DELTA_CLOCK_C2(co->Sat[i].Clock.DeltaA2)
    245     }
    246     ENDBLOCK
    247   }
    248   if(gpsco)
    249   {
    250 #ifdef SPLITBLOCK
    251     int nums = co->NumberOfGPSSat;
    252     int left, start = 0;
    253     if(nums > 28) /* split block when more than 28 sats */
    254     {
    255       left = nums - 28;
    256       nums = 28;
    257     }
    258     else
    259     {
    260       left = 0;
    261     }
    262     while(nums)
    263     {
    264 #endif
     217    if(status[s][COBOFS_ORBIT])
     218    {
    265219      INITBLOCK
    266       T_MESSAGE_NUMBER(COTYPE_GPSCOMBINED)
    267       T_GPS_EPOCH_TIME(co->GPSEpochTime)
     220      T_MESSAGE_NUMBER(corbase[s]+COBOFS_ORBIT)
     221      switch(s)
     222      {
     223      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     224      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     225      case CLOCKORBIT_SATBDS:
     226        T_GPS_EPOCH_TIME(co->EpochTime[s])
     227        break;
     228      case CLOCKORBIT_SATGLONASS:
     229        T_GLONASS_EPOCH_TIME(co->EpochTime[s])
     230        break;
     231      }
    268232      T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    269 #ifdef SPLITBLOCK
    270       T_MULTIPLE_MESSAGE_INDICATOR(/*mmi || */ left ? 1 : 0)
    271 #else
    272       T_MULTIPLE_MESSAGE_INDICATOR(/*mmi || */ 0)
    273 #endif
    274       --mmi;
     233      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
    275234      T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    276235      T_SSR_IOD(co->SSRIOD)
    277236      T_SSR_PROVIDER_ID(co->SSRProviderID)
    278237      T_SSR_SOLUTION_ID(co->SSRSolutionID)
    279 #ifdef SPLITBLOCK
    280       T_NO_OF_SATELLITES(nums)
    281       for(i = start; i < start+nums; ++i)
    282 #else
    283       T_NO_OF_SATELLITES(co->NumberOfGPSSat)
    284       for(i = 0; i < co->NumberOfGPSSat; ++i)
    285 #endif
    286       {
    287         T_GPS_SATELLITE_ID(co->Sat[i].ID)
    288         T_GPS_IODE(co->Sat[i].IOD)
     238      T_NO_OF_SATELLITES(co->NumberOfSat[s])
     239      for(i = satoffset[s]; i < satoffset[s]+co->NumberOfSat[s]; ++i)
     240      {
     241        switch(s)
     242        {
     243        case CLOCKORBIT_SATGPS:
     244          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     245          T_GPS_IODE(co->Sat[i].IOD)
     246          break;
     247        case CLOCKORBIT_SATGLONASS:
     248          T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
     249          T_GLONASS_IOD(co->Sat[i].IOD)
     250          break;
     251        case CLOCKORBIT_SATGALILEO:
     252          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     253          T_GALILEO_IOD(co->Sat[i].IOD)
     254          break;
     255        case CLOCKORBIT_SATQZSS:
     256          T_QZSS_SATELLITE_ID(co->Sat[i].ID)
     257          T_GPS_IODE(co->Sat[i].IOD)
     258          break;
     259        case CLOCKORBIT_SATSBAS:
     260          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     261          T_SBAS_T0MOD(co->Sat[i].toe)
     262          T_SBAS_IODCRC(co->Sat[i].IOD)
     263          break;
     264        case CLOCKORBIT_SATBDS:
     265          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     266          T_BDS_TOEMOD(co->Sat[i].toe)
     267          T_BDS_IODCRC(co->Sat[i].IOD)
     268          break;
     269        }
    289270        T_DELTA_RADIAL(co->Sat[i].Orbit.DeltaRadial)
    290271        T_DELTA_ALONG_TRACK(co->Sat[i].Orbit.DeltaAlongTrack)
     
    293274        T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack)
    294275        T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack)
     276      }
     277      ENDBLOCK
     278    }
     279    if(status[s][COBOFS_CLOCK])
     280    {
     281      INITBLOCK
     282      T_MESSAGE_NUMBER(corbase[s]+COBOFS_CLOCK)
     283      switch(s)
     284      {
     285      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     286      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     287      case CLOCKORBIT_SATBDS:
     288        T_GPS_EPOCH_TIME(co->EpochTime[s])
     289        break;
     290      case CLOCKORBIT_SATGLONASS:
     291        T_GLONASS_EPOCH_TIME(co->EpochTime[s])
     292        break;
     293      }
     294      T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     295      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     296      T_SSR_IOD(co->SSRIOD)
     297      T_SSR_PROVIDER_ID(co->SSRProviderID)
     298      T_SSR_SOLUTION_ID(co->SSRSolutionID)
     299      T_NO_OF_SATELLITES(co->NumberOfSat[s])
     300      for(i = satoffset[s]; i < satoffset[s]+co->NumberOfSat[s]; ++i)
     301      {
     302        switch(s)
     303        {
     304        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     305        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     306          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     307          break;
     308        case CLOCKORBIT_SATQZSS:
     309          T_QZSS_SATELLITE_ID(co->Sat[i].ID)
     310          break;
     311        case CLOCKORBIT_SATGLONASS:
     312          T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
     313          break;
     314        }
    295315        T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0)
    296316        T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1)
     
    298318      }
    299319      ENDBLOCK
     320    }
     321    if(status[s][COBOFS_COMBINED])
     322    {
    300323#ifdef SPLITBLOCK
    301       start += nums;
    302       nums = left;
    303       left = 0;
     324      int nums = co->NumberOfSat[s];
     325      int left, start = satoffset[s];
     326      if(nums > 28) /* split block when more than 28 sats */
     327      {
     328        left = nums - 28;
     329        nums = 28;
     330      }
     331      else
     332      {
     333        left = 0;
     334      }
     335      while(nums)
     336      {
     337#endif
     338        INITBLOCK
     339        T_MESSAGE_NUMBER(corbase[s]+COBOFS_COMBINED)
     340        switch(s)
     341        {
     342        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     343        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     344        case CLOCKORBIT_SATBDS:
     345          T_GPS_EPOCH_TIME(co->EpochTime[s])
     346          break;
     347        case CLOCKORBIT_SATGLONASS:
     348          T_GLONASS_EPOCH_TIME(co->EpochTime[s])
     349          break;
     350        }
     351        T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     352#ifdef SPLITBLOCK
     353        T_MULTIPLE_MESSAGE_INDICATOR((moremessagesfollow || left) ? 1 : 0)
     354#else
     355        T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     356#endif
     357        T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
     358        T_SSR_IOD(co->SSRIOD)
     359        T_SSR_PROVIDER_ID(co->SSRProviderID)
     360        T_SSR_SOLUTION_ID(co->SSRSolutionID)
     361#ifdef SPLITBLOCK
     362        T_NO_OF_SATELLITES(nums)
     363        for(i = start; i < start+nums; ++i)
     364#else
     365        T_NO_OF_SATELLITES(co->NumberOfSat[s])
     366        for(i = satoffset[s]; i < satoffset[s]+co->NumberOfSat[s]; ++i)
     367#endif
     368        {
     369          switch(s)
     370          {
     371          case CLOCKORBIT_SATGPS:
     372            T_GPS_SATELLITE_ID(co->Sat[i].ID)
     373            T_GPS_IODE(co->Sat[i].IOD)
     374            break;
     375          case CLOCKORBIT_SATGLONASS:
     376            T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
     377            T_GLONASS_IOD(co->Sat[i].IOD)
     378            break;
     379          case CLOCKORBIT_SATGALILEO:
     380            T_GPS_SATELLITE_ID(co->Sat[i].ID)
     381            T_GALILEO_IOD(co->Sat[i].IOD)
     382            break;
     383          case CLOCKORBIT_SATQZSS:
     384            T_QZSS_SATELLITE_ID(co->Sat[i].ID)
     385            T_GPS_IODE(co->Sat[i].IOD)
     386            break;
     387          case CLOCKORBIT_SATSBAS:
     388            T_GPS_SATELLITE_ID(co->Sat[i].ID)
     389            T_SBAS_T0MOD(co->Sat[i].toe)
     390            T_SBAS_IODCRC(co->Sat[i].IOD)
     391            break;
     392          case CLOCKORBIT_SATBDS:
     393            T_GPS_SATELLITE_ID(co->Sat[i].ID)
     394            T_BDS_TOEMOD(co->Sat[i].toe)
     395            T_BDS_IODCRC(co->Sat[i].IOD)
     396            break;
     397          }
     398          T_DELTA_RADIAL(co->Sat[i].Orbit.DeltaRadial)
     399          T_DELTA_ALONG_TRACK(co->Sat[i].Orbit.DeltaAlongTrack)
     400          T_DELTA_CROSS_TRACK(co->Sat[i].Orbit.DeltaCrossTrack)
     401          T_DELTA_DOT_RADIAL(co->Sat[i].Orbit.DotDeltaRadial)
     402          T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack)
     403          T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack)
     404          T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0)
     405          T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1)
     406          T_DELTA_CLOCK_C2(co->Sat[i].Clock.DeltaA2)
     407        }
     408        ENDBLOCK
     409#ifdef SPLITBLOCK
     410        start += nums;
     411        nums = left;
     412        left = 0;
     413      }
     414#endif
    304415    }
    305 #endif
     416    if(status[s][COBOFS_HR])
     417    {
     418      INITBLOCK
     419      T_MESSAGE_NUMBER(corbase[s]+COBOFS_HR)
     420      switch(s)
     421      {
     422      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     423      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     424      case CLOCKORBIT_SATBDS:
     425        T_GPS_EPOCH_TIME(co->EpochTime[s])
     426        break;
     427      case CLOCKORBIT_SATGLONASS:
     428        T_GLONASS_EPOCH_TIME(co->EpochTime[s])
     429        break;
     430      }
     431      T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     432      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     433      T_SSR_IOD(co->SSRIOD)
     434      T_SSR_PROVIDER_ID(co->SSRProviderID)
     435      T_SSR_SOLUTION_ID(co->SSRSolutionID)
     436      T_NO_OF_SATELLITES(co->NumberOfSat[s])
     437      for(i = satoffset[s]; i < satoffset[s]+co->NumberOfSat[s]; ++i)
     438      {
     439        switch(s)
     440        {
     441        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     442        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     443          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     444          break;
     445        case CLOCKORBIT_SATQZSS:
     446          T_QZSS_SATELLITE_ID(co->Sat[i].ID)
     447          break;
     448        case CLOCKORBIT_SATGLONASS:
     449          T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
     450          break;
     451        }
     452        T_HR_CLOCK_CORRECTION(co->Sat[i].hrclock)
     453      }
     454      ENDBLOCK
     455    }
     456    if(status[s][COBOFS_URA])
     457    {
     458      INITBLOCK
     459      T_MESSAGE_NUMBER(corbase[s]+COBOFS_URA)
     460      switch(s)
     461      {
     462      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     463      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     464      case CLOCKORBIT_SATBDS:
     465        T_GPS_EPOCH_TIME(co->EpochTime[s])
     466        break;
     467      case CLOCKORBIT_SATGLONASS:
     468        T_GLONASS_EPOCH_TIME(co->EpochTime[s])
     469        break;
     470      }
     471      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     472      T_SSR_IOD(co->SSRIOD)
     473      T_SSR_PROVIDER_ID(co->SSRProviderID)
     474      T_SSR_SOLUTION_ID(co->SSRSolutionID)
     475      T_NO_OF_SATELLITES(co->NumberOfSat[s])
     476      for(i = satoffset[s]; i < satoffset[s]+co->NumberOfSat[s]; ++i)
     477      {
     478        switch(s)
     479        {
     480        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     481        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     482          T_GPS_SATELLITE_ID(co->Sat[i].ID)
     483          break;
     484        case CLOCKORBIT_SATQZSS:
     485          T_QZSS_SATELLITE_ID(co->Sat[i].ID)
     486          break;
     487        case CLOCKORBIT_SATGLONASS:
     488          T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
     489          break;
     490        }
     491        T_SSR_URA(ValueToURA(co->Sat[i].UserRangeAccuracy))
     492      }
     493      ENDBLOCK
     494    }
    306495  }
    307   if(gpshr)
    308   {
    309     INITBLOCK
    310     T_MESSAGE_NUMBER(COTYPE_GPSHR)
    311     T_GPS_EPOCH_TIME(co->GPSEpochTime)
    312     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    313     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    314     --mmi;
    315     T_SSR_IOD(co->SSRIOD)
    316     T_SSR_PROVIDER_ID(co->SSRProviderID)
    317     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    318     T_NO_OF_SATELLITES(co->NumberOfGPSSat)
    319     for(i = 0; i < co->NumberOfGPSSat; ++i)
    320     {
    321       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    322       T_HR_CLOCK_CORRECTION(co->Sat[i].hrclock)
    323     }
    324     ENDBLOCK
    325   }
    326   if(gpsur)
    327   {
    328     INITBLOCK
    329     T_MESSAGE_NUMBER(COTYPE_GPSURA)
    330     T_GPS_EPOCH_TIME(co->GPSEpochTime)
    331     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    332     --mmi;
    333     T_SSR_IOD(co->SSRIOD)
    334     T_SSR_PROVIDER_ID(co->SSRProviderID)
    335     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    336     T_NO_OF_SATELLITES(co->NumberOfGPSSat)
    337     for(i = 0; i < co->NumberOfGPSSat; ++i)
    338     {
    339       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    340       T_SSR_URA(ValueToURA(co->Sat[i].UserRangeAccuracy))
    341     }
    342     ENDBLOCK
    343   }
    344   if(gloor)
    345   {
    346     INITBLOCK
    347     T_MESSAGE_NUMBER(COTYPE_GLONASSORBIT)
    348     T_GLONASS_EPOCH_TIME(co->GLONASSEpochTime)
    349     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    350     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    351     --mmi;
    352     T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    353     T_SSR_IOD(co->SSRIOD)
    354     T_SSR_PROVIDER_ID(co->SSRProviderID)
    355     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    356     T_NO_OF_SATELLITES(co->NumberOfGLONASSSat)
    357     for(i = CLOCKORBIT_NUMGPS;
    358     i < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat; ++i)
    359     {
    360       T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
    361       T_GLONASS_IOD(co->Sat[i].IOD)
    362       T_DELTA_RADIAL(co->Sat[i].Orbit.DeltaRadial)
    363       T_DELTA_ALONG_TRACK(co->Sat[i].Orbit.DeltaAlongTrack)
    364       T_DELTA_CROSS_TRACK(co->Sat[i].Orbit.DeltaCrossTrack)
    365       T_DELTA_DOT_RADIAL(co->Sat[i].Orbit.DotDeltaRadial)
    366       T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack)
    367       T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack)
    368     }
    369     ENDBLOCK
    370   }
    371   if(glocl)
    372   {
    373     INITBLOCK
    374     T_MESSAGE_NUMBER(COTYPE_GLONASSCLOCK)
    375     T_GLONASS_EPOCH_TIME(co->GLONASSEpochTime)
    376     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    377     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    378     --mmi;
    379     T_SSR_IOD(co->SSRIOD)
    380     T_SSR_PROVIDER_ID(co->SSRProviderID)
    381     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    382     T_NO_OF_SATELLITES(co->NumberOfGLONASSSat)
    383     for(i = CLOCKORBIT_NUMGPS;
    384     i < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat; ++i)
    385     {
    386       T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
    387       T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0)
    388       T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1)
    389       T_DELTA_CLOCK_C2(co->Sat[i].Clock.DeltaA2)
    390     }
    391     ENDBLOCK
    392   }
    393   if(gloco)
    394   {
    395     INITBLOCK
    396     T_MESSAGE_NUMBER(COTYPE_GLONASSCOMBINED)
    397     T_GLONASS_EPOCH_TIME(co->GLONASSEpochTime)
    398     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    399     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    400     --mmi;
    401     T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    402     T_SSR_IOD(co->SSRIOD)
    403     T_SSR_PROVIDER_ID(co->SSRProviderID)
    404     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    405     T_NO_OF_SATELLITES(co->NumberOfGLONASSSat)
    406     for(i = CLOCKORBIT_NUMGPS;
    407     i < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat; ++i)
    408     {
    409       T_GLONASS_SATELLITE_ID(co->Sat[i].ID)
    410       T_GLONASS_IOD(co->Sat[i].IOD)
    411       T_DELTA_RADIAL(co->Sat[i].Orbit.DeltaRadial)
    412       T_DELTA_ALONG_TRACK(co->Sat[i].Orbit.DeltaAlongTrack)
    413       T_DELTA_CROSS_TRACK(co->Sat[i].Orbit.DeltaCrossTrack)
    414       T_DELTA_DOT_RADIAL(co->Sat[i].Orbit.DotDeltaRadial)
    415       T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack)
    416       T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack)
    417       T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0)
    418       T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1)
    419       T_DELTA_CLOCK_C2(co->Sat[i].Clock.DeltaA2)
    420     }
    421     ENDBLOCK
    422   }
    423   if(glohr)
    424   {
    425     INITBLOCK
    426     T_MESSAGE_NUMBER(COTYPE_GLONASSHR)
    427     T_GLONASS_EPOCH_TIME(co->GLONASSEpochTime)
    428     T_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    429     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    430     --mmi;
    431     T_SSR_IOD(co->SSRIOD)
    432     T_SSR_PROVIDER_ID(co->SSRProviderID)
    433     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    434     T_NO_OF_SATELLITES(co->NumberOfGLONASSSat)
    435     for(i = CLOCKORBIT_NUMGPS;
    436     i < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat; ++i)
    437     {
    438       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    439       T_HR_CLOCK_CORRECTION(co->Sat[i].hrclock)
    440     }
    441     ENDBLOCK
    442   }
    443   if(glour)
    444   {
    445     INITBLOCK
    446     T_MESSAGE_NUMBER(COTYPE_GLONASSURA)
    447     T_GLONASS_EPOCH_TIME(co->GLONASSEpochTime)
    448     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    449     --mmi;
    450     T_SSR_IOD(co->SSRIOD)
    451     T_SSR_PROVIDER_ID(co->SSRProviderID)
    452     T_SSR_SOLUTION_ID(co->SSRSolutionID)
    453     T_NO_OF_SATELLITES(co->NumberOfGLONASSSat)
    454     for(i = CLOCKORBIT_NUMGPS;
    455     i < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat; ++i)
    456     {
    457       T_GPS_SATELLITE_ID(co->Sat[i].ID)
    458       T_SSR_URA(ValueToURA(co->Sat[i].UserRangeAccuracy))
    459     }
    460     ENDBLOCK
    461   }
    462 
    463496  return ressize;
    464497}
    465498
    466 size_t MakeBias(const struct Bias *b, enum BiasType type,
     499size_t MakeCodeBias(const struct CodeBias *b, enum CodeBiasType type,
    467500int moremessagesfollow, char *buffer, size_t size)
    468501{
    469   int gps=0, glo=0, mmi, i, j;
     502  unsigned int s, i, j;
    470503
    471504  STARTDATA
    472505
    473   if(b->NumberOfGPSSat && (type == BTYPE_AUTO || type == BTYPE_GPS))
    474     gps = 1;
    475   if(b->NumberOfGLONASSSat && (type == BTYPE_AUTO || type == BTYPE_GLONASS))
    476     glo = 1;
    477 
    478   mmi = gps+glo; /* required for multimessage */
    479   if(!moremessagesfollow) --mmi;
    480 
    481   if(gps)
     506  for(s = 0; s < CLOCKORBIT_SATNUM; ++s)
    482507  {
    483     INITBLOCK
    484     T_MESSAGE_NUMBER(BTYPE_GPS)
    485     T_GPS_EPOCH_TIME(b->GPSEpochTime)
    486     T_SSR_UPDATE_INTERVAL(b->UpdateInterval)
    487     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    488     --mmi;
    489     T_SSR_IOD(b->SSRIOD)
    490     T_SSR_PROVIDER_ID(b->SSRProviderID)
    491     T_SSR_SOLUTION_ID(b->SSRSolutionID)
    492     T_NO_OF_SATELLITES(b->NumberOfGPSSat)
    493     for(i = 0; i < b->NumberOfGPSSat; ++i)
    494     {
    495       T_GPS_SATELLITE_ID(b->Sat[i].ID)
    496       T_NO_OF_CODE_BIASES(b->Sat[i].NumberOfCodeBiases)
    497       for(j = 0; j < b->Sat[i].NumberOfCodeBiases; ++j)
    498       {
    499         T_GPS_SIGNAL_IDENTIFIER(b->Sat[i].Biases[j].Type)
    500         T_CODE_BIAS(b->Sat[i].Biases[j].Bias)
    501       }
     508    if(b->NumberOfSat[s] && (type == BTYPE_AUTO || type == corbase[s]+COBOFS_BIAS))
     509    {
     510      INITBLOCK
     511      T_MESSAGE_NUMBER(corbase[s]+COBOFS_BIAS)
     512      switch(s)
     513      {
     514      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     515      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     516      case CLOCKORBIT_SATBDS:
     517        T_GPS_EPOCH_TIME(b->EpochTime[s])
     518        break;
     519      case CLOCKORBIT_SATGLONASS:
     520        T_GLONASS_EPOCH_TIME(b->EpochTime[s])
     521        break;
     522      }
     523      T_SSR_UPDATE_INTERVAL(b->UpdateInterval)
     524      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     525      T_SSR_IOD(b->SSRIOD)
     526      T_SSR_PROVIDER_ID(b->SSRProviderID)
     527      T_SSR_SOLUTION_ID(b->SSRSolutionID)
     528      T_NO_OF_SATELLITES(b->NumberOfSat[s])
     529      for(i = satoffset[s]; i < satoffset[s]+b->NumberOfSat[s]; ++i)
     530      {
     531        switch(s)
     532        {
     533        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     534        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     535          T_GPS_SATELLITE_ID(b->Sat[i].ID)
     536          break;
     537        case CLOCKORBIT_SATQZSS:
     538          T_QZSS_SATELLITE_ID(b->Sat[i].ID)
     539          break;
     540        case CLOCKORBIT_SATGLONASS:
     541          T_GLONASS_SATELLITE_ID(b->Sat[i].ID)
     542          break;
     543        }
     544        T_NO_OF_CODE_BIASES(b->Sat[i].NumberOfCodeBiases)
     545        for(j = 0; j < b->Sat[i].NumberOfCodeBiases; ++j)
     546        {
     547          T_SIGNAL_IDENTIFIER(b->Sat[i].Biases[j].Type)
     548          T_CODE_BIAS(b->Sat[i].Biases[j].Bias)
     549        }
     550      }
     551      ENDBLOCK
    502552    }
    503     ENDBLOCK
    504553  }
    505   if(glo)
    506   {
    507     INITBLOCK
    508     T_MESSAGE_NUMBER(BTYPE_GLONASS)
    509     T_GLONASS_EPOCH_TIME(b->GLONASSEpochTime)
    510     T_SSR_UPDATE_INTERVAL(b->UpdateInterval)
    511     T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0)
    512     --mmi;
    513     T_SSR_IOD(b->SSRIOD)
    514     T_SSR_PROVIDER_ID(b->SSRProviderID)
    515     T_SSR_SOLUTION_ID(b->SSRSolutionID)
    516     T_NO_OF_SATELLITES(b->NumberOfGLONASSSat)
    517     for(i = CLOCKORBIT_NUMGPS;
    518     i < CLOCKORBIT_NUMGPS+b->NumberOfGLONASSSat; ++i)
    519     {
    520       T_GLONASS_SATELLITE_ID(b->Sat[i].ID)
    521       T_NO_OF_CODE_BIASES(b->Sat[i].NumberOfCodeBiases)
    522       for(j = 0; j < b->Sat[i].NumberOfCodeBiases; ++j)
    523       {
    524         T_GLONASS_SIGNAL_IDENTIFIER(b->Sat[i].Biases[j].Type)
    525         T_CODE_BIAS(b->Sat[i].Biases[j].Bias)
    526       }
    527     }
    528     ENDBLOCK
    529   }
    530 
    531554  return ressize;
    532555}
    533556
     557size_t MakePhaseBias(const struct PhaseBias *b, enum PhaseBiasType type,
     558int moremessagesfollow, char *buffer, size_t size)
     559{
     560  unsigned int s, i, j;
     561
     562  STARTDATA
     563
     564  for(s = 0; s < CLOCKORBIT_SATNUM; ++s)
     565  {
     566    if(b->NumberOfSat[s] && (type == PBTYPE_AUTO || type == corbase[s]+COBOFS_BIAS))
     567    {
     568      INITBLOCK
     569      T_MESSAGE_NUMBER(corbase[s]+COBOFS_BIAS)
     570      switch(s)
     571      {
     572      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     573      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     574      case CLOCKORBIT_SATBDS:
     575        T_GPS_EPOCH_TIME(b->EpochTime[s])
     576        break;
     577      case CLOCKORBIT_SATGLONASS:
     578        T_GLONASS_EPOCH_TIME(b->EpochTime[s])
     579        break;
     580      }
     581      T_SSR_UPDATE_INTERVAL(b->UpdateInterval)
     582      T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     583      T_SSR_IOD(b->SSRIOD)
     584      T_SSR_PROVIDER_ID(b->SSRProviderID)
     585      T_SSR_SOLUTION_ID(b->SSRSolutionID)
     586      T_DISPERSIVE_BIAS_INDICATOR(b->DispersiveBiasConsistencyIndicator ? 1 : 0)
     587      T_MW_CONSISTENCY_INDICATOR(b->MWConsistencyIndicator ? 1 : 0)
     588      T_NO_OF_SATELLITES(b->NumberOfSat[CLOCKORBIT_SATGPS])
     589      for(i = satoffset[s]; i < satoffset[s]+b->NumberOfSat[s]; ++i)
     590      {
     591        switch(s)
     592        {
     593        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     594        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     595          T_GPS_SATELLITE_ID(b->Sat[i].ID)
     596          break;
     597        case CLOCKORBIT_SATQZSS:
     598          T_QZSS_SATELLITE_ID(b->Sat[i].ID)
     599          break;
     600        case CLOCKORBIT_SATGLONASS:
     601          T_GLONASS_SATELLITE_ID(b->Sat[i].ID)
     602          break;
     603        }
     604        T_NO_OF_CODE_BIASES(b->Sat[i].NumberOfPhaseBiases)
     605        T_YAW_ANGLE(b->Sat[i].YawAngle)
     606        T_YAW_RATE(b->Sat[i].YawRate)
     607        for(j = 0; j < b->Sat[i].NumberOfPhaseBiases; ++j)
     608        {
     609          T_SIGNAL_IDENTIFIER(b->Sat[i].Biases[j].Type)
     610          T_INTEGER_INDICATOR(b->Sat[i].Biases[j].SignalIntegerIndicator ? 1 : 0)
     611          T_WIDE_LANE_INDICATOR(b->Sat[i].Biases[j].SignalsWideLaneIntegerIndicator ? 1 : 0)
     612          T_DISCONTINUITY_COUNTER(b->Sat[i].Biases[j].SignalDiscontinuityCounter)
     613          T_PHASE_BIAS(b->Sat[i].Biases[j].Bias)
     614        }
     615      }
     616      ENDBLOCK
     617    }
     618  }
     619  return ressize;
     620}
     621
     622size_t MakeVTEC(const struct VTEC *v, int moremessagesfollow, char *buffer,
     623size_t size)
     624{
     625  unsigned int l, o, d;
     626
     627  STARTDATA
     628  INITBLOCK
     629  T_MESSAGE_NUMBER(VTEC_BASE)
     630
     631  T_GPS_EPOCH_TIME(v->EpochTime)
     632  T_SSR_UPDATE_INTERVAL(v->UpdateInterval)
     633  T_MULTIPLE_MESSAGE_INDICATOR(moremessagesfollow ? 1 : 0)
     634  T_SSR_IOD(v->SSRIOD)
     635  T_SSR_PROVIDER_ID(v->SSRProviderID)
     636  T_SSR_SOLUTION_ID(v->SSRSolutionID)
     637  T_VTEC_QUALITY_INDICATOR(v->Quality)
     638  T_NO_IONO_LAYERS(v->NumLayers)
     639  for(l = 0; l < v->NumLayers; ++l)
     640  {
     641    T_IONO_HEIGHT(v->Layers[l].Height)
     642    T_IONO_DEGREE(v->Layers[l].Degree)
     643    T_IONO_ORDER(v->Layers[l].Order)
     644    for(o = 0; o <= v->Layers[l].Order; ++o)
     645    {
     646      for(d = o; d <= v->Layers[l].Degree; ++d)
     647      {
     648        T_IONO_COEFF(v->Layers[l].Cosinus[d][o])
     649      }
     650    }
     651    for(o = 1; o <= v->Layers[l].Order; ++o)
     652    {
     653      for(d = o; d <= v->Layers[l].Degree; ++d)
     654      {
     655        T_IONO_COEFF(v->Layers[l].Sinus[d][o])
     656      }
     657    }
     658  }
     659  ENDBLOCK
     660  return ressize;
     661}
    534662#endif /* NOENCODE */
    535663
     
    559687}
    560688
     689/* extract bits from data stream
     690   b = variable to store result, a = number of bits */
     691#define GETBITSFACTOR(b, a, c) \
     692{ \
     693  LOADBITS(a) \
     694  b = ((bitbuffer<<(64-numbits))>>(64-(a)))*(c); \
     695  numbits -= (a); \
     696}
     697
    561698/* extract signed floating value from data stream
    562699   b = variable to store result, a = number of bits */
     
    568705}
    569706
     707/* extract floating value from data stream
     708   b = variable to store result, a = number of bits, c = scale factor */
     709#define GETFLOAT(b, a, c) \
     710{ \
     711  LOADBITS(a) \
     712  b = ((double)((bitbuffer<<(sizeof(bitbuffer)*8-numbits))>>(sizeof(bitbuffer)*8-(a))))*(c); \
     713  numbits -= (a); \
     714}
     715
    570716#define SKIPBITS(b) { LOADBITS(b) numbits -= (b); }
    571717
    572 /* standard values */
     718/* GPS macros also used for other systems when matching! */
    573719#define G_HEADER(a)                      GETBITS(a,8)
    574720#define G_RESERVEDH(a)                   GETBITS(a,6)
    575721#define G_SIZE(a)                        GETBITS(a, 10)
    576 #define G_MESSAGE_NUMBER(a)              GETBITS(a, 12) /* DF002 */
    577 #define G_GPS_SATELLITE_ID(a)            GETBITS(a, 6)  /* DF068 */
    578 #define G_GPS_IODE(a)                    GETBITS(a, 8)  /* DF071 */
    579 #define G_GLONASS_IOD(a)                 GETBITS(a, 8)  /* DF237 */
     722#define G_MESSAGE_NUMBER(a)              GETBITS(a, 12)          /* DF002 */
     723#define G_GPS_SATELLITE_ID(a)            GETBITS(a, 6)           /* DF068 */
     724#define G_QZSS_SATELLITE_ID(a)           GETBITS(a, 4)           /* DF249 */
     725#define G_GLONASS_SATELLITE_ID(a)        GETBITS(a, 5)
     726
     727#define G_GPS_IODE(a)                    GETBITS(a, 8)           /* DF071 */
     728#define G_GLONASS_IOD(a)                 GETBITS(a, 8)           /* DF237 */
     729#define G_GALILEO_IOD(a)                 GETBITS(a, 10)          /* DF459 */
     730#define G_SBAS_T0MOD(a)                  GETBITSFACTOR(a, 9, 16) /* DF468 */
     731#define G_SBAS_IODCRC(a)                 GETBITS(a, 24)          /* DF469 */
     732#define G_BDS_TOEMOD(a)                  GETBITSFACTOR(a, 10, 8) /* DF470 */
     733#define G_BDS_IODCRC(a)                  GETBITS(a, 24)          /* DF471 */
    580734
    581735/* defined values */
     
    592746#define G_DELTA_CLOCK_C2(a)              GETFLOATSIGN(a, 27, 1/50000000.0)
    593747#define G_NO_OF_CODE_BIASES(a)           GETBITS(a, 5)
    594 #define G_GPS_SIGNAL_IDENTIFIER(a)       GETBITS(a, 5)
    595 #define G_GLONASS_SIGNAL_IDENTIFIER(a)   GETBITS(a, 5)
     748#define G_NO_OF_PHASE_BIASES(a)          GETBITS(a, 5)
     749#define G_SIGNAL_IDENTIFIER(a)           GETBITS(a, 5)
    596750#define G_CODE_BIAS(a)                   GETFLOATSIGN(a, 14, 1/100.0)
    597 #define G_GLONASS_SATELLITE_ID(a)        GETBITS(a, 5)
    598 
    599 #define G_GPS_EPOCH_TIME(a, b)           {int temp; GETBITS(temp, 20) \
     751#define G_YAW_ANGLE(a)                   GETFLOAT(a, 9, MPI/256.0)
     752#define G_YAW_RATE(a)                    GETFLOATSIGN(a, 8, MPI/8192.0)
     753#define G_PHASE_BIAS(a)                  GETFLOATSIGN(a, 20, 1/10000.0)
     754
     755#define G_GPS_EPOCH_TIME(a, b)           {unsigned int temp; GETBITS(temp, 20) \
    600756 if(b && a != temp) return GCOBR_TIMEMISMATCH; a = temp;}
    601 #define G_GLONASS_EPOCH_TIME(a, b)       {int temp; GETBITS(temp, 17) \
     757#define G_GLONASS_EPOCH_TIME(a, b)       {unsigned int temp; GETBITS(temp, 17) \
    602758 if(b && a != temp) return GCOBR_TIMEMISMATCH; a = temp;}
     759#define G_EPOCH_TIME(a)                  GETBITS(a, 20)
    603760#define G_NO_OF_SATELLITES(a)            GETBITS(a, 6)
    604761#define G_MULTIPLE_MESSAGE_INDICATOR(a)  GETBITS(a, 1)
     762#define G_DISPERSIVE_BIAS_INDICATOR(a)   GETBITS(a, 1)
     763#define G_MW_CONSISTENCY_INDICATOR(a)    GETBITS(a, 1)
     764#define G_INTEGER_INDICATOR(a)           GETBITS(a, 1)
     765#define G_WIDE_LANE_INDICATOR(a)         GETBITS(a, 1)
     766#define G_DISCONTINUITY_COUNTER(a)       GETBITS(a, 4)
    605767#define G_SSR_URA(a)                     {int temp; GETBITS(temp, 6) \
    606768 (a) = URAToValue(temp);}
     
    612774#define G_SSR_SOLUTION_ID(a)             GETBITS(a, 4)
    613775
    614 enum GCOB_RETURN GetClockOrbitBias(struct ClockOrbit *co, struct Bias *b,
    615 const char *buffer, size_t size, int *bytesused)
     776#define G_NO_IONO_LAYERS(a)              {unsigned int temp; GETBITS(temp, 2) a = temp+1; }
     777#define G_VTEC_QUALITY_INDICATOR(a)      GETFLOAT(a, 9,      1/20.0)
     778#define G_IONO_COEFF(a)                  GETFLOATSIGN(a, 16,1/200.0)
     779#define G_IONO_DEGREE(a)                 {unsigned int temp; GETBITS(temp, 4) a = temp+1; }
     780#define G_IONO_ORDER(a)                  {unsigned int temp; GETBITS(temp, 4) a = temp+1; }
     781#define G_IONO_HEIGHT(a)                 GETFLOAT(a, 8 ,    10000.0)
     782
     783enum GCOB_RETURN GetSSR(struct ClockOrbit *co, struct CodeBias *b, struct VTEC *v,
     784struct PhaseBias *pb, const char *buffer, size_t size, int *bytesused)
    616785{
    617   int type, mmi=0, i, j, h, rs, nums, pos, id;
     786  int mmi=0, h, rs;
     787  unsigned int type, pos, i, j, s, nums, id;
    618788  size_t sizeofrtcmblock;
    619789  const char *blockstart = buffer;
     
    624794
    625795#ifdef DEBUG
    626 fprintf(stderr, "GetClockOrbitBias START: size %d, numbits %d\n",size, numbits);
     796  fprintf(stderr, "GetClockOrbitBias START: size %d, numbits %d\n",size, numbits);
    627797#endif
    628798
     
    637807  if(CRC24(sizeofrtcmblock+3, (const unsigned char *) blockstart) !=
    638808  (uint32_t)((((unsigned char)buffer[sizeofrtcmblock])<<16)|
    639    (((unsigned char)buffer[sizeofrtcmblock+1])<<8)|
    640    (((unsigned char)buffer[sizeofrtcmblock+2]))))
     809  (((unsigned char)buffer[sizeofrtcmblock+1])<<8)|
     810  (((unsigned char)buffer[sizeofrtcmblock+2]))))
    641811    return GCOBR_CRCMISMATCH;
    642812  size = sizeofrtcmblock; /* reduce size, so overflows are detected */
     
    646816fprintf(stderr, "type %d size %d\n",type,sizeofrtcmblock);
    647817#endif
    648   switch(type)
    649   {
    650   case COTYPE_GPSORBIT:
    651     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    652     co->messageType = COTYPE_GPSORBIT;
    653     G_GPS_EPOCH_TIME(co->GPSEpochTime, co->NumberOfGPSSat)
    654     co->epochGPS[co->epochSize] = co->GPSEpochTime;   /* Weber, for latency */
    655     if(co->epochSize < 100) {co->epochSize += 1;}     /* Weber, for latency */
    656     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    657     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    658     G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    659     G_SSR_IOD(co->SSRIOD)
    660     G_SSR_PROVIDER_ID(co->SSRProviderID)
    661     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    662     G_NO_OF_SATELLITES(nums)
    663     co->OrbitDataSupplied |= 1;
    664 #ifdef DEBUG
    665 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GPSEpochTime,
    666 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums, co->SatRefDatum);
    667 #endif
    668     for(i = 0; i < nums; ++i)
    669     {
    670       G_GPS_SATELLITE_ID(id)
    671       for(pos = 0; pos < co->NumberOfGPSSat && co->Sat[pos].ID != id; ++pos)
    672         ;
    673       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    674       else if(pos == co->NumberOfGPSSat) ++co->NumberOfGPSSat;
    675       co->Sat[pos].ID = id;
    676 
    677       G_GPS_IODE(co->Sat[pos].IOD)
    678       G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
    679       G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
    680       G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
    681       G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
    682       G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
    683       G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
    684 #ifdef DEBUG
    685 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f\n",
    686 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial,
    687 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack,
    688 co->Sat[pos].Orbit.DotDeltaRadial,
    689 co->Sat[pos].Orbit.DotDeltaAlongTrack,
    690 co->Sat[pos].Orbit.DotDeltaCrossTrack);
    691 #endif
    692     }
    693     break;
    694   case COTYPE_GPSCLOCK:
    695     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    696     co->messageType = COTYPE_GPSCLOCK;
    697     G_GPS_EPOCH_TIME(co->GPSEpochTime, co->NumberOfGPSSat)
    698     co->epochGPS[co->epochSize] = co->GPSEpochTime;   /* Weber, for latency */
    699     if(co->epochSize < 100) {co->epochSize += 1;}     /* Weber, for latency */
    700     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    701     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    702     G_SSR_IOD(co->SSRIOD)
    703     G_SSR_PROVIDER_ID(co->SSRProviderID)
    704     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    705     G_NO_OF_SATELLITES(nums)
    706     co->ClockDataSupplied |= 1;
    707 #ifdef DEBUG
    708 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GPSEpochTime,
    709 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums);
    710 #endif
    711     for(i = 0; i < nums; ++i)
    712     {
    713       G_GPS_SATELLITE_ID(id)
    714       for(pos = 0; pos < co->NumberOfGPSSat && co->Sat[pos].ID != id; ++pos)
    715         ;
    716       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    717       else if(pos == co->NumberOfGPSSat) ++co->NumberOfGPSSat;
    718       co->Sat[pos].ID = id;
    719 
    720       G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
    721       G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
    722       G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
    723 #ifdef DEBUG
    724 fprintf(stderr, "id %2d c0 %8.3f c1 %8.3f c2 %8.3f\n",
    725 co->Sat[pos].ID, co->Sat[pos].Clock.DeltaA0, co->Sat[pos].Clock.DeltaA1,
    726 co->Sat[pos].Clock.DeltaA2);
    727 #endif
    728     }
    729     break;
    730   case COTYPE_GPSCOMBINED:
    731     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    732     co->messageType = COTYPE_GPSCOMBINED;
    733     G_GPS_EPOCH_TIME(co->GPSEpochTime, co->NumberOfGPSSat)
    734     co->epochGPS[co->epochSize] = co->GPSEpochTime;   /* Weber, for latency */
    735     if(co->epochSize < 100) {co->epochSize += 1;}     /* Weber, for latency */
    736     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    737     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    738     G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    739     G_SSR_IOD(co->SSRIOD)
    740     G_SSR_PROVIDER_ID(co->SSRProviderID)
    741     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    742     G_NO_OF_SATELLITES(nums)
    743     co->OrbitDataSupplied |= 1;
    744     co->ClockDataSupplied |= 1;
    745     for(i = 0; i < nums; ++i)
    746     {
    747       G_GPS_SATELLITE_ID(id)
    748       for(pos = 0; pos < co->NumberOfGPSSat && co->Sat[pos].ID != id; ++pos)
    749         ;
    750       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    751       else if(pos == co->NumberOfGPSSat) ++co->NumberOfGPSSat;
    752       co->Sat[pos].ID = id;
    753 
    754       G_GPS_IODE(co->Sat[pos].IOD)
    755       G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
    756       G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
    757       G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
    758       G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
    759       G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
    760       G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
    761       G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
    762       G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
    763       G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
    764     }
    765     break;
    766   case COTYPE_GPSURA:
    767     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    768     co->messageType = COTYPE_GPSURA;
    769     G_GPS_EPOCH_TIME(co->GPSEpochTime, co->NumberOfGPSSat)
    770     co->epochGPS[co->epochSize] = co->GPSEpochTime;   /* Weber, for latency */
    771     if(co->epochSize < 100) {co->epochSize += 1;}     /* Weber, for latency */
    772     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    773     G_SSR_IOD(co->SSRIOD)
    774     G_SSR_PROVIDER_ID(co->SSRProviderID)
    775     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    776     G_NO_OF_SATELLITES(nums)
    777     co->URADataSupplied |= 1;
    778     for(i = 0; i < nums; ++i)
    779     {
    780       G_GPS_SATELLITE_ID(id)
    781       for(pos = 0; pos < co->NumberOfGPSSat && co->Sat[pos].ID != id; ++pos)
    782         ;
    783       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    784       else if(pos == co->NumberOfGPSSat) ++co->NumberOfGPSSat;
    785       co->Sat[pos].ID = id;
    786 
    787       G_SSR_URA(co->Sat[pos].UserRangeAccuracy)
    788     }
    789     break;
    790   case COTYPE_GPSHR:
    791     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    792     co->messageType = COTYPE_GPSHR;
    793     G_GPS_EPOCH_TIME(co->GPSEpochTime, co->NumberOfGPSSat)
    794     co->epochGPS[co->epochSize] = co->GPSEpochTime;   /* Weber, for latency */
    795     if(co->epochSize < 100) {co->epochSize += 1;}     /* Weber, for latency */
    796     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    797     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    798     G_SSR_IOD(co->SSRIOD)
    799     G_SSR_PROVIDER_ID(co->SSRProviderID)
    800     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    801     G_NO_OF_SATELLITES(nums)
    802     co->HRDataSupplied |= 1;
    803     for(i = 0; i < nums; ++i)
    804     {
    805       G_GPS_SATELLITE_ID(id)
    806       for(pos = 0; pos < co->NumberOfGPSSat && co->Sat[pos].ID != id; ++pos)
    807         ;
    808       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    809       else if(pos == co->NumberOfGPSSat) ++co->NumberOfGPSSat;
    810       co->Sat[pos].ID = id;
    811 
    812       G_HR_CLOCK_CORRECTION(co->Sat[pos].hrclock)
    813     }
    814     break;
    815   case COTYPE_GLONASSORBIT:
    816     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    817     co->messageType = COTYPE_GLONASSORBIT;
    818     G_GLONASS_EPOCH_TIME(co->GLONASSEpochTime, co->NumberOfGLONASSSat)
    819     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    820     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    821     G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    822     G_SSR_IOD(co->SSRIOD)
    823     G_SSR_PROVIDER_ID(co->SSRProviderID)
    824     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    825     G_NO_OF_SATELLITES(nums)
    826     co->OrbitDataSupplied |= 2;
    827 #ifdef DEBUG
    828 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GLONASSEpochTime,
    829 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums, co->SatRefDatum);
    830 #endif
    831     for(i = 0; i < nums; ++i)
    832     {
    833       G_GLONASS_SATELLITE_ID(id)
    834       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat && co->Sat[pos].ID != id; ++pos)
    835         ;
    836       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    837       else if(pos == CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat) ++co->NumberOfGLONASSSat;
    838       co->Sat[pos].ID = id;
    839 
    840       G_GLONASS_IOD(co->Sat[pos].IOD)
    841       G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
    842       G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
    843       G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
    844       G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
    845       G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
    846       G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
    847 #ifdef DEBUG
    848 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f\n",
    849 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial,
    850 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack,
    851 co->Sat[pos].Orbit.DotDeltaRadial,
    852 co->Sat[pos].Orbit.DotDeltaAlongTrack,
    853 co->Sat[pos].Orbit.DotDeltaCrossTrack);
    854 #endif
    855     }
    856     break;
    857   case COTYPE_GLONASSCLOCK:
    858     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    859     co->messageType = COTYPE_GLONASSCLOCK;
    860     G_GLONASS_EPOCH_TIME(co->GLONASSEpochTime, co->NumberOfGLONASSSat)
    861     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    862     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    863     G_SSR_IOD(co->SSRIOD)
    864     G_SSR_PROVIDER_ID(co->SSRProviderID)
    865     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    866     G_NO_OF_SATELLITES(nums)
    867     co->ClockDataSupplied |= 2;
    868 #ifdef DEBUG
    869 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GLONASSEpochTime,
    870 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums);
    871 #endif
    872     for(i = 0; i < nums; ++i)
    873     {
    874       G_GLONASS_SATELLITE_ID(id)
    875       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat && co->Sat[pos].ID != id; ++pos)
    876         ;
    877       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    878       else if(pos == CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat) ++co->NumberOfGLONASSSat;
    879       co->Sat[pos].ID = id;
    880 
    881       G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
    882       G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
    883       G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
    884 #ifdef DEBUG
    885 fprintf(stderr, "id %2d c0 %8.3f c1 %8.3f c2 %8.3f\n",
    886 co->Sat[pos].ID, co->Sat[pos].Clock.DeltaA0, co->Sat[pos].Clock.DeltaA1,
    887 co->Sat[pos].Clock.DeltaA2);
    888 #endif
    889     }
    890     break;
    891   case COTYPE_GLONASSCOMBINED:
    892     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    893     co->messageType = COTYPE_GLONASSCOMBINED;
    894     G_GLONASS_EPOCH_TIME(co->GLONASSEpochTime, co->NumberOfGLONASSSat)
    895     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    896     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    897     G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
    898     G_SSR_IOD(co->SSRIOD)
    899     G_SSR_PROVIDER_ID(co->SSRProviderID)
    900     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    901     G_NO_OF_SATELLITES(nums)
    902     co->OrbitDataSupplied |= 2;
    903     co->ClockDataSupplied |= 2;
    904     for(i = 0; i < nums; ++i)
    905     {
    906       G_GLONASS_SATELLITE_ID(id)
    907       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat && co->Sat[pos].ID != id; ++pos)
    908         ;
    909       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    910       else if(pos == CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat) ++co->NumberOfGLONASSSat;
    911       co->Sat[pos].ID = id;
    912 
    913       G_GLONASS_IOD(co->Sat[pos].IOD)
    914       G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
    915       G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
    916       G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
    917       G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
    918       G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
    919       G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
    920       G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
    921       G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
    922       G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
    923     }
    924     break;
    925   case COTYPE_GLONASSURA:
    926     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    927     co->messageType = COTYPE_GLONASSURA;
    928     G_GLONASS_EPOCH_TIME(co->GLONASSEpochTime, co->NumberOfGLONASSSat)
    929     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    930     G_SSR_IOD(co->SSRIOD)
    931     G_SSR_PROVIDER_ID(co->SSRProviderID)
    932     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    933     G_NO_OF_SATELLITES(nums)
    934     co->URADataSupplied |= 2;
    935     for(i = 0; i < nums; ++i)
    936     {
    937       G_GLONASS_SATELLITE_ID(id)
    938       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat && co->Sat[pos].ID != id; ++pos)
    939         ;
    940       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    941       else if(pos == CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat) ++co->NumberOfGLONASSSat;
    942       co->Sat[pos].ID = id;
    943 
    944       G_SSR_URA(co->Sat[pos].UserRangeAccuracy)
    945     }
    946     break;
    947   case COTYPE_GLONASSHR:
    948     if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
    949     co->messageType = COTYPE_GLONASSHR;
    950     G_GLONASS_EPOCH_TIME(co->GLONASSEpochTime, co->NumberOfGLONASSSat)
    951     G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
    952     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    953     G_SSR_IOD(co->SSRIOD)
    954     G_SSR_PROVIDER_ID(co->SSRProviderID)
    955     G_SSR_SOLUTION_ID(co->SSRSolutionID)
    956     G_NO_OF_SATELLITES(nums)
    957     co->HRDataSupplied |= 2;
    958     for(i = 0; i < nums; ++i)
    959     {
    960       G_GLONASS_SATELLITE_ID(id)
    961       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat && co->Sat[pos].ID != id; ++pos)
    962         ;
    963       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    964       else if(pos == CLOCKORBIT_NUMGPS+co->NumberOfGLONASSSat) ++co->NumberOfGLONASSSat;
    965       co->Sat[pos].ID = id;
    966 
    967       G_HR_CLOCK_CORRECTION(co->Sat[pos].hrclock)
    968     }
    969     break;
    970   case BTYPE_GPS:
    971     if(!b) return GCOBR_NOBIASPARAMETER;
    972     b->messageType = BTYPE_GPS;
    973     G_GPS_EPOCH_TIME(b->GPSEpochTime, b->NumberOfGPSSat)
    974     G_SSR_UPDATE_INTERVAL(b->UpdateInterval)
    975     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    976     G_SSR_IOD(b->SSRIOD)
    977     G_SSR_PROVIDER_ID(b->SSRProviderID)
    978     G_SSR_SOLUTION_ID(b->SSRSolutionID)
    979     G_NO_OF_SATELLITES(nums)
    980     for(i = 0; i < nums; ++i)
    981     {
    982       G_GPS_SATELLITE_ID(id)
    983       for(pos = 0; pos < b->NumberOfGPSSat && b->Sat[pos].ID != id; ++pos)
    984         ;
    985       if(pos >= CLOCKORBIT_NUMGPS) return GCOBR_DATAMISMATCH;
    986       else if(pos == b->NumberOfGPSSat) ++b->NumberOfGPSSat;
    987       b->Sat[pos].ID = id;
    988 
    989       G_NO_OF_CODE_BIASES(b->Sat[pos].NumberOfCodeBiases)
    990       for(j = 0; j < b->Sat[pos].NumberOfCodeBiases; ++j)
    991       {
    992         G_GPS_SIGNAL_IDENTIFIER(b->Sat[pos].Biases[j].Type)
    993         G_CODE_BIAS(b->Sat[pos].Biases[j].Bias)
    994       }
    995     }
    996     break;
    997   case BTYPE_GLONASS:
    998     if(!b) return GCOBR_NOBIASPARAMETER;
    999     b->messageType = BTYPE_GLONASS;
    1000     G_GLONASS_EPOCH_TIME(b->GLONASSEpochTime, b->NumberOfGLONASSSat)
    1001     G_SSR_UPDATE_INTERVAL(b->UpdateInterval)
    1002     G_MULTIPLE_MESSAGE_INDICATOR(mmi)
    1003     G_SSR_IOD(b->SSRIOD)
    1004     G_SSR_PROVIDER_ID(b->SSRProviderID)
    1005     G_SSR_SOLUTION_ID(b->SSRSolutionID)
    1006     G_NO_OF_SATELLITES(nums)
    1007     for(i = 0; i < nums; ++i)
    1008     {
    1009       G_GLONASS_SATELLITE_ID(id)
    1010       for(pos = CLOCKORBIT_NUMGPS; pos < CLOCKORBIT_NUMGPS+b->NumberOfGLONASSSat && b->Sat[pos].ID != id; ++pos)
    1011         ;
    1012       if(pos >= CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS) return GCOBR_DATAMISMATCH;
    1013       else if(pos == CLOCKORBIT_NUMGPS+b->NumberOfGLONASSSat) ++b->NumberOfGLONASSSat;
    1014       b->Sat[pos].ID = id;
    1015 
    1016       G_NO_OF_CODE_BIASES(b->Sat[pos].NumberOfCodeBiases)
    1017       for(j = 0; j < b->Sat[pos].NumberOfCodeBiases; ++j)
    1018       {
    1019         G_GLONASS_SIGNAL_IDENTIFIER(b->Sat[pos].Biases[j].Type)
    1020         G_CODE_BIAS(b->Sat[pos].Biases[j].Bias)
    1021       }
    1022     }
    1023     break;
    1024   default:
    1025     if(bytesused)
    1026       *bytesused = sizeofrtcmblock+6;
    1027     return GCOBR_UNKNOWNTYPE;
    1028   }
    1029 #ifdef DEBUG
    1030 for(type = 0; type < (int)size && (unsigned char)buffer[type] != 0xD3; ++type)
    1031   numbits += 8;
    1032 fprintf(stderr, "numbits left %d\n",numbits);
    1033 #endif
    1034818  if(bytesused)
    1035819    *bytesused = sizeofrtcmblock+6;
    1036   return mmi ? GCOBR_MESSAGEFOLLOWS : GCOBR_OK;
     820  if(type == VTEC_BASE)
     821  {
     822    unsigned int l, o, d;
     823    if(!v) return GCOBR_NOVTECPARAMETER;
     824    memset(v, 0, sizeof(*v));
     825    G_EPOCH_TIME(v->EpochTime)
     826    G_SSR_UPDATE_INTERVAL(v->UpdateInterval)
     827    G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     828    G_SSR_IOD(v->SSRIOD)
     829    G_SSR_PROVIDER_ID(v->SSRProviderID)
     830    G_SSR_SOLUTION_ID(v->SSRSolutionID)
     831    G_VTEC_QUALITY_INDICATOR(v->Quality)
     832    G_NO_IONO_LAYERS(v->NumLayers)
     833    for(l = 0; l < v->NumLayers; ++l)
     834    {
     835      G_IONO_HEIGHT(v->Layers[l].Height)
     836      G_IONO_DEGREE(v->Layers[l].Degree)
     837      G_IONO_ORDER(v->Layers[l].Order)
     838      for(o = 0; o <= v->Layers[l].Order; ++o)
     839      {
     840        for(d = o; d <= v->Layers[l].Degree; ++d)
     841        {
     842          G_IONO_COEFF(v->Layers[l].Cosinus[d][o])
     843        }
     844      }
     845      for(o = 1; o <= v->Layers[l].Order; ++o)
     846      {
     847        for(d = o; d <= v->Layers[l].Degree; ++d)
     848        {
     849          G_IONO_COEFF(v->Layers[l].Sinus[d][o])
     850        }
     851      }
     852    }
     853#ifdef DEBUG
     854    for(type = 0; type < (int)size && (unsigned char)buffer[type] != 0xD3; ++type)
     855      numbits += 8;
     856    fprintf(stderr, "numbits left %d\n",numbits);
     857#endif
     858    return mmi ? GCOBR_MESSAGEFOLLOWS : GCOBR_OK;
     859  }
     860  for(s = CLOCKORBIT_SATNUM; s-- > 0;)
     861  {
     862    if(type == PBTYPE_BASE+s)
     863    {
     864      if(!pb) return GCOBR_NOPHASEBIASPARAMETER;
     865      pb->messageType = type;
     866      switch(s)
     867      {
     868      case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     869      case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     870      case CLOCKORBIT_SATBDS:
     871        G_GPS_EPOCH_TIME(pb->EpochTime[s], pb->NumberOfSat[s])
     872        break;
     873      case CLOCKORBIT_SATGLONASS:
     874        G_GLONASS_EPOCH_TIME(pb->EpochTime[s], pb->NumberOfSat[s])
     875        break;
     876      }
     877      G_SSR_UPDATE_INTERVAL(pb->UpdateInterval)
     878      G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     879      G_SSR_IOD(pb->SSRIOD)
     880      G_SSR_PROVIDER_ID(pb->SSRProviderID)
     881      G_SSR_SOLUTION_ID(pb->SSRSolutionID)
     882      G_DISPERSIVE_BIAS_INDICATOR(pb->DispersiveBiasConsistencyIndicator)
     883      G_MW_CONSISTENCY_INDICATOR(pb->MWConsistencyIndicator)
     884      G_NO_OF_SATELLITES(nums)
     885      for(i = 0; i < nums; ++i)
     886      {
     887        switch(s)
     888        {
     889        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     890        case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     891          G_GPS_SATELLITE_ID(id)
     892          break;
     893        case CLOCKORBIT_SATQZSS:
     894          G_QZSS_SATELLITE_ID(id)
     895          break;
     896        case CLOCKORBIT_SATGLONASS:
     897          G_GLONASS_SATELLITE_ID(id)
     898          break;
     899        }
     900        for(pos = satoffset[s]; pos < satoffset[s]+pb->NumberOfSat[s] && pb->Sat[pos].ID != id; ++pos)
     901          ;
     902        if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     903        else if(pos == pb->NumberOfSat[s] + satoffset[s]) ++pb->NumberOfSat[s];
     904        pb->Sat[pos].ID = id;
     905
     906        G_NO_OF_PHASE_BIASES(pb->Sat[pos].NumberOfPhaseBiases)
     907        G_YAW_ANGLE(pb->Sat[pos].YawAngle)
     908        G_YAW_RATE(pb->Sat[pos].YawRate)
     909        for(j = 0; j < pb->Sat[pos].NumberOfPhaseBiases; ++j)
     910        {
     911          G_SIGNAL_IDENTIFIER(pb->Sat[pos].Biases[j].Type)
     912          G_INTEGER_INDICATOR(pb->Sat[pos].Biases[j].SignalIntegerIndicator)
     913          G_WIDE_LANE_INDICATOR(pb->Sat[pos].Biases[j].SignalsWideLaneIntegerIndicator)
     914          G_DISCONTINUITY_COUNTER(pb->Sat[pos].Biases[j].SignalDiscontinuityCounter)
     915          G_PHASE_BIAS(pb->Sat[pos].Biases[j].Bias)
     916        }
     917      }
     918    }
     919    else if(type >= corbase[s])
     920    {
     921      switch(type-corbase[s])
     922      {
     923      case COBOFS_ORBIT:
     924        if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
     925        co->messageType = type;
     926        switch(s)
     927        {
     928        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     929        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     930        case CLOCKORBIT_SATBDS:
     931          G_GPS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     932          break;
     933        case CLOCKORBIT_SATGLONASS:
     934          G_GLONASS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     935          break;
     936        }
     937        G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     938        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     939        G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
     940        G_SSR_IOD(co->SSRIOD)
     941        G_SSR_PROVIDER_ID(co->SSRProviderID)
     942        G_SSR_SOLUTION_ID(co->SSRSolutionID)
     943        G_NO_OF_SATELLITES(nums)
     944        co->Supplied[COBOFS_ORBIT] |= 1;
     945#ifdef DEBUG
     946        fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->EpochTime[s],
     947        co->UpdateInterval,mmi,co->NumberOfSat[s],nums, co->SatRefDatum);
     948#endif
     949        for(i = 0; i < nums; ++i)
     950        {
     951          switch(s)
     952          {
     953          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     954          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     955            G_GPS_SATELLITE_ID(id)
     956            break;
     957          case CLOCKORBIT_SATQZSS:
     958            G_QZSS_SATELLITE_ID(id)
     959            break;
     960          case CLOCKORBIT_SATGLONASS:
     961            G_GLONASS_SATELLITE_ID(id)
     962            break;
     963          }
     964          for(pos = satoffset[s]; pos < satoffset[s]+co->NumberOfSat[s] && co->Sat[pos].ID != id; ++pos)
     965            ;
     966          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     967          else if(pos == co->NumberOfSat[s] + satoffset[s]) ++co->NumberOfSat[s];
     968          co->Sat[pos].ID = id;
     969
     970          switch(s)
     971          {
     972          case CLOCKORBIT_SATGPS:
     973          case CLOCKORBIT_SATQZSS:
     974            G_GPS_IODE(co->Sat[pos].IOD)
     975            break;
     976          case CLOCKORBIT_SATGLONASS:
     977            G_GLONASS_IOD(co->Sat[pos].IOD)
     978            break;
     979          case CLOCKORBIT_SATGALILEO:
     980            G_GALILEO_IOD(co->Sat[pos].IOD)
     981            break;
     982          case CLOCKORBIT_SATSBAS:
     983            G_SBAS_T0MOD(co->Sat[pos].toe)
     984            G_SBAS_IODCRC(co->Sat[pos].IOD)
     985            break;
     986          case CLOCKORBIT_SATBDS:
     987            G_BDS_TOEMOD(co->Sat[pos].toe)
     988            G_BDS_IODCRC(co->Sat[pos].IOD)
     989            break;
     990          }
     991          G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
     992          G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
     993          G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
     994          G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
     995          G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
     996          G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
     997#ifdef DEBUG
     998          fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f\n",
     999          co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial,
     1000          co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack,
     1001          co->Sat[pos].Orbit.DotDeltaRadial,
     1002          co->Sat[pos].Orbit.DotDeltaAlongTrack,
     1003          co->Sat[pos].Orbit.DotDeltaCrossTrack);
     1004#endif
     1005        }
     1006        break;
     1007      case COBOFS_CLOCK:
     1008        if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
     1009        co->messageType = type;
     1010        switch(s)
     1011        {
     1012        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1013        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     1014        case CLOCKORBIT_SATBDS:
     1015          G_GPS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1016          break;
     1017        case CLOCKORBIT_SATGLONASS:
     1018          G_GLONASS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1019          break;
     1020        }
     1021        G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     1022        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     1023        G_SSR_IOD(co->SSRIOD)
     1024        G_SSR_PROVIDER_ID(co->SSRProviderID)
     1025        G_SSR_SOLUTION_ID(co->SSRSolutionID)
     1026        G_NO_OF_SATELLITES(nums)
     1027        co->Supplied[COBOFS_CLOCK] |= 1;
     1028#ifdef DEBUG
     1029        fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->EpochTime[s],
     1030        co->UpdateInterval,mmi,co->NumberOfSat[s],nums);
     1031#endif
     1032        for(i = 0; i < nums; ++i)
     1033        {
     1034          switch(s)
     1035          {
     1036          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1037          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     1038            G_GPS_SATELLITE_ID(id)
     1039            break;
     1040          case CLOCKORBIT_SATQZSS:
     1041            G_QZSS_SATELLITE_ID(id)
     1042            break;
     1043          case CLOCKORBIT_SATGLONASS:
     1044            G_GLONASS_SATELLITE_ID(id)
     1045            break;
     1046          }
     1047          for(pos = satoffset[s]; pos < satoffset[s]+co->NumberOfSat[s] && co->Sat[pos].ID != id; ++pos)
     1048            ;
     1049          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     1050          else if(pos == co->NumberOfSat[s] + satoffset[s]) ++co->NumberOfSat[s];
     1051          co->Sat[pos].ID = id;
     1052
     1053          G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
     1054          G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
     1055          G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
     1056#ifdef DEBUG
     1057          fprintf(stderr, "id %2d c0 %8.3f c1 %8.3f c2 %8.3f\n",
     1058          co->Sat[pos].ID, co->Sat[pos].Clock.DeltaA0, co->Sat[pos].Clock.DeltaA1,
     1059          co->Sat[pos].Clock.DeltaA2);
     1060#endif
     1061        }
     1062        break;
     1063      case COBOFS_COMBINED:
     1064        if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
     1065        co->messageType = type;
     1066        switch(s)
     1067        {
     1068        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1069        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     1070        case CLOCKORBIT_SATBDS:
     1071          G_GPS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1072          break;
     1073        case CLOCKORBIT_SATGLONASS:
     1074          G_GLONASS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1075          break;
     1076        }
     1077        G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     1078        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     1079        G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum)
     1080        G_SSR_IOD(co->SSRIOD)
     1081        G_SSR_PROVIDER_ID(co->SSRProviderID)
     1082        G_SSR_SOLUTION_ID(co->SSRSolutionID)
     1083        G_NO_OF_SATELLITES(nums)
     1084        co->Supplied[COBOFS_ORBIT] |= 1;
     1085        co->Supplied[COBOFS_CLOCK] |= 1;
     1086        for(i = 0; i < nums; ++i)
     1087        {
     1088          switch(s)
     1089          {
     1090          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1091          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     1092            G_GPS_SATELLITE_ID(id)
     1093            break;
     1094          case CLOCKORBIT_SATQZSS:
     1095            G_QZSS_SATELLITE_ID(id)
     1096            break;
     1097          case CLOCKORBIT_SATGLONASS:
     1098            G_GLONASS_SATELLITE_ID(id)
     1099            break;
     1100          }
     1101          for(pos = satoffset[s]; pos < satoffset[s]+co->NumberOfSat[s] && co->Sat[pos].ID != id; ++pos)
     1102            ;
     1103          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     1104          else if(pos == co->NumberOfSat[s] + satoffset[s]) ++co->NumberOfSat[s];
     1105          co->Sat[pos].ID = id;
     1106
     1107          switch(s)
     1108          {
     1109          case CLOCKORBIT_SATGPS:
     1110          case CLOCKORBIT_SATQZSS:
     1111            G_GPS_IODE(co->Sat[pos].IOD)
     1112            break;
     1113          case CLOCKORBIT_SATGLONASS:
     1114            G_GLONASS_IOD(co->Sat[pos].IOD)
     1115            break;
     1116          case CLOCKORBIT_SATGALILEO:
     1117            G_GALILEO_IOD(co->Sat[pos].IOD)
     1118            break;
     1119          case CLOCKORBIT_SATSBAS:
     1120            G_SBAS_T0MOD(co->Sat[pos].toe)
     1121            G_SBAS_IODCRC(co->Sat[pos].IOD)
     1122            break;
     1123          case CLOCKORBIT_SATBDS:
     1124            G_BDS_TOEMOD(co->Sat[pos].toe)
     1125            G_BDS_IODCRC(co->Sat[pos].IOD)
     1126            break;
     1127          }
     1128          G_DELTA_RADIAL(co->Sat[pos].Orbit.DeltaRadial)
     1129          G_DELTA_ALONG_TRACK(co->Sat[pos].Orbit.DeltaAlongTrack)
     1130          G_DELTA_CROSS_TRACK(co->Sat[pos].Orbit.DeltaCrossTrack)
     1131          G_DELTA_DOT_RADIAL(co->Sat[pos].Orbit.DotDeltaRadial)
     1132          G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack)
     1133          G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack)
     1134          G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0)
     1135          G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1)
     1136          G_DELTA_CLOCK_C2(co->Sat[pos].Clock.DeltaA2)
     1137        }
     1138        break;
     1139      case COBOFS_URA:
     1140        if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
     1141        co->messageType = type;
     1142        switch(s)
     1143        {
     1144        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1145        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     1146        case CLOCKORBIT_SATBDS:
     1147          G_GPS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1148          break;
     1149        case CLOCKORBIT_SATGLONASS:
     1150          G_GLONASS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1151          break;
     1152        }
     1153        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     1154        G_SSR_IOD(co->SSRIOD)
     1155        G_SSR_PROVIDER_ID(co->SSRProviderID)
     1156        G_SSR_SOLUTION_ID(co->SSRSolutionID)
     1157        G_NO_OF_SATELLITES(nums)
     1158        co->Supplied[COBOFS_URA] |= 1;
     1159        for(i = 0; i < nums; ++i)
     1160        {
     1161          switch(s)
     1162          {
     1163          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1164          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     1165            G_GPS_SATELLITE_ID(id)
     1166            break;
     1167          case CLOCKORBIT_SATQZSS:
     1168            G_QZSS_SATELLITE_ID(id)
     1169            break;
     1170          case CLOCKORBIT_SATGLONASS:
     1171            G_GLONASS_SATELLITE_ID(id)
     1172            break;
     1173          }
     1174          for(pos = satoffset[s]; pos < satoffset[s]+co->NumberOfSat[s] && co->Sat[pos].ID != id; ++pos)
     1175            ;
     1176          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     1177          else if(pos == co->NumberOfSat[s] + satoffset[s]) ++co->NumberOfSat[s];
     1178          co->Sat[pos].ID = id;
     1179
     1180          G_SSR_URA(co->Sat[pos].UserRangeAccuracy)
     1181        }
     1182        break;
     1183      case COBOFS_HR:
     1184        if(!co) return GCOBR_NOCLOCKORBITPARAMETER;
     1185        co->messageType = type;
     1186        switch(s)
     1187        {
     1188        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1189        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     1190        case CLOCKORBIT_SATBDS:
     1191          G_GPS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1192          break;
     1193        case CLOCKORBIT_SATGLONASS:
     1194          G_GLONASS_EPOCH_TIME(co->EpochTime[s], co->NumberOfSat[s])
     1195          break;
     1196        }
     1197        G_SSR_UPDATE_INTERVAL(co->UpdateInterval)
     1198        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     1199        G_SSR_IOD(co->SSRIOD)
     1200        G_SSR_PROVIDER_ID(co->SSRProviderID)
     1201        G_SSR_SOLUTION_ID(co->SSRSolutionID)
     1202        G_NO_OF_SATELLITES(nums)
     1203        co->Supplied[COBOFS_HR] |= 1;
     1204        for(i = 0; i < nums; ++i)
     1205        {
     1206          switch(s)
     1207          {
     1208          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1209          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     1210            G_GPS_SATELLITE_ID(id)
     1211            break;
     1212          case CLOCKORBIT_SATQZSS:
     1213            G_QZSS_SATELLITE_ID(id)
     1214            break;
     1215          case CLOCKORBIT_SATGLONASS:
     1216            G_GLONASS_SATELLITE_ID(id)
     1217            break;
     1218          }
     1219          for(pos = satoffset[s]; pos < satoffset[s]+co->NumberOfSat[s] && co->Sat[pos].ID != id; ++pos)
     1220            ;
     1221          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     1222          else if(pos == co->NumberOfSat[s] + satoffset[s]) ++co->NumberOfSat[s];
     1223          co->Sat[pos].ID = id;
     1224
     1225          G_HR_CLOCK_CORRECTION(co->Sat[pos].hrclock)
     1226        }
     1227        break;
     1228      case COBOFS_BIAS:
     1229        if(!b) return GCOBR_NOCODEBIASPARAMETER;
     1230        b->messageType = type;
     1231        switch(s)
     1232        {
     1233        case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1234        case CLOCKORBIT_SATQZSS: case CLOCKORBIT_SATSBAS:
     1235        case CLOCKORBIT_SATBDS:
     1236          G_GPS_EPOCH_TIME(b->EpochTime[s], b->NumberOfSat[s])
     1237          break;
     1238        case CLOCKORBIT_SATGLONASS:
     1239          G_GLONASS_EPOCH_TIME(b->EpochTime[s], b->NumberOfSat[s])
     1240          break;
     1241        }
     1242        G_SSR_UPDATE_INTERVAL(b->UpdateInterval)
     1243        G_MULTIPLE_MESSAGE_INDICATOR(mmi)
     1244        G_SSR_IOD(b->SSRIOD)
     1245        G_SSR_PROVIDER_ID(b->SSRProviderID)
     1246        G_SSR_SOLUTION_ID(b->SSRSolutionID)
     1247        G_NO_OF_SATELLITES(nums)
     1248        for(i = 0; i < nums; ++i)
     1249        {
     1250          switch(s)
     1251          {
     1252          case CLOCKORBIT_SATGPS: case CLOCKORBIT_SATGALILEO:
     1253          case CLOCKORBIT_SATSBAS: case CLOCKORBIT_SATBDS:
     1254            G_GPS_SATELLITE_ID(id)
     1255            break;
     1256          case CLOCKORBIT_SATQZSS:
     1257            G_QZSS_SATELLITE_ID(id)
     1258            break;
     1259          case CLOCKORBIT_SATGLONASS:
     1260            G_GLONASS_SATELLITE_ID(id)
     1261            break;
     1262          }
     1263          for(pos = satoffset[s]; pos < satoffset[s]+b->NumberOfSat[s] && b->Sat[pos].ID != id; ++pos)
     1264            ;
     1265          if(pos >= satoffset[s+1]) return GCOBR_DATAMISMATCH;
     1266          else if(pos == b->NumberOfSat[s] + satoffset[s]) ++b->NumberOfSat[s];
     1267          b->Sat[pos].ID = id;
     1268
     1269          G_NO_OF_CODE_BIASES(b->Sat[pos].NumberOfCodeBiases)
     1270          for(j = 0; j < b->Sat[pos].NumberOfCodeBiases; ++j)
     1271          {
     1272            G_SIGNAL_IDENTIFIER(b->Sat[pos].Biases[j].Type)
     1273            G_CODE_BIAS(b->Sat[pos].Biases[j].Bias)
     1274          }
     1275        }
     1276        break;
     1277      default:
     1278        return GCOBR_UNKNOWNTYPE;
     1279      }
     1280#ifdef COR_LATENCY
     1281      if(s == CLOCKORBIT_SATGPS && type-corbase[s] != COBOFS_BIAS)
     1282      {
     1283        co->epochGPS[co->epochSize] = co->EpochTime[s];
     1284        if(co->epochSize < COR_LATENCYCOUNT)
     1285          ++co->epochSize;
     1286      }
     1287#endif
     1288#ifdef DEBUG
     1289      for(type = 0; type < (int)size && (unsigned char)buffer[type] != 0xD3; ++type)
     1290        numbits += 8;
     1291      fprintf(stderr, "numbits left %d\n",numbits);
     1292#endif
     1293      return mmi ? GCOBR_MESSAGEFOLLOWS : GCOBR_OK;
     1294    }
     1295  }
     1296  return GCOBR_UNKNOWNTYPE;
    10371297}
    10381298#endif /* NODECODE */
  • trunk/clock_and_orbit/lib/clock_orbit_rtcm.h

    r4241 r5664  
    1414
    1515enum SatelliteReferenceDatum { DATUM_ITRF=0, DATUM_LOCAL=1 };
     16
     17enum COR_BASE {
     18  COBBASE_GPS = 1057,
     19  COBBASE_GLONASS = 1063,
     20  COBBASE_GALILEO = 1240,
     21  COBBASE_QZSS = 1246,
     22  COBBASE_SBAS = 1252,
     23  COBBASE_BDS = 1258,
     24};
     25
     26enum COR_OFFSET {
     27  COBOFS_ORBIT = 0,
     28  COBOFS_CLOCK,
     29  COBOFS_BIAS,
     30  COBOFS_COMBINED,
     31  COBOFS_URA,
     32  COBOFS_HR,
     33  COBOFS_NUM
     34};
     35
    1636enum ClockOrbitType {
    17      COTYPE_GPSORBIT=1057, COTYPE_GPSCLOCK=1058,
    18      COTYPE_GPSCOMBINED=1060, COTYPE_GPSURA=1061, COTYPE_GPSHR=1062,
    19 
    20      COTYPE_GLONASSORBIT=1063, COTYPE_GLONASSCLOCK=1064,
    21      COTYPE_GLONASSCOMBINED=1066, COTYPE_GLONASSURA=1067, COTYPE_GLONASSHR=1068,
    22 
    23      COTYPE_AUTO=0 };
    24 enum BiasType { BTYPE_GPS=1059, BTYPE_GLONASS=1065, BTYPE_AUTO = 0 };
    25 
     37  COTYPE_GPSORBIT = COBBASE_GPS + COBOFS_ORBIT,
     38  COTYPE_GPSCLOCK,
     39  COTYPE_GPSCOMBINED = COBBASE_GPS + COBOFS_COMBINED,
     40  COTYPE_GPSURA,
     41  COTYPE_GPSHR,
     42
     43  COTYPE_GLONASSORBIT = COBBASE_GLONASS + COBOFS_ORBIT,
     44  COTYPE_GLONASSCLOCK,
     45  COTYPE_GLONASSCOMBINED = COBBASE_GLONASS + COBOFS_COMBINED,
     46  COTYPE_GLONASSURA,
     47  COTYPE_GLONASSHR,
     48
     49  COTYPE_GALILEOORBIT = COBBASE_GALILEO + COBOFS_ORBIT,
     50  COTYPE_GALILEOCLOCK,
     51  COTYPE_GALILEOCOMBINED = COBBASE_GALILEO + COBOFS_COMBINED,
     52  COTYPE_GALILEOURA,
     53  COTYPE_GALILEOHR,
     54
     55  COTYPE_QZSSORBIT = COBBASE_QZSS + COBOFS_ORBIT,
     56  COTYPE_QZSSCLOCK,
     57  COTYPE_QZSSCOMBINED = COBBASE_QZSS + COBOFS_COMBINED,
     58  COTYPE_QZSSURA,
     59  COTYPE_QZSSHR,
     60
     61  COTYPE_SBASORBIT = COBBASE_SBAS + COBOFS_ORBIT,
     62  COTYPE_SBASCLOCK,
     63  COTYPE_SBASCOMBINED = COBBASE_QZSS + COBOFS_COMBINED,
     64  COTYPE_SBASURA,
     65  COTYPE_SBASHR,
     66
     67  COTYPE_BDSORBIT = COBBASE_BDS + COBOFS_ORBIT,
     68  COTYPE_BDSCLOCK,
     69  COTYPE_BDSCOMBINED = COBBASE_BDS + COBOFS_COMBINED,
     70  COTYPE_BDSURA,
     71  COTYPE_BDSHR,
     72
     73  COTYPE_AUTO = 0,
     74};
     75
     76enum CodeBiasType {
     77  BTYPE_GPS = COBBASE_GPS + COBOFS_BIAS,
     78  BTYPE_GLONASS = COBBASE_GLONASS + COBOFS_BIAS,
     79  BTYPE_GALILEO = COBBASE_GALILEO + COBOFS_BIAS,
     80  BTYPE_QZSS = COBBASE_QZSS + COBOFS_BIAS,
     81  BTYPE_SBAS = COBBASE_QZSS + COBOFS_BIAS,
     82  BTYPE_BDS = COBBASE_BDS + COBOFS_BIAS,
     83  BTYPE_AUTO = 0
     84};
     85
     86enum PhaseBiasType {
     87  PBTYPE_BASE = 1265,
     88  PBTYPE_GPS = PBTYPE_BASE,
     89  PBTYPE_GLONASS,
     90  PBTYPE_GALILEO,
     91  PBTYPE_QZSS,
     92  PBTYPE_SBAS,
     93  PBTYPE_BDS,
     94  PBTYPE_AUTO = 0
     95};
     96
     97enum VTECType {
     98  VTEC_BASE = 1264
     99};
     100
     101/* if some systems aren't supported at all, change the following numbers to zero
     102for these systems to save space */
    26103enum COR_CONSTANTS {
    27104  CLOCKORBIT_BUFFERSIZE=2048,
    28105  CLOCKORBIT_NUMGPS=32,
    29106  CLOCKORBIT_NUMGLONASS=24,
    30   CLOCKORBIT_NUMBIAS=10
     107  CLOCKORBIT_NUMGALILEO=36,
     108  CLOCKORBIT_NUMQZSS=10,
     109  CLOCKORBIT_NUMSBAS=38,
     110  CLOCKORBIT_NUMBDS=37,
     111  CLOCKORBIT_NUMBIAS=10,
     112  CLOCKORBIT_NUMIONOLAYERS=4,
     113  CLOCKORBIT_MAXIONOORDER=8,
     114  CLOCKORBIT_MAXIONODEGREE=8
     115};
     116
     117enum COR_SATSYSTEM {
     118  CLOCKORBIT_SATGPS=0,
     119  CLOCKORBIT_SATGLONASS,
     120  CLOCKORBIT_SATGALILEO,
     121  CLOCKORBIT_SATQZSS,
     122  CLOCKORBIT_SATSBAS,
     123  CLOCKORBIT_SATBDS,
     124  CLOCKORBIT_SATNUM
     125};
     126
     127enum COR_OFFSETS {
     128  CLOCKORBIT_OFFSETGPS=0,
     129  CLOCKORBIT_OFFSETGLONASS=CLOCKORBIT_NUMGPS,
     130  CLOCKORBIT_OFFSETGALILEO=CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS,
     131  CLOCKORBIT_OFFSETQZSS=CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS
     132  +CLOCKORBIT_NUMGALILEO,
     133  CLOCKORBIT_OFFSETSBAS=CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS
     134  +CLOCKORBIT_NUMGALILEO+CLOCKORBIT_NUMQZSS,
     135  CLOCKORBIT_OFFSETBDS=CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS
     136  +CLOCKORBIT_NUMGALILEO+CLOCKORBIT_NUMQZSS+CLOCKORBIT_NUMSBAS,
     137  CLOCKORBIT_COUNTSAT=CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS
     138  +CLOCKORBIT_NUMGALILEO+CLOCKORBIT_NUMQZSS+CLOCKORBIT_NUMSBAS
     139  +CLOCKORBIT_NUMBDS
    31140};
    32141
     
    54163  CODETYPEGLONASS_L2_CA      = 2,
    55164  CODETYPEGLONASS_L2_P       = 3,
     165
     166  CODETYPEGALILEO_E1_A       = 0,
     167  CODETYPEGALILEO_E1_B       = 1,
     168  CODETYPEGALILEO_E1_C       = 2,
     169  CODETYPEGALILEO_E5A_I      = 5,
     170  CODETYPEGALILEO_E5A_Q      = 6,
     171  CODETYPEGALILEO_E5B_I      = 8,
     172  CODETYPEGALILEO_E5B_Q      = 9,
     173  CODETYPEGALILEO_E5_I       = 11,
     174  CODETYPEGALILEO_E5_Q       = 12,
     175  CODETYPEGALILEO_E6_A       = 14,
     176  CODETYPEGALILEO_E6_B       = 15,
     177  CODETYPEGALILEO_E6_C       = 16,
     178
     179  CODETYPEQZSS_L1_CA         = 0,
     180  CODETYPEQZSS_L1C_D         = 1,
     181  CODETYPEQZSS_L1C_P         = 2,
     182  CODETYPEQZSS_L2_CM         = 3,
     183  CODETYPEQZSS_L2_CL         = 4,
     184  CODETYPEQZSS_L2_CML        = 5,
     185  CODETYPEQZSS_L5_I          = 6,
     186  CODETYPEQZSS_L5_Q          = 7,
     187  CODETYPEQZSS_L5_IQ         = 8,
     188  CODETYPEQZSS_LEX_S         = 9,
     189  CODETYPEQZSS_LEX_L         = 10,
     190  CODETYPEQZSS_LEX_SL        = 11,
     191  CODETYPEQZSS_L1C_DP        = 12,
     192
     193  CODETYPE_SBAS_L1_CA        = 0,
     194  CODETYPE_SBAS_L5_I         = 1,
     195  CODETYPE_SBAS_L5_Q         = 2,
     196  CODETYPE_SBAS_L5_IQ        = 3,
     197
     198  CODETYPE_BDS_B1_I          = 0,
     199  CODETYPE_BDS_B1_Q          = 1,
     200  CODETYPE_BDS_B1_IQ         = 2,
     201  CODETYPE_BDS_B3_I          = 3,
     202  CODETYPE_BDS_B3_Q          = 4,
     203  CODETYPE_BDS_B3_IQ         = 5,
     204  CODETYPE_BDS_B2_I          = 6,
     205  CODETYPE_BDS_B2_Q          = 7,
     206  CODETYPE_BDS_B2_IQ         = 8,
    56207};
    57208
    58209#define SSR_MAXURA 5.5 /* > 5466.5mm in meter */
    59210
    60 /* GLONASS data is stored with offset CLOCKORBIT_NUMGPS in the data structures.
    61 So first GLONASS satellite is at xxx->Sat[CLOCKORBIT_NUMGPS], first
    62 GPS satellite is xxx->Sat[0]. */
     211/* satellite system data data is stored with offset CLOCKORBIT_OFFSET...
     212in the data structures. So first GLONASS satellite is at
     213xxx->Sat[CLOCKORBIT_OFFSETGLONASS], first GPS satellite is
     214xxx->Sat[CLOCKORBIT_OFFSETGPS]. */
     215
     216#ifdef COR_LEGACY
     217/* old names */
     218#define NumberOfGPSSat     NumberOfSat[CLOCKORBIT_SATGPS]
     219#define NumberOfGLONASSSat NumberOfSat[CLOCKORBIT_SATGLONASS]
     220#define GPSEpochTime       EpochTime[CLOCKORBIT_SATGPS] /* 0 .. 604799 s */
     221#define GLONASSEpochTime   EpochTime[CLOCKORBIT_SATGLONASS] /* 0 .. 86399 s (86400 for leap second) */
     222#define ClockDataSupplied  Supplied[COBOFS_CLOCK]
     223#define HRDataSupplied     Supplied[COBOFS_HR]
     224#define OrbitDataSupplied  Supplied[COBOFS_ORBIT]
     225#define URADataSupplied    Supplied[COBOFS_URA]
     226#define GetClockOrbitBias(a,b,c,d,e) GetSSR(a,b,0,0,c,d,e)
     227#endif /* COR_LEGACY */
     228
     229/* latency check code, disabled by default */
     230#ifdef COR_LATENCY
     231#define COR_LATENCYCOUNT 100
     232#endif
    63233
    64234struct ClockOrbit
    65235{
    66236  enum ClockOrbitType messageType;
    67   int GPSEpochTime;                 /* 0 .. 604799 s */
    68   int GLONASSEpochTime;             /* 0 .. 86399 s (86400 for leap second) */
    69   int NumberOfGPSSat;               /* 0 .. 32 */
    70   int NumberOfGLONASSSat;           /* 0 .. 24 */
    71   int ClockDataSupplied;            /* boolean */
    72   int HRDataSupplied;               /* boolean */
    73   int OrbitDataSupplied;            /* boolean */
    74   int URADataSupplied;              /* boolean */
    75   int epochGPS[101];                /* Weber, for latency */
    76   int epochSize;                    /* Weber, for latency */
    77   int SSRIOD;
    78   int SSRProviderID;
    79   int SSRSolutionID;
    80   int UpdateInterval;
     237  unsigned int EpochTime[CLOCKORBIT_SATNUM];   /* 0 .. system specific maximum */
     238  unsigned int NumberOfSat[CLOCKORBIT_SATNUM]; /* 0 .. CLOCKORBIT_NUM... */
     239
     240  unsigned int Supplied[COBOFS_NUM];           /* boolean */
     241#ifdef COR_LATENCY
     242  unsigned int epochGPS[COR_LATENCYCOUNT+1];   /* Weber, for latency */
     243  unsigned int epochSize;                      /* Weber, for latency */
     244#endif
     245  unsigned int SSRIOD;
     246  unsigned int SSRProviderID;
     247  unsigned int SSRSolutionID;
     248  unsigned int UpdateInterval;
    81249  enum SatelliteReferenceDatum SatRefDatum;
    82250  struct SatData {
    83     int ID; /* GPS or GLONASS */
    84     int IOD; /* GPS or GLONASS */
     251    unsigned int ID; /* all */
     252    unsigned int IOD; /* all */
     253    unsigned int toe; /* SBAS, BDS */
    85254    double UserRangeAccuracy; /* accuracy values in [m] */
    86255    double hrclock;
     
    100269      double DeltaA2;               /* m/ss */
    101270    } Clock;
    102   } Sat[CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS];
    103 };
    104 
    105 struct Bias
     271  } Sat[CLOCKORBIT_COUNTSAT];
     272};
     273
     274struct CodeBias
    106275{
    107   enum BiasType messageType;
    108   int GPSEpochTime;                 /* 0 .. 604799 s */
    109   int GLONASSEpochTime;             /* 0 .. 86399 s (86400 for leap second) */
    110   int NumberOfGPSSat;               /* 0 .. 32 */
    111   int NumberOfGLONASSSat;           /* 0 .. 24 */
    112   int UpdateInterval;
    113   int SSRIOD;
    114   int SSRProviderID;
    115   int SSRSolutionID;
     276  enum CodeBiasType messageType;
     277  unsigned int EpochTime[CLOCKORBIT_SATNUM];   /* 0 .. system specific maximum */
     278  unsigned int NumberOfSat[CLOCKORBIT_SATNUM]; /* 0 .. CLOCKORBIT_NUM... */
     279  unsigned int UpdateInterval;
     280  unsigned int SSRIOD;
     281  unsigned int SSRProviderID;
     282  unsigned int SSRSolutionID;
    116283  struct BiasSat
    117284  {
    118     int ID; /* GPS or GLONASS */
    119     int NumberOfCodeBiases;
    120     struct CodeBias
     285    unsigned int ID; /* all */
     286    unsigned int NumberOfCodeBiases;
     287    struct CodeBiasEntry
    121288    {
    122289      enum CodeType Type;
    123290      float         Bias;           /* m */
    124291    } Biases[CLOCKORBIT_NUMBIAS];
    125   } Sat[CLOCKORBIT_NUMGPS+CLOCKORBIT_NUMGLONASS];
     292  } Sat[CLOCKORBIT_COUNTSAT];
     293};
     294
     295struct PhaseBias
     296{
     297  enum PhaseBiasType messageType;
     298  unsigned int EpochTime[CLOCKORBIT_SATNUM];   /* 0 .. system specific maximum */
     299  unsigned int NumberOfSat[CLOCKORBIT_SATNUM]; /* 0 .. CLOCKORBIT_NUM... */
     300  unsigned int UpdateInterval;
     301  unsigned int SSRIOD;
     302  unsigned int SSRProviderID;
     303  unsigned int SSRSolutionID;
     304  unsigned int DispersiveBiasConsistencyIndicator;
     305  unsigned int MWConsistencyIndicator;
     306  struct PhaseBiasSat
     307  {
     308    unsigned int ID; /* all */
     309    unsigned int NumberOfPhaseBiases;
     310    double YawAngle; /* radiant */
     311    double YawRate;  /* radiant/s */
     312    struct PhaseBiasEntry
     313    {
     314      enum CodeType Type;
     315      unsigned int  SignalIntegerIndicator;
     316      unsigned int  SignalsWideLaneIntegerIndicator;
     317      unsigned int  SignalDiscontinuityCounter;
     318      float         Bias;           /* m */
     319    } Biases[CLOCKORBIT_NUMBIAS];
     320  } Sat[CLOCKORBIT_COUNTSAT];
     321};
     322
     323struct VTEC
     324{
     325  unsigned int EpochTime; /* GPS */
     326  unsigned int UpdateInterval;
     327  unsigned int SSRIOD;
     328  unsigned int SSRProviderID;
     329  unsigned int SSRSolutionID;
     330  unsigned int NumLayers; /* 1-4 */
     331  double Quality;
     332  struct IonoLayers {
     333    double       Height; /* m */
     334    unsigned int Degree; /* 1-8 */
     335    unsigned int Order; /* 1-8 */
     336    double       Sinus[CLOCKORBIT_MAXIONODEGREE][CLOCKORBIT_MAXIONOORDER];
     337    double       Cosinus[CLOCKORBIT_MAXIONODEGREE][CLOCKORBIT_MAXIONOORDER];
     338  } Layers[CLOCKORBIT_NUMIONOLAYERS];
    126339};
    127340
     
    129342size_t MakeClockOrbit(const struct ClockOrbit *co, enum ClockOrbitType type,
    130343       int moremessagesfollow, char *buffer, size_t size);
    131 size_t MakeBias(const struct Bias *b, enum BiasType type,
     344size_t MakeCodeBias(const struct CodeBias *b, enum CodeBiasType type,
    132345       int moremessagesfollow, char *buffer, size_t size);
     346size_t MakePhaseBias(const struct PhaseBias *b, enum PhaseBiasType type,
     347       int moremessagesfollow, char *buffer, size_t size);
     348size_t MakeVTEC(const struct VTEC *b, int moremessagesfollow, char *buffer,
     349       size_t size);
    133350
    134351enum GCOB_RETURN {
     
    143360  /* failed to do the work */
    144361  GCOBR_NOCLOCKORBITPARAMETER = -10,
    145   GCOBR_NOBIASPARAMETER = -11,
     362  GCOBR_NOCODEBIASPARAMETER = -11,
     363  GCOBR_NOPHASEBIASPARAMETER = -12,
     364  GCOBR_NOVTECPARAMETER = -13,
    146365  /* data mismatch - data in storage does not match new data */
    147366  GCOBR_TIMEMISMATCH = -20,
     
    155374
    156375/* buffer should point to a RTCM3 block */
    157 enum GCOB_RETURN GetClockOrbitBias(struct ClockOrbit *co, struct Bias *b,
    158        const char *buffer, size_t size, int *bytesused);
     376enum GCOB_RETURN GetSSR(struct ClockOrbit *co, struct CodeBias *b, struct VTEC *v,
     377       struct PhaseBias *pb, const char *buffer, size_t size, int *bytesused);
    159378
    160379#endif /* RTCM3_CLOCK_ORBIT_RTCM_H */
  • trunk/clock_and_orbit/readcoold.c

    • Property svn:executable deleted
    r5661 r5664  
    33
    44#include <stdio.h>
     5#include <stdlib.h>
    56
    67/* prototype, don't use any of this code in a final application */
     
    1112int main(void)
    1213{
    13   char buffer[4096];
     14  char * buffer = 0;
     15  size_t len = 0;
    1416  char obuffer[CLOCKORBIT_BUFFERSIZE];
    1517
    16   while(gets(buffer))
     18  while(getline(&buffer, &len, stdin) > 0)
    1719  {
    1820    char type;
     
    2830        if(lasttow >= 0)
    2931        {
     32          FILE *f;
    3033          int l = MakeClockOrbit(&co, COTYPE_AUTO, 0, obuffer, sizeof(obuffer));
    3134          if(!l) fprintf(stderr, "BUILD ERROR\n");
     
    3538            struct ClockOrbit c;
    3639
    37 //            fwrite(obuffer, l, 1, stdout);
     40            if((f = fopen("outfile.raw", "ab+")))
     41            {
     42              fwrite(obuffer, l, 1, f);
     43              fclose(f);
     44            }
     45            else fprintf(stderr, "SAVE ERROR\n");
     46            //fwrite(obuffer, l, 1, stdout);
    3847            memset(&c, 0, sizeof(c));
    39             nl = GetClockOrbitBias(&c, 0, obuffer, l, &ns);
     48            nl = GetSSR(&c, 0, 0, 0, obuffer, l, &ns);
    4049            if(nl < 0) fprintf(stderr, "EXTRACT ERROR %d\n", nl);
    4150            else if(nl > 0) fprintf(stderr, "MULTIBLOCK UNSUPPORTED IN TEST\n");
     
    4453            {
    4554              int i;
    46               for(i = 0; i < c.NumberOfGPSSat; ++i)
     55              for(i = 0; i < c.NumberOfSat[CLOCKORBIT_SATGPS]; ++i)
    4756              {
    48                 printf("%d G%d %d %f %f %f %f\n", c.GPSEpochTime,
     57                printf("%d G%02d %d %f %f %f %f\n", c.EpochTime[CLOCKORBIT_SATGPS],
    4958                c.Sat[i].ID, co.Sat[i].IOD, c.Sat[i].Clock.DeltaA0,
    5059                c.Sat[i].Orbit.DeltaRadial, c.Sat[i].Orbit.DeltaAlongTrack,
     
    5665        memset(&co, 0, sizeof(co));
    5766        lasttow = tow;
    58         co.GPSEpochTime = (int)tow;
     67        co.EpochTime[CLOCKORBIT_SATGPS] = (int)tow;
    5968        /* co.GLONASSEpochTime = 0; */
    60         co.ClockDataSupplied = 1;
    61         co.OrbitDataSupplied = 1;
     69        co.Supplied[COBOFS_CLOCK] = 1;
     70        co.Supplied[COBOFS_ORBIT] = 1;
    6271        co.SatRefDatum = DATUM_ITRF;
    6372      }
    6473
    65       sd = co.Sat + co.NumberOfGPSSat;
     74      sd = co.Sat + co.NumberOfSat[CLOCKORBIT_SATGPS];
    6675      sd->ID = prn;
    6776      sd->IOD = iode;
     
    7079      sd->Orbit.DeltaAlongTrack = along;
    7180      sd->Orbit.DeltaCrossTrack = outofplane;
    72     printf("%d %d/%f %c %d %d %d %f %f %f %f\n",num, week, tow, type, prn,
     81      printf("%d %d/%f %c%02d %d %d %f %f %f %f\n",num, week, tow, type, prn,
    7382      iodc, iode, clock, radial, along, outofplane);
    74       ++co.NumberOfGPSSat;
     83      ++co.NumberOfSat[CLOCKORBIT_SATGPS];
    7584    }
    7685  }
     86  {
     87    struct VTEC v;
     88    memset(&v, 0, sizeof(v));
     89    v.EpochTime = 218764;
     90    v.NumLayers = 1;
     91    v.UpdateInterval = 1;
     92    v.Layers[0].Height = 450000;
     93    v.Layers[0].Degree = 4;
     94    v.Layers[0].Order = 4;
     95    v.Layers[0].Cosinus[0][0] = 24.435;
     96    v.Layers[0].Cosinus[1][0] = 4.495;
     97    v.Layers[0].Cosinus[2][0] = -7.805;
     98    v.Layers[0].Cosinus[3][0] = -1.900;
     99    v.Layers[0].Cosinus[4][0] = 2.045;
     100    v.Layers[0].Cosinus[1][1] = -9.960;
     101    v.Layers[0].Cosinus[2][1] = 0.845;
     102    v.Layers[0].Cosinus[3][1] = 2.260;
     103    v.Layers[0].Cosinus[4][1] = -0.315;
     104    v.Layers[0].Cosinus[2][2] = 3.730;
     105    v.Layers[0].Cosinus[3][2] = -0.780;
     106    v.Layers[0].Cosinus[4][2] = -0.055;
     107    v.Layers[0].Cosinus[3][3] = -0.020;
     108    v.Layers[0].Cosinus[4][3] = 1.150;
     109    v.Layers[0].Cosinus[4][4] = 0.990;
     110
     111    v.Layers[0].Sinus[1][1] = -6.070;
     112    v.Layers[0].Sinus[2][1] = -3.105;
     113    v.Layers[0].Sinus[3][1] = 1.310;
     114    v.Layers[0].Sinus[4][1] = 1.545;
     115    v.Layers[0].Sinus[2][2] = 0.325;
     116    v.Layers[0].Sinus[3][2] = -1.050;
     117    v.Layers[0].Sinus[4][2] = -0.750;
     118    v.Layers[0].Sinus[3][3] = 0.170;
     119    v.Layers[0].Sinus[4][3] = -0.690;
     120    v.Layers[0].Sinus[4][4] = -0.705;
     121    FILE *f;
     122    int l = MakeVTEC(&v, 0, obuffer, sizeof(obuffer));
     123    if(!l) fprintf(stderr, "BUILD ERROR\n");
     124    else
     125    {
     126      int nl, ns;
     127      struct VTEC vv;
     128
     129      if((f = fopen("outfile.raw", "ab+")))
     130      {
     131        fwrite(obuffer, l, 1, f);
     132        fclose(f);
     133      }
     134      else fprintf(stderr, "SAVE ERROR\n");
     135      //fwrite(obuffer, l, 1, stdout);
     136      memset(&vv, 0, sizeof(vv));
     137      nl = GetSSR(0, 0, &vv, 0, obuffer, l, &ns);
     138      if(nl < 0) fprintf(stderr, "EXTRACT ERROR %d\n", nl);
     139      else if(nl > 0) fprintf(stderr, "MULTIBLOCK UNSUPPORTED IN TEST\n");
     140      else if(ns != l) fprintf(stderr, "SIZE MISMATCH (%d/%d)\n", ns,l);
     141      else
     142      {
     143        int i, j, k;
     144        for(i = 0; i < vv.NumLayers; ++i)
     145        {
     146          printf("%d layer %d height %f degree %d order %d\n", vv.EpochTime,
     147          i, vv.Layers[i].Height, vv.Layers[i].Degree, vv.Layers[i].Order);
     148          for(j = 0; j <= vv.Layers[i].Degree; ++j)
     149          {
     150            printf("Cn%d ",j);
     151            for(k = 0; k <= vv.Layers[i].Order; ++k)
     152            {
     153              printf(" %7.3f",vv.Layers[i].Cosinus[k][j]);
     154            }
     155            printf("\n");
     156          }
     157          for(j = 0; j <= vv.Layers[i].Degree; ++j)
     158          {
     159            printf("Sn%d ",j);
     160            for(k = 0; k <= vv.Layers[i].Order; ++k)
     161            {
     162              printf(" %7.3f",vv.Layers[i].Sinus[k][j]);
     163            }
     164            printf("\n");
     165          }
     166        }
     167      }
     168    }
     169  }
     170  free(buffer);
    77171  return 0;
    78172}
Note: See TracChangeset for help on using the changeset viewer.