- Timestamp:
- Apr 14, 2010, 4:16:23 PM (15 years ago)
- Location:
- trunk
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/BNC/RTCM3/RTCM3coDecoder.cpp
r2425 r2427 282 282 _co.messageType == COTYPE_GLONASSURA ) { 283 283 QString line; 284 line.sprintf(" %3d % f",285 _co.Sat[ii].IOD, _co.Sat[ii].U serRangeAccuracy);284 line.sprintf(" %3d %d", 285 _co.Sat[ii].IOD, _co.Sat[ii].URA); 286 286 printLine(linePart+line, coTime); 287 287 } -
trunk/BNC/RTCM3/clock_orbit_rtcm.c
r2425 r2427 3 3 Name: clock_orbit_rtcm.c 4 4 Project: RTCM3 5 Version: $Id: clock_orbit_rtcm.c,v 1. 19 2010/04/14 13:11:26mervart Exp $5 Version: $Id: clock_orbit_rtcm.c,v 1.20 2010/04/14 14:13:45 mervart Exp $ 6 6 Authors: Dirk Stöcker 7 7 Description: state space approach for RTCM3 8 8 */ 9 9 10 #include <math.h>11 10 #include <stdio.h> 12 11 #include <string.h> … … 94 93 /* standard values */ 95 94 #define T_MESSAGE_NUMBER(a) ADDBITS(12, a) /* DF002 */ 96 #define T_RESERVED4 ADDBITS(1, 0) /* DF001 */97 95 #define T_RESERVED5 ADDBITS(5, 0) /* DF001 */ 98 96 #define T_GPS_SATELLITE_ID(a) ADDBITS(6, a) /* DF068 */ … … 107 105 #define T_DELTA_DOT_ALONG_TRACK(a) SCALEADDBITS(19, 250000.0, a) 108 106 #define T_DELTA_DOT_CROSS_TRACK(a) SCALEADDBITS(19, 250000.0, a) 107 #define T_DELTA_DOT_DOT_RADIAL(a) SCALEADDBITS(27, 50000000.0, a) 108 #define T_DELTA_DOT_DOT_ALONG_TRACK(a) SCALEADDBITS(25, 12500000.0, a) 109 #define T_DELTA_DOT_DOT_CROSS_TRACK(a) SCALEADDBITS(25, 12500000.0, a) 110 #define T_SATELLITE_REFERENCE_POINT(a) ADDBITS(1, a) 109 111 110 112 #define T_SATELLITE_REFERENCE_DATUM(a) ADDBITS(1, a) … … 115 117 #define T_GPS_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 116 118 #define T_GLONASS_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 119 #define T_GALILEO_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 117 120 #define T_CODE_BIAS(a) SCALEADDBITS(14, 100.0, a) 118 121 #define T_GLONASS_SATELLITE_ID(a) ADDBITS(5, a) … … 122 125 #define T_NO_OF_SATELLITES(a) ADDBITS(6, a) 123 126 #define T_MULTIPLE_MESSAGE_INDICATOR(a) ADDBITS(1, a) 124 #define T_SSR_URA(a) ADDBITS( 6, a)127 #define T_SSR_URA(a) ADDBITS(4, a) 125 128 #define T_HR_CLOCK_CORRECTION(a) SCALEADDBITS(22, 10000.0, a) 126 129 #define T_SSR_UPDATE_INTERVAL(a) ADDBITS(4, a) 127 128 static double URAToValue(int ura)129 {130 int urac, urav;131 urac = ura >> 3;132 urav = ura & 7;133 if(!ura)134 return 0;135 else if(ura == 63)136 return SSR_MAXURA;137 return (pow(3,urac)*(1.0+urav/4.0)-1.0)/1000.0;138 }139 140 static int ValueToURA(double val)141 {142 int ura;143 if(!val)144 return 0;145 else if(val > 5.4665)146 return 63;147 for(ura = 1; ura < 63 && val > URAToValue(ura); ++ura)148 ;149 return ura;150 }151 130 152 131 size_t MakeClockOrbit(const struct ClockOrbit *co, enum ClockOrbitType type, … … 205 184 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 206 185 --mmi; 207 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 208 T_RESERVED4 186 T_RESERVED5 209 187 T_NO_OF_SATELLITES(co->NumberOfGPSSat) 210 188 for(i = 0; i < co->NumberOfGPSSat; ++i) … … 218 196 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 219 197 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 198 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 199 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 200 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 201 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 202 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 220 203 } 221 204 ENDBLOCK … … 261 244 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi || */ left ? 1 : 0) 262 245 --mmi; 263 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 264 T_RESERVED4 246 T_RESERVED5 265 247 T_NO_OF_SATELLITES(nums) 266 248 for(i = start; i < start+nums; ++i) … … 274 256 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 275 257 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 258 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 259 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 260 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 261 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 262 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 276 263 T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0) 277 264 T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1) … … 313 300 { 314 301 T_GPS_SATELLITE_ID(co->Sat[i].ID) 315 T_SSR_URA( ValueToURA(co->Sat[i].UserRangeAccuracy))302 T_SSR_URA(co->Sat[i].URA) 316 303 } 317 304 ENDBLOCK … … 325 312 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 326 313 --mmi; 327 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 328 T_RESERVED4 314 T_RESERVED5 329 315 T_NO_OF_SATELLITES(co->NumberOfGLONASSSat) 330 316 for(i = CLOCKORBIT_NUMGPS; … … 339 325 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 340 326 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 327 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 328 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 329 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 330 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 331 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 341 332 } 342 333 ENDBLOCK … … 371 362 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 372 363 --mmi; 373 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 374 T_RESERVED4 364 T_RESERVED5 375 365 T_NO_OF_SATELLITES(co->NumberOfGLONASSSat) 376 366 for(i = CLOCKORBIT_NUMGPS; … … 385 375 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 386 376 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 377 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 378 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 379 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 380 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 381 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 387 382 T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0) 388 383 T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1) … … 422 417 { 423 418 T_GPS_SATELLITE_ID(co->Sat[i].ID) 424 T_SSR_URA( ValueToURA(co->Sat[i].UserRangeAccuracy))419 T_SSR_URA(co->Sat[i].URA) 425 420 } 426 421 ENDBLOCK … … 537 532 #define G_SIZE(a) GETBITS(a, 10) 538 533 #define G_MESSAGE_NUMBER(a) GETBITS(a, 12) /* DF002 */ 539 #define G_RESERVED4 SKIPBITS(4) /* DF001 */540 534 #define G_RESERVED5 SKIPBITS(5) /* DF001 */ 541 535 #define G_GPS_SATELLITE_ID(a) GETBITS(a, 6) /* DF068 */ … … 550 544 #define G_DELTA_DOT_ALONG_TRACK(a) GETFLOATSIGN(a, 19, 1/250000.0) 551 545 #define G_DELTA_DOT_CROSS_TRACK(a) GETFLOATSIGN(a, 19, 1/250000.0) 546 #define G_DELTA_DOT_DOT_RADIAL(a) GETFLOATSIGN(a, 27, 1/50000000.0) 547 #define G_DELTA_DOT_DOT_ALONG_TRACK(a) GETFLOATSIGN(a, 25, 1/12500000.0) 548 #define G_DELTA_DOT_DOT_CROSS_TRACK(a) GETFLOATSIGN(a, 25, 1/12500000.0) 549 #define G_SATELLITE_REFERENCE_POINT(a) GETBITS(a, 1) 552 550 553 551 #define G_SATELLITE_REFERENCE_DATUM(a) GETBITS(a, 1) … … 558 556 #define G_GPS_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 559 557 #define G_GLONASS_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 558 #define G_GALILEO_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 560 559 #define G_CODE_BIAS(a) GETFLOATSIGN(a, 14, 1/100.0) 561 560 #define G_GLONASS_SATELLITE_ID(a) GETBITS(a, 5) … … 567 566 #define G_NO_OF_SATELLITES(a) GETBITS(a, 6) 568 567 #define G_MULTIPLE_MESSAGE_INDICATOR(a) GETBITS(a, 1) 569 #define G_SSR_URA(a) {int temp; GETBITS(temp, 6) \ 570 (a) = URAToValue(temp);} 568 #define G_SSR_URA(a) GETBITS(a, 4) 571 569 #define G_HR_CLOCK_CORRECTION(a) GETFLOATSIGN(a, 22, 1/10000.0) 572 570 #define G_SSR_UPDATE_INTERVAL(a) GETBITS(a, 4) … … 616 614 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 617 615 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 618 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 619 G_RESERVED4 616 G_RESERVED5 620 617 G_NO_OF_SATELLITES(nums) 621 618 co->OrbitDataSupplied |= 1; 622 619 #ifdef DEBUG 623 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GPSEpochTime,624 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums , co->SatRefDatum);620 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GPSEpochTime, 621 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums); 625 622 #endif 626 623 for(i = 0; i < nums; ++i) … … 640 637 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 641 638 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 642 #ifdef DEBUG 643 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", 639 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 640 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 641 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 642 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 643 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 644 #ifdef DEBUG 645 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f rp %d rd %d\n", 644 646 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial, 645 647 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack, 646 648 co->Sat[pos].Orbit.DotDeltaRadial, 647 649 co->Sat[pos].Orbit.DotDeltaAlongTrack, 648 co->Sat[pos].Orbit.DotDeltaCrossTrack); 650 co->Sat[pos].Orbit.DotDeltaCrossTrack, 651 co->Sat[pos].Orbit.DotDotDeltaRadial, 652 co->Sat[pos].Orbit.DotDotDeltaAlongTrack, 653 co->Sat[pos].Orbit.DotDotDeltaCrossTrack, 654 co->SatRefPoint, 655 co->SatRefDatum); 649 656 #endif 650 657 } … … 692 699 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 693 700 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 694 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 695 G_RESERVED4 701 G_RESERVED5 696 702 G_NO_OF_SATELLITES(nums) 697 703 co->OrbitDataSupplied |= 1; … … 713 719 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 714 720 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 721 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 722 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 723 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 724 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 725 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 715 726 G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0) 716 727 G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1) … … 737 748 co->Sat[pos].ID = id; 738 749 739 G_SSR_URA(co->Sat[pos].U serRangeAccuracy)750 G_SSR_URA(co->Sat[pos].URA) 740 751 } 741 752 break; … … 769 780 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 770 781 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 771 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 772 G_RESERVED4 782 G_RESERVED5 773 783 G_NO_OF_SATELLITES(nums) 774 784 co->OrbitDataSupplied |= 2; 775 785 #ifdef DEBUG 776 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GLONASSEpochTime,777 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums , co->SatRefDatum);786 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GLONASSEpochTime, 787 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums); 778 788 #endif 779 789 for(i = 0; i < nums; ++i) … … 793 803 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 794 804 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 795 #ifdef DEBUG 796 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", 805 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 806 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 807 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 808 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 809 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 810 #ifdef DEBUG 811 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f rp %d rd %d\n", 797 812 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial, 798 813 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack, 799 814 co->Sat[pos].Orbit.DotDeltaRadial, 800 815 co->Sat[pos].Orbit.DotDeltaAlongTrack, 801 co->Sat[pos].Orbit.DotDeltaCrossTrack); 816 co->Sat[pos].Orbit.DotDeltaCrossTrack, 817 co->Sat[pos].Orbit.DotDotDeltaRadial, 818 co->Sat[pos].Orbit.DotDotDeltaAlongTrack, 819 co->Sat[pos].Orbit.DotDotDeltaCrossTrack, 820 co->SatRefPoint, 821 co->SatRefDatum); 802 822 #endif 803 823 } … … 841 861 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 842 862 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 843 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 844 G_RESERVED4 863 G_RESERVED5 845 864 G_NO_OF_SATELLITES(nums) 846 865 co->OrbitDataSupplied |= 2; … … 862 881 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 863 882 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 883 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 884 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 885 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 886 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 887 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 864 888 G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0) 865 889 G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1) … … 884 908 co->Sat[pos].ID = id; 885 909 886 G_SSR_URA(co->Sat[pos].U serRangeAccuracy)910 G_SSR_URA(co->Sat[pos].URA) 887 911 } 888 912 break; -
trunk/BNC/RTCM3/clock_orbit_rtcm.h
r2425 r2427 6 6 Name: clock_orbit_rtcm.h 7 7 Project: RTCM3 8 Version: $Id: clock_orbit_rtcm.h,v 1.1 4 2010/04/14 13:11:26mervart Exp $8 Version: $Id: clock_orbit_rtcm.h,v 1.15 2010/04/14 14:13:45 mervart Exp $ 9 9 Authors: Dirk Stöcker 10 10 Description: state space approach for RTCM3 … … 14 14 15 15 enum SatelliteReferenceDatum { DATUM_ITRF=0, DATUM_LOCAL=1 }; 16 enum SatelliteReferencePoint { POINT_IONOFREE=0, POINT_CENTER=1 }; 16 17 enum ClockOrbitType { 17 18 COTYPE_GPSORBIT=1057, COTYPE_GPSCLOCK=1058, … … 45 46 }; 46 47 47 #define SSR_MAXURA 5.5 /* > 5466.5mm in meter */48 49 48 /* GLONASS data is stored with offset CLOCKORBIT_NUMGPS in the data structures. 50 49 So first GLONASS satellite is at xxx->Sat[CLOCKORBIT_NUMGPS], first … … 65 64 int epochSize; /* Weber, for latency */ 66 65 int UpdateInterval; 66 enum SatelliteReferencePoint SatRefPoint; 67 67 enum SatelliteReferenceDatum SatRefDatum; 68 68 struct SatData { 69 69 int ID; /* GPS or GLONASS */ 70 70 int IOD; /* GPS or GLONASS */ 71 double UserRangeAccuracy; /* accuracy values in [m] */71 int URA; 72 72 double hrclock; 73 73 struct OrbitPart … … 79 79 double DotDeltaAlongTrack; /* m/s */ 80 80 double DotDeltaCrossTrack; /* m/s */ 81 double DotDotDeltaRadial; /* m/ss */ 82 double DotDotDeltaAlongTrack; /* m/ss */ 83 double DotDotDeltaCrossTrack; /* m/ss */ 81 84 } Orbit; 82 85 struct ClockPart -
trunk/BNS/RTCM/clock_orbit_rtcm.c
r2424 r2427 3 3 Name: clock_orbit_rtcm.c 4 4 Project: RTCM3 5 Version: $Id: clock_orbit_rtcm.c,v 1.1 0 2010/04/14 11:09:18 stoeckerExp $5 Version: $Id: clock_orbit_rtcm.c,v 1.19 2010/02/23 07:41:07 mervart Exp $ 6 6 Authors: Dirk Stöcker 7 7 Description: state space approach for RTCM3 8 8 */ 9 9 10 #include <math.h>11 10 #include <stdio.h> 12 11 #include <string.h> … … 94 93 /* standard values */ 95 94 #define T_MESSAGE_NUMBER(a) ADDBITS(12, a) /* DF002 */ 96 #define T_RESERVED4 ADDBITS(1, 0) /* DF001 */97 95 #define T_RESERVED5 ADDBITS(5, 0) /* DF001 */ 98 96 #define T_GPS_SATELLITE_ID(a) ADDBITS(6, a) /* DF068 */ … … 107 105 #define T_DELTA_DOT_ALONG_TRACK(a) SCALEADDBITS(19, 250000.0, a) 108 106 #define T_DELTA_DOT_CROSS_TRACK(a) SCALEADDBITS(19, 250000.0, a) 107 #define T_DELTA_DOT_DOT_RADIAL(a) SCALEADDBITS(27, 50000000.0, a) 108 #define T_DELTA_DOT_DOT_ALONG_TRACK(a) SCALEADDBITS(25, 12500000.0, a) 109 #define T_DELTA_DOT_DOT_CROSS_TRACK(a) SCALEADDBITS(25, 12500000.0, a) 110 #define T_SATELLITE_REFERENCE_POINT(a) ADDBITS(1, a) 109 111 110 112 #define T_SATELLITE_REFERENCE_DATUM(a) ADDBITS(1, a) … … 115 117 #define T_GPS_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 116 118 #define T_GLONASS_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 119 #define T_GALILEO_SIGNAL_IDENTIFIER(a) ADDBITS(5, a) 117 120 #define T_CODE_BIAS(a) SCALEADDBITS(14, 100.0, a) 118 121 #define T_GLONASS_SATELLITE_ID(a) ADDBITS(5, a) … … 122 125 #define T_NO_OF_SATELLITES(a) ADDBITS(6, a) 123 126 #define T_MULTIPLE_MESSAGE_INDICATOR(a) ADDBITS(1, a) 124 #define T_SSR_URA(a) ADDBITS( 6, a)127 #define T_SSR_URA(a) ADDBITS(4, a) 125 128 #define T_HR_CLOCK_CORRECTION(a) SCALEADDBITS(22, 10000.0, a) 126 129 #define T_SSR_UPDATE_INTERVAL(a) ADDBITS(4, a) 127 128 static double URAToValue(int ura)129 {130 int urac, urav;131 urac = ura >> 3;132 urav = ura & 7;133 if(!ura)134 return 0;135 else if(ura == 63)136 return SSR_MAXURA;137 return (pow(3,urac)*(1.0+urav/4.0)-1.0)/1000.0;138 }139 140 static int ValueToURA(double val)141 {142 int ura;143 if(!val)144 return 0;145 else if(val > 5.4665)146 return 63;147 for(ura = 1; ura < 63 && val > URAToValue(ura); ++ura)148 ;149 return ura;150 }151 130 152 131 size_t MakeClockOrbit(const struct ClockOrbit *co, enum ClockOrbitType type, … … 205 184 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 206 185 --mmi; 207 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 208 T_RESERVED4 186 T_RESERVED5 209 187 T_NO_OF_SATELLITES(co->NumberOfGPSSat) 210 188 for(i = 0; i < co->NumberOfGPSSat; ++i) … … 218 196 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 219 197 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 198 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 199 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 200 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 201 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 202 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 220 203 } 221 204 ENDBLOCK … … 261 244 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi || */ left ? 1 : 0) 262 245 --mmi; 263 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 264 T_RESERVED4 246 T_RESERVED5 265 247 T_NO_OF_SATELLITES(nums) 266 248 for(i = start; i < start+nums; ++i) … … 274 256 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 275 257 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 258 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 259 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 260 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 261 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 262 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 276 263 T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0) 277 264 T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1) … … 313 300 { 314 301 T_GPS_SATELLITE_ID(co->Sat[i].ID) 315 T_SSR_URA( ValueToURA(co->Sat[i].UserRangeAccuracy))302 T_SSR_URA(co->Sat[i].URA) 316 303 } 317 304 ENDBLOCK … … 325 312 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 326 313 --mmi; 327 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 328 T_RESERVED4 314 T_RESERVED5 329 315 T_NO_OF_SATELLITES(co->NumberOfGLONASSSat) 330 316 for(i = CLOCKORBIT_NUMGPS; … … 339 325 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 340 326 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 327 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 328 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 329 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 330 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 331 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 341 332 } 342 333 ENDBLOCK … … 371 362 T_MULTIPLE_MESSAGE_INDICATOR(/*mmi ? 1 :*/0) 372 363 --mmi; 373 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 374 T_RESERVED4 364 T_RESERVED5 375 365 T_NO_OF_SATELLITES(co->NumberOfGLONASSSat) 376 366 for(i = CLOCKORBIT_NUMGPS; … … 385 375 T_DELTA_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDeltaAlongTrack) 386 376 T_DELTA_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDeltaCrossTrack) 377 T_DELTA_DOT_DOT_RADIAL(co->Sat[i].Orbit.DotDotDeltaRadial) 378 T_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[i].Orbit.DotDotDeltaAlongTrack) 379 T_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[i].Orbit.DotDotDeltaCrossTrack) 380 T_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 381 T_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 387 382 T_DELTA_CLOCK_C0(co->Sat[i].Clock.DeltaA0) 388 383 T_DELTA_CLOCK_C1(co->Sat[i].Clock.DeltaA1) … … 422 417 { 423 418 T_GPS_SATELLITE_ID(co->Sat[i].ID) 424 T_SSR_URA( ValueToURA(co->Sat[i].UserRangeAccuracy))419 T_SSR_URA(co->Sat[i].URA) 425 420 } 426 421 ENDBLOCK … … 537 532 #define G_SIZE(a) GETBITS(a, 10) 538 533 #define G_MESSAGE_NUMBER(a) GETBITS(a, 12) /* DF002 */ 539 #define G_RESERVED4 SKIPBITS(4) /* DF001 */540 534 #define G_RESERVED5 SKIPBITS(5) /* DF001 */ 541 535 #define G_GPS_SATELLITE_ID(a) GETBITS(a, 6) /* DF068 */ … … 550 544 #define G_DELTA_DOT_ALONG_TRACK(a) GETFLOATSIGN(a, 19, 1/250000.0) 551 545 #define G_DELTA_DOT_CROSS_TRACK(a) GETFLOATSIGN(a, 19, 1/250000.0) 546 #define G_DELTA_DOT_DOT_RADIAL(a) GETFLOATSIGN(a, 27, 1/50000000.0) 547 #define G_DELTA_DOT_DOT_ALONG_TRACK(a) GETFLOATSIGN(a, 25, 1/12500000.0) 548 #define G_DELTA_DOT_DOT_CROSS_TRACK(a) GETFLOATSIGN(a, 25, 1/12500000.0) 549 #define G_SATELLITE_REFERENCE_POINT(a) GETBITS(a, 1) 552 550 553 551 #define G_SATELLITE_REFERENCE_DATUM(a) GETBITS(a, 1) … … 558 556 #define G_GPS_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 559 557 #define G_GLONASS_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 558 #define G_GALILEO_SIGNAL_IDENTIFIER(a) GETBITS(a, 5) 560 559 #define G_CODE_BIAS(a) GETFLOATSIGN(a, 14, 1/100.0) 561 560 #define G_GLONASS_SATELLITE_ID(a) GETBITS(a, 5) … … 567 566 #define G_NO_OF_SATELLITES(a) GETBITS(a, 6) 568 567 #define G_MULTIPLE_MESSAGE_INDICATOR(a) GETBITS(a, 1) 569 #define G_SSR_URA(a) {int temp; GETBITS(temp, 6) \ 570 (a) = URAToValue(temp);} 568 #define G_SSR_URA(a) GETBITS(a, 4) 571 569 #define G_HR_CLOCK_CORRECTION(a) GETFLOATSIGN(a, 22, 1/10000.0) 572 570 #define G_SSR_UPDATE_INTERVAL(a) GETBITS(a, 4) … … 616 614 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 617 615 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 618 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 619 G_RESERVED4 616 G_RESERVED5 620 617 G_NO_OF_SATELLITES(nums) 621 618 co->OrbitDataSupplied |= 1; 622 619 #ifdef DEBUG 623 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GPSEpochTime,624 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums , co->SatRefDatum);620 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GPSEpochTime, 621 co->UpdateInterval,mmi,co->NumberOfGPSSat,nums); 625 622 #endif 626 623 for(i = 0; i < nums; ++i) … … 640 637 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 641 638 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 642 #ifdef DEBUG 643 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", 639 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 640 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 641 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 642 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 643 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 644 #ifdef DEBUG 645 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f rp %d rd %d\n", 644 646 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial, 645 647 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack, 646 648 co->Sat[pos].Orbit.DotDeltaRadial, 647 649 co->Sat[pos].Orbit.DotDeltaAlongTrack, 648 co->Sat[pos].Orbit.DotDeltaCrossTrack); 650 co->Sat[pos].Orbit.DotDeltaCrossTrack, 651 co->Sat[pos].Orbit.DotDotDeltaRadial, 652 co->Sat[pos].Orbit.DotDotDeltaAlongTrack, 653 co->Sat[pos].Orbit.DotDotDeltaCrossTrack, 654 co->SatRefPoint, 655 co->SatRefDatum); 649 656 #endif 650 657 } … … 692 699 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 693 700 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 694 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 695 G_RESERVED4 701 G_RESERVED5 696 702 G_NO_OF_SATELLITES(nums) 697 703 co->OrbitDataSupplied |= 1; … … 713 719 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 714 720 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 721 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 722 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 723 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 724 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 725 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 715 726 G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0) 716 727 G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1) … … 737 748 co->Sat[pos].ID = id; 738 749 739 G_SSR_URA(co->Sat[pos].U serRangeAccuracy)750 G_SSR_URA(co->Sat[pos].URA) 740 751 } 741 752 break; … … 769 780 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 770 781 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 771 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 772 G_RESERVED4 782 G_RESERVED5 773 783 G_NO_OF_SATELLITES(nums) 774 784 co->OrbitDataSupplied |= 2; 775 785 #ifdef DEBUG 776 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d rd %d\n",co->GLONASSEpochTime,777 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums , co->SatRefDatum);786 fprintf(stderr, "epochtime %d ui %d mmi %d sats %d/%d\n",co->GLONASSEpochTime, 787 co->UpdateInterval,mmi,co->NumberOfGLONASSSat,nums); 778 788 #endif 779 789 for(i = 0; i < nums; ++i) … … 793 803 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 794 804 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 795 #ifdef DEBUG 796 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", 805 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 806 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 807 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 808 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 809 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 810 #ifdef DEBUG 811 fprintf(stderr, "id %2d iod %3d dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f dr %8.3f da %8.3f dc %8.3f rp %d rd %d\n", 797 812 co->Sat[pos].ID,co->Sat[pos].IOD,co->Sat[pos].Orbit.DeltaRadial, 798 813 co->Sat[pos].Orbit.DeltaAlongTrack,co->Sat[pos].Orbit.DeltaCrossTrack, 799 814 co->Sat[pos].Orbit.DotDeltaRadial, 800 815 co->Sat[pos].Orbit.DotDeltaAlongTrack, 801 co->Sat[pos].Orbit.DotDeltaCrossTrack); 816 co->Sat[pos].Orbit.DotDeltaCrossTrack, 817 co->Sat[pos].Orbit.DotDotDeltaRadial, 818 co->Sat[pos].Orbit.DotDotDeltaAlongTrack, 819 co->Sat[pos].Orbit.DotDotDeltaCrossTrack, 820 co->SatRefPoint, 821 co->SatRefDatum); 802 822 #endif 803 823 } … … 841 861 G_SSR_UPDATE_INTERVAL(co->UpdateInterval) 842 862 G_MULTIPLE_MESSAGE_INDICATOR(mmi) 843 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 844 G_RESERVED4 863 G_RESERVED5 845 864 G_NO_OF_SATELLITES(nums) 846 865 co->OrbitDataSupplied |= 2; … … 862 881 G_DELTA_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDeltaAlongTrack) 863 882 G_DELTA_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDeltaCrossTrack) 883 G_DELTA_DOT_DOT_RADIAL(co->Sat[pos].Orbit.DotDotDeltaRadial) 884 G_DELTA_DOT_DOT_ALONG_TRACK(co->Sat[pos].Orbit.DotDotDeltaAlongTrack) 885 G_DELTA_DOT_DOT_CROSS_TRACK(co->Sat[pos].Orbit.DotDotDeltaCrossTrack) 886 G_SATELLITE_REFERENCE_POINT(co->SatRefPoint) 887 G_SATELLITE_REFERENCE_DATUM(co->SatRefDatum) 864 888 G_DELTA_CLOCK_C0(co->Sat[pos].Clock.DeltaA0) 865 889 G_DELTA_CLOCK_C1(co->Sat[pos].Clock.DeltaA1) … … 884 908 co->Sat[pos].ID = id; 885 909 886 G_SSR_URA(co->Sat[pos].U serRangeAccuracy)910 G_SSR_URA(co->Sat[pos].URA) 887 911 } 888 912 break; -
trunk/BNS/RTCM/clock_orbit_rtcm.h
r2424 r2427 6 6 Name: clock_orbit_rtcm.h 7 7 Project: RTCM3 8 Version: $Id: clock_orbit_rtcm.h,v 1. 8 2010/04/14 11:09:18 stoeckerExp $8 Version: $Id: clock_orbit_rtcm.h,v 1.14 2010/03/11 10:50:05 mervart Exp $ 9 9 Authors: Dirk Stöcker 10 10 Description: state space approach for RTCM3 … … 14 14 15 15 enum SatelliteReferenceDatum { DATUM_ITRF=0, DATUM_LOCAL=1 }; 16 enum SatelliteReferencePoint { POINT_IONOFREE=0, POINT_CENTER=1 }; 16 17 enum ClockOrbitType { 17 18 COTYPE_GPSORBIT=1057, COTYPE_GPSCLOCK=1058, … … 45 46 }; 46 47 47 #define SSR_MAXURA 5.5 /* > 5466.5mm in meter */48 49 48 /* GLONASS data is stored with offset CLOCKORBIT_NUMGPS in the data structures. 50 49 So first GLONASS satellite is at xxx->Sat[CLOCKORBIT_NUMGPS], first … … 65 64 int epochSize; /* Weber, for latency */ 66 65 int UpdateInterval; 66 enum SatelliteReferencePoint SatRefPoint; 67 67 enum SatelliteReferenceDatum SatRefDatum; 68 68 struct SatData { 69 69 int ID; /* GPS or GLONASS */ 70 70 int IOD; /* GPS or GLONASS */ 71 double UserRangeAccuracy; /* accuracy values in [m] */71 int URA; 72 72 double hrclock; 73 73 struct OrbitPart … … 79 79 double DotDeltaAlongTrack; /* m/s */ 80 80 double DotDeltaCrossTrack; /* m/s */ 81 double DotDotDeltaRadial; /* m/ss */ 82 double DotDotDeltaAlongTrack; /* m/ss */ 83 double DotDotDeltaCrossTrack; /* m/ss */ 81 84 } Orbit; 82 85 struct ClockPart -
trunk/BNS/bns.cpp
r2424 r2427 476 476 ++bias.NumberOfGPSSat; 477 477 } 478 //else if (prn[0] == 'R') {479 //biasSat = bias.Sat + CLOCKORBIT_NUMGPS + bias.NumberOfGLONASSSat;480 //++bias.NumberOfGLONASSSat;481 //}478 else if (prn[0] == 'R') { 479 biasSat = bias.Sat + CLOCKORBIT_NUMGPS + bias.NumberOfGLONASSSat; 480 ++bias.NumberOfGLONASSSat; 481 } 482 482 483 483 // Coefficient of Ionosphere-Free LC
Note:
See TracChangeset
for help on using the changeset viewer.