Changeset 9205 in ntrip for branches/BNC_2.12/src/RTCM3


Ignore:
Timestamp:
Nov 3, 2020, 1:15:38 PM (4 years ago)
Author:
stuerze
Message:

ephemeris checks + debugging output added

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/BNC_2.12/src/RTCM3/RTCM3Decoder.cpp

    r9193 r9205  
    936936    if ((i & ((1 << 20) - 1)) != 0x80000) {
    937937      frqObs->_code = l1range * 0.02;
    938       frqObs->_phase = (l1range * 0.02 + i * 0.0005)
    939           / GLO_WAVELENGTH_L1(freq - 7);
     938      frqObs->_phase = (l1range * 0.02 + i * 0.0005) / GLO_WAVELENGTH_L1(freq - 7);
    940939      frqObs->_codeValid = frqObs->_phaseValid = true;
    941940    }
     
    10471046    GETFLOATSIGN(eph._Cus, 16, 1.0 / (double )(1 << 29))
    10481047    GETFLOAT(eph._sqrt_A, 32, 1.0 / (double )(1 << 19))
    1049     if (eph._sqrt_A < 1000.0) {return false;}
     1048    if (eph._sqrt_A < 1000.0) {
     1049      emit(newMessage(QString("%1: Block %2 (%3) SQRT_A %4 m!")
     1050           .arg(_staID).arg(1020,4).arg(eph._prn.toString().c_str())
     1051           .arg(eph._sqrt_A,10,'F',3).toAscii(), true));
     1052      return false;
     1053    }
    10501054    GETBITS(i, 16)
    10511055    i <<= 4;
     
    11021106    GETBITS(eph._almanac_health, 1) /* almanac healthy */
    11031107    GETBITS(eph._almanac_health_availablility_indicator, 1) /* almanac health ok */
    1104     if (eph._almanac_health_availablility_indicator == 0.0) {return false;}
     1108    if (eph._almanac_health_availablility_indicator == 0.0) {
     1109      emit(newMessage(QString("%1: Block %2 (%3): ALM = %4: missing data!")
     1110           .arg(_staID).arg(1019,4).arg(eph._prn.toString().c_str())
     1111           .arg(eph._almanac_health_availablility_indicator).toAscii(), true));
     1112      return false;
     1113    }
    11051114    GETBITS(eph._P1, 2) /*  P1 */
    11061115    GETBITS(i, 5)
     
    11381147    GETBITS(eph._M_FT, 4) /* GLONASS-M Ft */
    11391148    GETBITS(eph._M_NT, 11) /* GLONASS-M Nt */
    1140     if (eph._M_NT == 0.0) {return false;}
     1149    if (eph._M_NT == 0.0) {
     1150      emit(newMessage(QString("%1: Block %2 (%3): NT = %4: missing data!")
     1151           .arg(_staID).arg(1019,4).arg(eph._prn.toString().c_str()).arg(eph._M_NT,4).toAscii(), true));
     1152      return false;
     1153    }
    11411154    GETBITS(eph._M_M, 2) /* GLONASS-M M */
    11421155    GETBITS(eph._additional_data_availability, 1) /* GLONASS-M The Availability of Additional Data */
    1143     if (eph._additional_data_availability == 0.0) {return false;}
     1156    if (eph._additional_data_availability == 0.0) {
     1157      emit(newMessage(QString("%1: Block %2 (%3): ADD = %4: missing data!")
     1158           .arg(_staID).arg(1019,4).arg(eph._prn.toString().c_str())
     1159           .arg(eph._additional_data_availability).toAscii(), true));
     1160      return false;
     1161    }
    11441162    GETBITS(eph._NA, 11) /* GLONASS-M Na */
    11451163    GETFLOATSIGNM(eph._tauC, 32, 1.0/(double)(1<<30)/(double)(1<<1)) /* GLONASS tau c */
     
    11561174    eph._xv(2) = eph._y_pos * 1.e3;
    11571175    eph._xv(3) = eph._z_pos * 1.e3;
     1176    if (eph._xv.Rows(1,3).NormFrobenius() < 1.0) {
     1177      emit(newMessage(QString("%1: Block %2 (%3): zero position!")
     1178           .arg(_staID).arg(1019,4).arg(eph._prn.toString().c_str()).toAscii(), true));
     1179      return false;
     1180    }
    11581181    eph._xv(4) = eph._x_velocity * 1.e3;
    11591182    eph._xv(5) = eph._y_velocity * 1.e3;
    11601183    eph._xv(6) = eph._z_velocity * 1.e3;
    1161 
     1184    if (eph._xv.Rows(4,6).NormFrobenius() < 1.0) {
     1185      emit(newMessage(QString("%1: Block %2 (%3): zero velocity!")
     1186           .arg(_staID).arg(1019,4).arg(eph._prn.toString().c_str()).toAscii(), true));
     1187      return false;
     1188    }
    11621189    GLOFreq[sv - 1] = 100 + eph._frequency_number ; /* store frequency for other users (MSM) */
    11631190    _gloFrq = QString("%1 %2").arg(eph._prn.toString().c_str()).arg(eph._frequency_number, 2, 'f', 0);
     
    12041231    GETFLOATSIGN(eph._Cus, 16, 1.0 / (double )(1 << 29))
    12051232    GETFLOAT(eph._sqrt_A, 32, 1.0 / (double )(1 << 19))
    1206     if (eph._sqrt_A < 1000.0) {return false;}
     1233    if (eph._sqrt_A < 1000.0) {
     1234      emit(newMessage(QString("%1: Block %2 (%3) SQRT_A %4 m!")
     1235           .arg(_staID).arg(1044,4).arg(eph._prn.toString().c_str())
     1236           .arg(eph._sqrt_A,10,'F',3).toAscii(), true));
     1237      return false;
     1238    }
    12071239    GETBITS(i, 16)
    12081240    i <<= 4;
     
    13131345    GETFLOAT(eph._e,            32, 1.0 / (double )(1 << 30) / (double )(1 << 3))
    13141346    GETFLOAT(eph._sqrt_A,       32, 1.0 / (double )(1 << 19))
    1315     if (eph._sqrt_A < 1000.0) {return false;}
     1347    if (eph._sqrt_A < 1000.0) {
     1348      emit(newMessage(QString("%1: Block %2 (%3) SQRT_A %4 m!")
     1349           .arg(_staID).arg(1041,4).arg(eph._prn.toString().c_str())
     1350           .arg(eph._sqrt_A,10,'F',3).toAscii(), true));
     1351      return false;
     1352    }
    13161353    GETFLOATSIGN(eph._OMEGA0,   32, R2R_PI/(double)(1<<30)/(double)(1<< 1))
    13171354    GETFLOATSIGN(eph._omega,    32, R2R_PI/(double)(1<<30)/(double)(1<< 1))
     
    13551392    GETFLOATSIGN(eph._y_pos, 30, 0.08)
    13561393    GETFLOATSIGN(eph._z_pos, 25, 0.4)
     1394    ColumnVector pos(3);
     1395    pos(1) = eph._x_pos; pos(2) = eph._y_pos; pos(3) = eph._z_pos;
     1396    if (pos.NormFrobenius() < 1.0) {
     1397      emit(newMessage(QString("%1: Block %2 (%3): zero position!")
     1398           .arg(_staID).arg(1043,4).arg(eph._prn.toString().c_str()).toAscii(), true));
     1399      return false;
     1400    }
    13571401    GETFLOATSIGN(eph._x_velocity, 17, 0.000625)
    13581402    GETFLOATSIGN(eph._y_velocity, 17, 0.000625)
     
    14111455    GETFLOATSIGN(eph._Cus, 16, 1.0 / (double )(1 << 29))
    14121456    GETFLOAT(eph._sqrt_A, 32, 1.0 / (double )(1 << 19))
    1413     if (eph._sqrt_A < 1000.0) {return false;}
    14141457    GETBITSFACTOR(eph._TOEsec, 14, 60)
    14151458    /* FIXME: overwrite value, copied from old code */
     
    14341477      GETBITS(eph._e1DataInValid, 1)
    14351478      if (eph._E5bHS != eph._E1_bHS) {
     1479        emit(newMessage(QString("%1: Block %2 (%3) SHS E5b %4 E1B %5: inconsistent health!")
     1480             .arg(_staID).arg(1046,4).arg(eph._prn.toString().c_str())
     1481             .arg(eph._E5bHS).arg(eph._E1_bHS).toAscii(), true));
    14361482        return false;
    14371483      }
    14381484      if ((eph._BGD_1_5A == 0.0 && fabs(eph._BGD_1_5B) > 1e-9) ||
    14391485          (eph._BGD_1_5B == 0.0 && fabs(eph._BGD_1_5A) > 1e-9)) {
     1486        emit(newMessage(QString("%1: Block %2 (%3) BGD_15a = %4 BGD_15b = %5: inconsistent BGD!")
     1487             .arg(_staID).arg(1046,4).arg(eph._prn.toString().c_str())
     1488             .arg(eph._BGD_1_5A,10,'E',3).arg(eph._BGD_1_5B,10,'E',3).toAscii(), true));
    14401489        return false;
    14411490      }
     
    14531502    }
    14541503    eph._TOT = 0.9999e9;
     1504
     1505    if (eph._sqrt_A < 1000.0) {
     1506      emit(newMessage(QString("%1: Block %2 (%3) SQRT_A %4 m!")
     1507           .arg(_staID).arg(eph._inav? 1046 : 1045,4).arg(eph._prn.toString().c_str())
     1508           .arg(eph._sqrt_A,10,'F',3).toLatin1(), true));
     1509      return false;
     1510    }
    14551511
    14561512    emit newGalileoEph(eph);
     
    14991555    GETFLOATSIGN(eph._Cus, 18, 1.0 / (double )(1 << 30) / (double )(1 << 1))
    15001556    GETFLOAT(eph._sqrt_A, 32, 1.0 / (double )(1 << 19))
    1501         if (eph._sqrt_A < 1000.0) {return false;}
    1502         GETBITS(i, 17)
     1557    if (eph._sqrt_A < 1000.0) {
     1558      emit(newMessage(QString("%1: Block %2 (%3) SQRT_A %4 m!")
     1559           .arg(_staID).arg(1042,4).arg(eph._prn.toString().c_str())
     1560           .arg(eph._sqrt_A,10,'F',3).toAscii(), true));
     1561      return false;
     1562    }
     1563          GETBITS(i, 17)
    15031564    i <<= 3;
    15041565    eph._TOEsec = i;
     
    16921753          case 1045:
    16931754          case 1046:
    1694             // reject 1045/1046 from JAXA RTKLIB encoded stations
    16951755            if (_staID.contains("AIRA") || _staID.contains("STK2") ||
    16961756                _staID.contains("CCJ2") || _staID.contains("SYOG")) {
     1757              emit(newMessage(QString("%1: Block temporary %2 from JAXA RTKLIB encoded stations!")
     1758                   .arg(_staID).arg(id).toAscii(), true));
    16971759              break;
    16981760            }
     
    17251787uint32_t RTCM3Decoder::CRC24(long size, const unsigned char *buf) {
    17261788  uint32_t crc = 0;
    1727   int i;
    1728 
    1729   while (size--) {
     1789  int ii;
     1790 while (size--) {
    17301791    crc ^= (*buf++) << (16);
    1731     for (i = 0; i < 8; i++) {
     1792    for (ii = 0; ii < 8; ii++) {
    17321793      crc <<= 1;
    17331794      if (crc & 0x1000000)
Note: See TracChangeset for help on using the changeset viewer.