Полярный H10 до RPI Ноль W: HR уведомления прекращаются после ок. 100 с без сообщения об ошибке - PullRequest
1 голос
/ 09 ноября 2019

Я использую pygatt на RPI Zero W для доступа к потоку уведомлений о людских ресурсах с нагрудного пояса Polar H10. Цель состоит в том, чтобы светодиод мигал с частотой сердечных сокращений. Уведомления приходят за ок. 100-е, тогда никто не прибывает больше. Никаких сообщений об ошибках или каких-либо (для меня узнаваемых) подсказок не отображается в журнале отладки. Любая помощь приветствуется.

Используемый код:

from pygatt.util import uuid16_to_uuid
from pygatt.exceptions import NotConnectedError, NotificationTimeout
import binascii
import time
import logging
import RPi.GPIO as gpio

MAC = 'E7:17:FD:20:B1:AA'   # MAC address of the Polar H10 belt
HR = 0
RRi1 = 0
RRi2 = 0
LED_On_time = 0.15       # seconds
GPIO_port = 19
gpio.setmode(gpio.BCM)
gpio.setup(GPIO_port, gpio.OUT)

logging.basicConfig(filename='/home/pi/python/debug.log',filemode='w',level=logging.DEBUG)
logging.getLogger('pygatt').setLevel(logging.DEBUG)

def callback(handle, measure):
    global HR, RRi1, RRi2

    if handle == 16:
        for i in range(len(measure)):
            if i == 1:
                print('Heart rate = ',measure[1],' bpm')
                HR = measure[1]
            if i == 2:
                RRi1 = round((measure[2] + 256*measure[3])/1024,2)
                print('RR intervall = %.2f' % RRi1,' s')
            if i == 4:
                RRi2 = round((measure[4] + 256*measure[5])/1024,2)
                print('RR intervall = %.2f' % RRi2,' s')


def Init():

    adapter = pygatt.GATTToolBackend()
    adapter.start()

    try:
        """ connect to bluetooth MAC addres with 5 seconds timeout"""
        device = adapter.connect(MAC, address_type=pygatt.BLEAddressType.random)
        device.bond()

        """ generate characteristics uuid's  """
        uuid_heart_service = uuid16_to_uuid(0x2A37)
        """ discover all characteristics uuid's"""
        device.discover_characteristics()


        device.subscribe(uuid_heart_service, callback, True)

    except NotConnectedError:
        print('No connection established ')
        quit()



Init()
t = time.time()    # Initialite with a reasonable value
while(1):
    gpio.output(GPIO_port, gpio.HIGH)
    time.sleep(LED_On_time)
    gpio.output(GPIO_port, gpio.LOW)
    time.sleep(max(0, 60/max(HR,30) - (time.time() - t)))    
    t = time.time()```
...