-
Notifications
You must be signed in to change notification settings - Fork 0
/
week5_task2a.py
71 lines (60 loc) · 2.02 KB
/
week5_task2a.py
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
# Write a code that calculates the basic HRV analysis parameters and shows the values on the OLED:
# ▪ Mean PPI
# ▪ mean heart rate (HR)
# ▪ Standard deviation of PPI (SDNN)
# ▪ Root mean square of successive differences (RMSSD)
import array
import ssd1306
from machine import Pin, I2C
from utime import sleep_ms
# OLED
i2c = I2C(1, sda=Pin(14), scl=Pin(15))
oled = ssd1306.SSD1306_I2C(128, 64, i2c)
# Rotary encoder button
button = Pin(12, mode = Pin.IN, pull = Pin.PULL_UP)
# Testdata
test_set1 = array.array('I', [1000, 1100, 1000, 1100, 1000, 1100, 1000, 1100, 1000, 1100, 1000, 1100,
1000, 1100, 1000, 1100, 1000, 1100, 1000, 1100])
def meanPPI_calculator(data):
sumPPI = 0
for i in data:
sumPPI += i
meanPPI = sumPPI/len(data)
print('Mean PPI value:', int(meanPPI), 'ms')
return meanPPI
def meanHR_calculator(meanPPI):
HR = 60000/meanPPI
rounded_HR = round(HR, 0)
print('Mean HR value:', int(rounded_HR), 'bpm')
return rounded_HR
def SDNN_calculator(data, PPI):
summary = 0
for i in data:
summary += (i-PPI)**2
SDNN = (summary/(len(data)-1))**(1/2)
rounded_SDNN = round(SDNN, 0)
print('SDNN value:', int(rounded_SDNN), 'ms')
return rounded_SDNN
def RMSSD_calculator(data):
i = 0
summary = 0
while i < len(data)-1:
summary += (data[i+1]-data[i])**2
i +=1
RMSSD = (summary/(len(data)-1))**(1/2)
rounded_RMSSD = round(RMSSD, 0)
print('RMSSD value:', int(rounded_RMSSD), 'ms')
return rounded_RMSSD
PPI1= meanPPI_calculator(test_set1)
HR1 = meanHR_calculator(PPI1)
SSDN1 = SDNN_calculator(test_set1, PPI1)
RMSSD1 = RMSSD_calculator(test_set1)
oled.text('MeanPPI:'+ str(int(PPI1)) +'ms', 0, 0, 1)
oled.text('MeanHR:'+ str(int(HR1)) +'bpm', 0, 10, 1)
oled.text('SDNN:'+str(int(SSDN1)) +'ms', 0, 20, 1)
oled.text('RMSSD:'+str(int(RMSSD1)) +'ms', 0, 30, 1)
oled.show()
while True:
if button.value() == 0:
oled.fill(0)
oled.show()