RTL-SDR Tutorial: Cheap AIS Ship Tracking

Large ships and passenger boats are required to broadcast an identification signal containing position, course, speed, destination, and vessel dimension information to help prevent sea collisions. This system is known as the “Automatic Identification System” or AIS for short. There are dedicated AIS receivers intended to be used on boats, or by hobbyists, but they can be expensive. A radio scanner or the cheap RTL-SDR software defined radio can be used to receive these signals, and with the help of decoding software, ship positions can be plotted on a map.

This tutorial will show you how to set up an AIS receiver with the RTL-SDR. Most parts of this tutorial are also applicable to other software radios, such as the Funcube dongle, Airspy and HackRF, or even regular hardware scanners if a discriminator tap is used, but the RTL-SDR is the cheapest option.

Safety Warning: This probably should not be used a navigational aid on a boat as the field reliability of the RTL-SDR or other software radios is not proven. This guide is intended for land based scanner hobbyists.

Note, tracking ships with AIS is very similar to tracking aircraft with ADS-B, which is another project that may interest you.

Examples of AIS received with RTL-SDR

An AIS radar example is shown by YouTube user Vinicius Lenci who uses an RTL-SDR, SDRSharp and ShipPlotter. This video also shows what a strong AIS signal sounds like.

Recebendo sinais (AIS) com RTL-SDR

Another example of AIS radar displayed on Google maps using an RTL-SDR, SDRSharp and ShipPlotter is shown by YouTube user Superphish.

AIS Ship Position Second Attempt with RTL SDR (RTL2832), SDR Sharp and ShipPlotter

Requirements and Setup

To set up an AIS ship radar on a windows system you will need four things.

  1. An RTL-SDR dongle working with SDRSharp.
  2. An audio piping method.
  3. A vertically polarized antenna tuned to 162MHz.
  4. Software for decoding the AIS signals.

We will assume you have the RTL-SDR dongle set up and working already. If you have not bought a dongle yet, see the Buy RTL-SDR page for information, and the check out the Quickstart Guide for an easy setup routine with SDRSharp. You will also need to have an audio piping method installed and set up. Audio piping will allow the audio from SDRSharp to be passed to a decoding program. You can use either windows stereo mix, VB-cable (free) or virtual audio cable (paid with trial version).

The sampling rate of your audio piping method must be set to 48000 samples/sec. To set this in Windows, right click your device in the Windows sound recording tab, go to properties and under the advanced tab, set the sample rate to 48000Hz. Do the same to the same device under the Playback tab as well.

Sound Properties

AIS Antennas

AIS signals are broadcast at both 161.975 MHz and 162.025 MHz and have a maximum range of approximately 74 kilometers. So if your radio set up is more than 74 kilometers away from any boats, you will probably not be able to receive AIS signals. AIS is also considered a line of sight signal, meaning that if there are large buildings or mountains in the way of your antenna and the boats, AIS signals could be blocked. Because of this reason it is important to put your antenna as high up as possible.

There are multiple commercial AIS antennas designed for marine use that will work. However, sometimes home made antennas work even better and they of course are cheaper. Some home made AIS antennas are shown below.

Coax Collinear Antenna

A good antenna for AIS is the coax collinear antenna.  The collinear antenna has very high omnidirectional gain directed towards the horizon. This means it will receive signals best from sources that are near the horizon, which is where ships will be.

A collinear coax antenna is basically a length of multiple short coax cables, where the coax outer conductor is connected to the inner conductor in an alternating fashion. As it is made out of coax cable almost entirely, it is a very cheap antenna to build.Colinear Antenna Design

On this page there is excellent instructions on constructing a few versions of a high gain coax colinear AIS antenna.

Yagi-Uda (Yagi)

If the majority of ships in your area are focused in one direction only, a high gain Yagi antenna may be a good choice. A Yagi is a very directional antenna, meaning that it will only pick up signals in the direction it is pointed. The advantage is that with directionality we can get a very large signal gain, which allows reception of further and weaker signals.

Building a Yagi is definitely a tougher job compared to the building a coax collinear antenna, but it is much more compact and can have a similar gain to a coax collinear. One page on a homemade AIS Yagi’ can be found here and another here.

A commercial AIS Yagi can be bought from here and a review of this antenna can be found from here.

InnovAntenna AIS

Slim-Jim

The slim-jim is another high gain antenna that is reported to work well with AIS. A slim-jim antenna can be easily made on a budget using common 300 Ohm twin lead ribbon cable. A page showing a twin lead slim-jim is here, but that version is designed for 145 MHz. To calculate the correct lengths for AIS, this calculator can be used by inputting 162 Mhz into the frequency box. An image showing a slim-jim with AIS dimensions is here.

Software Tutorials

First, use SDRSharp to tune to an AIS signal. Open SDRSharp, set your audio piping method in the Audio output drop down box, and tune to an AIS frequency (161.975MHz or 162.025MHz). In SDRSharp, the signals may not appear exactly on the AIS frequencies, since the rtl-sdr is not frequency accurate. Just tune manually until the signals are properly centered.

Play with the RF gain in the SDRSharp configure button until you get good reception of the AIS signals. You want to adjust the RF gain such that the signal is strong, but the noise floor is low.

Set the receive mode to NFM, bandwidth to 12.5 kHz, Filter Audio to OFF and squelch to OFF. Be double sure that you have set Filter Audio to OFF or this will cause bad or no decodes.

AIS signals look like small horizontal lines on the waterfall, as is shown on the image below. If you are listening to the AIS signals through your speakers, they will just sound like blips of noise. An example audio snippet of a busy AIS signal is provided below. (Warning: Might be loud.)

AIS Waterfall
AIS Waterfall

The two AIS frequencies broadcast the same information and are used in commercial AIS receivers for redundancy and to help avoid transmission collisions. We only need to choose one frequency for scanning however, so choose the one with less interference, and stronger signals.

Once you have AIS reception set up you can then use a program for decoding. There are two programs useful for decoding and displaying AIS information. ShipPlotter is a commercial program with a 21-day trial and AISMon + OpenCPN are free programs, but are a little harder to set up.

ShipPlotter Tutorial

ShipPlotter is a software tool that can decode and plot the location data stored in AIS signals. ShipPlotter is commercial software and costs 25 euros for personal use, but has a 21-day trial. Instructions on using ShipPlotter are shown below.

  1. Download and install ShipPlotter from their website here.
  2. Open ShipPlotter. Go to Options -> Audio -> SoundCard and select your audio piping method.

ShipPlotter Audio Select

  1. Under Options -> I/O Settings, ensure that enable audio input processing is checked.

ShipPlotter I/O Settings

  1. Ensure the Demodulator options in Options -> Demodulator are set to the default values, with ‘Require Preamble’ and ‘Require HDLC FCS correct’ both checked.

Ship Plotter Demodulator Options

  1. Tune to your AIS signal and push the green ‘Start’ button and then click on the ‘Raw’ icon which looks like a horizontal line with a squiggle (sine wave) going through it. This will show a waveform of the input audio. Ensure the audio levels are adequate and not clipping, by making sure the waveform peaks at about halfway on the graph by adjusting the volume settings in SDRSharp, or the windows volume settings.
  2. Now you should be able to click on the ‘Ships’ and ‘Messages’ icons to see the decoded AIS information. To see ships visually, you will need to follow the ShipPlotter instructions for downloading charts.

ShipPlotter Ship View

An easier method than downloading charts is to display the ships in Google Earth. To get ShipPlotter to work with Google Earth, you must first enable the Google Earth server in Options->I/O Settings. The HTTP port can be left as default.

ShipPlotter I/O Settings

Then you can go to the folder ShipPlotter was installed to (most likely in ‘Program Files (x86)/COAA/ShipPlotter’), and open the google_ships.kml file in Google Earth, to see the ships. Note that you will need to open ShipPlotter and begin decoding AIS signals by pressing the green button first BEFORE opening the google_ships.kml file, otherwise ships will not show up.

Google Earth AIS Screenshot

AISMon Tutorial

AISMon is a free AIS decoding program. It can be downloaded from the AISMon Yahoo group files section. You may need to first join this group using a Yahoo account to access the files section. The Yahoo group also contains a sample AIS .wav file, which when used with stereo mix, can be used to test both AISMon and ShipPlotter.

  1. Open AISMon, set the audio piping device to the one you have chosen, and set the sampling rate to 48000. Press start monitoring.
  2. Tune to your AIS signal and adjust the volume in SDRSharp, and/or the Windows volume settings until the Level meter in AISMon reads at about halfway.

If everything is working you should begin to see numbers appear in the Demodulator Counts section of AISMon.

AISMon Screenshot

By itself, AISMon does not display any ship information. To view ship information you will need another free opensource program called OpenCPN, which is a chart plotting and navigation software. OpenCPN can read the NMEA information that is output by AISMon, and plot the ship positions on a map.

  1. Download and install OpenCPN from here.
  2. Click on the Options button (looks like a wrench) in OpenCPN, and go to the Connections tab.
  3. Under Data Connections, click on Add Connection, and add a Network UDP connection, with address 127.0.0.1, and port 10110. Click Apply and OK.

OpenCPN Add UDP Connection

  1. Now back in AISMon under Output Options, check UDP Output, and enter 127.0.0.1:10110 into the IP:Port box. (You will need to stop monitoring first if monitoring is still running).

AISMon UDP Enabled

  1. You can now click Start Monitoring again. If everything has been set up correctly, ships will begin to appear in the OpenCPN map.

OpenCPN Screenshot

If you want more accurate maps or charts you will need to follow the instructions on the OpenCPN website for downloading charts for your particular location.

Another possible method for displaying AISMon data is to share your UDP data to the marinetraffic.com website, and view the ships on their shared map. You can do this by simply using the marinetraffic.com IP address to send the UDP traffic to. Instructions are here. Note, be careful that you do not send delayed AIS data to marinetraffic.com, such as with the sample AIS file from the AISMon Yahoo group.

Decoding Both AIS Channels

By using the SDR-Radio instead of SDR# as your receiving software it is possible to listen to both AIS channels simultaenously. To do this, simply set up two VFO’s in SDR-Radio that listen to both AIS channels, and also set up two audio pipes. Set the audio from each VFO to go to a seperate audio pipe. Then open two instances of AISMon, setting each instance to listen to a different audio pipe. Make one AISMon instance output data to a different port number. Then in OpenCPN add a second UDP receiver with the other port number.

Linux Software

There is an AIS Linux decoder available called AISDecoder. AISDecoder listens to AIS data via the just like ShipPlotter and AISMon do. It can be downloaded from the aishub forums through this thread. Instructions for compiling and using AISDecoder are also available on that thread. Like AISMon AISDecocder will output NMEA messages via UDP so that other software such as OpenCPN can display the data on a map.

Another AIS decoding option is to use GNU Radio with gr-ais. Using gr-ais has the advantage in that it can use the two AIS channels to decode, and thus may have better reception of data.

From a thread on the cruisersforum.com user larsed has provided a detailed guide on getting GNU Radio working with gr-ais on a Linux SuSE12.3 install. Get the guide in pdf form here. (Full credit goes to Lars Edman, author of the pdf file).

Some Tips

  • You may need to play with the bandwidth setting in SDRSharp if your signals are weak in order to get a good decode. Just ensure the bandwidth covers the signal width adequately.
  • A low noise amplifier (LNA) such as this one or this one may help you to pick up weak AIS signals better.
  • Antenna height is important, the higher and more unobstructed the better.
  • You can test AIS decoding without an antenna using the example AIS .wav file in the AISMon Yahoo groups files section. Just use stereo mix as the audio piping method and play the audio in any audio player on your computer.

If you enjoyed this tutorial you may like our ebook available on Amazon.

The Hobbyist’s Guide to the RTL-SDR: Really Cheap Software Defined radio.

33 comments

  1. longjohn

    Can’t get ShipPlotter to show the CABLE input, only the inputs to my other 2 soundcards. so I’m stuck on step one. It’s working in AISMon and SDR# just fine, but I can’t choose something that doesn’t show up on the list.

    Are the examples XP or something because it dosn’t look like Win 7 64 bit

  2. lagunacomputer

    Any idea why when I pick “Other (Sound Card)” in SDRSharp, I can only tune to 24Khz? no higher?
    I have tried all the drivers in zdiag. using RTL2xxx usb adapter the cheap one. Also, if I select RTL-USB it tunes just fine. I am trying to pipe audio to the shipplotter. thx

  3. Pingback: Hacks all the way down | Dolske's blog
  4. HB9DTX

    Thanks for the tutorial. Install of all SW went fine on two different computers, inclusive a small ACER Aspire One (1.6 GHz, 1GB RAM) under Win7 Dongle is the Nooelec R820T SDR&DVB-T NESDR Mini. Now I just need to go in a region where there are some AIS signals to listen to… In Switzerland we are too far away from the Sea to receive something:-) This is planned for in a couple of days.

    • HB9DTX

      I could teset tes system with real signal. Worked very well! Only detail, I needed to connect to a network (WiFi or Cable) just to have the UPD packets forwarded between AISMON and OpenCPN… Strange behavior of the network under Win7, this should not be necessary in an ideal world.

  5. Pingback: Collection of sites using RTLSDR to hack RF | Alan C. Assis
  6. Pingback: AIS | Pearltrees
  7. Pingback: Rtl-sdr | Pearltrees
  8. Pingback: An Optimistic View Of A Disruptive Technology | Preparedness United
  9. Pingback: Receiving, Decoding and Plotting AIS using a RTL-SDR Dongle | RTLSDR.com
  10. Andrés

    First: Thank you very much for the tutorial.

    Then: I have a problem with the Aismon program.
    I’m using Aismon to send Ais signals already decoded to OpenCpn.
    Selecting UDP output, putting as: 127.0.0. 1:10110
    It works (OpenCpn shows boats) only if the computer is connected to Internet.
    If the computer is not connected to the Internet, the box of the Aismon Ip:Port selection blink red and OpenCpn shows no boats.

    How could I fix it?
    Thanks.

  11. Pingback: Software | Pearltrees
  12. Aardvark

    I have been playing with ADSBSharp in the NYC area and came across this article as I wanted to see if there was an AIS equivalent. I live near the water so I there is plenty of marine traffic to monitor. I was hoping there would be something called AISSharp but these instructions are doable. Maybe I’ll take a stab at the ADSBSharp code someday and see if it can be massaged into handling AIS.

    • admin

      An ‘AISSharp’ program would be great. It would still help to have a waterfall display though, as the frequency error of the dongle can make it difficult to get exact tuning, and also AIS is sometimes near interfering pager signals requiring careful visual tuning of the gain.

      If you know Linux well, gr-ais might also be worth looking into.

      • Angen

        I agree! ‘AISSharp’ would be a great thing! A missing peace in the field right now. Aismon do exist but it’s designed only for decoding and I think is only one channel. Maybe possible to have a automatic calibration.

      • N2JTX

        The frequency error is definitely an issue. I used Kalibrate to analyze my dongle and it comes in with a 22ppm error. After applying a 22ppm correction I get an error of around 200Hz.

        I started digging around a bit in the ADSBSharp code. Ouch! I am very impressed at the work. Besides the “trivial” task of removing the ADS-B decoding routines and replacing them with AIS code, the easiest part IMHO would be swapping port 47806 for port 5414 which AISMon could then connect to instead of using the audio port. I really need to look at AISMon to see what its data requirements are on port 5414. So many ideas, so much other job related work that has to be done!

  13. Pingback: ติดตามเครื่องบินด้วย SDR | Raspberry Pi Thailand
  14. Pingback: Tracking ships using software-defined radio (SDR) | Make, Electronics projects, electronic Circuits, DIY projects, Microcontroller Projects - makeelectronic.com
  15. Pingback: Tracking ships using software-defined radio (SDR) Via Hack a Day | reDDstaGG
  16. Pingback: rndm(mod) » Tracking ships using software-defined radio (SDR)
  17. Pingback: Tracking ships using software-defined radio (SDR) | Daily IT News on IT BlogIT Blog
  18. Pingback: Tracking ships using software-defined radio (SDR) - RaspberryPiBoards
  19. Pingback: Tracking ships using software-defined radio (SDR)

Post a comment

You may use the following HTML:
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>