User:Bertrik Sikken: Difference between revisions
| No edit summary | No edit summary | ||
| Line 30: | Line 30: | ||
| === Zigbee stick for home automation === | === Zigbee stick for home automation === | ||
| zigbee2mqtt | zigbee2mqtt site has information on how to flash a CC2531 usb-zigbee stick: | ||
| * How to flash using an ESP8266 https://www.zigbee2mqtt.io/information/alternative_flashing_methods.html | |||
| * Supported Zigbee devices (like an IKEA TRADFRI): https://www.zigbee2mqtt.io/information/supported_devices.html | |||
| === Battery-powered ESP8266 nodes === | === Battery-powered ESP8266 nodes === | ||
Revision as of 10:54, 23 February 2019
| 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), working on http://rockbox.org
- studying bats and making electronics for recording/listening to bat sounds
- radio stuff, in particular software-defined radio
Projects I work(ed) on (refresh):
Project ideas
This is a list of ideas I'm thinking about, but have not fully developed into an actual project yet.
Zigbee stick for home automation
zigbee2mqtt site has information on how to flash a CC2531 usb-zigbee stick:
- How to flash using an ESP8266 https://www.zigbee2mqtt.io/information/alternative_flashing_methods.html
- Supported Zigbee devices (like an IKEA TRADFRI): https://www.zigbee2mqtt.io/information/supported_devices.html
Battery-powered ESP8266 nodes
These ESP8266 boards with 18650 battery look like nice candidates for a low-power standalone sensor node.
The battery makes it a standalone board. Putting it in sleep mode most of the time makes it low power. Using ESP now makes it possible to send data with very low latency so the time that the board is actually powered up is very short time (approximately 200 ms) and so power consumption stays low.
FPGA
Cheap FPGA boards and nice applications:
- https://bitbucket.org/appanp/artificial-neural-networks/wiki/Home/FPGAsAndNeuralNets.md#!sbcs-and-iot-boards
- inexpensive ep2c5t144 board
- http://land-boards.com/blwiki/index.php?title=Cyclone_II_EP2C5_Mini_Dev_Board
AI on Raspberry Pi
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/
Particulate matter sensor at RevSpace
- Sensor id: 12012657
- BME280 https://www.madavi.de/sensor/graph.php?sensor=esp8266-12012657-bme280
- SDS011 https://www.madavi.de/sensor/graph.php?sensor=esp8266-12012657-sds011
P1 meter on MQTT
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.
I have a Kaifa M105a, more info about smart meters: http://domoticx.com/p1-poort-slimme-meter-hardware/
This could be as simple as an ESP8266-based microcontroller (Wemos D1 mini) just listening on the P1 port and forwarding the data. 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.
LoRa node for airborne particulate matter measurement
The idea is to use an SDS011 particulate matter sensor and make it send its measurement data over LoRa to TheThingsNetwork (TTN). An application listens on the TTN MQTT stream and forwards it to luftdaten.
This has been done by TTN Ulm, see https://github.com/verschwoerhaus/ttn-ulm-feinstaub (the sensor code) and https://github.com/verschwoerhaus/ttn-ulm-muecke (the forwarder, in python)
TODO
- configure an application with TTN (application id, keys etc.)
- 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
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
For the embedded software:
- use Arduino framework
- use Arduino LMIC library for TTN communication
- use Arduino SDS011 libs from luftdaten.info?
For the forwarding software:
- use Java to listen on TTN MQTT
- use Java code I've already written to forward it to luftdaten API
- all sensors send to the same TTN 'application'
SpaceBike tracker
The idea is to use an ESP32-LoRa board + GPS to track the location of the SpaceBike. It sends periodic position updates of the location using radio to TheThingsNetwork. 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. Perhaps we can do other fun/useful stuff too:
- send data about the state of the battery.
- capture WiFi APs for projects like https://wigle.net/
- measure air pollution vs position
- collect cool stats about usage, e.g. distance achieved, hours spent, etc.
QR codes for money transfer
The following document is a short description on how to encode a money transfer request in a QR code: https://www.europeanpaymentscouncil.eu/document-library/guidance-documents/quick-response-code-guidelines-enable-data-capture-initiation
The SEPA QR code is basically just a set of text lines with predefined meaning, describing the amount and the beneficiary.
https://qrcode.tec-it.com/en/sepa https://en.m.wikipedia.org/wiki/EPC_QR_code
STM32 stlink V2
Interesting to see you can flash inexpensive stlink v2 clones into even more useful debuggers:
ESP32 LoRa
I have one of these ESP32 TTGO LoRa boards.
First thing I tried:
- https://github.com/osresearch/esp32-ttgo seems mostly concerned with pretty graphics on the OLED, no LoRa code
Some more promising links:
- https://primalcortex.wordpress.com/2017/11/24/the-esp32-oled-lora-ttgo-lora32-board-and-connecting-it-to-ttn
- https://github.com/fcgdam/TTGO_LoRa32
- https://ictoblog.nl/2018/01/10/mijn-eerste-chinese-esp32-verbonden-met-the-things-network
HC-06 stuff
The HC-06 is a serial-bluetooth converter. Default settings are 9600 baud, no parity. It doesn't really have a 'command mode' you need to enter, just make sure no BT client is connected and just send the command as a string of characters from the serial side within one second or so (without any CR/LF!).
To set odd parity:
AT+PO
WiFi "top"
This idea is about a simple demo application that shows the number of unique WiFi stations detected. 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.
The implementation is done using an ESP8266 in promiscuous mode. Using the callback for promiscuous mode, a table is built with an entry for each unique MAC address:
- 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:
- entries older than 60 minutes are removed from the table.
- 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:
- 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)
- random MACs: apparently some devices randomize their MAC address if they're not connected to a station. Not sure yet how to handle that.
- 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
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). This gives nice opportunity to either:
- transmit our own control signal, to control a quadcopter from something different than the manual remote control, e.g. automatic control
- 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).
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.
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. 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".
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 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
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.
Example C code
(this is the general idea, but I don't know if it compiles):
#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;
    ...
}
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 analytic signal, by creating the imaginary part using a 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". 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):
ESP8266 as modbus master:
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:
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.