implemented arduino ehealth platform and added sensors2osc ehealth handler
This commit is contained in:
parent
c9fa341744
commit
7f416fddc2
2 changed files with 95 additions and 2 deletions
68
ehealth_sketch/ehealth_eno/ehealth_eno.ino
Normal file
68
ehealth_sketch/ehealth_eno/ehealth_eno.ino
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
Serial.begin(115200);
|
||||||
|
}
|
||||||
|
|
||||||
|
float getTemperature(void)
|
||||||
|
{
|
||||||
|
//Local variables
|
||||||
|
float Temperature; //Corporal Temperature
|
||||||
|
float Resistance; //Resistance of sensor.
|
||||||
|
float ganancia=5.0;
|
||||||
|
float Vcc=3.3;
|
||||||
|
float RefTension=3.0; // Voltage Reference of Wheatstone bridge.
|
||||||
|
float Ra=4700.0; //Wheatstone bridge resistance.
|
||||||
|
float Rc=4700.0; //Wheatstone bridge resistance.
|
||||||
|
float Rb=821.0; //Wheatstone bridge resistance.
|
||||||
|
int sensorValue = analogRead(A3);
|
||||||
|
|
||||||
|
float voltage2=((float)sensorValue*Vcc)/1023; // binary to voltage conversion
|
||||||
|
|
||||||
|
// Wheatstone bridge output voltage.
|
||||||
|
voltage2=voltage2/ganancia;
|
||||||
|
// Resistance sensor calculate
|
||||||
|
float aux=(voltage2/RefTension)+Rb/(Rb+Ra);
|
||||||
|
Resistance=Rc*aux/(1-aux);
|
||||||
|
if (Resistance >=1822.8) {
|
||||||
|
// if temperature between 25ºC and 29.9ºC. R(tª)=6638.20457*(0.95768)^t
|
||||||
|
Temperature=log(Resistance/6638.20457)/log(0.95768);
|
||||||
|
} else {
|
||||||
|
if (Resistance >=1477.1){
|
||||||
|
// if temperature between 30ºC and 34.9ºC. R(tª)=6403.49306*(0.95883)^t
|
||||||
|
Temperature=log(Resistance/6403.49306)/log(0.95883);
|
||||||
|
} else {
|
||||||
|
if (Resistance >=1204.8){
|
||||||
|
// if temperature between 35ºC and 39.9ºC. R(tª)=6118.01620*(0.96008)^t
|
||||||
|
Temperature=log(Resistance/6118.01620)/log(0.96008);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
if (Resistance >=988.1){
|
||||||
|
// if temperature between 40ºC and 44.9ºC. R(tª)=5859.06368*(0.96112)^t
|
||||||
|
Temperature=log(Resistance/5859.06368)/log(0.96112);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (Resistance >=811.7){
|
||||||
|
// if temperature between 45ºC and 50ºC. R(tª)=5575.94572*(0.96218)^t
|
||||||
|
Temperature=log(Resistance/5575.94572)/log(0.96218);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return Temperature;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
int airFlow = analogRead(A1);
|
||||||
|
int emg = analogRead(0);
|
||||||
|
int temp = getTemperature();
|
||||||
|
Serial.print(airFlow);
|
||||||
|
Serial.print(";");
|
||||||
|
Serial.print(emg);
|
||||||
|
Serial.print(";");
|
||||||
|
Serial.println(temp);
|
||||||
|
delay(100);
|
||||||
|
}
|
||||||
|
|
|
@ -53,7 +53,31 @@ class EHealth2OSC(Forwarder):
|
||||||
super(EHealth2OSC, self).__init__(actor, platform, device)
|
super(EHealth2OSC, self).__init__(actor, platform, device)
|
||||||
|
|
||||||
def handleRead(self, osc_sock):
|
def handleRead(self, osc_sock):
|
||||||
pass
|
data = self.serial.readline()[:-2]
|
||||||
|
print repr(data)
|
||||||
|
try:
|
||||||
|
airFlow, emg, temp = data.split(";")
|
||||||
|
except ValueError:
|
||||||
|
return
|
||||||
|
try:
|
||||||
|
airFlow = int(airFlow)
|
||||||
|
emg = int(emg)
|
||||||
|
temp = int(temp);
|
||||||
|
except ValueError:
|
||||||
|
return
|
||||||
|
osc_message = OSCMessage("/%s/airFlow" % self.actor)
|
||||||
|
osc_message.appendTypedArg(airFlow, "i")
|
||||||
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
osc_message = OSCMessage("/%s/emg" % self.actor)
|
||||||
|
osc_message.appendTypedArg(emg, "i")
|
||||||
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
osc_message = OSCMessage("/%s/temperatur" % self.actor)
|
||||||
|
osc_message.appendTypedArg(temp, "i")
|
||||||
|
osc_sock.sendall(osc_message.encode_osc())
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class EKG2OSC(Forwarder):
|
class EKG2OSC(Forwarder):
|
||||||
|
@ -150,7 +174,8 @@ def main():
|
||||||
}
|
}
|
||||||
|
|
||||||
naming = {
|
naming = {
|
||||||
"/dev/ttyACM0" : ["merle", "pulse"],
|
#"/dev/ttyACM0" : ["merle", "pulse"],
|
||||||
|
"/dev/ttyUSB0" : ["merle", "ehealth"],
|
||||||
#"/dev/ttyACM1" : ["merle", "pulse"]
|
#"/dev/ttyACM1" : ["merle", "pulse"]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue