A game of Knots-and-Crosses (Tic-Tac-Toe) built from 2458 individual mosfets, featuring both player-vs-player and player-vs-computer modes.
A fully discrete 14bit, 41kHz, FPGA-controlled successive-approximation audio ADC and R2R audio DAC.
An 8-bit, 1MHz processor built from individual logic and memory ICs, featuring a custom ISA, peripheral interface, USB programmer and macro assembler.
A full practical university-level embedded systems course based on a custom hardware platform and tooling running annually at ETH Zürich with 250+ participants.
A self-contained, miniaturized, BLE-enabled embedded platform for low-power, wearable, and hearable applications.
A low-power in-ear hand-gesture recognition system based on 50GHz mm-wave radars, efficient spatial and temporal Convolutional neural networks, and an energy-optimized hardware design.
An in-ear multi-vital sign monitor that measures heart rate, blood oxygenation (SpO2), and skin temperature.
A small embedded systems tracer with support for bare-metal and FreeRTOS-based targets. Targets the Perfetto trace viewer.
A modular chest-patch with integrated PPG, ECG, bio impedance, body temperature, and seismocardiographical sensors.
A fully discrete 8bit, 300Hz, successive-approximation ADC controlled by a 74-series logic gate state machine.
A 127 Step Audio Relay Step-Attenuator and 4-way input switcher designed to fit into a Schiit SYS enclosure.
A simple python BLE data logger which receives, decodes, stores, and plots characteristic data in real time.
A simple but flexible, unit-tested, cross-platform library to communicate with WS2812B-style LEDs using an SPI peripheral.
Compilers and tools in the VLSI and RTL world often produce a very large number of warnings and errors when run. I was interested in being able to quickly see all and navigate these diagnostics directly in (Neo)Vim.
This is easily achievable using the :make command and compiler plugins, or by
manually generating diagnostics with a lua script.
While my neovim configuration works out of the box for most of my projects, I have increasingly encountered situations where I need to adjust certain aspects on a per-project basis.
As with anything related to neovim configuration there are about 50 different ways this can be achieved, and because neovim is usually configured with executable code instead of declarative config files, a few gotchas that might not be immediately obvious.
Read More...