User:Bertrik Sikken: Difference between revisions

From RevSpace
Jump to navigation Jump to search
 
(206 intermediate revisions by the same user not shown)
Line 5: Line 5:
}}
}}


You can reach me at bertrik@sikken.nl or bertrik@gmail.com
You can reach me at [mailto:bertrik@sikken.nl bertrik@sikken.nl] or [mailto:bertrik@gmail.com bertrik@gmail.com].


Studied Electrical Engineering at Twente University.
Studied Electrical Engineering at Twente University.
Line 11: Line 11:


Main interests:
Main interests:
* reverse-engineering things (USB stuff, mp3 players), working on http://rockbox.org
* reverse-engineering things (USB stuff, mp3 players), worked on http://rockbox.org (sansa clip players)
* studying bats and making electronics for recording/listening to bat sounds
* studying bats and making electronics for recording/listening to bat sounds
* radio stuff, in particular software-defined radio
* radio stuff, in particular software-defined radio
 
* energy-related stuff, visualisation
* citizen science, particulate matter measurement, noise


Projects I work(ed) on ([https://revspace.nl/index.php?title=User:Bertrik_Sikken&action=purge refresh]):
Projects I work(ed) on ([https://revspace.nl/index.php?title=User:Bertrik_Sikken&action=purge refresh]):
Line 27: Line 28:


== Project ideas ==
== Project ideas ==
[[File:always10oclock.jpg|right]]
[[File:praktischnut.jpg|right]]
[[File:idea.jpg|right]]
This is a list of ideas I'm thinking about, but have not fully developed into an actual project yet.
This is a list of ideas I'm thinking about, but have not fully developed into an actual project yet.


=== Measuring audio as a citizen science project ===
https://pine64.com/product/128mb-ox64-sbc-available-on-december-2-2022/
 
=== tuya serial protocol ===
 
=== action lsc stekker ===
https://keetsupport.nl/2024/03/20/how-to-flash-lsc-power-plug-with-esphome/
 
=== sipeed maix dock ===
Bought this a couple of years ago. Get familiar with this board.
Can I run a chess program on this, for example?
 
* https://wiki.sipeed.com/soft/maixpy/en/develop_kit_board/maix_dock.html
 
=== rfid keyfob ===
* aliexpress page: https://nl.aliexpress.com/item/1005009569496736.html
* firmware github:
** https://github.com/RfidResearchGroup/ChameleonUltra
** https://github.com/GameTec-live/ChameleonUltraGUI
 
=== advanced lidars for bat detection ===
livox:
* github page https://github.com/Livox-SDK/Livox-SDK/tree/master
* web page: https://www.livoxtech.com/
 
=== cubecell meshtastic motion detector ===
I have a cubecell AB01 board.
This board is focused on low power, has a connection to attach a solar panel and has a lora radio.
Relatively small amount of RAM, barely enough to run a LoRaWAN stack but probably plenty to run meshtastic
 
The plan is to build a simple motion detector from this (using a PIR).
The PIR can wake up the board from low-power, or a timer can wake it periodically.
 
See also: https://github.com/HelTecAutomation/CubeCell-Arduino/tree/master/libraries/Basics/examples/LowPower
 
=== configure multitech outdoor gateway ===
https://www.multitech.net/developer/products/multiconnect-conduit-platform/basestation/
 
https://multitech.com/product/multitech-conduit-mtcdt-246a-868-eu-gb/
 
emergency procedure:
https://www.multitech.net/developer/software/mlinux/using-mlinux/flashing-mlinux-firmware-for-conduit/
 
=== esp32 wtf ===
* https://forum.arduino.cc/t/ttgo-lilygo-lora-esp32-26mhz-problem/1353750
* "26 MHz crystal has been deprecated" https://github.com/espressif/arduino-esp32/issues/10117
 
=== kakofonie counter ===
Sample room audio, use neural network to distinguish voices to estimate number of people talking in the past 30 seconds or so.
Show this number on some kind of display, publish it to MQTT, make a nice graph of it.
 
Stuff to figure out:
* this is called 'speaker diarization'
* can it run on an ESP32?
* make a prototype
 
=== hypno toad ===
Put these LEDS https://nl.aliexpress.com/item/1005007583528891.html into https://www.action.com/nl-nl/p/2560347/solar-tuinbeeldje/
 
Turns out that the default circuit is really basic and output a rough step-up waveform to the LED.
The self-fading LEDs don't work very well with that.
 
Also, putting some IPA on hotglue makes it release really easy.
 
=== wasbeer / kat classifier ===
ESP32 with resnet50 neural net to distinguish house cats from other animals, see also:
* https://ieeexplore.ieee.org/document/10556848/
 
=== Nespresso brew counter ===
Several hacker spaces have one of these Nespresso cup coffee makers, but there's no obvious easy way to monitor usage (monitor ALL the things!).
Inspired by https://hackaday.com/2021/04/25/arduino-mkr-makes-nespresso-monitoring-easy/ this idea is making an even simpler nespresso monitor,
using an inexpensive WiFi enabled ESP8266 with an ubiquitous I2S microphone such as the INMP441.
 
Use this sound monitoring project:
https://github.com/aleiei/ESP8266-BUG-I2S-MIC
and turn it into a WiFi connected brew counter.
 
Software for getting microphone data from an ESP8266/I2S mic into Linux https://github.com/bertrik/EspMicServer
Nespresso sound is typically 50 Hz with overtones.
In a recording with the ESP8266, it appears that oddly the 17th harmonic (around 850 Hz) is quite strong.
 
The plan in the short term is this:
* apply a gentle IIR filter to subtract any DC bias from the microphone signal
* calculate autocovariance at offsets 0 and 20 ms (inverse of 50 Hz), representing the total energy and the energy at 50 Hz respectively
* compare amplitudes to decide about presence of 50 Hz signal, e.g. calculate ratio in dB
* use this to count the length of time that a 50 Hz signal is heard (increments of 100 ms or so)
* decide about none / espresso / lungo based on time
 
Might even integrate with esphome / home assistant later.
 
=== Remote bat box monitor ===
Idea:
* goal: check if remote bat boxes are occupied and identify the species
* challenges:
** connectivity: need to transport images/videos (no LoRaWAN), possibly out of range of mobile data networks
** autonomy: cannot reach the bat box once installed
** power: no fixed power connection, so probably needs a battery + solar panel
* design
** wake up every hour, take a picture, go to sleep, upload photos/videos once per day
** run from batteries, recharge by solar, rules of thumb
*** batteries should last for about 10 days
*** battery should be able to charge in 1 day
*** consider only 10% of peak solar power
** KPN "4G-op-zee" somewhat confusing article: https://www.kpn.com/zakelijk/mobiel/roaming/noordzee
* hardware
** main processor: raspberry pi zero
*** raspberry pi power consumption overview: https://www.pidramble.com/wiki/benchmarks/power-consumption
** this hat to wake up the main CPU: https://www.waveshare.com/wiki/Power_Management_HAT_(B) sold at https://www.kiwi-electronics.com/en/power-management-hat-for-raspberry-pi-with-rtc-and-rp2040-mcu-11373
 
=== KNMI API ===
Get familiar with https://developer.dataplatform.knmi.nl/open-data-api
 
=== Grid frequency measurer with web page ===
See https://github.com/bertrik/GridFrequency
SSE source is gridfrequency.local/events
 
=== WeAct CH55x board ===
Cheap little boards, using a similar chip as used in USB-serial converters.
 
The hardware
https://github.com/WeActStudio/WeActStudio.CH552CoreBoard
 
Flashing it:
https://hackaday.io/page/137447-flashing-the-ch552-dev-board-from-the-command-line
 
See also:
* https://hackaday.io/project/198238-more-weact-ch5xx
* https://community.platformio.org/t/manually-adding-support-for-ch55x-controller-by-adding-existing-ardunio-core/41138
 
=== Zigbee device with esp32 ===
See https://github.com/P-R-O-C-H-Y/arduino-esp32/blob/8169a434c3e46e1bb7711ebcc04f27267db2093c/libraries/ESP32/examples/Zigbee/Zigbee_Light_Bulb/Zigbee_Light_Bulb.ino
 
See https://github.com/espressif/arduino-esp32/tree/master/libraries/ESP32/examples/Zigbee
 
Espressif32 arduino platform git: https://github.com/platformio/platform-espressif32
 
=== Cameratoezicht in Gouda ===
Gemeente Gouda publiceert een lijst van camera's in Gouda, zie
https://gis.gouda.nl/nl/app/Basisviewer_open#!eAGT8uRiNBRy4ZIRYFKSyKkssjJwdzFxNDMz8TKKsLC0cnb0dQ1y5FIByirgkg3xd43ydPYIAQBXGBFm
 
Aanmelden (semi-automatisch) bij bijvoorbeeld [https://mapcomplete.org/surveillance Surveillance-under-surveillance] ?
 
=== SolarEdge ===
Interact with the solar edge api for PV installations.
 
https://developers.solaredge.com/
 
See https://github.com/bertrik/solaredge-api
 
=== Stookalert ===
Idee: gekleurd lampje dat aangeeft of er op dit moment een stookalert actief is
 
Implementatie:
* kijk m.b.v. WiFi locatieservice in welke provincie je je bevindt
* haal JSON op bij https://www.lml.rivm.nl/stookalert/stookalert.json
* toon de bijbehorende kleur op het lampje
 
Resources:
* Officiele pagina: https://www.atlasleefomgeving.nl/stookwijzer
* Achterliggende JSON met toestand per provincie: https://www.lml.rivm.nl/stookalert/stookalert.json
* Er moet ook nog ergens een API zijn die fijnmaziger aangeeft wat de toestand is ...
 
=== Display of current electricity usage ===
I have a [https://www.zuidwijk.com/product/slimmelezer-plus/ slimme lezer] connected to the P1 port of my smart electricity meter.
The default firmware exposes meter readings using an event stream (SSE) at http://slimmelezer.local/events
 
So for example, you can read this with curl:
  curl http://slimmelezer.local/events
With result:
  event: state
  data: {"id":"sensor-power_consumed_phase_1","value":0.046,"state":"0.046 kW"}
 
Specification of SSE: https://html.spec.whatwg.org/multipage/server-sent-events.html#parsing-an-event-stream
 
What I would like to do is to read these events and control a simple display to display  the current usage number.
 
=== Participating in ultrasonic sound project ===
https://bat-migration-europe.netlify.app/project/
 
Use an audiomoth for this.
 
=== ESP32 C3 ===
* [https://www.espressif.com/en/products/socs/esp32-c3 processor page]
* [https://wiki.luatos.com/chips/esp32c3/index.html luatos basic esp32 c3 board]
 
=== Flexible LED ticker ===
Ordered a flexible 32x8 RGB LED display:
https://nl.aliexpress.com/item/4001296811800.html
 
Matching diffuser to be 3D printed:
https://www.thingiverse.com/thing:1903744
 
=== Washing machine API ===
https://tratt.net/laurie/blog/2023/displaying_my_washing_machines_remaining_time_with_curl_jq_pizauth.html
 
=== TinyML ===
Investigate TinyML, see https://www.tinyml.org/
Apparently can run on a RP2040 (raspi pi pico).
 
https://www.hackster.io/mjrobot/esp32-cam-tinyml-image-classification-fruits-vs-veggies-4ab970
 
=== Bat box busy signal ===
My brother built little pyramid 'blinkies': solar cell + Lithium-supercapacitor + harvesting circuit + LED encased in clear expoxy.
 
Can we add a low-power PIR sensor to this, and make a blinky that blinks if movement was detected by the PIR in the past hour?
 
=== Super tiny RFID ===
See https://www.sparkfun.com/products/16464 an almost sand grain size RFID chip, 1.25mmx1.25mmx0.55mm
 
The accompanying reader "M6E Nano" is still quite expensive at $235.95 : https://www.sparkfun.com/products/14066
 
Uses the MuRata LXMSJZNCMF-198:
"This product can be used as an ultra small tag and this can be
fit on any metal objects, non-metal objects, as well as
embedding into any objects by glue or adhesive and so on."
 
See also: ISO18000-63 and EPC global Gen2(v2)
 
Specification:
* https://www.gs1.org/standards/rfid/uhf-air-interface-protocol
 
=== TheThingsNetwork-Sondehub bridge ===
Uploads balloon telemetry to sondehub.
 
See https://github.com/bertrik/ttnhabbridge/issues/6


Possibly a nice match for measuring stuff by citiziens could be to measure audio:
=== Actually smart boiler ===
* ESP8266/ESP32 have an I2S input, there are cheap microphones available that directly output I2S, saving on interface electronics
The boiler for hot water is about half of my electricity bill.
* ESP8266/ESP32 is probably powerful enough to do basic processing, like FFT, summing power in various frequency ranges, etc.
The idea is to use/build a smart switch that switches it on at time when electricity prices are lowest.
* ESP8266/ESP32 has a wifi connection so it can easily upload data


Questions/stuff to investigate:
Currently have a "Slimme boiler module" from Eneco, which is *not* actually smart,
* what kind of measurements can we do reliably?
since it allows me no control whatsoever when it switches on (besides cutting the power in the meterkast).
** probably absolute measurements are very difficult
For example, it will switch on mid-day when my price is high and eneco's price is low, perhaps good for Eneco, not for me.
** possibly useful relative measurements
Apparently, they even received a [https://nieuws.eneco.nl/slim-apparaatje-bij-boiler-vangt-pieken-wind--en-zonnestroom-op/ subsidy] for this.
*** calculate average over (say) 10 seconds, and compare it with the average over (say) 10 minutes
*** compare averages over time, e.g. compare daytime minute average with each other
*** determine peak-to-average ratios


Waag society uses the following microphone in their [https://waag.org/en/article/new-version-smart-citizen-kit-available kit 2.1]: Invensense ICS4342
A boiler is a pretty big load, about 3 kW, but it is not inductive.


On AliExpress you can find many INMP441, with claims of compatibility with ESP32, so I order those
Alternatives:
[https://aliexpress.com/item/INMP441/32960945048.html INMP441].
* https://www.shelly.cloud/en-nl/products/product-overview/shelly-plus-1-pm-2-pack/shelly-plus-1-pm
* https://www.solyxenergy.nl/solar-iboost/ to store excess solar energy in hot water, might also be useful for just controlling a boiler to use cheaper rates
* tuya smartplug, like https://www.wifilampkoning.nl/merken-slimme-verlichting/tuya/tuya-enkele-smartplug-met-energiemeting ?
* tuya 20A smart plug: https://nl.aliexpress.com/item/1005003347568206.html


External things to investigate:
=== Receiving gas meters ===
* https://www.rijksoverheid.nl/onderwerpen/geluidsoverlast/geluidsoverlast-in-de-wet
Apparently gas meters send gas consumption data to the slimme meter using a wireless link in the 868 MHz band.
* [https://www.invensense.com/wp-content/uploads/2015/02/INMP441.pdf INMP441 microphone datasheet]
Probably just FSK at 38.4, as mentioned here: https://a35.veron.nl/nieuwe-elektra-en-gasmeters/


=== ESP mesh networking ===
Interesting leads:
The makers of the ESP8266 provide a software stack to run a 'mesh network' between ESP8266 nodes.
* https://github.com/stef/smeter
As I understand this allows several ESP devices to join together and create a kind of dynamic network.
* https://www.rtl-sdr.com/reading-household-wireless-utility-meters-with-an-rtl-sdr-and-plotting-the-data-in-home-automation-software/
* https://github.com/bemasher/rtlamr


What is not quite clear is how this is all modelled. For example, do devices have addresses. And if so, what kind? Does this thing run on top of TCP/IP, or does it run on raw wifi frames?
=== Multi-network wifi manager ===
Can you designate one particular node as the 'root node' and let it bridge communication with other networks?
Figure out or create software so that ESP8266/ESP32 wifi manager can use multiple networks to connect (not just one),
Can you do transient low-power communication with the mesh network, e.g. wake-up, send a message, go back to sleep?
so it allowing storing credentials for more than one network. For example, the network at home, the hacker space, at work.
Instead of reconfiguring the wifi manager for each network, you just *add* your credentials (and the existing credentials
are not replaced).


The plan is to experiment a bit with this, perhaps use it in the hacker space for the sensor/actuator infrastructure.
See https://github.com/folkertvanheusden/M.A.X.X


Links:
Interesting candidates:
* https://docs.espressif.com/projects/esp-idf/en/latest/api-reference/network/esp_mesh.html
* https://registry.platformio.org/libraries/martinverges/ESP32%20Wifi%20Manager wifi manager for ESP32, has a REST API for managing wifi network, but is incomplete in the sense that you need to write your own code (e.g. javascript) to actually *use* its API
* https://github.com/arduino-libraries/Arduino_MultiWiFi is the arduino multi wifi library, to allow connecting to multiple different WiFi networks, but it is not a wifi manager, that starts a captive portal, etc


=== Battery-powered ESP8266 nodes ===
=== Automated bat counting ===
[https://aliexpress.com/item/esp-with-18650/32860090110.html These ESP8266 boards with 18650 battery] look like nice candidates for a low-power standalone sensor node.
Can we automatically count the number of bats from the image of a webcam mounted in a bat colony?
Perhaps using some kind of AI or machine learning algorithm?


Measured battery current: the board still draws about 14 mA in deep sleep mode. The ESP8266 itself probably draws less than 1 mA in deep sleep mode.
The image in question:
This totally ruins any low-power possibilities, draining a typical 18650 in about 100 hours (about 4 days).
https://stofradar.nl/coenecoop/


There is an AMS1117 chip onboard, possibly this is the source of the high idle current and perhaps we can replace it.
=== Use TheThingsIndoorGateway as Helium/ThingSix hotspot ===
I have a spare TTIG that could perhaps be used as a Helium gateway, investigate what is possible.


=== FPGA ===
One possiblity is to capture the gateway traffic from the TTN gateway events API, convert uplink data to a format that the Helium network understands and forward it.
Cheap FPGA boards and nice applications:
I don't really care about the Helium crypto tokens, this is just for fun and science.
* https://bitbucket.org/appanp/artificial-neural-networks/wiki/Home/FPGAsAndNeuralNets.md#!sbcs-and-iot-boards
* [http://nl.aliexpress.com/item/Altera-fpga-cycloneii-ep2c5t144-learning-board-development-board/872520721.html inexpensive ep2c5t144 board]
* http://land-boards.com/blwiki/index.php?title=Cyclone_II_EP2C5_Mini_Dev_Board


=== AI on Raspberry Pi ===
What I definitely can do:
Investigate if you can run a powerful neural network on relatively low-end/cheap/low-power hardware. For example a Raspberry pi.
* Capture data from the TTN gateway events API, convert it back to Semtech UP format and forward it somewhere to Helium (just not sure where!)
A RPI runs Linux, run python, just like some common neural frameworks.
* See also my https://github.com/bertrik/ttn-gateway-collector project which contains an initial implementation of TTN-to-UDP conversion
Do we need hardware acceleration from the GPU and does the RPI GPU support that?


Read list:
Showstoppers:
* https://www.zdnet.com/pictures/raspberry-pi-meets-ai-the-projects-that-put-machine-learning-on-the-35-board/
* If you want to be a gateway on the Helium network, you have to *pay Helium*! Obviously I don't want that, I just want to share data to improve *their* network.  
* https://www.pyimagesearch.com/2017/12/18/keras-deep-learning-raspberry-pi/
* https://www.indiegogo.com/projects/sipeed-maix-the-world-first-risc-v-64-ai-module#/
* https://ai.intel.com/intel-neural-compute-stick-2-smarter-faster-plug-and-play-ai-at-the-edge/


=== Particulate matter sensor at RevSpace ===
Open work:
* Investigate if Helium has an open uplink API for their hotspots, if so study it etc, without paying the gateway fee
* Investigate if Thingsix has an open uplink API for their hotspots, if so study it etc, without paying any gateway fee
* Investigate if Thingsix is just another Helium, with weird crypto money


* Sensor id: 12012657
Interesting stuff:
* BME280 https://www.madavi.de/sensor/graph.php?sensor=esp8266-12012657-bme280
* https://docs.helium.com/use-the-network/setup-a-packet-forwarder unfortunately the link to setting up the 'light hotspot client' does not work!
* SDS011 https://www.madavi.de/sensor/graph.php?sensor=esp8266-12012657-sds011
* https://docs.helium.com/mine-hnt/light-hotspots/
* https://thingsix.com/


=== P1 meter on MQTT ===
=== Adding BLE GATT interface to sensors ===
The plan is to push the P1-data from my smart meter onto MQTT and then have other things listening on it and perhaps do actual smart things with this data.
The GATT specification allows measurement properties to be defined and transferred continuously over Bluetooth low-energy.


I have a Kaifa M105a, more info about smart meters:
With GATT you can define a collection of properties (e.g. measurement items like temperature/humidity/particulate matter/noise, etc)
http://domoticx.com/p1-poort-slimme-meter-hardware/
organised in a simple structure of a BLE service.
The 'notification' method allows you to basically push the data continuously to a connected host, e.g. a smart phone.


This could be as simple as an ESP8266-based microcontroller (Wemos D1 mini) just listening on the P1 port and forwarding the data.
Services collects characteristic, a characteristic has values with units.
Unfortunately the port does not appear to provide enough power for the microcontroller, and I have no socket to plug in a power supply in the metering closet.
Each of these (service, characteristic, unit) have their own unique "UUID".
This is described in the so-called [https://btprodspecificationrefs.blob.core.windows.net/assigned-values/16-bit%20UUID%20Numbers%20Document.pdf 16-bit UUID numbers document]


=== LoRa node for airborne particulate matter measurement ===
Interesting stuff in GATT:
The idea is to use an SDS011 particulate matter sensor and make it send its measurement data over LoRa to TheThingsNetwork (TTN).
* See GATT_Specification_Supplement_v5 paragraph 3.151, it has a noise characteristic with 1 dB resolution.
An application listens on the TTN MQTT stream and forwards it to luftdaten.
* 0x27C3 is the GATT *unit* for sound pressure
* 0x181A is the GATT environmental sensing *service*, document name "ESP_V1.0.0.pdf"
* 0x2A6E is the GATT Characteristic and Object Type for temperature
* 0x2A6F is the GATT Characteristic and Object Type for humidity
* 0x2BD5 is the GATT Characteristic and Object Type for Particulate Matter - PM1 Concentration
* 0x2BD6 is the GATT Characteristic and Object Type for Particulate Matter - PM2.5 Concentration
* 0x2BD7 is the GATT Characteristic and Object Type for Particulate Matter - PM10 Concentration
* Unfortunately I cannot find a characteristic for carbon-dioxide (CO2) in the BLE GATT unit document


This has been done by TTN Ulm, see https://github.com/verschwoerhaus/ttn-ulm-feinstaub (the sensor code) and
See also https://programmaticponderings.com/2020/08/04/getting-started-with-bluetooth-low-energy-ble-and-generic-attribute-profile-gatt-specification-for-iot/
https://github.com/verschwoerhaus/ttn-ulm-muecke (the forwarder, in python) 


TODO
=== Reverse engineering XS-8217 bluetooth air quality meter ===
* configure an application with TTN (application id, keys etc.)
This is a thing that measures CO2, humidity, temperature, TVOC and formaldehyde.
* create firmware for an ESP32-TTGO-LoRa module
* create middleware that listens on the TTN MQTT stream, decodes it and forwards the data to luftdaten (I have done both before in Java, just combine it in a new application).


==== Hardware ====
See also https://wiki.liutyi.info/display/CO2/ZN-2CO3+Inside
The plan is:
* I have a cool housing for this, which already has a connection for the antenna and a bunch of solar cells.
* Use with an SDS011 for airborne particulate measurement


==== Software ====
This teardown looks a lot like my sensor: https://www.youtube.com/watch?v=APnjhMrJChI
For the embedded software:
Mine contains a "TPM-300A" sensor for measuring VOC.
* use Arduino framework
* use Arduino LMIC library for TTN communication
* use Arduino SDS011 libs from luftdaten.info?


For the forwarding software:
It has a bluetooth interface, device name is XS-8217.
* use Java to listen on TTN MQTT
It has a BLE GATT profile, with the following services
* use Java code I've already written to forward it to luftdaten API
* service 0xC760
* all sensors send to the same TTN 'application'
** characteristic 0xC762 (WRITE)
** characteristic 0xC761 (NOTIFY)
*** example data: 0x23 0x06 0x10 0x04 0xF1 0x00 0x23 0x65
*** example data: 0x23 0x08 0x10 0x04 0x01 0x9A 0x00 0x0A 0x00 0x03 0x0E
*** data shown on screen was approximately: CO2=418ppm, HCHO=0.003mg/m3, TVOC=0.013mg/m3, temp=24degC, humi=35%


=== SpaceBike tracker ===
So data in the characteristic 0xC761 seems to have a 4 byte constant header:
The idea is to use an ESP32-LoRa board + GPS to track the location of the SpaceBike.
* 0x23
It sends periodic position updates of the location using radio to TheThingsNetwork.
* length byte
Power consumption is not really an issue since it's an e-bike and has a huge onboard battery, but is still expected to be fairly low anyway (milliamps).


For the privacy-conscious, it can be switched on/off.
Then we have for the first message: 0x10 0x04 0xF1 0x00 0x23 0x65
Perhaps we can do other fun/useful stuff too:
* 0x10 0x04 fixed header
* send data about the state of the battery.
* 0xF1 is temperature in 0.1 degree Celcius most likely (24.1)
* capture WiFi APs for projects like https://wigle.net/
* 0x00 is ...
* measure air pollution vs position
* 0x23 is humidity most likely (35)
* collect cool stats about usage, e.g. distance achieved, hours spent, etc.
* 0x65 is ... checksum perhaps


=== QR codes for money transfer ===
And for the second message: 0x10 0x04 0x01 0x9A 0x00 0x0A 0x00 0x03 0x0E
* 0x10 0x04 fixed header
* 0x01 0x9A is the CO2 concentration (410)
* 0x00 0x0A is TVOC most likely (10)
* 0x00 0x03 is HCHO most likely (3)
* 0x0E is ... checksum perhaps


The following document is a short description on how to encode a money transfer request in a QR code:
=== ribbon tweeter for bat audio ===
https://www.europeanpaymentscouncil.eu/document-library/guidance-documents/quick-response-code-guidelines-enable-data-capture-initiation
Someone gave me this idea:
Use a ribbon tweeter like this for playing back bat audio:
<s>https://nl.aliexpress.com/item/4000973201791.html</s>
<s>https://nl.aliexpress.com/item/1005002565880660.html</s>
https://nl.aliexpress.com/item/1005002635086050.html


The SEPA QR code is basically just a set of text lines with predefined meaning, describing the amount and the beneficiary.
The frequency spectrum shows no sign of dropping off at 20 kHz.


https://qrcode.tec-it.com/en/sepa
=== 3d glasses ===
https://en.m.wikipedia.org/wiki/EPC_QR_code
I got some 2nd hand 3d glasses, they look exactly like these ones:
* GH-15 https://www.dhgate.com/product/g15-dlp-3d-active-shutter-glasses-96-144hz/213983026.html
* Sintron https://www.amazon.de/Sintron-Kompatibel-TDG-BT500A-TDG-BT400A-Deutschland/dp/B015PCWMZ8
The common name appears to be "G15-DLP".


=== STM32 stlink V2 ===
A tear-down here:
Interesting to see you can flash inexpensive stlink v2 clones into even more useful debuggers:
* https://blog.danman.eu/3d-shutter-glasses-teardown/
* https://madnessinthedarkness.transsys.com/blog:2017:0122_black_magic_probe_bmp_on_st-link_v2_clones


=== ESP32 LoRa ===
Interesting documents:
I have one of these ESP32 TTGO LoRa boards.
* http://cmst.curtin.edu.au/wp-content/uploads/sites/4/2016/05/2012-28-woods-helliwell-cross-compatibility_of_shutter_glasses.pdf
* http://cmst.curtin.edu.au/local/docs/pubs/2011-17-woods-helliwell-3D-Sync-IR.pdf


First thing I tried:
Someone claims he got something to work with some hacks:
* https://github.com/osresearch/esp32-ttgo seems mostly concerned with pretty graphics on the OLED, no LoRa code
https://www.avsforum.com/threads/how-i-got-cheap-dlp-link-glasses-to-work-great.1887145/


Some more promising links:
=== Waterniveaumeter ===
* https://primalcortex.wordpress.com/2017/11/24/the-esp32-oled-lora-ttgo-lora32-board-and-connecting-it-to-ttn
Op verschillende plekken in Gouda staat er water in de kruipruimte van huizen van bewoners.
* https://github.com/fcgdam/TTGO_LoRa32
Kunnen we dat meten en inzichtelijk maken, voor bewoners, op een kaart bijvoorbeeld?
* https://ictoblog.nl/2018/01/10/mijn-eerste-chinese-esp32-verbonden-met-the-things-network


=== HC-06 stuff ===
Idee:
The HC-06 is a serial-bluetooth converter. Default settings are 9600 baud, no parity.
* in de kruipruimte plaats je een module die waterhoogte kan meten
It doesn't really have a 'command mode' you need to enter, just make sure no BT client is connected and
* de module bestaat uit een microcontroller en een afstandsmeter, die de waterhoogte bepaalt
just send the command as a string of characters from the serial side within one second or so (without any CR/LF!).
* de gegevens worden via WiFi doorgestuurd naar een centraal punt, waar de data wordt verwerkt en gevisualiseerd
* op een webpagina kan je een overzicht zien van alle meters die online zijn
* de meting wordt gedaan door bijv. een laser-afstandsmeter of een ultrasoon-afstandsmeter
* voeding? lastig, hoe krijg je 5v naar een potentieel natte plek?
* kosten? verwachting < E 40,-


To set odd parity:
In Gouda wordt op veel verschillende plekken de grondwaterstand gemeten, zie https://opendata.munisense.net/portal/wareco-water2/group/581/Gouda-KJ38A , maar:
AT+PO
* geen visualisatie op de kaart, je ziet alleen de meetlokaties d.m.v. een icoontje!
* geen meetpunten in Gouda noord!


=== WiFi "top" ===
=== Online bat detector ===
This idea is about a simple demo application that shows the number of unique WiFi stations detected.
Idea: use an ultrasonic microphone, connect it to a WebSDR, so people can tune into bat sounds remotely.
This gives an idea about how busy a place is.


A bit like the CPU load in the unix/linux "top" tool, this is indicated as a number at different timescales, e.g. number of unique WiFi stations detected in the last minute, last 5 minutes and last 15 minute, last hour, etc.
=== Raspberry pi airplane tracking ===
Apparently now you can also participate in MLAT tracking of planes that don't transmit GPS coordinates themselves.


The implementation is done using an ESP8266 in promiscuous mode.
=== APRS gateway ===
Using the callback for promiscuous mode, a table is built with an entry for each unique MAC address:
http://qso365.co.uk/2017/02/a-guide-to-setting-up-an-aprs-receive-only-igate-using-a-raspberry-pi-and-an-rtl-sdr-dongle/
* only "stations" (like phones, laptops, etc) are recorded in this table, not access points
* the table records the following:
** the unique MAC address
** the time is has been seen first
** the time is has been seen last
* the wifi channel is switched at some interval
* every minute (for example), the stats are calculated from the table and published on MQTT


Operations on this table:
=== JQ6500 ===
* entries older than 60 minutes are removed from the table.
Small inexpensive modules that play mp3 from an internal flash. Could be nice for a custom door bell for example.
* when we see a new unknown MAC, it's added to the table (if it fits) and we set the first-seen timestamp
* when we see a known MAC, the last-seen timestamp is updated
* getting stats from the table, for example:
** number of unique station MACs seen in the last minute
** number of unique station MACs seen in the last 5 minutes
** number of unique station MACs seen in the last 15 minutes
** number of unique station MACs seen in the last 60 minutes
* perhaps we can get stats using either the first-seen or the last-seen timestap?


Possible issues:
More info at:  
* privacy: the unique MAC of any Wifi station is never exposed, only cumulative numbers. If you're really concerned, consider turning off your WiFi devices (e.g. using airplane mode)
* https://www.elecfreaks.com/wiki/index.php?title=JQ6500_Mini_MP3_Module
* random MACs: apparently some devices randomize their MAC address if they're not connected to a station. Not sure yet how to handle that.
* https://sparks.gogo.co.nz/jq6500/index.html
* switching between promiscuous mode (for sniffing) and station mode (for reporting stats): I don't know how complicated this is, we'll see.


=== investigate quadcopter remote control ===
=== FPGA ===
It turns out that the typical little cheap Chinese quadcopters use a remote-control protocol that can be easily recreated using the famous NRF24L01+ chip (< $1 and easily connected to an arduino).
Cheap FPGA boards and nice applications:
This gives nice opportunity to either:
* https://bitbucket.org/appanp/artificial-neural-networks/wiki/Home/FPGAsAndNeuralNets.md#!sbcs-and-iot-boards
# transmit our own control signal, to control a quadcopter from something different than the manual remote control, e.g. automatic control
* [http://nl.aliexpress.com/item/Altera-fpga-cycloneii-ep2c5t144-learning-board-development-board/872520721.html inexpensive ep2c5t144 board]
# receive the control signal, so the manual remote control that comes with a quadcopter can be used to steer other things (like a model car).
* http://land-boards.com/blwiki/index.php?title=Cyclone_II_EP2C5_Mini_Dev_Board


I haven't found a good overview of quadcopter remote control protocol specifications yet, there seem to be plenty examples of "here-is-the-code" however.
=== Neural networks on low-end hardware ===
Investigate if you can run a powerful neural network on relatively low-end/cheap/low-power hardware. For example a Raspberry pi.
A RPI runs Linux, run python, just like some common neural frameworks.
Do we need hardware acceleration from the GPU and does the RPI GPU support that?
 
Read list:
* https://www.zdnet.com/pictures/raspberry-pi-meets-ai-the-projects-that-put-machine-learning-on-the-35-board/
* https://www.pyimagesearch.com/2017/12/18/keras-deep-learning-raspberry-pi/
* https://www.indiegogo.com/projects/sipeed-maix-the-world-first-risc-v-64-ai-module#/
* https://ai.intel.com/intel-neural-compute-stick-2-smarter-faster-plug-and-play-ai-at-the-edge/
 
Bought a MaixPy:
* see https://maixpy.sipeed.com/en/
* see https://www.youtube.com/watch?v=KResVuAIMb4
* see http://educ8s.tv/sipeed-m1-dock-review/
* interesting? https://www.instructables.com/id/Transfer-Learning-With-Sipeed-MaiX-and-Arduino-IDE/


=== mini word clock in dutch ===
=== mini word clock in dutch ===
Line 226: Line 474:
See [https://plus.google.com/103276078656203197145/posts/7ki7rpJzk3a here for a demo] running on an arduino nano.
See [https://plus.google.com/103276078656203197145/posts/7ki7rpJzk3a here for a demo] running on an arduino nano.


The plan is to run this from an ESP8266 instead of an arduino nano, so it can get the time from the internet using NTP. The time offset will be fixed to Dutch local time, i.e. GMT+1 taking into account summer time. Summer time will be determined using the general rule "from 2:00 local time on the last sunday of March until 3:00 local time on the last sunday of October".
The plan is to run this from an ESP8266 instead of an arduino nano, so it can get the time from the internet using NTP.
 
Andreas Spiess demonstrated on youtube how existing libraries on the ESP8266 can be used to do the local time (including summer-time) calculations.
Local date calculation:
* http://stackoverflow.com/questions/5590429/calculating-daylight-saving-time-from-only-date
* https://github.com/niekproductions/word-clock
 
=== Understanding LoRa ===
Ultimate goal is to create an SDR algorithm to decode LoRa without the need for dedicated LoRa hardware. This could be useful when tracking HABs transmitting LoRa for example. See [[DecodingLora]] and [[EncodingLora]].
 
In particular, I should definitely check out [https://github.com/rpp0/gr-lora this gr-lora project].
Perhaps make it work for decoding balloon telemetry modes.
 
An ambitious goal is to be able to decode LoRAWAN transmissions and implement an rtl-sdr based gateway.


=== Cypress PSOC5 ===
=== Cypress PSOC5 ===
Line 275: Line 512:
As far as I understand, the ADC clock can be set to 1 MHz.
As far as I understand, the ADC clock can be set to 1 MHz.
Conversion takes 13 cycles, so this can be a problem to reach a sample rate above 80 kHz.
Conversion takes 13 cycles, so this can be a problem to reach a sample rate above 80 kHz.
==== Example C code ====
(this is the general idea, but I don't know if it compiles):
<pre>
#define BUF_SIZE    16
static void ISR(void)
{
    static int16_t buffer[BUF_SIZE];
    static int16_t lowpass = 0;
    static int32_t sum = 0;
    static bool even = false;
    int16_t input, signal, mixed;
    // sample signal as 16 bits (10 bits significant)
    input = ....
    // HPF input signal
    signal = input - lowpass;
    lowpass += signal >> 4;
    // multiply by carrier
    mixed = even ? signal : -signal;
    even = !even;
    // calculate moving average sum
    sum += mixed ;
    sum -= buffer[index];
    buffer[index] = mixed ;
    index = (index + 1) % BUF_SIZE;
    // output LPF as 8-bit number
    out = sum >> 7;
    ...
}
</pre>
=== Bat call cleaner ===
This idea is about a simple push-button tool to clean up bat call recordings, to make them more suitable for playback in a bat lure.
By cleaning up, I mean removing the background noise and turning it into a pure sine wave like signal characterized only by an instantaneous frequency and amplitude.
Any harmonics will be lost.
This way, you can pick a nice bat call recording and turn it into a file suitable for playing back at relatively loud volume from a bat call player / lure, without the broadband noise.
The signal is put through the following signal processing stages:
* Apply a high-pass filter to get rid of non-ultrasonics like speech, say at 10 kHz
* Convert the signal into a complex [https://en.wikipedia.org/wiki/Analytic_signal analytic signal], by creating the imaginary part using a [https://en.wikipedia.org/wiki/Hilbert_transform Hilbert transform].
** The Hilbert transform can be approximated by a FIR filter of appropriate length to get the desired bandwidth.
* Split the complex signal into an instantaneous frequency and amplitude.
** The frequency is determined by differentiating the instantaneous phase (inverse tangens i/q).
** The amplitude is determined by calculating the norm of the complex signal (sqrt of i^2 + q^2)
* Average/low-pass the frequency component, say at 0.1 ms intervals. Do the same to the amplitude.
* Re-synthesize the signal s using the simple model s = A.sin(2.pi.t/f) where A is amplitude, t is time and f is frequency, interpolating A and f.
Alternative:
* Apply a high-pass filter to get rid of non-ultrasonics like speech, say at 10 kHz
* chop the signal up in segments of (say) 100 ms and determine the total energy content in each segment
* choose the quietest segment and use this as a "background noise template"
** perform a fourier analysis on the template
* reduce the noise on the signal using the template:
** for each segment, apply for each frequency an attenuation based on the signal level compared to the template level
** resynthesize from fourier back into the time domain using an overlap-add method
=> perhaps there is already software which performs these steps?
=== ESP8266 modbus adapter for solar converters ===
This idea is about programming an ESP8266 to talk to solar converter over RS485 on one side as a MODBUS/serial master, and making it appear as a MODBUS/TCP slave on the other side. This way you can talk to your solar converter using an existing MODBUS/TCP slave application.
The particular solar converter is the "EP Solar MPPT Tracer A 3210A".
[https://github.com/kasbert/epsolar-tracer This github project] may give some clues to which modbus registers contain what.
The RS485 side is done using a (soft-)UART on the ESP8266 with a TTL-to-RS485 converter.
The TCP/IP side is done using the built-in wifi of the ESP8266.
ESP8266 as modbus slave (over network):
* https://github.com/andresarmento/modbus-esp8266
* https://github.com/yaacov/ArduinoModbusSlaveTCP
ESP8266 as modbus master:
* https://github.com/4-20ma/ModbusMaster
=== GPS repeater ===
This idea is about experimenting with a cheap GPS repeater built out of an "active" GPS antenna.
The problem this solves is that often indoors you have no GPS reception, but you like to have some signal to experiment with (e.g. a LoRa tracker).
Plan:
* get a cheap active GPS antenna from AliExpress (some as cheap as E2,- !), most just mention one frequency (1575.42 MHz)
* get a bias-T circuit to feed it the supply voltage (e.g. from a KOPPLA) and pass the RF signal onto an indoor antenna
* the indoor antenna may be as simple as a 1/4 wave coax dipole: center conductor sticking up (about 47 mm), coax shielding is divided into 3 of 4 ground radials sticking sideways
* build it and test it with a smart phone, tracker hardware, etc.
See also:
* [https://electronics.stackexchange.com/a/156488 Reradiating antena for GPS]


=== Indoor radar speed sign ===
=== Indoor radar speed sign ===

Latest revision as of 19:45, 5 October 2025

User info Bertrik Sikken
Name Bertrik Sikken
Nick bertrik
Tagline heb ik niet

You can reach me at bertrik@sikken.nl or bertrik@gmail.com.

Studied Electrical Engineering at Twente University.


Main interests:

  • reverse-engineering things (USB stuff, mp3 players), worked on http://rockbox.org (sansa clip players)
  • studying bats and making electronics for recording/listening to bat sounds
  • radio stuff, in particular software-defined radio
  • energy-related stuff, visualisation
  • citizen science, particulate matter measurement, noise

Projects I work(ed) on (refresh):

 Project Status
FrontDoorDisplayAbandoned
HabAlertAppAbandoned
ISSOAbandoned
IbmPosDisplayAbandoned
Pico TrackersAbandoned
RadarOnAStickAbandoned
WifiLampAbandoned
A4PaperDispenserCompleted
BuildStatusTrafficLightCompleted
CJMCU-811Completed
CO2MeterHackingCompleted
CrawlSpaceSensorCompleted
DecodingLoraCompleted
DustSensorCompleted
ElectronicLoadCompleted
EspNowSkipCompleted
IntakefancontrollerCompleted
LichtKrantCompleted
LoRaGatewayCompleted
LoraBatBoxCompleted
LoraWanNodeCompleted
MHZ19Completed
MainsFrequencyCompleted
MiniSTM32F103ZECompleted
PowerLightCompleted
RC522HackingCompleted
RevRadioCompleted
STM32Completed
Secure iButtonCompleted
SoilHumiditySensorCompleted
StofAnanasCompleted
StofradarCompleted
TTNHABBridgeCompleted
VINDRIKTNINGCompleted
ZigbeeCoordinatorCompleted
Sensor-data-bridgeCompleted
AntiLostIn progress
AudioMothIn progress
BT785In progress
CubeCellIn progress
EspAudioSensorIn progress
Esp32camIn progress
FMCWRadarIn progress
KaraburanIn progress
LoRa-E5-miniIn progress
LoraWanDustSensorIn progress
MainsFrequency2.0In progress
MeshtasticIn progress
Msi2500SDRIn progress
MysteryLidarIn progress
... further results


Project ideas

This is a list of ideas I'm thinking about, but have not fully developed into an actual project yet.

https://pine64.com/product/128mb-ox64-sbc-available-on-december-2-2022/

tuya serial protocol

action lsc stekker

https://keetsupport.nl/2024/03/20/how-to-flash-lsc-power-plug-with-esphome/

sipeed maix dock

Bought this a couple of years ago. Get familiar with this board. Can I run a chess program on this, for example?

rfid keyfob

advanced lidars for bat detection

livox:

cubecell meshtastic motion detector

I have a cubecell AB01 board. This board is focused on low power, has a connection to attach a solar panel and has a lora radio. Relatively small amount of RAM, barely enough to run a LoRaWAN stack but probably plenty to run meshtastic

The plan is to build a simple motion detector from this (using a PIR). The PIR can wake up the board from low-power, or a timer can wake it periodically.

See also: https://github.com/HelTecAutomation/CubeCell-Arduino/tree/master/libraries/Basics/examples/LowPower

configure multitech outdoor gateway

https://www.multitech.net/developer/products/multiconnect-conduit-platform/basestation/

https://multitech.com/product/multitech-conduit-mtcdt-246a-868-eu-gb/

emergency procedure: https://www.multitech.net/developer/software/mlinux/using-mlinux/flashing-mlinux-firmware-for-conduit/

esp32 wtf

kakofonie counter

Sample room audio, use neural network to distinguish voices to estimate number of people talking in the past 30 seconds or so. Show this number on some kind of display, publish it to MQTT, make a nice graph of it.

Stuff to figure out:

  • this is called 'speaker diarization'
  • can it run on an ESP32?
  • make a prototype

hypno toad

Put these LEDS https://nl.aliexpress.com/item/1005007583528891.html into https://www.action.com/nl-nl/p/2560347/solar-tuinbeeldje/

Turns out that the default circuit is really basic and output a rough step-up waveform to the LED. The self-fading LEDs don't work very well with that.

Also, putting some IPA on hotglue makes it release really easy.

wasbeer / kat classifier

ESP32 with resnet50 neural net to distinguish house cats from other animals, see also:

Nespresso brew counter

Several hacker spaces have one of these Nespresso cup coffee makers, but there's no obvious easy way to monitor usage (monitor ALL the things!). Inspired by https://hackaday.com/2021/04/25/arduino-mkr-makes-nespresso-monitoring-easy/ this idea is making an even simpler nespresso monitor, using an inexpensive WiFi enabled ESP8266 with an ubiquitous I2S microphone such as the INMP441.

Use this sound monitoring project: https://github.com/aleiei/ESP8266-BUG-I2S-MIC and turn it into a WiFi connected brew counter.

Software for getting microphone data from an ESP8266/I2S mic into Linux https://github.com/bertrik/EspMicServer Nespresso sound is typically 50 Hz with overtones. In a recording with the ESP8266, it appears that oddly the 17th harmonic (around 850 Hz) is quite strong.

The plan in the short term is this:

  • apply a gentle IIR filter to subtract any DC bias from the microphone signal
  • calculate autocovariance at offsets 0 and 20 ms (inverse of 50 Hz), representing the total energy and the energy at 50 Hz respectively
  • compare amplitudes to decide about presence of 50 Hz signal, e.g. calculate ratio in dB
  • use this to count the length of time that a 50 Hz signal is heard (increments of 100 ms or so)
  • decide about none / espresso / lungo based on time

Might even integrate with esphome / home assistant later.

Remote bat box monitor

Idea:

KNMI API

Get familiar with https://developer.dataplatform.knmi.nl/open-data-api

Grid frequency measurer with web page

See https://github.com/bertrik/GridFrequency SSE source is gridfrequency.local/events

WeAct CH55x board

Cheap little boards, using a similar chip as used in USB-serial converters.

The hardware https://github.com/WeActStudio/WeActStudio.CH552CoreBoard

Flashing it: https://hackaday.io/page/137447-flashing-the-ch552-dev-board-from-the-command-line

See also:

Zigbee device with esp32

See https://github.com/P-R-O-C-H-Y/arduino-esp32/blob/8169a434c3e46e1bb7711ebcc04f27267db2093c/libraries/ESP32/examples/Zigbee/Zigbee_Light_Bulb/Zigbee_Light_Bulb.ino

See https://github.com/espressif/arduino-esp32/tree/master/libraries/ESP32/examples/Zigbee

Espressif32 arduino platform git: https://github.com/platformio/platform-espressif32

Cameratoezicht in Gouda

Gemeente Gouda publiceert een lijst van camera's in Gouda, zie https://gis.gouda.nl/nl/app/Basisviewer_open#!eAGT8uRiNBRy4ZIRYFKSyKkssjJwdzFxNDMz8TKKsLC0cnb0dQ1y5FIByirgkg3xd43ydPYIAQBXGBFm

Aanmelden (semi-automatisch) bij bijvoorbeeld Surveillance-under-surveillance ?

SolarEdge

Interact with the solar edge api for PV installations.

https://developers.solaredge.com/

See https://github.com/bertrik/solaredge-api

Stookalert

Idee: gekleurd lampje dat aangeeft of er op dit moment een stookalert actief is

Implementatie:

Resources:

Display of current electricity usage

I have a slimme lezer connected to the P1 port of my smart electricity meter. The default firmware exposes meter readings using an event stream (SSE) at http://slimmelezer.local/events

So for example, you can read this with curl:

 curl http://slimmelezer.local/events

With result:

 event: state
 data: {"id":"sensor-power_consumed_phase_1","value":0.046,"state":"0.046 kW"}

Specification of SSE: https://html.spec.whatwg.org/multipage/server-sent-events.html#parsing-an-event-stream

What I would like to do is to read these events and control a simple display to display the current usage number.

Participating in ultrasonic sound project

https://bat-migration-europe.netlify.app/project/

Use an audiomoth for this.

ESP32 C3

Flexible LED ticker

Ordered a flexible 32x8 RGB LED display: https://nl.aliexpress.com/item/4001296811800.html

Matching diffuser to be 3D printed: https://www.thingiverse.com/thing:1903744

Washing machine API

https://tratt.net/laurie/blog/2023/displaying_my_washing_machines_remaining_time_with_curl_jq_pizauth.html

TinyML

Investigate TinyML, see https://www.tinyml.org/ Apparently can run on a RP2040 (raspi pi pico).

https://www.hackster.io/mjrobot/esp32-cam-tinyml-image-classification-fruits-vs-veggies-4ab970

Bat box busy signal

My brother built little pyramid 'blinkies': solar cell + Lithium-supercapacitor + harvesting circuit + LED encased in clear expoxy.

Can we add a low-power PIR sensor to this, and make a blinky that blinks if movement was detected by the PIR in the past hour?

Super tiny RFID

See https://www.sparkfun.com/products/16464 an almost sand grain size RFID chip, 1.25mmx1.25mmx0.55mm

The accompanying reader "M6E Nano" is still quite expensive at $235.95 : https://www.sparkfun.com/products/14066

Uses the MuRata LXMSJZNCMF-198: "This product can be used as an ultra small tag and this can be fit on any metal objects, non-metal objects, as well as embedding into any objects by glue or adhesive and so on."

See also: ISO18000-63 and EPC global Gen2(v2)

Specification:

TheThingsNetwork-Sondehub bridge

Uploads balloon telemetry to sondehub.

See https://github.com/bertrik/ttnhabbridge/issues/6

Actually smart boiler

The boiler for hot water is about half of my electricity bill. The idea is to use/build a smart switch that switches it on at time when electricity prices are lowest.

Currently have a "Slimme boiler module" from Eneco, which is *not* actually smart, since it allows me no control whatsoever when it switches on (besides cutting the power in the meterkast). For example, it will switch on mid-day when my price is high and eneco's price is low, perhaps good for Eneco, not for me. Apparently, they even received a subsidy for this.

A boiler is a pretty big load, about 3 kW, but it is not inductive.

Alternatives:

Receiving gas meters

Apparently gas meters send gas consumption data to the slimme meter using a wireless link in the 868 MHz band. Probably just FSK at 38.4, as mentioned here: https://a35.veron.nl/nieuwe-elektra-en-gasmeters/

Interesting leads:

Multi-network wifi manager

Figure out or create software so that ESP8266/ESP32 wifi manager can use multiple networks to connect (not just one), so it allowing storing credentials for more than one network. For example, the network at home, the hacker space, at work. Instead of reconfiguring the wifi manager for each network, you just *add* your credentials (and the existing credentials are not replaced).

See https://github.com/folkertvanheusden/M.A.X.X

Interesting candidates:

Automated bat counting

Can we automatically count the number of bats from the image of a webcam mounted in a bat colony? Perhaps using some kind of AI or machine learning algorithm?

The image in question: https://stofradar.nl/coenecoop/

Use TheThingsIndoorGateway as Helium/ThingSix hotspot

I have a spare TTIG that could perhaps be used as a Helium gateway, investigate what is possible.

One possiblity is to capture the gateway traffic from the TTN gateway events API, convert uplink data to a format that the Helium network understands and forward it. I don't really care about the Helium crypto tokens, this is just for fun and science.

What I definitely can do:

  • Capture data from the TTN gateway events API, convert it back to Semtech UP format and forward it somewhere to Helium (just not sure where!)
  • See also my https://github.com/bertrik/ttn-gateway-collector project which contains an initial implementation of TTN-to-UDP conversion

Showstoppers:

  • If you want to be a gateway on the Helium network, you have to *pay Helium*! Obviously I don't want that, I just want to share data to improve *their* network.

Open work:

  • Investigate if Helium has an open uplink API for their hotspots, if so study it etc, without paying the gateway fee
  • Investigate if Thingsix has an open uplink API for their hotspots, if so study it etc, without paying any gateway fee
  • Investigate if Thingsix is just another Helium, with weird crypto money

Interesting stuff:

Adding BLE GATT interface to sensors

The GATT specification allows measurement properties to be defined and transferred continuously over Bluetooth low-energy.

With GATT you can define a collection of properties (e.g. measurement items like temperature/humidity/particulate matter/noise, etc) organised in a simple structure of a BLE service. The 'notification' method allows you to basically push the data continuously to a connected host, e.g. a smart phone.

Services collects characteristic, a characteristic has values with units. Each of these (service, characteristic, unit) have their own unique "UUID". This is described in the so-called 16-bit UUID numbers document

Interesting stuff in GATT:

  • See GATT_Specification_Supplement_v5 paragraph 3.151, it has a noise characteristic with 1 dB resolution.
  • 0x27C3 is the GATT *unit* for sound pressure
  • 0x181A is the GATT environmental sensing *service*, document name "ESP_V1.0.0.pdf"
  • 0x2A6E is the GATT Characteristic and Object Type for temperature
  • 0x2A6F is the GATT Characteristic and Object Type for humidity
  • 0x2BD5 is the GATT Characteristic and Object Type for Particulate Matter - PM1 Concentration
  • 0x2BD6 is the GATT Characteristic and Object Type for Particulate Matter - PM2.5 Concentration
  • 0x2BD7 is the GATT Characteristic and Object Type for Particulate Matter - PM10 Concentration
  • Unfortunately I cannot find a characteristic for carbon-dioxide (CO2) in the BLE GATT unit document

See also https://programmaticponderings.com/2020/08/04/getting-started-with-bluetooth-low-energy-ble-and-generic-attribute-profile-gatt-specification-for-iot/

Reverse engineering XS-8217 bluetooth air quality meter

This is a thing that measures CO2, humidity, temperature, TVOC and formaldehyde.

See also https://wiki.liutyi.info/display/CO2/ZN-2CO3+Inside

This teardown looks a lot like my sensor: https://www.youtube.com/watch?v=APnjhMrJChI Mine contains a "TPM-300A" sensor for measuring VOC.

It has a bluetooth interface, device name is XS-8217. It has a BLE GATT profile, with the following services

  • service 0xC760
    • characteristic 0xC762 (WRITE)
    • characteristic 0xC761 (NOTIFY)
      • example data: 0x23 0x06 0x10 0x04 0xF1 0x00 0x23 0x65
      • example data: 0x23 0x08 0x10 0x04 0x01 0x9A 0x00 0x0A 0x00 0x03 0x0E
      • data shown on screen was approximately: CO2=418ppm, HCHO=0.003mg/m3, TVOC=0.013mg/m3, temp=24degC, humi=35%

So data in the characteristic 0xC761 seems to have a 4 byte constant header:

  • 0x23
  • length byte

Then we have for the first message: 0x10 0x04 0xF1 0x00 0x23 0x65

  • 0x10 0x04 fixed header
  • 0xF1 is temperature in 0.1 degree Celcius most likely (24.1)
  • 0x00 is ...
  • 0x23 is humidity most likely (35)
  • 0x65 is ... checksum perhaps

And for the second message: 0x10 0x04 0x01 0x9A 0x00 0x0A 0x00 0x03 0x0E

  • 0x10 0x04 fixed header
  • 0x01 0x9A is the CO2 concentration (410)
  • 0x00 0x0A is TVOC most likely (10)
  • 0x00 0x03 is HCHO most likely (3)
  • 0x0E is ... checksum perhaps

ribbon tweeter for bat audio

Someone gave me this idea: Use a ribbon tweeter like this for playing back bat audio: https://nl.aliexpress.com/item/4000973201791.html https://nl.aliexpress.com/item/1005002565880660.html https://nl.aliexpress.com/item/1005002635086050.html

The frequency spectrum shows no sign of dropping off at 20 kHz.

3d glasses

I got some 2nd hand 3d glasses, they look exactly like these ones:

The common name appears to be "G15-DLP".

A tear-down here:

Interesting documents:

Someone claims he got something to work with some hacks: https://www.avsforum.com/threads/how-i-got-cheap-dlp-link-glasses-to-work-great.1887145/

Waterniveaumeter

Op verschillende plekken in Gouda staat er water in de kruipruimte van huizen van bewoners. Kunnen we dat meten en inzichtelijk maken, voor bewoners, op een kaart bijvoorbeeld?

Idee:

  • in de kruipruimte plaats je een module die waterhoogte kan meten
  • de module bestaat uit een microcontroller en een afstandsmeter, die de waterhoogte bepaalt
  • de gegevens worden via WiFi doorgestuurd naar een centraal punt, waar de data wordt verwerkt en gevisualiseerd
  • op een webpagina kan je een overzicht zien van alle meters die online zijn
  • de meting wordt gedaan door bijv. een laser-afstandsmeter of een ultrasoon-afstandsmeter
  • voeding? lastig, hoe krijg je 5v naar een potentieel natte plek?
  • kosten? verwachting < E 40,-

In Gouda wordt op veel verschillende plekken de grondwaterstand gemeten, zie https://opendata.munisense.net/portal/wareco-water2/group/581/Gouda-KJ38A , maar:

  • geen visualisatie op de kaart, je ziet alleen de meetlokaties d.m.v. een icoontje!
  • geen meetpunten in Gouda noord!

Online bat detector

Idea: use an ultrasonic microphone, connect it to a WebSDR, so people can tune into bat sounds remotely.

Raspberry pi airplane tracking

Apparently now you can also participate in MLAT tracking of planes that don't transmit GPS coordinates themselves.

APRS gateway

http://qso365.co.uk/2017/02/a-guide-to-setting-up-an-aprs-receive-only-igate-using-a-raspberry-pi-and-an-rtl-sdr-dongle/

JQ6500

Small inexpensive modules that play mp3 from an internal flash. Could be nice for a custom door bell for example.

More info at:

FPGA

Cheap FPGA boards and nice applications:

Neural networks on low-end hardware

Investigate if you can run a powerful neural network on relatively low-end/cheap/low-power hardware. For example a Raspberry pi. A RPI runs Linux, run python, just like some common neural frameworks. Do we need hardware acceleration from the GPU and does the RPI GPU support that?

Read list:

Bought a MaixPy:

mini word clock in dutch

Basically an monochrome 8x8 word clock, in Dutch, showing local time in the Netherlands.

This git repo has the current code.

See here for a demo running on an arduino nano.

The plan is to run this from an ESP8266 instead of an arduino nano, so it can get the time from the internet using NTP. Andreas Spiess demonstrated on youtube how existing libraries on the ESP8266 can be used to do the local time (including summer-time) calculations.

Cypress PSOC5

Play with the Cypress PSOC5 platform, which combines a ARM Cortex-m3 processor with configurable analog blocks. I'm thinking of combining it with a 24 GHz doppler radar sensor, to process the signal and present it as a USB audio device (stereo signal contains I and Q parts). See RadarOnAStick.

Simple Doppler motion sensors

You can find basic doppler microwave motion sensors based on a single transistor, with some weird traces on the PCB very cheaply, for example

Typically the microwave part of these consists of a single transistor with a rectangular area on one leg and a meandering trace (with lots of vias to the other side) on the other leg. The output of this circuit seems to go into a chip very much like the ones used in PIR sensors.

See also https://github.com/jdesbonnet/RCWL-0516 for a reverse engineering effort of these doppler radar modules.

Bare-bones Arduino bat detector

This is an idea for a very basic heterodyne bat detector, doing signal processing on an Arduino, requiring minimal external components.

The basic principle of a heterodyne detector is that it just mixes (multiplies) the audio signal with a square wave, low-pass filters the result and puts it on a speaker.

Multiplying with a square wave can also be considered to be just alternatively inverting and not-inverting the signal. So if you sample an ultrasonic signal at twice the rate you want to multiply, you can just subtract odd samples from even samples and low-pass filter that.

How this can be done in an AVR Arduino:

  • sample the audio signal at twice the detection frequency, say 84 kHz. An AVR should just be able to do that.
  • apply a 1-pole IIR high-pass filter to remove DC bias, this takes one shift instruction and one addition.
  • multiply by the detection frequency, this means just inverting the odd samples.
  • low-pass filter the signal, this can be done using a moving average filter, say 16 samples long (first null at 5.25 kHz). Theoretically, averaging 16 samples should result in two bits extra accuracy. This operation takes some storage, an addition and a subtraction.
  • output the filtered signal using PWM, possibly at the same rate that we are sampling the input audio.

The microphone can be a 40 kHz piezo transducer, to keep it cheap (but also limited to 40 kHz). The pre-amplifier can be a single transistor with some resistors around it, providing about 40x gain. The arduino does the signal processing (mixing, low-pass filter) to shift the bat audio to human range. The speaker amplifier can just be a simple two transistor push-pull circuit, since the output from the Arduino is digital/PWM.

AVR Arduino sample rate

As far as I understand, the ADC clock can be set to 1 MHz. Conversion takes 13 cycles, so this can be a problem to reach a sample rate above 80 kHz.

Indoor radar speed sign

This idea about placing a simple IQ-output radar sensor indoors in the hacker space, do some basic signal processing on the IQ doppler signal and determine movement speed and direction, then display this on a LED display. This is of no immediate practical use other than fun, but helps me to gain a bit more experience with microwave radar sensors and eventually build a more effective setup for detecting/counting bats flying in and out of a roost.

Implement this on a PSOC5 platform or on the STM32 using Arduino.