All GPS units (except for aviation and some without serial ports) output data according to the National Marine Electronics Standard, NMEA- 0183. The data is generated about once every 2 seconds and APRS looks for the position, course and speed. There are two distinct arrangements:
STAND-ALONE-TRACKER - This is the combination of a GPS, a TNC and a radio. It tansmits raw NMEA data over the air. There is no laptop or display in the vehicle.APRS-TRACKER - The GPS is connected to an APRS serial port and APRS uses the data to transmit its own shorter formats. If only a single port is available, the GPS and TNC may share a COMM port if a suitable momentary switch circuit is provided. APRS must be registered for the GPS option for this to work.
OVERVIEW: We began seriously parsing GPS data within APRS for amateur applications when the MAGELAN OEM GPS card dropped from $1000 to $445 in Sept 92. Later the Motorola OEM GPS card came down to the same price range and DRSI made a special APRS ROM for TAPR-2 clone TNC's to permit power-up in the converse mode. In August 93, we added the GPS serial interface to APRS, but it required a second comm port. By Dec 93, APRS could share a single port with GPS cards that could be programmed to a 1 minute or so reporting rate. This is called the SINGLE-PORT-MODE (SPM). Later I developed the HARDWARE-SINGLE-PORT (HSP) mode for use with any GPS regardless of its output rate. In HSP mode, APRS toggles the DTR line on the single serial port so that two transistors can then switch between the GPS and the TNC on the same port.
About this time, PACCOMM added a GPS mode to its TNC's and Howie Goldstein, N2WX, wrote special GPS commands into the standard TAPR-2 TNC code. AEA and Kantronics soon followed. Now that handheld GPS units are under $250 and most TNCs include GPS commands, the only significant advantage of the OEM GPS cards is in totally autonomous stand-alone tracking devices which can power up without human interaction. Handheld consumer GPS units require a Human finger to turn them on and off! Conversly, the OEM cards power up whenever ignition power is applied.
FOR DUAL-PORT LAPTOPS: ANY NMEA GPS and ANY TNC will work with APRS
SINGLE-PORT LAPTOPS: Choose between the following options:
SPM (SINGLE PORT) MODE: Program an OEM GPS circuit board to a 1 or 2 minute rate and diode-OR the data with the TNC data to the same serial port. There are occasional glitches when both the TNC and GPS data collide.PUSH BUTTON MODE: Configure APRS for SPM, and connect both the GPS and TNC to your serial port via a SPDT Push Button. Press the button for 2 secs whenever you want a fresh posit. The rest of the time, the TNC is connected normally. Glitches will still occasionally occur. But you have the advantage of an exact posit on demand.
HSP (HARDWARE SINGLE PORT) MODE: Use ANY GPS with APRS in the HSP mode using a simple two transistor interface which permits APRS to switch between the two devices. Since APRS controls the switching, the potential for garbling is reduced. HSP devices are available from PacComm, AEA, and Kantronics.
West Marine 1-800-538-0775 Currently (Feb 95) the GARMIN 40 is going Boat US 1-800-937-2628 for $259 and the GPS-45 for $299 E & B 1-800-533-5007 these are LIST prices! 1-800-262-8464MAGELAN OEM CIRCUIT BOARD: My first GPS. Cost $450 plus $130 antenna. Well documented later in this file. Output fully programmable and includes GGA, GLL and VTG data. Great for any TNC for stand-alone. LNA on board, can use home-made antenna. 5 channel. Obsolete! NMEA output no longer available!
MOTORLOA OEM CIRCUIT BOARD: Very small circuit. Requires active antenna. Output fully programmable and has GGA,GLL,VTG and RMC. The RMC gives posit, CSE/SPD all in one packet. Great for any TNC stand-alone. 5 channel. $380 with active antenna. $335 without. VP-ENCORE is the latest 5 volt version (TTL) for $299. ($344 w/antenna). These prices have been the same for over a year! (its now Jul 95).
GARMIN-50: $300 and includes mounting bracket, NMEA cable and 6-40 volt supply capability built in! Has RMC, but does NOT have GGA (no altitude). Handheld antenna can be remoted about 6 ft. 8 channel. CAUTION: To make pilots spend more for the aeronautical version, all nautical GARMINS have a 90 kt limit and will NOT WORK above that speed!
GARMIN GPS-45: Seems to be the most popular (by 10 to 1 over the last 2 years (thru 96). About the size of a tall cigarette pack, and includes a full graphic display. Zoom in close and far out. The graphics on the screen show your track relative to the Waypoints and your own track history. Price about $249 INCLUDED bracket and detachable NMEA cable. Antenna is BNC and remotable too. Replay track histories stored in the unit into APRS conversion programs and build your own APRS maps. Output is +/- 2.5 volts and is usually RS-232 compatible.
GARMIN GPS-40: Same as the GPS-45, but has internal antenna only and less power supply voltage range. About $50 less.
MAGELAN MERIDIAN: The latest Magelan Neridians no longer have the RMC sentence, which means that you cannot get Course and Speed in the same packet for a stand alone tracker with some TNC's. It works fine with direct connection to APRS though. Call Magelan at 909-394-5073. Otherwise a good GPS. Dropped below $250 recently. Mounting bracket, NMEA and external 12v converter are extra for $75, but are not needed if you give it 6 volts and make your own data cable. 8 channel. Handheld antenna can be remoted about 6 feet. Current drain is 130 ma. Runs on 3 AA cells. Also has SAMPLING mode that extends battery life by factor of 10 or more. Below is the pinout, looking at the back of the GPS with wire colors for their $80 power/data cable. Note that you do NOT need their box for NMEA data, only for 6V power. (This is MY OPINION. I AM NOT LIABLE FOR ANY PROBLEMS IF YOU MAKE YOUR OWN INTERFACE!)
GPS POWER/DATA CABLE BOX WIRES OUT SIGNALSI do not know how they manage power internally, but the GPS will run from internal 3 AA cells with or without the cable attached. If there is external power, it knows it, and switches to external power. When external power goes away, THE GPS POWERS DOWN. Pressing the ON button will power it back up again on internal power!*- +6V --[*reg*]-------------- Red 9 to 16 volts input *--------[-----]-------------- Yellow reserved for future *--------[-----]-------------- orange NMEA (+) *--------[?????]-------------- white -20k +100K continuity through box *--------[-----]-------------- brown NMEA (-) *--------[-----]-------------- black Ground
Final comments, the Meridian does NOT output any data unless it is getting a good GPS fix. THis means you will be doing a lot of troubleshooting out at the picnic table! The Garmin, on the other hand, continues to output NULL NMEA strings with only the comma separators when it looses GPS lock.
TEKK DATA RADIO: Not a GPS, but is a 2 watt UHF 9600 baud data radio about the size of a credit card (and 3/4 inch thick). See page 18 in Feb 94 QST. Cost between $120 to $130. Great for future 9600 baud POSITION REPORTING NET TO DEVELOP on 445.925 MHz. See UHFFREQ.HTM.
MFJ DATA RADIO: Advertised in Nov 94 MFJ catalog. Is a 5 watt single channel XTAL controlled 9600 baud capable data radio on 2 meters! Costs about $119 crystaled on 145.01. Add $14 to get it factory xtaled on 145.79. Call them at 1-800-647-8324.
0.25 CUBIC INCH 500 mw XMTR! Agrello Engineering 518-381-1057 is selling a postage stamp sized xmtr called the VFC400 for $99. Glue it to your GPS with the PACCOM PICO-TNC and you have a hand-held stand-alone tracker!
PACCOMM PICO-TNC: Smaller than a cigarette pack. Has an optional 2nd GPS serial port! Will sell for about $130 plus options..
MOTOROLA HT-220: The venerable HAMFEST single channel HT can be bought for as low as $20. After taking off the front and back covers, hacksawing off the battery compartment, and replacing the PTT switch with a tiny RELAY from Radio Shack (PN# 275-241, you have a nice 3/4 watt packet radio, about the size of a cigarette pack. The PTT leads also carry the antenna RF, so put the relay in place of the PTT switch and keep the leads short. Add $20 worth of crystals for 145.79, and away you go on 2-meters. Be sure to get the models that will tune down to 2m.
The first describes the TNC GPS interfaces.TNC GPS STAND ALONE TRACKERS: All recent TNC's have GPS modes which let the TNC periodically transmit position reports at a rate significantly below the normal 2 second rate. WHILE IN GPS MODE, the TNC is not used for other packet communications (except for the Pico by PacComm). You may also connect some of these TNC's to an Ultimeter weather station for remote reporting of WX conditions by programming the TNC to look for just a * or a # instead of the usual $xxxxx GPS strnigs. (See WX.HTM)
Second is the direct APRS software interface of GPS to your PC
Third is the direct TNC/GPS interface for building stand alone trackers using the MAGELAN and Motorola OEM cards.
Forth, in March 94, I added a section on Differential correction.
Since each TNC implementation is different, you should refer to the instructions that come with your TNC. I will describe the PACCOMM unit as an example. They define a LOCATION TEXT similar to the BEACON TEXT except that it is updated by the GPS (or manually entered). This maintains the same distinction between BTEXT and POSITS that APRS already handles easily. Similaraly, the LText command allows you to manually enter your LAT/LONG or grid square in your TNC, even without a GPS, so that TNC's in networks will send their locations periodically. The LText permits a free text format so that it is compatible with any future specific formats (currently APRS parses GGA, RMC, VTG, APRS L/L, grid squares and a special compressed format for the APRS MicEncoder.
DIRECT APRS GPS/LORAN INTERFACE OPTION: The optional APRS GPS registration enables APRS to read data from a GPS directly connected to the PC. APRS will not only plot the position of the attached GPS and its movements, but will also transmit those position reports into the APRS net. In this mode, you can also select TRACK on the P-list to keep your mobile always on the map. There are four possible operational configurations:
TNC only - 1 Serial - Normal APRS for tracking other stations TNC/GPS - 2 Serial - Normal APRS with automatic GPS position update GPS only - 1 Serial - Tracking yourself (no other stations appear) TNC/GPS - 1 Serial - Single Port Mode will do both! See below TNC/GPS - 0 Serial - Stand-alone-tracker. Doesnt use APRS except to plot the resulting packets off-the-airNMEA INTERFACING NOTES: Note that NMEA and RS-232 are not exactly compatible. The NMEA data is actually EIA-422, an isolated differential receive circuit. But in most cases it should also work by simply connecting the NMEA pin A to the PC RXD and pin B to ground. Both standards have the same sense, with NMEA at 0 and +5 volts, and RS-232 at least a -3 and +3 volt signal. The direct connection may not work with some serial ports without a (-) voltage pulldown resistor. In this case a series 1k resistor and a 5 to 10k resistor tied to your unused TXD data line will suffice to provide the (-) voltage:
GPS NMEA OUT LAPTOP SERIAL PORT 1 k A >-------------//\//\---*------------------------> RXD | 10K *-------/\//\/--------< TXD B *-------------------------------------------------* GNDNOTE 1: If you use this circuit to your TNC, then remember that the definitions of TXD and RXD are reversed. This is the biggest cause of initial setup problems for new users. Also, if you use this biasing on your GPS when connected to a TNC for a stand-alone-tracker, be sure to set ECHO OFF so that echoed data on the TXD(RXD) line do NOT come back and garble the bias! Usually you do not need the opposite serial data going from the PC to the GPS. APRS recognizes four of the NMEA-0183 formats:
$GPGGA - for position and height (no loran equivalent) ] Use only one $GPGLL - for position only ($LCGLL for LORAN) ] of these two $GPVTG - for velocity and course ($LCVTG for LORAN) $GPRMC - Posn, Course and speed (Has all but height) ] Preferred $PMGLB - Magelan Altitude $PGRMZ - Garmin AltitudeAPRS has two commands under the alt-SETUP-GPS-MODES to force APRS to only use GGA or RMC sentences. The default is RMC. The data on the NMEA interface is nearly continuous and refreshed every two seconds. For the much slower APRS network, however, APRS only samples the data at a much slower rate called the REFRESH rate usually set to once every 15 seconds or so. This period determines how often your screen is updated from your own GPS. The other period called PACKET PERIOD is usually set for 1 to 10 minutes. Set these periods with the alt-S-POSRATE command. We have found that 30 seconds updates are OK for special events when there are only a few mobile APRS stations. As more and more stations go mobile with GPS/APRS, 1 minute or 2 minute updates are more appropriate. To further reduce channel loading, APRS will decay the period when the station is not moving.
DIODE OR-ing of GPS and TNC in SINGLE PORT MODE: GPS DATA OUT >----------*------>|--------*-----> TNC RXD |----//\//\----| | TNC DATA OUT >----------*------>|--------* both R's abt 10K |----//\//\----|A simple SPDT PUSH BUTTON switch can do the same thing and doesnt require the special programmable GPS's. The switch has the advantage that it gives the user control of when he wants a FIX. The operator only needs to press and hold the button for 2 seconds, in order to get a posit at any time.
To activate this Single Port Mode (SPM), bring up APRS in one-port TNC mode being sure to set the TNC to the same BAUD RATE as your GPS. Then enter the ALT-S SETUP Menu. Select SPM under the GPS selection and then do SETUP again to SAVE the config file. You will be asked for your regular validation and your GPS number. If you did this correctly, you will see the lower case (spm) on the yellow control panel go to uppercase. ALSO NOTE THAT BOTH THE TNC AND THE GPS MUST BE RUNNING AT THE SAME BAUD RATE. THIS IS USUALLY 4800 BAUD FOR NORMAL NMEA OUTPUTS.
In the Single Port mode, the screen refresh rate is set by the period programmed into your programmable GPS (45 seconds or longer is about right). The position report transmission rate from APRS to the TNC is set by POS-RATE command in the SETUP Menu.
PACCOMM now sells this little circuit assembled inside of DB-9 connector with two pigtail connectors for your TNC and GPS for about $30.
*------------------< +V (PC RTS) GPS NMEA |/ c or TNC DSR) >--------------//\//---*----*--| OUTPUT 1k | NPN | e * see important notes below | *--->|-->|---*-----> RXD TNC RXD | diode | >--*-------------------------------*----->|-----* | 15k | | 10k | SINGLE *-|<-*-/\/\/--*-------* *---/\/\/\/--* LAPTOP | note 1 | c \| RS-232 === | |--*--------/\/\/\/--* PORT | 1uF | e /| NPN 10k | TNC DTR --- | | | (or RTS) /// | //// | <-----------------------------------------------*-----< DTR | 1uF |-----/\/\/\----*--||--------* | 15k | | | note 2 *-->|--* --- TNC TXD * | /// <--------*-----> *----------------------*-------------< TXD SW-1 *-----------------------------------------------------* GND GND
Install these components in a back-to-back DB-9 connector on the cable comming from my GPS so that it is always handy. Almost any NPN transistor and switching diodes will work. A 2N2222 is fine. The SWITCH SW-1 allows you to easily re-configure for STAND-ALONE-TRACKER without re-cabling. You still need to use the laptop to tell the TNC to got to GPS mode, however. In the implementation below you will notice that a dotted line shows how to add just one wire to take the output of the TNC to the DGPS input of the GPS if your GPS is DGPS capable and if someone in your area is transmitting DGPS data on your packet channel.Note1: This resistor-diode-cap provides a little -V bias to the GPS output line going to SW-1 when the GPS is used with the TNC only in stand alone tracker mode (no PC). Note2: This 10K resistor-diode provides a little -V bias to the GPS output when the PC and GPS are operated alone (WITHOUT the TNC).
PHYSICAL LAYOUT OF BACK-TO-BACK DB-9's WITH HSP CIRCUIT INSTALLED 1 2 3 4 5 DB-9 FEMALE TO COMM PORT O O O O O | 7 | | | O | O | O | O | | | | | | | | | | | NMEA N C------ | -* | | *--------E N FROM P E--->|--* | *---- | -//\/-B P (2N2222 or equiv) GPS N B---*-- | --- | --- | --- | -------C N | | | | | | *--* | | | A >-----//\/--* | | | | | - | | | DGPS < - - - - * / ^ | | | | \ | | | | | | | | | | * - *--* | | | B ---------------- | --- | --- | ----* | | | | | | | | O 1 O 2 O 3 O 4 O 5 DB-9 MALE TO TNC CABLE O O O OIn this adapter, the voltage to provide the -V bias to convert the NMEA output to RS-232 levels comes from the RXD output of the TNC. For this reason, if the GPS is used alone with the PC, without the TNC, you must include the components of note2. OR you may connect a jumper between pins 2 and 3 of the empty TNC connector. This takes the -v from the unused TXD output of the PC. I recommend carrying a stubby DB-9 female connector with this jumper permanently installed.
O 1 O 2 O 3 O 4 O 5 FEMALE STUB USED TO PROVIDE | | -V BIAS WHEN TNC IS NOT USED O | O | O O | | *-----*HSP OPERATIONS: Setup HSP just like SPM from the alt-SETUP-GPS menu. Be sure your GPS and TNC are at the same baud RATE as your GPS, usually 4800. Select HSP under the SETUP menu and then SAVE a new CONFIG file. You will be asked for your GPS validation number. If everything is done correctly, you will see the lower case (hsp) on the TAB control panel shift to upper case. In HSP mode both the screen refresh rate and position transmission rate are set with the POS-RATE command. You may force an HSP update at any time by pressing the F8 key. CAUTION: This interface is operating with slim voltage margins at the RS-232 level and may need to be tailored to your particular PC, GPS and TNC. Some experimenting may be required to make it work for you and once working, it may not work if you change TNC, GPS or PC. You may have to try one or two or NO series diodes in the emiter lead of the GPS switching transistor as well as different R values for the 1k series resistor. IF YOU ARE USING A GARMIN 45 YOU MIGHT NEED TO TAKE BOTH diodes out, since the GARMIN ouputs +/- voltages...
* write down your V#'s IN THE CAR! You may need to re-configure! * Recommend making a trimmed down disk with only the maps you will need. * When you QUIT APRS, your TRACK HISTORY is NOT saved UNLESS you sepcify a file name OTHER than BACKUP.BK (or do a FILE-SAVE). * Use the TRACK mode to keep yourself on the map. * Set your refresh rate long enough (20 sesc or more) so that APRS is not always processing GPS and has time to service the keyboard. * Make notes of any map errors or disagreements with GPS, so at home you can use MAPFIX.bas, to replay your track history and fix the map easily. * Use the TIME-SYNC command to sync your PC time to GPS time on the next receipt of a GGA or RMC sentence to eliminate dead-reckoning errors.For most highway maps and 1 minute reporting at 60 MPH, zooming in below eight miles is usually a waste of time. For this reason don't waste your time making maps with every little twist and turn in the road; it just takes time and memory and makes no difference. A straight line between A and B is not as pretty, but shows the road as well as 20 points showing all the curves. If you do save any RAW GPS data outside of the APRS environment, the following two programs may be useful in reconstructing GPS data. They were written hastilly for a one time need and are provided as-is. Still, they might be useful to others as a basis for writing your own routines. FILTRHST.bas: APRS automatically builds a track history for all moving stations. APRS avoids saving redundant position reports automatically with its POS-FILTER. The default value of the filter is wide enough to include the variations in position due to GPS selective avaiability. (+/- 0.03 mins) With the filter off, this is reduced to 0.01. FILTRHST.bas can be used to re-filter a track history file to remove additional points. Use the source code to write your own filters for your own needs. In addition to filtering, this program can be used to combine a number of separate track history files into one file. GPStoHST.bas: Takes any DOS text file and generate an APRS track history file. It only looks for the GGA and VTG NMEA-0183 sentences and combines them into the one line APRS format.
MAGELAN COMMANDS: $PMGLI,00,B00,7,A (for GGA GPS position only) Where 6 = 30 Secs $PMGLI,00,B01,7,A (for GLL LORAN position only) 7 = 1 Minute $PMGLI,00,EOO,7,A (for course and speed with either) 8 = 2 Minutes 9 = 5 minutesEach line must end with a carriage return-linefeed. The GPS engine gives no responses to commands, other than doing what it is commanded. You might try a value of 5 which is once every 10 seconds as a test to be sure the GPS card is recognizing your commands. The commands for the MOTOROLA card are similar, but MUST have the proper checksum. Use my MOTOROLA.BAS program to send these commands with proper checksum calculated...
$PMOTG,GGA,0030*csCRLF (sets up GGA once every 30 secs) $PMOTG,RMC,0060*csCRLF (sets up RMC once every 60 secs etc..)BATTERY BACKUP: Be sure to add the battery back up supply so that the card can be turned off without having to re-initialize every time. Each of the cards has a connection for a 3.6 volt battery. I use 3 AA cells soldered together. TNC SETUP DETAILS: If your OEM card does NOT output the RMC sentence, you must use the GGA and also the VTG sentence to get course and speed. Problem is that these two sentences are separated by enough time that the TNC usually generates two packets, one right after the other. This is a problem when a digipeater path is used, because the digipeat of the 1st packet will collide with the second VTG packet. To solve this, (not needed for balloons which dont need digipeaters), the sending TNC needs to be instructed to send packets not on receipt of every carriage return, but on a timing function. Set CPACTIME ON and change the SENDPACK character from $0D to anything else (say $01). This way, both the position fix and velocity lines will be sent together in the same packet one second after the last character is received from the GPS. This packet, containing two frames, will then be digipeated all together by the digipeater with no break in between. If you use the Motorola card, with the RMC sentence, this double packet problem does not exist. LINEFEEDS and FLOW CONTROL: Since the GPS is sending each line with a CR/LF on the end, your TNC will always end up placing the superfluous linefeed at the beginnning of the next packet. To defeat linefeeds, set LFIGNORE on. (for AEA, try Linefeed Supress, LFS ON). Similarly, your terminal program must send CR-LF on each command to the GPS card. When you try to talk to your TNC with CR-LF, you will experience a lockup condition since the extra LF will look to the TNC like the beginning of a new command line and will hold off all TNC output. To overcome this problem, set FLOW OFF. Here are the commands which must be changed from factory defaults for most TNC's:
ECHO OFF, FLOW OFF, LFIGNORE ON, CPACTIME ON, SENDPAC $01(Remember that you have SENDPAC set to $01, and change it back to $0D for normal packet operations! I was pulling my hair out while driving through Knoxville and trying to connect to the local BBS node. It ignored all of my node commands as if I was personna-non-grata! I finally realized it didn't like the $01's being imbedded in my packets!) UNPROTO-CONVERSE-MODE: And now for the last problem; keeping the TNC in converse mode. Since TNC's always default to command mode when turned on, they cannot be expected to operate autonomously with GPS data supplied to their inputs from power up. As of 1995, most new TNC's now include some kind of UI mode that will force the TNC to power up in CONVERSE. To get out of this mode, you just hit ctrl-c as usual. DUMB TERMINAL SETUP: While programming a GPS, you may want to configure your terminal for half duplex so you can see what you are sending to the GPS. The GPS may also need the CR/LF sequence at the end of each command, so set the terminal to translate CR to the CR/LF sequence. SYMBOLS: To specify the APRS symbol character for a STAND-ALONE-TRACKER, there are 2 methods. First, when APRS receives a raw NMEA posit over the air, it will use one of 15 default symbols based on the callsign SSID. See SYMBOLS.HTM. Secondly, any APRS symbol characters can be placed at the beginning of the TNC BText surrounded by {} braces. Once the BText with that symbol is received, the station will then appear with the proper display symbol. We have assembled a number of these GPS/PACKET tracking devices, some by simply placing the GPS within some of the larger TNC enclosures. Then add two switches to the front panel for switching the GPS serial data to the TNC or PC, or the PC to the GPS or TNC. MOST OF THIS TEXT AND THE HOOK-UP SCHEMATICS WERE PUBLISHED IN THE FEB 94 ISSUE OF QEX.
BT !3859.11N/07629.11W.RTCM data provided by TOM W3IWI...Everything after the (.) symbol character is free text. APRS will flash a DGPS flag on the screen each time it hears a DGPS transmission, but will not add the station to the L or P-Lists unless it also sees the (.) symbol in the position report. Set your beacon to every half hour or so. Finally, set your TNC into CONVERSE and tell your RTCM-104 DGPS receiver to output once every 30 seconds. See the new HSP mode schematic above where I added the interface wire between your TNC and GPS for automatic DGPS operations. CONFIGURING FOR DGPS: There are two options for routing the DGPS data from your TNC to your GPS unit: 1) For ANY arrangement: run an external wire from your TNC RXD data output over to your GPS DGPS data input. 2) For dual port operations only: connect your GPS DGPS input to the PC serial port TXD line and select DGPS from the SETUP menu in order to enable DGPS data output from APRS. CAUTION: This will not work if you are operating in the SPM or HSP modes or if you are using the same serial port TXD output as a source of -V bias for the NMEA conversion as suggested in the above paragraphs.