Karaburan: Difference between revisions

From RevSpace
Jump to navigation Jump to search
 
(50 intermediate revisions by the same user not shown)
Line 8: Line 8:


== Next steps ==
== Next steps ==
* <s>engage with PX4 community on getting a feel if this is useful to use and if so, how to get started</s>
* <s>figure out how to duplicate an MQTT stream</s> don't bother
* write python scripts
* write python scripts
** arduino turbidity
** <s>arduino turbidity</s> don't bother
** turbidity-to-mqtt
** <s>turbidity-to-mqtt</s> maybe make this ROS module
** <s>HID-to-mqtt</s> maybe make this ROS module
** position/velocity listener script: latitude, longitude, altitude, heading/bearing/track/whatever, velocity
* hook things into systemd / udev
* hook things into systemd / udev
** e.g. insert GPS -> create symlink with udev -> trigger (re)start of gpsd
* analoog in op de pi:
* analoog in op de pi:
** https://elektronicavoorjou.nl/product/adc-pi/
** https://elektronicavoorjou.nl/product/adc-pi/
Line 22: Line 24:
** 1-wire adapter emulation on an stm32: https://github.com/alitekin2fx/stm32_ds2480_emu
** 1-wire adapter emulation on an stm32: https://github.com/alitekin2fx/stm32_ds2480_emu
** owfs.org for easy interfacing with multiple 1-wire devices in a hierarchical way on linux
** owfs.org for easy interfacing with multiple 1-wire devices in a hierarchical way on linux
* Figure out the udev/hotplug mess, we probably need this because many of our peripherals use a serial port:
** in how many places can we store the udev renaming logic (config files)
** can we automate this, make it user friendlier, e.g. some kind of "insert device X now" script


Check:
Check:
Line 56: Line 61:


See https://github.com/bertrik/karaburan/tree/master/influxdb
See https://github.com/bertrik/karaburan/tree/master/influxdb
=== ROS ===
Investigation:
* Use ROS 2, not the old ROS 1
* Cannot work comfortably with debian, works best with ubuntu
* Using gpsd:
** install ros-jazzy-desktop
** ros2 launch gpsd_client gpsd_client-launch.py


== Introduction ==
== Introduction ==
Line 104: Line 117:
* Use with Linux / gpsd: https://stackoverflow.com/questions/77314115/drotek-gpsd-and-ntrip-correction-data-for-precise-positioning ?
* Use with Linux / gpsd: https://stackoverflow.com/questions/77314115/drotek-gpsd-and-ntrip-correction-data-for-precise-positioning ?
* Chipsets
* Chipsets
** Quectel LC29H
** Quectel LC29H (default: 115200 bps)
*** review: see https://rtklibexplorer.wordpress.com/2024/04/28/dual-frequency-rtk-for-less-than-60-with-the-quectel-lc29hea/
*** review: see https://rtklibexplorer.wordpress.com/2024/04/28/dual-frequency-rtk-for-less-than-60-with-the-quectel-lc29hea/
*** configuration: https://rtklibexplorer.wordpress.com/2024/05/06/configuring-the-quectel-lc29hea-receiver-for-real-time-rtk-solutions/
*** configuration: https://rtklibexplorer.wordpress.com/2024/05/06/configuring-the-quectel-lc29hea-receiver-for-real-time-rtk-solutions/
Line 138: Line 151:


==== Comparison with reference coordinate ====
==== Comparison with reference coordinate ====
On october 4th, we took the RTK GPS to a kernnet reference point at 51.99712236/4.68886324, results below:
On october 4th 2024, we took the RTK GPS to a kernnet reference point at 51.99712236/4.68886324, results below:
 
From https://www.nsgi.nl/iv-api/rdinfo/rdpoint/389346:
* Year 2021: "51 59 49,64004", "4 41 19,90584", 48.039. In decimal degrees that is


Differences between the reference point and the measurements are calculated to easting ('X') and northing ('Y'), unit meter. To calculate distance in meters, we use a linear approximation:
Differences between the reference point and the measurements are calculated to easting ('X') and northing ('Y'), unit meter. To calculate distance in meters, we use a linear approximation:
Line 147: Line 163:
|+ Measurements + deviations
|+ Measurements + deviations
|-
|-
! Name !! Latitude !! Longitude !! dx !! dy !! absolute !! Remark
! Name !! Latitude !! Longitude !! dx (m) !! dy (m) !! absolute (m) !! Remark
|-
| Reference 2012 || 51.99712236 || 4.68886324 || - || - || 0 || by definition
|-
|-
| Reference || 51.99712236 || 4.68886324 || - || - || 0 || by definition
| Reference 2021 || 51.99712223 || 4.68886273 || - || - || 0 || by definition
|-
|-
| Screenshot 1 || 51.99712217 || 4.68886567 || 0.167 || -0.021 || 0.168 || -  
| Screenshot 1 || 51.99712217 || 4.68886567 || 0.167 || -0.021 || 0.168 || -  
Line 161: Line 179:
| Average || - || - || 0.177 || -0.030 || 0.180 || -
| Average || - || - || 0.177 || -0.030 || 0.180 || -
|}
|}
According to [https://www.unavco.org/software/geodetic-utilities/plate-motion-calculator/plate-motion-calculator.html this page], the rate of movement is about
15.75mm/year to the north and 17.45 mm/year to the east (ITRF2020 model).
Over 12 years, that amounts to 0.189m north and 0.209m east.


== Air quality sensors ==
== Air quality sensors ==
Line 174: Line 196:
RIVM report on inexpensive nitrogen-in-air sensors: https://www.samenmeten.nl/sensoren-voor-no2
RIVM report on inexpensive nitrogen-in-air sensors: https://www.samenmeten.nl/sensoren-voor-no2
Conclusion: most sensors are not sensitive enough to be used in typical outdoor conditions, with perhaps one exception: alphasense NO2-B43F
Conclusion: most sensors are not sensitive enough to be used in typical outdoor conditions, with perhaps one exception: alphasense NO2-B43F
== Sonar sensors ==
Investigate this because it allows us to measure depth.
AliExpress has several types of affordable sonar sensors, focused at detecting fish, but also able to measure depth.
I ordered this one: https://nl.aliexpress.com/item/1005006388343879.html
* 125 kHz main frequency, range up to 200 ft deep (about 60m)
* bluetooth low-power interface (basically serial-over-BLE)
* built-in battery, powers on automatically when submerged
* reports 120-element array with raw sonar return intensity-vs-depth
* measures water temperature
* about 45 euro
Fish helper pro application for android https://apkpure.com/fish-helper-pro/com.fishfinderpro.xdx
=== Debug tool ===
I wrote a python script to connect to it from a linux computer: https://github.com/bertrik/wireless-sonar-sensor
It's connects to a "Fish Helper Pro" wireless sonar sensor over bluetooth low-energy, reports depth and temperature
=== ROS2 integration ===
The most appropriate message for a simple range would be: https://docs.ros2.org/foxy/api/sensor_msgs/msg/Range.html
There are other messages to perhaps report the raw echo return array.


== Water physical analysis ==
== Water physical analysis ==
Line 189: Line 236:


So the Aliexpress sensor is suited only for "dirty" water.
So the Aliexpress sensor is suited only for "dirty" water.
=== Water measurement probes ===
I bought this one: Tuya compatible BT785 EC meter: https://nl.aliexpress.com/i/1005007462079781.html inexpensive, focused on EC, runs on 4x LR44
Probably speaks the tuya serial protocol:
https://developer.tuya.com/en/docs/iot/tuya-cloud-universal-serial-port-access-protocol?id=K9hhi0xxtn9cb
* https://nl.aliexpress.com/item/1005003784454381.html BLE-9908 Inexpensie "Yieryi" PH/EC/Temp probe with bluetooth and app, about E25,- (Uses 3x LR44 coin cell batteries)
* Several different models: https://nl.aliexpress.com/item/1005007810989801.html
** EZ9901: TDS/pH/temp
** EZ9902: EC/pH/temp
** EZ9908: EC/TDS/pH/temp
** EZ9909: TDS/EC/pH/salt/temp
* The bluetooth versions are probably as above, with numbers like BLE9902 and BLE9908
* Yiery BLE9902: https://shop.yieryimeters.com/products/yieryi-ble-9902-3-in-1-digital-ph-meter-with-bluetooth-ec-and-temperature-measurement-ideal-for-water-quality-testing-in-pools-fish-tanks-hydroponics-more
* BLE-EC01 is a bluetooth EC meter, can find it here https://www.amazon.com/BLE-EC01-Smart4-TDS-Temp-Meter/dp/B0DPZZC7BV, not on AliExpress?
Note:
* Some probes indicate EC (electrical conductivity), other indicate TDS (total dissolved liquids). TDS is derived from EC (knowing the liquid type). EC is the more universal/fundamental property!
* EC is typically expressed in uS/cm or mS/cm (micro or milli siemens per centimeter), say 500 uS/cm for outdoor water.
* EC is temperature dependent, typically you need the value extrapolated to 25 degrees Celcius. Temperature-EC correlation rule of thumb: about 2% more conductive per K.
* pH sensors are almost by definition fragile and last only a limited time, so probably don't bother trying to use one at all. The pH of outdoor water might not be that interesting to measure.


== Boat control ==
== Boat control ==
Line 239: Line 308:


== Implementation ==
== Implementation ==
=== udev handling of serial ports ===
Many peripheral devices are connected through serial.
The plan is to have an udev config file with renaming rules, so each peripheral gets a stable name in /dev .
The plan is also to create the udev config using some python: insert device X now -> write line to udev config.
The udev config file is:
  /etc/udev/rules.d/99-usb-serial.rules
<pre>
# LIDAR serial converter
SUBSYSTEM=="tty", ATTRS{idVendor}=="10c4", ATTRS{idProduct}=="ea60", SYMLINK+="ttyLIDAR", MODE="0660", GROUP="dialout"
# quectel GPS
SUBSYSTEM=="tty", ATTRS{idVendor}=="1a86", ATTRS{idProduct}=="7523", SYMLINK+="ttyGPS", MODE="0660", GROUP="dialout"
# ublox GPS
SUBSYSTEM=="tty", ATTRS{idVendor}=="0403", ATTRS{idProduct}=="6001", SYMLINK+="ttyGPS", MODE="0660", GROUP="dialout"
</pre>
An USB-nano also appears to have a USB vendor/product id of 1a86/7523 ("USB2.0-Serial") ... same as the quectel GPS?
Same for "AI thinker" USB-serial: vendor/product id of 1a86/7523 (product: "USB2.0-Serial")
To (re)load the properties:
<pre>
sudo udevadm control --reload-rules
</pre>
=== reading temperature sensor ===
=== reading temperature sensor ===
The idea is to to use a DB18B20 temperature sensor, read it using an arduino nano board acting as a 1-wire adapter.
The idea is to to use a DB18B20 temperature sensor, read it using an arduino nano board acting as a 1-wire adapter.

Latest revision as of 14:12, 24 October 2025

Project Karaburan
Monitoring water quality
Status In progress
Contact bertrik
Last Update 2025-10-24

Next steps

Check:

USB HID as analog input

An stm32 based bluepill board can be flashed with firmware to allow its analog inputs to be exposed as USB HID sliders.

Flashing the bluepill with openocd to the freejoy firmware:

  • install openocd
 sudo apt install openocd
  • connect an stlinkv2 to an stm32 bluepill, connect the stlinkv2 to USB
  • flash the freejoy firmware as follows:
 openocd -s /usr/share/openocd/scripts -f interface/stlink.cfg -f target/stm32f1x.cfg -c init -c "program firmware.hex verify reset exit"
  • watch the kernel logs
 sudo dmesg -w
  • connect the stm32 using a USB cable
  • download the freejoy configurator from https://github.com/FreeJoy-Team/FreeJoyConfiguratorQt
  • start the configurator and load the karaburan.cfg setting
  • Write config to device -> it should reboot now and come up with the new settings

Verify that it works:

  • install the evtest package
  • run
 evtest /dev/input/by-id/usb-FreeJoy_FreeJoy_v1.7.1-event-if00

See also https://github.com/vostrenkov/EazyJoy

influxdb

See https://hub.docker.com/_/influxdb

See https://github.com/bertrik/karaburan/tree/master/influxdb

ROS

Investigation:

  • Use ROS 2, not the old ROS 1
  • Cannot work comfortably with debian, works best with ubuntu
  • Using gpsd:
    • install ros-jazzy-desktop
    • ros2 launch gpsd_client gpsd_client-launch.py

Introduction

Topics:

  • air quality sensors
    • ammonia
    • NOx
  • water chemical analysis
    • nitrates
    • ammonia
    • dissolved oxygen
    • sulfide/sulfate
    • phosphates?
    • salinity (chlorides?)
  • water physical analysis
    • temperature
    • clarity/turbidity -> investigate standard ways of measuring/expressing this
    • conductivity/total dissolved solids
    • water properties by light reflection, hyperspectral/polarity
    • depth?
  • boat control
    • trajectory -> steering
    • idea: interface with the remote control, not with the boat
    • idea: find a boat with easily hackable remote control protocol
    • idea: can we get sensor data over this link too, e.g. GPS?
  • camera control
  • post-processing
    • data presentation
      • video/photo stitching
      • time lapse view
      • map view of properties
  • use cases
    • verify with domain experts, how to engage?
    • slootview, under/above water
    • minimum viable prototype
    • high-res measurement by location, by time
  • materials
    • boat selection
    • processing platform selection
    • communication platform selection

Investigate RTK GPS

Goal: figure out if it is practically possible to achieve cm resolution with a 200-euro GPS and a free correction service: YES

Edit /etc/default/gpsd, set GPSD_OPTIONS:

 GPSD_OPTIONS="-Gn ntrip://user:pass@ntrip.kadaster.nl:2101/CBW100NLD0"

Option -G exposes the control socket on all network interfaces, option -n keeps the GPS active if there is no one currently connected.

Plotting live location on a map:

Station at Stolwijk (close to Gouda): https://gnss1.tudelft.nl/dpga/station/Stolwijk.html#STWK ?

Starting from the command line:

  • stop gpsd.socket
 sudo systemctl stop gpsd.socket
  • run from command line
 sudo /usr/sbin/gpsd -Gn -D 1 -N /dev/ttyUSB0 .... (not sure yet)

Validation

How to show that RTK GPS is actually accurate?

  • Relative positioning: with an "fix RTK" solution, place the antenna at 4 points 25cm apart, each point for 20 seconds or so -> you see 4 distinct clusters of points
  • Positioning over short time: put it in a fixed location, make sure that it has "fix RTK" solution, take 100 measurements or so -> determine the radius of the circle that contains 90% of the points
  • Positioning over longer time: do this for (say) an hour
  • Absolute positioning: look up a national reference point, for example "RD-punt 389346", located on the Sluisdijk between Gouda and Moordrecht. Technical data: https://www.nsgi.nl/iv-api/rdinfo/rdpoint/389346

Comparison with reference coordinate

On october 4th 2024, we took the RTK GPS to a kernnet reference point at 51.99712236/4.68886324, results below:

From https://www.nsgi.nl/iv-api/rdinfo/rdpoint/389346:

  • Year 2021: "51 59 49,64004", "4 41 19,90584", 48.039. In decimal degrees that is

Differences between the reference point and the measurements are calculated to easting ('X') and northing ('Y'), unit meter. To calculate distance in meters, we use a linear approximation:

  • For dy: 40075km/360 = 111,319 m/deg
  • For dx: dy * cos(latitude) = 68,549 m/deg
Measurements + deviations
Name Latitude Longitude dx (m) dy (m) absolute (m) Remark
Reference 2012 51.99712236 4.68886324 - - 0 by definition
Reference 2021 51.99712223 4.68886273 - - 0 by definition
Screenshot 1 51.99712217 4.68886567 0.167 -0.021 0.168 -
Screenshot 2 51.99712200 4.68886533 0.143 -0.040 0.149 -
Meting 1 51.9971220 4.6888663 0.210 -0.040 0.214 -
Meting 2 51.9971222 4.6888660 0.189 -0.018 0.190 -
Average - - 0.177 -0.030 0.180 -

According to this page, the rate of movement is about 15.75mm/year to the north and 17.45 mm/year to the east (ITRF2020 model). Over 12 years, that amounts to 0.189m north and 0.209m east.

Air quality sensors

Nitrogen compounds in air

According to https://www.rivm.nl/stikstof/monitoren-advies-onderzoek/overzicht-stikstofmetingen/metingen-stikstof-in-de-lucht average (typical?) values of

  • Ammonia (NH3): 6.7 ug/m3 (9.6 ppb)
  • NOx: 27.3 ug/m3
  • NO2: 18.6 ug/m3 (9.9 ppb)

(ppb-conversion using https://www.breeze-technologies.de/blog/air-pollution-how-to-convert-between-mgm3-%C2%B5gm3-ppm-ppb/ )

RIVM report on inexpensive nitrogen-in-air sensors: https://www.samenmeten.nl/sensoren-voor-no2 Conclusion: most sensors are not sensitive enough to be used in typical outdoor conditions, with perhaps one exception: alphasense NO2-B43F

Sonar sensors

Investigate this because it allows us to measure depth.

AliExpress has several types of affordable sonar sensors, focused at detecting fish, but also able to measure depth.

I ordered this one: https://nl.aliexpress.com/item/1005006388343879.html

  • 125 kHz main frequency, range up to 200 ft deep (about 60m)
  • bluetooth low-power interface (basically serial-over-BLE)
  • built-in battery, powers on automatically when submerged
  • reports 120-element array with raw sonar return intensity-vs-depth
  • measures water temperature
  • about 45 euro

Fish helper pro application for android https://apkpure.com/fish-helper-pro/com.fishfinderpro.xdx

Debug tool

I wrote a python script to connect to it from a linux computer: https://github.com/bertrik/wireless-sonar-sensor

It's connects to a "Fish Helper Pro" wireless sonar sensor over bluetooth low-energy, reports depth and temperature

ROS2 integration

The most appropriate message for a simple range would be: https://docs.ros2.org/foxy/api/sensor_msgs/msg/Range.html

There are other messages to perhaps report the raw echo return array.

Water physical analysis

Turbidity / clarity

See https://en.wikipedia.org/wiki/Turbidity

Aliexpress sensor TS-300B: https://nl.aliexpress.com/item/1005006732956937.html Has a range 0 ~ 1000 ± 30 NTU

Order of magnitude for turbidity:

  • Drinking water upper limit: 4 NTU (European turbidity standard for drinking water)
  • Ambient water: 10-150 NTU. The US state of Washington use a "background" value of 50 NTU as reference.

(see https://en.wikipedia.org/wiki/Turbidity#Standards_and_test_methods )

So the Aliexpress sensor is suited only for "dirty" water.

Water measurement probes

I bought this one: Tuya compatible BT785 EC meter: https://nl.aliexpress.com/i/1005007462079781.html inexpensive, focused on EC, runs on 4x LR44

Probably speaks the tuya serial protocol: https://developer.tuya.com/en/docs/iot/tuya-cloud-universal-serial-port-access-protocol?id=K9hhi0xxtn9cb

Note:

  • Some probes indicate EC (electrical conductivity), other indicate TDS (total dissolved liquids). TDS is derived from EC (knowing the liquid type). EC is the more universal/fundamental property!
  • EC is typically expressed in uS/cm or mS/cm (micro or milli siemens per centimeter), say 500 uS/cm for outdoor water.
  • EC is temperature dependent, typically you need the value extrapolated to 25 degrees Celcius. Temperature-EC correlation rule of thumb: about 2% more conductive per K.
  • pH sensors are almost by definition fragile and last only a limited time, so probably don't bother trying to use one at all. The pH of outdoor water might not be that interesting to measure.

Boat control

Typically the wireless link looks like this:

  • 2.4 GHz working frequency
  • 500m range

Interesting links:

remote control

Image of remote control RF chip: [...]

Parts:

  • 12.000 MHz crystal/oscillator
  • 16-pin control chip: 20_CL6L071
  • 6-pin RF chip: 1110 / VKA3, could be an rx/tx switch, amplifier or filter circuit

See also: https://www.open-tx.org/

Next steps:

  • map out the connections between the mainboard and the rf board, expected: VCC, GND, spi ?

Use cases

material:

Useful distinction, typically used in documents/guidelines:

  • chemical quality, what substances are present in the water?
  • biological / ecology quality, what kind of living organisms live in the water?

Reeuwijkse plassen

See

potential applications:

  • inspect water sides (oever) over time
  • underwater camera: detect invasive cray fish
  • sample water properties at high spatial resolution, high time resolution
  • early detection of indicators for cyanobacteria: temperature and nutrients

Detect/find pollution source

  • ...

Implementation

udev handling of serial ports

Many peripheral devices are connected through serial. The plan is to have an udev config file with renaming rules, so each peripheral gets a stable name in /dev . The plan is also to create the udev config using some python: insert device X now -> write line to udev config.

The udev config file is:

 /etc/udev/rules.d/99-usb-serial.rules
# LIDAR serial converter
SUBSYSTEM=="tty", ATTRS{idVendor}=="10c4", ATTRS{idProduct}=="ea60", SYMLINK+="ttyLIDAR", MODE="0660", GROUP="dialout"
# quectel GPS
SUBSYSTEM=="tty", ATTRS{idVendor}=="1a86", ATTRS{idProduct}=="7523", SYMLINK+="ttyGPS", MODE="0660", GROUP="dialout"
# ublox GPS
SUBSYSTEM=="tty", ATTRS{idVendor}=="0403", ATTRS{idProduct}=="6001", SYMLINK+="ttyGPS", MODE="0660", GROUP="dialout"

An USB-nano also appears to have a USB vendor/product id of 1a86/7523 ("USB2.0-Serial") ... same as the quectel GPS?

Same for "AI thinker" USB-serial: vendor/product id of 1a86/7523 (product: "USB2.0-Serial")

To (re)load the properties:

sudo udevadm control --reload-rules

reading temperature sensor

The idea is to to use a DB18B20 temperature sensor, read it using an arduino nano board acting as a 1-wire adapter. Use openwire-fs as user-side openwire software http://owfs.org

Preparation:

  • Add the regular user to the 'dialout' group, so it can access serial ports
 sudo adduser <name> dialout

Setting up the hardware:

  • connect the DS18B20 to the connector board with the pull-ups
  • wire the connector board to the arduino nano, see ...
  • plug the arduino nano in the pi

Setting up the software:

  • Install openwire fs
 sudo apt install owfs
  • Create the openwire fs mountpoint
 sudo mkdir /mnt/1wire
  • Configure owfs, edit /etc/owfs.conf
 server: device = /dev/ttyUSB0
 mountpoint = /mnt/1wire
 allow_other
 (comment out the line with the FAKE devices)
  • Configure systemd services
 sudo systemctl enable owserver owhttpd
 sudo systemctl disable owftpd
  • Start the systemd service
 sudo systemctl start owserver owhttpd
  • Check the logs
 sudo journalctl -xeu owserver -f
  • Open a browser to view the web interface
 http://localhost:2121 or
 http://raspberrypi.local:2121