Deteksi aliran darah dan suhu tubuh merupakan
hal dasar yang diperlukan untuk pembuatan Health Diagnostic Mouse. Hal ini sangat diperlukan disebabkan
pengukuran yang dilakukan oleh alat ini melalui aliran darah dan suhu tubuh.
Jika aliran darah tidak terdeteksi oleh sensor heart rate yaitu infrared dan
photodiode, maka pengukuran detak jantung tidak dapat di lakukan. Begitu juga
dengan suhu tubuh, apabila sensor DS18B20 tidak bekerja, maka pengukuran suhu
tubuh tidak dapat dilakukan.
Berikut source code untuk perhitungan heart rate dan body temperature. Untuk menggunakan program ini kita harus
menyediakan 2 buah library terlebih dahulu yaitu library TimeOne.h dan
OneWire.h. untuk download library tersebut silahkan klik pada masing-masing library.
#include "TimerOne.h"
#include "OneWire.h"
const int LEDHR=12;
int time;
int detak=1;
int heartRate;
int DS18S20_Pin = 3; //DS18S20 Signal pin on digital 3
float temperature;
// Global variable
const int THRESHOLD = 10;
int heartBeat = 0;
float currentBeat = 0;
int beatPerMinute = 0;
long timeDiffBetween[THRESHOLD-1];
long totalDiffTime = 0;
long lastBeatTime = 0;
long newBeatTime = 0;
int beatCounter = 0;
OneWire ds(DS18S20_Pin); // on digital pin 3
void setup(){
Serial.begin(115200);
pinMode(12,INPUT);
}
void loop(){
getHeartBeat2();
}
long timeSignal(){
int isHigh = 0;
int isLow = 0;
int isFalling = 0;
long totalTime = 0;
long startTime = 0;
long endTime = 0;
while(digitalRead(LEDHR) == HIGH){
if(isHigh == 0){
startTime = millis();
isHigh = 1;
}
}
endTime = millis();
if(isHigh){
totalTime = endTime - startTime;
}
return totalTime;
}
void getHeartBeat2(){
if(beatCounter >= THRESHOLD && digitalRead(LEDHR) == HIGH){
// mendapatkan waktu beat terbaru
newBeatTime = millis();
// mencatat waktu yang terakhir akan dibuang
long oldDiffTime = timeDiffBetween[beatCounter % THRESHOLD];
// menghitung selisih waktu antara beat terbaru dengan beat terakhir
timeDiffBetween[beatCounter % THRESHOLD] = newBeatTime - lastBeatTime;
int temp = 0;
totalDiffTime = 0;
while(temp < THRESHOLD-1){
totalDiffTime += timeDiffBetween[temp];
temp++;
}
//totalDiffTime -= oldDiffTime;
//totalDiffTime += newBeatTime - lastBeatTime;
// waktu beat terbaru akan menjadi waktu beat terakhir pada loop selanjutnya
lastBeatTime = newBeatTime;
// menghitung beat
beatCounter++;
timeSignal();
// rumus heartBeat
currentBeat = (60000.0/(float)(totalDiffTime)) * (THRESHOLD - 1);
beatPerMinute = currentBeat;
temperature = getTemp();
//print detak jantung
Serial.print(beatPerMinute);
//print spliter
Serial.print("|");
//print temperatur
Serial.println(temperature);
delay(50);
}
while(beatCounter < THRESHOLD){
if(digitalRead(LEDHR) == HIGH){
if(beatCounter == 0){
// set waktu beat terakhir untuk pertama kali
lastBeatTime = millis();
beatCounter++;
}else{
// mendapatkan waktu beat terbaru
newBeatTime = millis();
// menghitung selisih waktu antara beat terbaru dengan beat terakhir
timeDiffBetween[beatCounter-1] = newBeatTime - lastBeatTime;
totalDiffTime += newBeatTime - lastBeatTime;
// waktu beat terbaru akan menjadi waktu beat terakhir pada loop selanjutnya
lastBeatTime = newBeatTime;
// menghitung beat
beatCounter++;
}
timeSignal();
}
}
}
// penghitungan suhu menggunakan method getTemp()
float getTemp(){
//returns the temperature from one DS18S20 in DEG Celsius
byte data[12];
byte addr[8];
if ( !ds.search(addr)) {
//no more sensors on chain, reset search
ds.reset_search();
return -1000;
}
if ( OneWire::crc8( addr, 7) != addr[7]) {
//Serial.println("CRC is not valid!");
return -1000;
}
if ( addr[0] != 0x10 && addr[0] != 0x28) {
//Serial.print("Device is not recognized");
return -1000;
}
ds.reset();
ds.select(addr);
ds.write(0x44,1); // start conversion, with parasite power on at the end
byte present = ds.reset();
ds.select(addr);
ds.write(0xBE); // Read Scratchpad
for (int i = 0; i < 9; i++) { // we need 9 bytes
data[i] = ds.read();
}
ds.reset_search();
byte MSB = data[1];
byte LSB = data[0];
float tempRead = ((MSB << 8) | LSB); //using two's compliment
float TemperatureSum = tempRead / 16;
return TemperatureSum;
}
Hasil Running Program Pada Serial Monitor Arduino.![]() |
| Hasil Running Program |

sensornya pakai apa pak?
BalasHapussensor jantungnya pakek apa ya?? pulse sensor atau heart beet??
BalasHapus