-
Notifications
You must be signed in to change notification settings - Fork 77
Signal K
(draft)
By adding Signal K, the GX device becomes a data hub for all marine electronics on your yacht. For example audio, boat speed and wind data, and more. Signal K is the, after configuration invisible-, converter. That unlocks data from NMEA0183, NMEA2000 and more protocols towards mobile Apps on phones tablets and the alikes.
Popular navigational tools compatible with Signal K:
- WilhelmSK: WilhelmSK is a highly customizable boat instrument display available for iPhone, iPad, Apple Watch and AppleTV.
- ...
Signal K is a modern and open data format for marine use. Its goal is to
- create a shared data model for marine related data
- make marine related data easy to access, handle and build applications on
The shared data model allows you to handle the data in a uniform way independent of how the data is produced. In practice this means that you can refer to your battery voltage with electrical/batteries/1/voltage
and not care where data came from: Victron BMV, NMEA 2000 bus or some other voltage sensor.
Easy access means that you can use modern standards like HTTP, WebSockets and JSON that are in widespread. There is a wealth of knowledge and skilled people are easy to find, with no special marine related knowledge needed to get started.
In Venus OS it brings all the data available in the GX system, including NMEA 2000 data, to a single data model and programming interface.
The type of install described in this document, running Venus OS including SignalK, has these advantages: TODO elaborate. Doing this was born out of a wish to make SignalK more mainstream, less of a rapsberrypi / hobbieists/tinkerers product.
The other common type of SignalK install, installed on a RaspberryPi running Raspbian, has the advantages of more flexibility, and ease of installing extra components such as Grafana or Influx. The disadvantage is that you are basically setting up a Linux computer yourself, which you’ll also have to maintain yourself. Whereas the Venus OS type is more of a complete product; no need to bother about keeping individual components up to date and worrying about their compatibility.
There is no one right way for everyone to do this; the best solution will depend on the requirement.
For raspberrypi owners, note that its very easy to try both methods and change between them: simply have two sdcards.
TODO: word this in proper english.
SignalK Slack, or https://community.victronenergy.com and then the Modifications space.
whatever you do, don't contact normal victron support for any help on SignalK. Its based on community support, not official support.
A Venus GX, or one of the support RaspberryPi models. SignalK is not available for any other GX devices. It will be available for the soon coming new product, Cerbo GX.
Currently used Signalk-node version is 1.18.0. Installed plugins are:
- Node-red plugin, v2.8.0, contains Node-red version ???
- Victron Venus Plugin, v1.10.0
- Step 1. Disable auto updates. See Settings -> Firmware -> Online updates in Remote Console.
- Step 2. Download below .swu file, see chapter 5, and install it using the offline install method.
TODO: Add note on what to do on a Venus GX of serial number xyz or earlier, because partition are is too small. Answer is here: https://github.com/SignalK/signalk-server-node/issues/517
To install Venus OS + Signalk on an sdcard for a rasperrypi; follow these instructions; but then using below file instead of the one mentioned in the instructions:
Once completed, disable automatic updates, to prevent the SignalK image to be replaced by a normal one; which don't have SignalK.
To update to a newer version, download the latest available .swu file for your device (Venus GX, raspberrypi), and install it using the offline install method.
Note for the raspberrypis that it is not necessary, nor recommended to reinstall a full image on an sdcard. Doing so will also remove all configuration and stored data.
Latest available files:
- Venus GX: venus-swu-beaglebone-20191221131757-v2.50~2-signalk-1.swu.
- RaspberryPis: venus-swu-raspberrypi2-20191221133738-v2.50~2-signalk-1.swu
Open a web browser, and go to the SignalK Dashboard by navigating to http://192.168.178.122:3000 (replace the ip address by the ip of your GX Device).
Further documentation about that is ... (some link to singalk-node documentation?)
Use this to, for example, configure a USB-connected NMEA0183 connection in SignalK. To do so, go to the dashboard (http://0.0.0.0:3000), and there to Server -> Connections.
Make sure to not add a connecting using any of the built-in serial ports (/dev/ttyO0, /dev/ttyO2, /dev/ttyO4, /dev/ttyO5). These are the VE.Bus- and VE.Direct ports on the Venus GX, and it is not necessary to configure them in SignalK. Data from any devices there connected is already available in SignalK, by means of the "Victron Venus Plugin"; see Dashboard -> Server -> Plugin Config.
Note that once configured in SignalK, for example a USB-serial port, that port is no longer normally available in Venus OS. For example, when plugging in a USB-GPS; and then adding a connection for its corresponding tty in the SignalK, makes for that GPS to be no longer be recognised and available in Venus OS.
For the Venus GX, SignalK comes pre-configured with a NMEA2000 listener for the VE.Can ports, its named "n2k-on-ve.can-socket", and uses the canboatjs.
Note that, to keep that operational, that port must be configured as a 250kbit VE.Can & NMEA2000 port in the Remote Console.
TODO: explain & warn about data partition size & space (since thats where plugins are installed by signalk on Venus OS). FIlling up the datapartition can corrupt Venus OS. More information about data partition on Venus OS here: https://github.com/victronenergy/venus/wiki/data-partition
You want the data available in SignalK and in Venus OS, so that it gets to VRM. And preferably a quality GPS.
USB GPS Dongle
Plugging it into the GX Device will make it be recognised automatically; within Venus OS itself as well as in SignalK, using the victron venus plugin. No need to configure anything.
NMEA2000 GPS Data
Connect it to the GX Device on the canbus port. Consider using our VE.Can to NMEA2000 cable to go from Micro-C to RJ-45.
Venus OS itself is unfortunately not yet able to pickup GPS data from the canbus.
But SignalK will pick it up.
There is no way (yet) to share it from within SignalK to Venus OS; and therefor it also will not be available to use on the VRM Portal.
Part of a NMEA0183 network
Tbd.