Skip to content

Open Source echo sounder / depth sounder / SONAR for bathymetry and research. Arduino based and compatible.

Notifications You must be signed in to change notification settings

Neumi/open_echo

Repository files navigation

Open Echo Cover

Universal Open-Source SONAR Controller and Development Stack

An ongoing open-source hardware and software project for building sonar systems for testing, boating, bathymetry, and research.
The most commonly used hardware is the TUSS4470 Arduino Shield, which stacks on top of an Arduino Uno to drive the TUSS4470 ultrasonic driver.
The board can run the RAW Data Firmware to operate a wide variety of ultrasonic transducers, covering frequencies from 40 kHz up to 1000 kHz in different media such as air or water.

The NMEA Output Firmware can read depth data from commercially available in-water ultrasonic transducers (e.g., on boats) and output NMEA0183-compatible data to a computer or a UART-connected device such as a Pixhawk or other controllers.

Open Echo has been tested on multiple ultrasonic transducers and is compatible with all of them—from car parking sensors to Lowrance Tripleshot side-scan transducers.

The Python Interface Software connects to Open Echo boards running the RAW Data Firmware. It can display raw echo data, change configurations, output a TCP depth data stream, and more.

Check the Getting Started Guide!

If something is unclear or you find a bug, please open an issue.

If you need the hardware, you can order it using the Hardware Files from a board + SMT house (JLC recommended), or send me a DM on the Discord server, or send an email to: [email protected] One assmebled board is 50€ + shipping.

Open Echo Interface Software

TUSS4470 Arduino Shield:
PCB overview TUSS4470

This project is currently in development. The TUSS4470 Development Shield is ready for external use!

Development is ongoing—check the documentation and Discord channel for the latest updates.

Want to stay updated or participate? Join the Discord!

Check the Getting Started Guide.

Vision

An accessible Open Source SONAR stack for development, research and real use:

  • Open Source SONAR technology for differernt use cases
  • support for a variety of commercial or DIY transducers in water and air
  • relatively simple hardware that can be ordered from a board house
  • easy entry for less experienced users
  • community for exchange and development
  • development of more advanced SONAR applications

Current State

  • Universal TUSS4470-based Arduino shield for testing ultrasonic transducers
  • Python interface software for raw data visualization, configuration, and TCP data output
  • Tested depth range of at least 50 m in water
  • NMEA0183 compatible (DBT data output to other devices)
  • New all-in-one boards with STM32, TUSS4470, and boost converter currently in development
  • picoW implementation in development (already successfull)
  • UDP network RAW data transfer from picoW to Python interface running

Progress

The new (May 2025) TUSS4470 Arduino Shield supports transducers from 40 kHz to 1000 kHz. It can drive them, receive echoes, filter signals, and send raw echo data to the Python backend.
Driver voltage can be supplied from Arduino VIN or via the external XT30 connector. With an MT3608 boost converter, USB can be used as a power supply and boosted to the desired drive voltage (manual soldering required).

The TUSS4470 Arduino Shield is and will remain the main development board for this project. It is an excellent platform for testing and development.
It can drive a wide range of transducers at different voltages, but it is limited by RAM size and sampling speed. You can capture 1800 samples at 12 microseconds per sample (~18 m range in water) with 8-bit resolution. For longer ranges, you can add a delay to capture echoes from more distant objects.
This makes it a perfect board for learning, testing, and prototyping. Most software development is done using this board.

For special use cases, additional boards are under development.
Some use STM32 + TUSS4470, some include additional data outputs, some have a boost transformer stage between the TUSS4470 and the transducer, and others are purely experimental.
Check the development folder.

All-In-One Board


Open Echo Interface Software

Firmware examples are available in each project folder.
The Open Echo Interface Software allows you to control Open Echo boards, view live data, and adjust board settings.

Live echogram in water on Python software (6x speed):
Software running with live echo data

Test results Baltic Sea

Tested using a built-in 150 kHz SEAFARER transducer, powered at 15-20 V via an MT3608 boost converter from USB. In the plots, data capture begins at the bottom.

38m Range
38 m range test
Kiel Channel
Kiel Channel sand and mud
Stollergrund
Slope near Stollergrund
Stones and Sand
Stones and sandy seabed
Fish
Fish detection
Multiple Reflections
Multiple reflections and seaweed

Videos

LINK TO LATEST VIDEO

https://www.youtube.com/watch?v=R3_NO2F7PsI
https://www.youtube.com/watch?v=msbLVsY8xhQ
https://www.youtube.com/watch?v=eJ8jVEQSx_Y
https://www.youtube.com/watch?v=Bxh3rWd5RZk
https://www.youtube.com/watch?v=UDYWQIizN7A

Useful Links

https://www.rapp-instruments.de/RemoteSensing/Roves/sidescan/sidescan.htm
https://www.youtube.com/watch?v=ZtUkt8Q4EJE

Shopping List

Transducers:

Transformers (to step up transducer voltage):
https://de.aliexpress.com/item/1005003733606845.html

Matching capacitors:
https://de.aliexpress.com/item/1005007159862392.html

Lucky Fishfinder:
https://de.aliexpress.com/item/32711659077.html

Big Thanks for Your Support!

www.kogger.tech

to the awesome project contributors:

Check this Cheap Yellow Display implementation out: https://github.com/matztam/open_echo_cyd_display

And all the great stuff JohnCHarrington contributed: https://github.com/JohnCHarrington/open_echo

About

Open Source echo sounder / depth sounder / SONAR for bathymetry and research. Arduino based and compatible.

Resources

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published