# open_echo
**Repository Path**: ctguhzy/open_echo
## Basic Information
- **Project Name**: open_echo
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2026-01-18
- **Last Updated**: 2026-01-18
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
## 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](TUSS4470_shield_002/), which stacks on top of an Arduino Uno to drive the TUSS4470 ultrasonic driver.
The board can run the [RAW Data Firmware](TUSS4470_shield_002/getting_started_TUSS4470_firmware.md) 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](TUSS4470_shield_002/arduino/NMEA_DBT_OUT/NMEA_DBT_OUT.ino) 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](TUSS4470_shield_002/getting_started_interface.md) connects to Open Echo boards running the [RAW Data Firmware](TUSS4470_shield_002/getting_started_TUSS4470_firmware.md). It can display raw echo data, change configurations, output a TCP depth data stream, and more.
Check the [Getting Started Guide](TUSS4470_shield_002/README.md)!
If something is unclear or you find a bug, please open an issue.
Raw Data Waterfall chart in the Python Desktop software:
## Getting the Hardware
If you need the hardware, you can order it using the [Hardware Files](TUSS4470_shield_002/TUSS4470_shield_hardware/TUSS4470_shield) from a board + SMT house ([JLC recommended](https://jlcpcb.com/?from=Neumi)).
They can also be bought as a complete and tested set direclty from Elecrow: https://www.elecrow.com/open-echo-tuss4470-development-shield.html
If they’re out of stock, or if you’d prefer to order them within Germany to reduce shipping costs, please send me an email at: openechoes@gmail.com
All profits go directly toward supporting and advancing the Open Echo project!
If you don't order the boards directly from me or Elecrow, please be aware that I can't provide support.
[TUSS4470 Arduino Shield](TUSS4470_shield_002/):
### This project is currently in development. The [TUSS4470 Development Shield](TUSS4470_shield_002/) 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](https://discord.com/invite/rerCyqAcrw)!
Check the [Getting Started Guide](TUSS4470_shield_002/README.md).
## 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](TUSS4470_shield_002/) 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](TUSS4470_shield_002/) 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 and software are under development.
Check the [development](development) folder for development work.
--------
## Open Echo Interface Software
Firmware examples are available in each project folder.
The [**Open Echo Interface Software**](TUSS4470_shield_002/echo_interface.py) allows you to control Open Echo boards, view live data, and adjust board settings.
Live echogram in water on Python software (6x speed):
## 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.
![]() 38 m range test |
![]() Kiel Channel sand and mud |
![]() Slope near Stollergrund |
![]() Stones and sandy seabed |
![]() Fish detection |
![]() Multiple reflections and seaweed |