added ekg and better pulse detection
This commit is contained in:
parent
2a72572026
commit
b676520936
1 changed files with 55 additions and 18 deletions
|
@ -12,6 +12,7 @@ import socket
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import struct
|
import struct
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -60,31 +61,64 @@ class EKG2OSC(Forwarder):
|
||||||
super(EKG2OSC, self).__init__(actor, platform, device)
|
super(EKG2OSC, self).__init__(actor, platform, device)
|
||||||
|
|
||||||
def handleRead(self, osc_sock):
|
def handleRead(self, osc_sock):
|
||||||
pass
|
t = ord(self.serial.read(1))
|
||||||
|
osc_message = OSCMessage("/%s/ekg" % self.actor)
|
||||||
|
osc_message.appendTypedArg(t, "i")
|
||||||
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Pulse2OSC(Forwarder):
|
class Pulse2OSC(Forwarder):
|
||||||
def __init__(self, actor, platform, device):
|
def __init__(self, actor, platform, device):
|
||||||
super(Pulse2OSC, self).__init__(actor, platform, device)
|
super(Pulse2OSC, self).__init__(actor, platform, device)
|
||||||
|
self.buf = [0 for i in xrange(24)]
|
||||||
|
self.position = 0
|
||||||
|
self.start = -1
|
||||||
|
self.heartbeat_send = False
|
||||||
|
|
||||||
def handleRead(self, osc_sock):
|
def handleRead(self, osc_sock):
|
||||||
t = self.serial.read(5)
|
t = ord(self.serial.read(1))
|
||||||
print repr(t)
|
pos = (self.position + 1) % 24
|
||||||
sync1, sync2, heart_signal, heart_rate, o2 = struct.unpack("BBBBB", t)
|
self.buf[pos] = t
|
||||||
print sync1, sync2, heart_signal, heart_rate, o2
|
self.position = pos
|
||||||
if heart_signal > 200:
|
if t == 0:
|
||||||
|
self.start = pos
|
||||||
|
|
||||||
|
#print "start", self.start
|
||||||
|
if self.start > -1:
|
||||||
|
data = range(6)
|
||||||
|
for i in range(6):
|
||||||
|
data[i] = self.buf[(self.start + i) % 24]
|
||||||
|
|
||||||
|
sync1, sync2, heart_signal, heart_rate, o2, pulse = data
|
||||||
|
|
||||||
|
#print sync1, sync2, heart_signal, heart_rate, o2, pulse
|
||||||
|
if pulse == 245 and not self.heartbeat_send:
|
||||||
osc_message = OSCMessage("/%s/heartbeat" % self.actor)
|
osc_message = OSCMessage("/%s/heartbeat" % self.actor)
|
||||||
osc_message.appendTypedArg(1, "i")
|
osc_message.appendTypedArg(1, "i")
|
||||||
|
osc_message.appendTypedArg(heart_rate, "i")
|
||||||
|
osc_message.appendTypedArg(o2, "i")
|
||||||
osc_sock.sendall(osc_message.encode_osc())
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
print "heartbeat", datetime.datetime.now(), heart_signal
|
||||||
osc_message = OSCMessage("/%s/o2" % self.actor)
|
self.heartbeat_send = True
|
||||||
|
elif pulse == 1 and self.heartbeat_send:
|
||||||
|
#print "off heartbeat", datetime.datetime.now(), heart_signal
|
||||||
|
self.heartbeat_send = False
|
||||||
|
osc_message = OSCMessage("/%s/heartbeat" % self.actor)
|
||||||
|
osc_message.appendTypedArg(0, "i")
|
||||||
|
osc_message.appendTypedArg(heart_rate, "i")
|
||||||
osc_message.appendTypedArg(o2, "i")
|
osc_message.appendTypedArg(o2, "i")
|
||||||
osc_sock.sendall(osc_message.encode_osc())
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
|
||||||
osc_message = OSCMessage("/%s/heartrate" % self.actor)
|
#osc_message = OSCMessage("/%s/o2" % self.actor)
|
||||||
osc_message.appendTypedArg(heart_rate, "i")
|
#osc_message.appendTypedArg(o2, "i")
|
||||||
osc_sock.sendall(osc_message.encode_osc())
|
#osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
|
||||||
|
#osc_message = OSCMessage("/%s/heartrate" % self.actor)
|
||||||
|
#osc_message.appendTypedArg(heart_rate, "i")
|
||||||
|
#osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
self.start = -1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -116,8 +150,8 @@ def main():
|
||||||
}
|
}
|
||||||
|
|
||||||
naming = {
|
naming = {
|
||||||
"/tmp/tty2" : ["merle", "ehealth"],
|
"/dev/ttyACM0" : ["merle", "pulse"],
|
||||||
"/tmp/tty4" : ["merle", "pulse"]
|
#"/dev/ttyACM1" : ["merle", "pulse"]
|
||||||
}
|
}
|
||||||
|
|
||||||
used_devices = dict()
|
used_devices = dict()
|
||||||
|
@ -128,10 +162,13 @@ def main():
|
||||||
if device not in used_devices:
|
if device not in used_devices:
|
||||||
actor, platform = naming[device]
|
actor, platform = naming[device]
|
||||||
if description[1] == "ehealth":
|
if description[1] == "ehealth":
|
||||||
|
print device, actor, platform
|
||||||
used_devices[device] = EHealth2OSC(actor, platform, device)
|
used_devices[device] = EHealth2OSC(actor, platform, device)
|
||||||
elif description[1] == "ekg":
|
elif description[1] == "ekg":
|
||||||
|
print device, actor, platform
|
||||||
used_devices[device] = EKG2OSC(actor, platform, device)
|
used_devices[device] = EKG2OSC(actor, platform, device)
|
||||||
elif description[1] == "pulse":
|
elif description[1] == "pulse":
|
||||||
|
print device, actor, platform
|
||||||
used_devices[device] = Pulse2OSC(actor, platform, device)
|
used_devices[device] = Pulse2OSC(actor, platform, device)
|
||||||
else:
|
else:
|
||||||
raise ValueError("unknown description %r for device %r" % (description, device))
|
raise ValueError("unknown description %r for device %r" % (description, device))
|
||||||
|
@ -147,6 +184,6 @@ def main():
|
||||||
read_map[forwarder.serial] = forwarder.handleRead
|
read_map[forwarder.serial] = forwarder.handleRead
|
||||||
|
|
||||||
readers, writers, errors = select.select(read_map, [], [], 0.1)
|
readers, writers, errors = select.select(read_map, [], [], 0.1)
|
||||||
print "readers", readers
|
#print "readers", readers
|
||||||
for reader in readers:
|
for reader in readers:
|
||||||
read_map[reader](osc_sock)
|
read_map[reader](osc_sock)
|
||||||
|
|
Loading…
Reference in a new issue