4 <meta http-equiv=
"content-type" content=
"text/html;charset=iso-8859-1">
5 <title>MX4200 Receiver Data Format
</title>
6 <link href=
"scripts/style.css" type=
"text/css" rel=
"stylesheet">
10 <h1>MX4200 Receiver Data Format
</h1>
12 <h2>Table of Contents
</h2>
14 <li><a href=
"#control">Control Port Sentences
</a>
15 <li><a href=
"#input">Control Port Input Sentences
</a>
17 <li><a href=
"#input_000">$PMVXG,
000</a> Initialization/Mode Control - Part A
18 <li><a href=
"#input_001">$PMVXG,
001</a> Initialization/Mode Control - Part B
19 <li><a href=
"#input_007">$PMVXG,
007</a> Control Port Configuration
20 <li><a href=
"#input_023">$PMVXG,
023</a> Time Recovery Configuration
21 <li><a href=
"#input_gpq">$CDGPQ,YYY
</a> Query From a Remote Device / Request to Output a Sentence
23 <li><a href=
"#output">Control Port Output Sentences
</a>
25 <li><a href=
"#output_000">$PMVXG,
000</a> Receiver Status
26 <li><a href=
"#output_021">$PMVXG,
021</a> Position, Height, Velocity
27 <li><a href=
"#output_022">$PMVXG,
022</a> DOPs
28 <li><a href=
"#output_030">$PMVXG,
030</a> Software Configuration
29 <li><a href=
"#output_101">$PMVXG,
101</a> Control Sentence Accept/Reject
30 <li><a href=
"#output_523">$PMVXG,
523</a> Time Recovery Configuration
31 <li><a href=
"#output_830">$PMVXG,
830</a> Time Recovery Results
35 <h2><a name=
"control">Control Port Sentences
</a></h2>
36 <p>The Control (CDU) Port is used to initialize, monitor, and control the receiver. The structure of the control port sentences is based on the
<cite>NMEA-
0183</cite> Standard for Interfacing Marine Electronics Navigation Devices (version
1.5). For more details, please refer to the
<cite>NMEA-
0183</cite> Specification available from the
<a href=
"http://www.nmea.org/">National Marine Electronics Association
</a>.
</p>
37 <p>Reserved characters are used to indicate the beginning and the end of records in the data stream, and to delimit data fields within a sentence. Only printable ASCII characters (Hex
20 through
7F) may be used in a sentence.
<a href=
"#table_2">Table
2</a> lists the reserved characters and defines their usage.
<a href=
"#table_1">Table
1</a> illustrates the general Magnavox proprietary NMEA sentence format.
</p>
38 <h4><a name=
"table_1">Table
1. Magnavox Proprietary NMEA Sentence Format
</a></h4>
39 <code>$PMVXG,XXX,...................*CK
</code>
47 <td><code>$
</code></td>
48 <td>Sentence Start Character
</td>
51 <td><code>P
</code></td>
52 <td>Special ID (P = Proprietary)
</td>
55 <td><code>MVX
</code></td>
56 <td>Originator ID (MVX = Magnavox)
</td>
59 <td><code>G
</code></td>
60 <td>Interface ID (G = GPS)
</td>
63 <td><code>XXX
</code></td>
64 <td>Sentence Type
</td>
67 <td><code>...
</code></td>
71 <td><code>*
</code></td>
72 <td>Optional Checksum Field Delimiter
</td>
75 <td><code>CK
</code></td>
76 <td>Optional Checksum
</td>
79 <h4><a name=
"table_2">Table
2. NMEA Sentence Reserved Characters
</a></h4>
87 <td><code>$
</code></td>
89 <td>Start of Sentence Identifier
</td>
92 <td><code>{cr}{lf}
</code></td>
94 <td>End of Sentence Identifier
</td>
97 <td><code>,
</code></td>
99 <td>Sentence Delimiter
</td>
102 <td><code>*
</code></td>
104 <td>Optional Checksum Field Delimiter
</td>
107 <p>Following the start character
<code>$
</code>, are five characters which constitute the block label of the sentence. For Magnavox proprietary sentences, this label is always
<code>PMVXG
</code>. The next field after the block label is the sentence type, consisting of three decimal digits.
</p>
108 <p>The data, delimited by commas, follows the sentence type. Note that the receiver uses a free-format parsing algorithm, so you need not send the exact number of characters shown in the examples. You will need to use the commas to determine how many bytes of data need to be retrieved.
</p>
109 <p>The notation
<code>CK
</code> shown in
<a href=
"#table_1">Table
1</a> symbolically indicates the optional checksum in the examples. The checksum is computed by exclusive-ORing all of the bytes between the
<code>$
</code> and the
<code>*
</code> characters. The
<code>$
</code>,
<code>*
</code> and the checksum are not included in the checksum computation.
</p>
110 <p>Checksums are optional for Control Port input sentences, but are highly recommended to limit the effects of communication errors. Magnavox receivers always generate checksums for Control Port output sentences.
</p>
111 <p>ASCII data characters are transmitted in the following format:
</p>
115 <td>8 (msb always
0)
</td>
126 <p>NULL fields are fields which do not contain any data. They would appear as two commas together in the sentence format, except for the final field. Some Magnavox proprietary sentences require that the format contain NULL fields. mandatory NULL fields are identified by an '*' next to the respective field.
</p>
128 <h2><a name=
"input">Control Port Input Sentences
</a></h2>
129 These are the subset of the MX4200 control port input sentences sent by the NTP driver to the GPS receiver.
131 <h3><a name=
"input_000">$PMVXG,
000</a></h3>
132 <h4>Initialization/Mode Control - Part A
</h4>
133 Initializes the time, position and antenna height of the MX4200.
174 <td>000000-
235959</td>
178 <td>WGS-
84 Latitude
</td>
182 <td>0 -
8959.9999</td>
186 <td>North/South Indicator
</td>
194 <td>WGS-
84 Longitude
</td>
198 <td>0 -
17959.9999</td>
202 <td>East/West Indicator
</td>
210 <td>Altitude (height above Mean Sea Level) in meters (WGS-
84)
</td>
226 <code>$PMVXG,
000,,,,,,,,,,*
48</code><br>
227 <code>$PMVXG,
000,,,,,
5128.4651,N,
00020.0715,W,
58.04,*
4F
</code>
229 <h3><a name=
"input_001">$PMVXG,
001</a></h3>
230 <h4>Initialization/Mode Control - Part B
</h4>
231 Specifies various navigation parameters: Altitude aiding, acceleration DOP limits, and satellite elevation limits.
244 <td>Constrain Altitude
</td>
262 <td>Horizontal Acceleration Factor
</td>
294 <td>Elevation Limit
</td>
302 <td>Time Output Mode
</td>
311 <td>Local Time Offset
</td>
319 <code>$PMVXG,
001,
3,,
0.1,
0.1,
10,
10,
5,U,
0*
06</code>
321 <h3><a name=
"input_007">$PMVXG,
007</a></h3>
322 <h4>Control Port Output Configuration
</h4>
323 This message enables or disables output of the specified sentence and defines the output rate. The user sends this message for each sentence that the receiver is to output.
336 <td>Control Port Output Block Label
</td>
344 <td>Clear Current Output List
</td>
353 <td>Add/Delete Sentence from List
</td>
370 <td>Sentence Output Rate
</td>
378 <td># digits of Precision for CGA and GLL sentences
</td>
402 <code>$PMVXG,
007,
022,
0,
1,,
1,,,*
4F
</code>
404 <h3><a name=
"input_023">$PMVXG,
023</a></h3>
405 <h4>Time Recovery Configuration
</h4>
406 This message is used to enable/disable the time recovery feature of the receiver. The time synchronization for the
1PPS output is specified in addition to a user time bias and an error tolerance for a valid pulse. This record is accepted in units configured for time recovery. If the back panel contains a
1PPS outlet, the receiver is a time recovery unit.
419 <td>Time Recovery Mode
</td>
426 N=No Time Recovery
</td>
430 <td>Time Synchronization
</td>
439 <td>Time Mark Mode
</td>
444 V=Valid Pulses Only
</td>
448 <td>Maximum Time Error
</td>
456 <td>User Time Bias
</td>
464 <td>ASCII Time Message Control
</td>
469 1=
830 to Control Port
<br>
470 2=
830 to Equipment Port
</td>
474 <td>Known Pos PRN
</td>
479 0=Track All Sats
</td>
483 <code>$PMVXG,
023,S,U,A,
500,
0,
1,*
16</code>
485 <h3><a name=
"input_gpq">$CDGPQ,YYY
</a></h3>
486 <h4>Query From a Remote Device / Request to Output a Sentence
</h4>
487 Enables the controller to request a one-time transmission of a specific block label. To output messages at a periodic rate, refer to input sentence
<a href=
"#input_007">$PMVXG,
007</a>.
500 <td>ID of Remote Device
</td>
504 <td>(See
<cite>NMEA-
0183</cite>)
</td>
512 <td>(See
<cite>NMEA-
0183</cite>)
</td>
520 <td>(See
<cite>NMEA-
0183</cite>)
</td>
524 <td>Label of Desired Sentence
</td>
528 <td>Any Valid NMEA or Magnavox Sentence Type
</td>
532 <code>$CDGPQ,
030*
5E
</code>
534 <h2><a name=
"output">Control Port Output Sentences
</a></h2>
535 These are the subset of the MX4200 control port output sentences recognized by the NTP driver.
537 <h3><a name=
"output_000">$PMVXG,
000</a></h3>
538 <h4>Receiver Status
</h4>
539 Returns the current status of the receiver including the operating mode, number of satellites visible, and the number of satellites being tracked.
551 <td>Current Receiver Status
</td>
554 <td>ACQ=Reacquisition
<br>
555 ALT=Constellation Selection
<br>
556 IAC=Initial Acquisition
<br>
557 IDL=Idle, No Satellites
<br>
559 STS=Search The Sky
<br>
564 <td>Number of Satellites that should be Visible
</td>
571 <td>Number of Satellites being Tracked
</td>
578 <td>Time since Last Navigation
</td>
585 <td>Initialization Status
</td>
588 <td>0=Waiting for Initialization
<br>
589 1=Initialization Complete
</td>
593 <code>$PMVXG,
000,TRK,
3,
3,
0122,
1*
19</code>
595 <h3><a name=
"output_021">$PMVXG,
021</a></h3>
596 <h4>Position, Height, Velocity
</h4>
597 This sentence gives the receiver position, height, navigation mode and velocity north/east.
<em>This sentence is intended for post analysis applications.
</em>
609 <td>UTC Measurement Time
</td>
610 <td>Seconds into the week
</td>
616 <td>WGS-
84 Latitude
</td>
623 <td>North/South Indicator
</td>
630 <td>WGS-
84 Longitude
</td>
637 <td>East/West Indicator
</td>
644 <td>Altitude (MSL)
</td>
651 <td>Geoidal Height
</td>
658 <td>Velocity East
</td>
665 <td>Velocity North
</td>
672 <td>Navigation Mode
</td>
675 <td><em>Navigating
</em><br>
676 1=Position From a Remote Device
<br>
679 4=
2D differential
<br>
680 5=
3D differential
<br>
681 <em>Not Navigating
</em><br>
682 51=Too Few Satellites
<br>
683 52=DOPs too large
<br>
684 53=Position STD too large
<br>
685 54=Velocity STD too large
<br>
686 55=Too many iterations for velocity
<br>
687 56=Too many iterations for position
<br>
688 57=
3 Sat Startup failed
</td>
692 <code>$PMVXG,
021,
142244.00,
5128.4744,N,
00020.0593,W,
00054.4,
0047.4,
0000.1,-
000.2,
03*
66</code>
694 <h3><a name=
"output_022">$PMVXG,
022</a></h3>
696 This sentence reports the DOP (Dilution Of Precision) values actually used in the measurement processing corresponding to the satellites listed. The satellites are listed in receiver channel order. Fields
11-
16 are output only on
12-channel receivers.
708 <td>UTC Measurement Time
</td>
709 <td>Seconds into the week
</td>
715 <td>East DOP (EDOP)
</td>
722 <td>North DOP (NDOP)
</td>
729 <td>Vertical DOP (VDOP)
</td>
736 <td>PRN on Channel #
1</td>
743 <td>PRN on Channel #
2</td>
750 <td>PRN on Channel #
3</td>
757 <td>PRN on Channel #
4</td>
764 <td>PRN on Channel #
5</td>
771 <td>PRN on Channel #
6</td>
778 <td>PRN on Channel #
7</td>
785 <td>PRN on Channel #
8</td>
792 <td>PRN on Channel #
9</td>
799 <td>PRN on Channel #
10</td>
806 <td>PRN on Channel #
11</td>
813 <td>PRN on Channel #
12</td>
820 <code>$PMVXG,
022,
142243.00,
00.7,
00.8,
01.9,
27,
26,
10,
09,
13,
23*
77</code>
822 <h3><a name=
"output_030">$PMVXG,
030</a></h3>
823 <h4>Software Configuration
</h4>
824 This sentence contains the navigation processor and baseband firmware version numbers.
836 <td>Nav Processor Version Number
</td>
843 <td>Baseband Firmware Version Number
</td>
850 <code>$PMVXG,
030,DA35,
015</code>
852 <h3><a name=
"output_101">$PMVXG,
101</a></h3>
853 <h4>Control Sentence Accept/Reject
</h4>
854 This sentence is returned (on the Control Port) for every
<strong>$PMVXG
</strong> and
<strong>$XXGPQ
</strong> sentence that is received.
873 <td>Accept/Reject Status
</td>
876 <td>0=Sentence Accepted
<br>
879 3=Unrecognized ID
<br>
880 4=Wrong # of fields
<br>
881 5=Required Data Field Missing
<br>
882 6=Requested Sentence Unavailable
</td>
886 <td>Bad Field Index
</td>
893 <td>Requested Sentence ID (If field #
1 = GPQ)
</td>
900 <code>$PMVXG,
101,GPQ,
0,,
030*
0D
</code>
902 <h3><a name=
"output_523">$PMVXG,
523</a></h3>
903 <h4>Time Recovery Configuration
</h4>
904 This sentence contains the configuration of the time recovery function of the receiver.
916 <td>Time Recovery Mode
</td>
922 N=No Time Recovery
</td>
926 <td>Time Synchronization
</td>
934 <td>Time Mark Mode
</td>
937 <td>A=Always Output Time Pulse
<br>
938 V=Only when Valid
</td>
942 <td>Maximum Time Error for which a time mark will be considered valid
</td>
949 <td>User Time Bias
</td>
956 <td>Time Message Control
</td>
960 1=
830 to Control Port
<br>
961 2=
830 to Equipment Port
</td>
972 <code>$PMVXG,
523,S,U,A,
0500,
000000,
1,
0*
23</code>
974 <h3><a name=
"output_830">$PMVXG,
830</a></h3>
975 <h4>Time Recovery Results
</h4>
976 This sentence is output approximately
1 second preceding the
1PPS output. It indicates the exact time of the next pulse, whether or not the time mark will be valid (based on operator-specified error tolerance), the time to which the pulse is synchronized, the receiver operating mode, and the time error of the
<strong>last
</strong> 1PPS output. The leap second flag (Field #
11) is not output by older receivers.
988 <td>Time Mark Valid
</td>
1020 <td>00:
00:
00-
23:
59:
59</td>
1024 <td>Time Synchronization
</td>
1032 <td>Operating Mode
</td>
1037 K=Known Position
</td>
1041 <td>Oscillator Offset - estimate of oscillator frequency error
</td>
1048 <td>Time Mark Error of last pulse
</td>
1055 <td>User Time Bias
</td>
1062 <td>Leap Second Flag - indicates that a leap second will occur. This value is usually zero except during the week prior to a leap second occurrence, when this value will be set to +/-
1. A value of +
1 indicates that GPS time will be
1 second further ahead of UTC time.
</td>
1069 <code>$PMVXG,
830,T,
1998,
10,
12,
15:
30:
46,U,S,
000298,
00003,
000000,
01*
02</code>
1071 <script type=
"text/javascript" language=
"javascript" src=
"scripts/footer.txt"></script>