1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310
|
`Tutorial for learning to use KuttyPy - A Python to real world bridge - in a 2 hour workshop session`
!!! info "Intended audience"
* Beginners who would like to explore microcontroller functions via Python without the compile+upload hassle.
* Hobbyists who want a way to control external parameters such as lights, fans, and [robots](../programming/intro/#slightly-complex-example) from their Python programs
* Scientists who want to use affordable and [easily available sensors](../sensors) for physical parameters( temperature, humidity, pressure...) without having to learn embedded systems and communications.
!!! info ""
{: style="position:relative;left:0px;right:0px;"}
## Software Installation
Given the paucity of time, the fastest ways for [installing](https://csparkresearch.in/kuttypyplus) the toolchain on different operating systems are listed. Click to expand.
??? abstract "Windows with Python3 installed"
* [Python3](https://www.python.org/ftp/python/3.8.0/python-3.8.0-amd64.exe) must be installed, and `pip` should be accessible.
* Open a command prompt as administrator, and use pip3 to install the KuttyPy package
```
py -3 -m pip install KuttyPy
```
* Download and install the [CH341 USB Driver](../assets/CH341SER.EXE)
* You will now be able to launch `kuttypyplus` from the prompt, and import the `kuttyPy` library from any Python script.
* you can also launch `kuttypyide`
* If you wish to compile C code and upload to the KuttyPy hardware, winavr must be installed, and `avr-gcc` must be accessible from a command prompt.
* Download and install `winavr` from [winavr.sourceforge.net](https://sourceforge.net/projects/winavr/files/WinAVR/20100110/WinAVR-20100110-install.exe/download)
??? warning "Windows bundled installer"
* The bundled installer includes Python3 and dependencies and KuttyPy software. Also includes winavr, usb driver.
[Download Bundled Installer](https://drive.google.com/uc?export=download&id=18PD-Llx12PTfMRWlHA447TCMxTA6smWZ)
!!! error "Made with Pyinstaller: Python will not be accessible globally"
Since the installer was made using PyInstaller, Python3 will not be accessible globally, and you will be limited to the ipython console within the KuttyPy software.
A better option would be to use pip to fetch PyQT5, qtconsole, pyserial, pyqtgraph, scipy , and KuttyPy . Winavr and the driver can be installed separately. Refer to the previous section.
??? abstract "Ubuntu"
* Download the [deb file from here](https://csparkresearch.in/assets/installers/KuttyPy-1.0.25.deb)
* Navigate to the Downloaded deb file location, and install it. This also fetches dependencies : scipy, qtconsole, avr-gcc etc
```
sudo apt install ./KuttyPy-1.0.25.deb
```
* launch the kuttyPy GUI from the command prompt using the command
```
kuttypyplus
```
It is also present in the applications menu as `KuttyPy GUI` .
* You can also launch the kuttyPy IDE from the menu, or using the command
```
kuttypyide
```
??? abstract "Using PIP on other OSes"
* Python3 must be installed
* Open a command prompt as administrator, and use pip3 to install the KuttyPy package
```
pip3 install kuttyPy
```
* You will now be able to launch `kuttypy` from the prompt, and import the `kuttyPy` library from Python.
* If you wish to compile C code, `avr-gcc` must be accessible from a command prompt. Install it from the package manager of your OS.
???warning "setting permissions on Linux based systems "
Accessing the hardware on linux requires certain permissions to be set.
Due to an apparent bug with pip3, the install script may fail to do this.
As a workaround, you can run the program as root to verify the permissions issue
```
sudo kuttypy
```
For a more permanent fix for regular users, please download and execute this
[post installation script](../assets/postinst.sh)
```bash
chmod +x postinst.sh
sudo ./postinst.sh
kuttypy
```
???abtract " Installing from source code "
```bash
sudo apt install python3-serial python3-pyqt5 python3-pyqt5.qtsvg gcc-avr avr-libc python3-qtconsole python3-scipy python3-pyqtgraph
git clone http://github.com/csparkresearch/kuttypy-gui
cd kuttypy-gui
python3 KuttyPyPlus.py
```
For setting hardware permissions, refer to the previous section
## KuttyPy Software
???+ success "Screenshot of the Graphical interface after launching `kuttypy` "

The title will show `Hardware not Detected` if not connected, or if a permissions issue exists
### Explore the functions
* You have already noticed that the User Interface(UI) resembles the kuttyPy board.
* It has four ports `PORTA, B , C, D` with 8 pins each, and each pin has a row representing it: 
---
* Each Pin is configured as an input by default, and the RED coloured box next to it indicates the input is `LOW` or near 0 Volts.
* If the input is `HIGH`, which can be accomplished by connecting it to 5V, or enabling the `pull-up` checkbox, the RED box will turn to `GREEN`
* Since the inputs are `floating`, merely touching the pins with your fingers will cause the inputs to fluctuate between `RED` and `GREEN` status. 
---
* Each pin can be reconfigured as an `OUTPUT` type by clicking on the `INPUT` button next to it.
* Make any of the pins `PD5`, `PD7`, or `PB3` an output type, and click on its square RED button to set it to `HIGH`. These pins are connected to the RGB LED on the board, so the LED will glow!
## Hello World
### Introduction to Registers
Programs executing on Microcontrollers use [special function registers(SFRs)](../programming/basics) to manipulate the hardware(Inputs, outputs, ADCs etc).
These are basically predefined variables, where each bit is associated with a hardware change.
??? tip " Binary conversion example "
{: style="width:100%"}
setReg and getReg Python function calls in the kuttyPy library can be used to read and write these registers.
Here's an example. Run it in a python3 shell.
```python
from kuttyPy import * #Import the library. also automatically connects to any available kuttypy hardware.
setReg('DDRD',160) #0b10100000 PD7(BLUE LED) and PD5(GREEN LED) made output type
setReg('PORTD',160) # PD5 and PD7 set to HIGH. Both LEDs start glowing. Colour looks like cyan.
```
For detailed examples, visit the [python coding page](../programming/intro).
You may skip to the [I/O examples](../programming/basics) page which will cover the following topics:
* Turning on an LED connected to any PIN
* Reading a voltage from an ADC enabled PIN
* Plotting with Matplotlib
* Using the iPython console
* Reading from I2C sensors
!!! note "Exercise : Python script for digital I/O"
* Write a python script to make PD5 and PD7 output type.
* Set PD5 HIGH (Green LED will glow)
* wait half a second ( time.sleep(0.5) )
* Set PD7 also HIGH. (Blue and Green will glow. resulting colour is Cyan )
* wait half a second ( time.sleep(0.5) )
* Set both LOW. (Nothing glows)
---
* Some pins have additional functionality:
* Analog to Digital Convertor enabled inputs:
* All pins on `PORTA (PA0 - PA7)` for this microcontroller have a 10-bit ADC functionality.
* Make it an `OUTPUT`, and click again to see a variable slider and an LCD number show a value between 0-1023 
* You can use this as an [8 channel, 0-5V voltmeter](../adc) for testing analog joysticks, sensors etc. Click on the LCD number to reveal a gauge and data logger!
* PWM outputs. PB3, PD5, PD7 . Adjust the RGB LED intensity using the sliders.

!!! note "Exercise : Python script for reading ADC"
* Enable ADC on PA0 via the graphical interface.
* Click on the LCD display, and from the dialog, check 'show register manipulations'
* Note the registers being written and read
* Disable the ADC (Set to input)
* `Go to the scripting tab, and write a program to read 10 values from PA0`
!!! tip "Stuff seems to be working?"
Now that we have skimmed over the basics of the graphical utility's `playground`, it would appear that the board is capable
of controlling real-world events from Python. For further details on the hardware schematic, [visit the page](../hw/) .
The pinout diagram will be very useful although the board itself is well labelled. The ATMEGA32 datasheet will be handy as well.
---
## Sensors using I2C communication
[Skip to the relevant page](../sensors/)
* [I2C Sensors](../sensors) for a range of physical parameters such as pressure, acceleration etc can be connected using PC0(SCL), and PC1(SDA).
* Use the graphical interface to scan for sensors and view readings
* Check out functionality, and explore potential applications.
* Write Python code to read data from an accelerometer.
!!! note "Sensors Exercise : Write a python program to read data from an accelerometer"
* The complete [docs are here](../programming/i2c) .
* `MPU6050_init()`
* `values = MPU6050_all()`
* Using the above two functions, one can get data from this sensor, where `values` is a 7 item long list.
* [Ax, Ay, Az, T, Gx, Gy, Gz] . A = acceleration. G = angular velocity
!!! note "Sensors Exercise #2: Plot 200 values from MPU6050 (Ax) using matplotlib"
* `pip3 install matplotlib` or `py -3 -m pip install matplotlib`
* The complete [docs are here](../programming/i2c) .
```python
from kuttyPy import *
from matplotlib import pyplot as plt
MPU6050_init() #Initialize the sensor
points = 0
for a in range(200):
x = MPU6050_all() #Fetch readings
if x is not None:
plt.scatter(points,x[0])
points +=1
plt.pause(0.01) #10ms delay.
```
* Replace the x-axis with timestamps instead of point numbers.
* Store 200 values, and timestamps in two lists, and plot using `plt.plot(x[],y[])` and `plt.show()`
!!! note "Sensors Exercise #3: Extract the oscillation frequency from the data using scipy's leastsq fitting "
```python
import numpy as np
from scipy import optimize
#-------------------------- Fourier Transform ------------------------------------
def fft(ya, si):
'''
Returns positive half of the Fourier transform of the signal ya.
Sampling interval 'si', in Seconds
'''
NP = len(ya)
if NP%2: #odd number
ya = ya[:-1]
NP-=1
v = np.array(ya)
tr = abs(np.fft.fft(v))/NP
frq = np.fft.fftfreq(NP, si)
x = frq.reshape(2,int(NP/2))
y = tr.reshape(2,int(NP/2))
return x[0], y[0]
def find_frequency(x,y): # Returns the fundamental frequency using FFT
tx,ty = fft(y, x[1]-x[0])
index = find_peak(ty)
if index == 0:
return None
else:
return tx[index]
def sine_eval(x,p): # y = a * sin(2*pi*f*x + phi)+ offset
return p[0] * np.sin(2*np.pi*p[1]*x+p[2])-p[3]
def sine_erf(p,x,y):
return y - sine_eval(x,p)
def fit_sine(xa,ya, freq = 0): # Time in S, V in volts, freq in Hz, accepts numpy arrays
size = len(ya)
mx = max(ya)
mn = min(ya)
amp = (mx-mn)/2
if freq == 0: # Guess frequency not given
freq = find_frequency(xa,ya)
if freq == None:
return None
#print 'guess a & freq = ', amp, freq
par = [amp, freq, 0.0, 0.0] # Amp, freq, phase , offset
par, pcov = optimize.leastsq(sine_erf, par, args=(xa, ya))
return par
####
#### YOU NEED TO WRITE CODE TO COLLECT data points and store timestamps to `TIMESTAMPS`
#### and values to `DATAPOINTS` here.
####
results=fit_sine(TIMESTAMPS,DATAPOINTS) #Returns : Amp, freq, phase , offset
if results is not None:
amp=abs(results[0])
freq=results[1]
print('Results: %5.2f amp, %5.3f Hz<br>'%(amp,freq))
```
---
## Basic C code
All the register manipulation commands issued by Python running on your laptop are interpreted by a bootloader firmware
executing on the microcontroller. In addition to this, you can also compile C code, and flash it to the remaining storage space
on the microcontroller, thereby making it independent and capable of functioning from any 5V power supply.
[Relevant section](../programming/c)
!!! note "Exercise : C program for digital I/O"
* Write a C program to make PD5 and PD7 output type.
* Set PD5 HIGH (Green LED will glow)
* wait half a second ( delay_ms(500); imported from "mh-utils.c" )
* Set PD7 also HIGH. (Blue and Green will glow. resulting colour is Cyan )
* wait half a second ( delay_ms(500); imported from "mh-utils.c" )
* Set both LOW. (Nothing glows)
|