/ClipperDuet2N2k

NASAmarine Clipper Duet Echo Sounder/Log to NMEA2000 converter

Primary LanguageCMIT LicenseMIT

NASA Clipper Duet Echo Sounder/Log to NMEA2000 converter (ClipperDuet2N2k) ⛵ 🛠️

(German HOWTO)

Intro

ClipperDuet2N2k project is about retrofitting1 a NASAmarine Clipper Duet echo sounder/log with NMEA2000.

It makes use of an ESP32 equipped with a CAN transceiver to read the LCD controller's data and recompute usable values for water depth, speed and distance logs to be send into the NMEA2000 CAN network.

A small "in action" photo with the ClipperDuet2N2k connected to a Raymarine display, and CANable PC adapter: ClipperDuet2N2k front side

On the back side, there are two additional cables for the NMEA2000 CAN bus wired through the existing cable port. This build also has a USB-C socket for serial communications with the ESP32 module, and as an alternative to the OTA firmware update via WIFI: ClipperDuet2N2k back side

See my chaotic test setup2 below: Test setup showing Clipper Duet connected to NMEA2000 bus

HOWTO

Prerequisites

Hardware needed:

  • NASAmarine Clipper Duet (in case there are different versions around: the LCD controller must be an HT1621 and the LCD segment/com layout must be the same as in this implementation)
  • ESP32 module with a CAN transceiver3
  • a power supply module for the ESP32 which runs with the ca. 12V of your boat. It should deliver either 5V or 3.3V depending on your ESP32 module

Software needed:

  • ClipperDuet2N2k firmware (maybe as an already compiled binary ready for upload)
  • some means of uploading the firmware to the ESP32

The firmware is written for the ESP32. It makes use of PlatformIO with the Arduino framework.

Additional libraries:

Clipper Duet modification

You need to attach SPI MOSI, CLK, CS and GND wires of the ESP32 to the Clipper Duet front pcb.

Connection schema: showing solder connections to the ESP32 SPI pins

It's easiest to directly solder wires to the pins of the through-hole technique PIC microcontroller on the back side of the front pcb.

It is unknown if there are different hardware revisions of the Clipper Duet around. Check yours to have the same ht1621 type of LCD controller and the same LCD layout.

The firmware expects these connections (Arduino style pin numbering):

ESP32 GPIO ClipperDuet function / comment
GPIO_NUM_12 (SPI MOSI) PIC µC pin 4 HT1621 DATA
GPIO_NUM_13 (SPI MISO) unconnected must exist due to SPI implementation
GPIO_NUM_14 (SPI CLK) PIC µC pin 5 HT1621 WR
GPIO_NUM_27 (SPI CS) PIC µC pin 7 HT1621 CS
GPIO_NUM_5 CAN TX CAN transceiver3
GPIO_NUM_4 CAN RX CAN transceiver3
GPIO_NUM_4 CAN RX CAN transceiver3
GND PIC µC pin 8 use any convenient GND connection
5V PIC µC pin 1 use any convenient 5V connection

The ESP32 is experienced to have 5V tolerance on the GPIO pins above. Considering the cheapness of the ESP32 modules, there is no level converter used.

Lolin32 board connected

I used cheap "Lolin32" ESP32 boards, as these were quite slim with a thin PCB. If you plan to remove the USB header, make sure to have your board programmed beforehand. Subsequent updates can be made OTA via WIFI.

A power supply for the ESP32 is needed. Most ESP32 modules want either 3.3V or 5V. The on-board 5V regulator of the Clipper Duet should not be used, as the ESP32 could draw too much power even without WIFI - YMMV.

On my builds, I removed the on-board 78L05 (TO-92 footprint) regulator and installed a more powerful 7805 with TO-220 footprint on the other side of the ClipperDuet PCB. This modification made room for the ESP32 board to fit between the backlight and the PCB.

Lolin32 board sandwiched between backlight and front PCB of the ClipperDuet

See also doc/ directory for more pictures,

First start

ClipperDuet2N2k firmware needs no special setup or configuration by the user.

Before real use, you should have at least once set your Clipper Duet into configuration mode (hold Illum key depressed while powering on) and confirm all the adjustments (keel offset, gain threshold, paddle wheel calibration value, units). ClipperDuet2N2k will read those settings and save it into its non-volatile memory, so that settings like the keel offset are known to the unit and can be sent in NMEA2000 sentences.

Without this configuration step, a keel offset of -3m is used as default for safety.

Usage

ClipperDuet2N2k will send NMEA2000 sentences for depth, speed, trip and total log.

Other NMEA2000 devices like chart plotters or MFDs are able to display these values. The units used on the NASA Clipper Duet can be adjusted to free will, values will automatically be converted to the base units of the respecticve NMEA2000 sentences.

Due to the nature of implementation, only the values shown are constantly sent out via NMEA2000. As unit conversion takes place using double float values, there might be minor rounding errors. This choice was made to ease development, as the NMEA2000 library also uses double floats.

Invalid water depth readings shown as "out" on the Clipper Duet are also sent as invalid value on NMEA2000, so other bus devices can detect false or missing readings. The keel offset configured in your Clipper Duet is sent as a negative offset in the water depth NMEA2000 sentence (your frontend display will most likely automatically account for this offset).

Beware that the update rate of the Clipper Duet and the small delay during data preparation adds up to the display delays on your frontend device. Also there are some bad implementations by some manufactures who preferred nice rolling values over fast update rates.

The trip and total distance log are sent in one NMEA2000 sentence. When showing the trip value, the trip distance and the last known total log are sent. When showing the total log, the trip and total values are sent only if they have been displayed less than 60s apart. If a the unit has read a system time/GNSS time (PGN 126992, 129029) from the NMEA2000 bus, this time is used to form a timestamp for the distance log sentence.

Configuration and calibration is done as usual by manually adjusting the settings via the buttons on the NASA Clipper Duet. Setting changes in the Clipper Duet are read by the ClipperDuet2N2k (see "First start").

For convenience, NMEA2000 traffic is output on the serial port in ActiSense format. So the ClipperDuet2N2k could be also used as a NMEA2000 to (USB-)serial gateway (with or without being connected to a Clipper Duet).

Firmware update

In case the firmware was compiled with OTA firmware update capability (WITH_OTA defined), ClipperDuet2N2k starts a WIFI access point when the Clipper Duet is in configuration mode. The access point will appear with a SSID ClipperDuet2N2k-..._.

You can access the update web page via going to clipperduet2n2k.local or 192.168.4.1 in the web browser of your device connected to the ClipperDuet2N2k-... access point.

As soon as configuration mode is left, ClipperDuet2N2k will reboot without WIFI.

Attention: Make sure your settings are configured correctly after a firmware upgrade! Non-volatile-memory might have been overwritten by the update.

Simulating sensors

Instead of the speed sensor, a function generator with ca. 3V amplitude, square signal at a few hundred Hz can be used.

For the transducer, I have no good benchtop solution. On one ClipperDuet device, it suffices to put a finger across the sensor port to get some readings, but a different one is rather immune against this trick. Beware of shock!

Implementation insights

The PIC microcontroller of the Clipper Duet tells the HT1621 LCD controller which segments should be on depending on the values to be displayed.

Pulseview screenshot of SPI-like communication of the PIC mcu with the HT1621 LCD controller

The segment/com lines have been explored by writing a test software which make the LCD controller highlight single segments, so that a map of the segments and common planes could be made.

LCD segment layout

The ESP32 reads the communications of the PIC microcontroller with the HT1621. The PIC periodically sends data for the entire display memory of the LCD controller.

ClipperDuet2N2k ESP32 maps this display memory back to the 5 digits plus some symbols. The digits and symbols are then used to deduce the values, units and state of the Clipper Duet. The assembled data is then translated into standard NMEA2000 sentences and written to the CAN bus.

Shallow depth and speed alarm settings are read by the ClipperDuet2N2k, but as there is no well-known NMEA2000 PGN, no sentence with these values is sent.

Firmware Development Info

Versioning scheme is major.minor.patch Version data is included via the version.py pre:-script run by PlatformUIO

The N2K software version is shown as

  • major.minor.patch.0 for tags
  • major.minor.patch.num_of_additional_commits for commits
  • 0.major.minor.patch for a "dirty" build

N2k software version also shows build date. The format seems to be the one which is used in Timo Lappalainen's library, so I'll stick to it.

A full "git describe --allways --dirty" version string is included in the binary in NMEA2000.SetInstallationDescription1.

The elegantWebpage.h has been compiled from the ui/ folder of the elegantOTA library. Logo and favicon was changed.

Hardware Development Info

Clipper Duet is a simple device which is more on the cheaper end of the price range of depth sounders. ClipperDuet2N2k accounts for this and tries to keep things simple.

Following this KISS principle, the hardware was just thrown together using modules which were lying around.

Footnotes

Footnotes

  1. I reverse-engineered the schematics and partially recreated the PCBs in KiCAD. Link will follow once I uploaded this.

  2. The test setup consisted of a NASA Clipper Duet with an ESP32 devboard connected via a CAN transceiver to a marine MFD (in this case a Raymarine St70, which btw. is not recommended due to a number of bugs).

  3. A TI SN65HV231 was used, as it operates on 3.3V 2 3 4