The kuttyPy (/kʊtipʌɪ/) Microcontroller training utility allows live manipulation of the registers in microcontrollers via a connected computer containing its python library. setReg and getReg function calls act as debugging and monitoring tools, and combined with Python's visualization and analytical utilities, this approach has immense pedagogical potential for beginners to the microcontroller world.
The kuttyPy hardware is an ATMEGA32 microcontroller development board developed by the ExpEYES project, and is currently supported by this software. It contains the kuttyPy firmware, but can also be used to run other programs via its bootloader.
- It's an atmega32 development board with a bootloader supporting the 'arduino' protocol
- The bootloader also allows real-time manipulation of registers through commmands sent via the serial port.
- This is done by the associated Python library and companion GUI
- You can monitor every input
- Toggle every output
- Deal with Peripherals such as PWMs and Counters
- View ADC readings via an analog gauge
- Scan for sensors connected to the I2C Bus
- Monitor readings from sensors [TSL2561 luminosity, and MPU6050 IMU supported]
- Compile code to hex with the avr-gcc compiler
- Upload hex via the built-in uploader
- Rapidly prototype and debug educational projects. For example, you can verify ADC input values before handing over control to the uploaded hex file which will likely have very limited debugging capabilities.
- Learn how registers are the key to microcontroller operation, as opposed to the Arduino ecosystem which prefers obfuscation of these details underneath abstraction layers.
Supports I2C sensors: Luminosity Example. | Video recording |
---|---|
- Scan for Sensors
- Click to monitor via analog gauge
- List of I2C sensors supported thus far (Minimal data logging. Configuration options via the graphical utility might be incomplete)
- MPU6050 3 Axis Accelerometer, 3 axis Angular velocity (Gyro)
- TSL2561 Luminosity measurements
- BMP280 Pressure and Temperature sensor
- MCP4725 Single channel DAC
- PCA9685 PWM controller
- MLX90614 Passive IR
Programming library and examples : READ THE DOCS
Hall Sensor | Servo Motor |
---|---|
Plug and play various accessories such as this Hall Sensor, & servo motor.
Monitor your code's activity while it executes
Add custom register blocks, twiddle bits, and observe! In this demo, the ADC is read by first setting the bits in the ADCSRA(control and status register), then reading back ADCL(8LSB)+ADCH(2MSB), and also checking the new status of ADCSRA after the operation.
The KuttyPy monitor code is part of the bootloader. This allows users to upload their own Hex files without losing the training utility features.
This example shows how to skip back and forth to an LED scanning code (which also prints letters to the serial port) written in C and uploaded.
In the animation, after fiddling a little with the PWM controls on the monitor, the 'user app' button is clicked. This triggers the following:
- Within a few ten milliseconds the user uploaded hex file starts executing
- The console turns into a serial monitor, and shows any text sent by the user uploaded hex.
The user can switch back to the monitoring utility in a snap!
A persistence of vision display made with C code! Write text in thin air using 8 LEDs on PORTB.
- sudo apt-get install python3 python3-pyqt5 python3-serial
- python3 KuttyPyGUI.py
- This code can be run from source, provided python3 and pyqt5 are installed.
- Download Bundled Installer
License: MIT
Developed by Jithin B.P @CSpark Research, 2018.
Special thanks to Georges Khazanadar for Debianizing efforts.