Arduino/pulse sensor /midi

I have been struggling with integrating the pulse sensor and the midi output withi the arduino. I can get pulse sensor to work and also can get midi to work. just cannot get pulse sensor to talk to midi port.

I am looking for an Arduino coder whom i can contract to help out on this and several other projects.

Thanks

Rick

Google must be down again…

The big question is…Can you afford it?

Not lookinig for the lowest price, but someone who can get the job done within a reasonable rate and timeframe

Have a larger project after this

Define reasonable rate & time frame…

I’ll bet your version of ‘reasonable rate’ and the industry’s version of ‘reasonable rate’ are many orders of magnitude different…

My guess is that if the OP has posted his code, stated what it was supposed to do and simply asked why doesn’t it work … it would have been answered in 10 minutes.

I will post the code this afternoon. I think I am close but need some help

Thanks formthenresponse MnM

Here is the code (Below) that I am using for the pulse sensor. I modified some midi code but not sure where it would go in the loop.

/*

Pulse Sensor Amped 1.1 <<

This code is for Pulse Sensor Amped by Joel Murphy and Yury Gitman

http://www.pulsesensor.com

Pulse Sensor purple wire goes to Analog Pin 0 <<<

Pulse Sensor sample aquisition and processing happens in the background via Timer 2 interrupt. 2mS sample rate.

PWM on pins 3 and 11 will not work when using this code, because we are using Timer 2!

The following variables are automatically updated:

Signal : int that holds the analog signal data straight from the sensor. updated every 2mS.

IBI : int that holds the time interval between beats. 2mS resolution.

BPM : int that holds the heart rate value, derived every beat, from averaging previous 10 IBI values.

QS : boolean that is made true whenever Pulse is found and BPM is updated. User must reset.

Pulse : boolean that is true when a heartbeat is sensed then false in time with pin13 LED going out.

This code is designed with output serial data to Processing sketch “PulseSensorAmped_Processing-xx”

The Processing sketch is a simple data visualizer.

All the work to find the heartbeat and determine the heartrate happens in the code below.

Pin 13 LED will blink with heartbeat.

If you want to use pin 13 for something else, adjust the interrupt handler

It will also fade an LED on pin fadePin with every beat. Put an LED and series resistor from fadePin to GND.

Check here for detailed code walkthrough:

http://pulsesensor.myshopify.com/pages/ … ino-v1dot1

Code Version 02 by Joel Murphy & Yury Gitman Fall 2012

This update changes the HRV variable name to IBI, which stands for Inter-Beat Interval, for clarity.

Switched the interrupt to Timer2. 500Hz sample rate, 2mS resolution IBI value.

Fade LED pin moved to pin 5 (use of Timer2 disables PWM on pins 3 & 11).

Tidied up inefficiencies since the last version.

*/

// VARIABLES

int pulsePin = 0; // Pulse Sensor purple wire connected to analog pin 0

int blinkPin = 13; // pin to blink led at each beat

int fadePin = 5; // pin to do fancy classy fading blink at each beat

int fadeRate = 0; // used to fade LED on with PWM on fadePin

// these variables are volatile because they are used during the interrupt service routine!

volatile int BPM; // used to hold the pulse rate

volatile int Signal; // holds the incoming raw data

volatile int IBI = 600; // holds the time between beats, the Inter-Beat Interval

volatile boolean Pulse = false; // true when pulse wave is high, false when it’s low

volatile boolean QS = false; // becomes true when Arduoino finds a beat.

void setup(){

pinMode(blinkPin,OUTPUT); // pin that will blink to your heartbeat!

pinMode(fadePin,OUTPUT); // pin that will fade to your heartbeat!

Serial.begin(115200); // we agree to talk fast!

interruptSetup(); // sets up to read Pulse Sensor signal every 2mS

// UN-COMMENT THE NEXT LINE IF YOU ARE POWERING The Pulse Sensor AT LOW VOLTAGE,

// AND APPLY THAT VOLTAGE TO THE A-REF PIN

//analogReference(EXTERNAL);

}

void loop(){

sendDataToProcessing(‘S’, Signal); // send Processing the raw Pulse Sensor data

if (QS == true){ // Quantified Self flag is true when arduino finds a heartbeat

fadeRate = 255; // Set ‘fadeRate’ Variable to 255 to fade LED with pulse

sendDataToProcessing(‘B’,BPM); // send heart rate with a ‘B’ prefix

sendDataToProcessing(‘Q’,IBI); // send time between beats with a ‘Q’ prefix

QS = false; // reset the Quantified Self flag for next time

}

ledFadeToBeat();

delay(20); // take a break

}

void ledFadeToBeat(){

fadeRate -= 15; // set LED fade value

fadeRate = constrain(fadeRate,0,255); // keep LED fade value from going into negative numbers!

analogWrite(fadePin,fadeRate); // fade LED

}

void sendDataToProcessing(char symbol, int data ){

Serial.print(symbol); // symbol prefix tells Processing what type of data is coming

Serial.println(data); // the data to send culminating in a carriage return

}

// Here is the Midi Code :

/*

The circuit:

  • digital transmit 1 connected to MIDI jack pin 5

  • MIDI jack pin 2 connected to ground

  • MIDI jack pin 4 connected to +5V through 220-ohm resistor

*/

void Midi() {

// Set MIDI baud rate:

Serial.begin(31250);

}

void PlayNote() {

// play note (0x51)

//Note on channel 10 (0x99), 0x51, middle velocity (0x45):

noteOn(0x099, 0x51, 0x45);

delay(2000);

}

// plays a MIDI note. Doesn’t check to see that

// cmd is greater than 127, or that data values are less than 127:

void noteOn(int cmd, int pitch, int velocity) {

Serial.write(cmd);

Serial.write(pitch);

Serial.write(velocity);

}

So what is it that you want the mash-up of the 2 to do ? There are to things I see immediately that might be a problem. First the MIDI baud rate is not the same as the HB code baud rate. Depending on how much data is to be sent out over the serial link and how often that’s supposed to happen, you may have a problem. Talking to true MIDI devices, which I assume is the intent, means you are stuck at the MIDI baud rate of 31250.

Secondly I note the loop rate on the HB code is approximately 20 msec. Again I might assume your intent is to send a MIDI command to play a note every so often. I expect that such notes last longer than 20 msec. Then again I might expect that some note only happens when a HB is detected and that’s about every sec or so (60 BPM being a normal resting heat beat rate) so it depends in what the mash-up is intended to do.

I’ll familiarize myself with the details of the 2 programs, awaiting your intent. Though I do have to mow the law before sunset.

PS - You’re missing the interruptSetup() and the actual interrupt code from the HB code. I suspect all the real work is done in that interrupt routine, that is it detects the HB and sets the QS boolean (which I suspect is all you care about).

PPS - if you use the code buttons, you’ll get nice formatted code boxes to place the code snippets in.

(click on to open)

So here’s my 1’st cut at your code assuming all you want it to do is send the MIDI command to play the noted specified. I eliminated the sending of the Signal data as that might not have fit in time-wise given the lower MIDI baud rate. Otherwise the rest of the data and blinking and PWM’ing of the LEDs is intact. If you don’t want those, you can further simplify the code by eliminating those parts.

//Modified the pulse code to send MIDI command whenever a heart beat is detected.

// VARIABLES
int pulsePin = 0; // Pulse Sensor purple wire connected to analog pin 0
int blinkPin = 13; // pin to blink led at each beat
int fadePin = 5; // pin to do fancy classy fading blink at each beat
int fadeRate = 0; // used to fade LED on with PWM on fadePin


// these variables are volatile because they are used during the interrupt service routine!
volatile int BPM; // used to hold the pulse rate
volatile int Signal; // holds the incoming raw data
volatile int IBI = 600; // holds the time between beats, the Inter-Beat Interval
volatile boolean Pulse = false; // true when pulse wave is high, false when it's low
volatile boolean QS = false; // becomes true when Arduoino finds a beat.


void setup(){
  pinMode(blinkPin,OUTPUT); // pin that will blink to your heartbeat!
  pinMode(fadePin,OUTPUT); // pin that will fade to your heartbeat!
  Serial.begin(31250); // we agree to talk fast!
  interruptSetup(); // sets up to read Pulse Sensor signal every 2mS
  // UN-COMMENT THE NEXT LINE IF YOU ARE POWERING The Pulse Sensor AT LOW VOLTAGE,
  // AND APPLY THAT VOLTAGE TO THE A-REF PIN
  //analogReference(EXTERNAL);
}

void loop(){
  //disable sending all the Signal data as that might take too long
  //sendDataToProcessing('S', Signal); // send Processing the raw Pulse Sensor data
  if (QS == true){ // Quantified Self flag is true when arduino finds a heartbeat
    //add command to play note only when HB has been detected
    noteOn(0x099, 0x51, 0x45);
    fadeRate = 255; // Set 'fadeRate' Variable to 255 to fade LED with pulse
    sendDataToProcessing('B',BPM); // send heart rate with a 'B' prefix
    sendDataToProcessing('Q',IBI); // send time between beats with a 'Q' prefix
    QS = false; // reset the Quantified Self flag for next time
  }

  ledFadeToBeat();

  delay(20); // take a break
}


void ledFadeToBeat(){
  fadeRate -= 15; // set LED fade value
  fadeRate = constrain(fadeRate,0,255); // keep LED fade value from going into negative numbers!
  analogWrite(fadePin,fadeRate); // fade LED
}

void sendDataToProcessing(char symbol, int data ){
  Serial.print(symbol); // symbol prefix tells Processing what type of data is coming
  Serial.println(data); // the data to send culminating in a carriage return
}

// plays a MIDI note. Doesn't check to see that
// cmd is greater than 127, or that data values are less than 127:
void noteOn(int cmd, int pitch, int velocity) {
  Serial.write(cmd);
  Serial.write(pitch);
  Serial.write(velocity);
}

I’ve made some assumptions about how the interrupt code runs and does it’s job, particularly how QS is set.

Thanks for what you have done to date, it is really appreciated. You have brought up some important points. Also I wasn’t sure about the baud rates being different and that would create a problem. I am going to review and I will report back in the am.

In the meantime here is Interrupt code that fires with the pulse sensor

volatile int rate[10];                    // used to hold last ten IBI values
volatile unsigned long sampleCounter = 0;          // used to determine pulse timing
volatile unsigned long lastBeatTime = 0;           // used to find the inter beat interval
volatile int P =512;                      // used to find peak in pulse wave
volatile int T = 512;                     // used to find trough in pulse wave
volatile int thresh = 512;                // used to find instant moment of heart beat
volatile int amp = 100;                   // used to hold amplitude of pulse waveform
volatile boolean firstBeat = true;        // used to seed rate array so we startup with reasonable BPM
volatile boolean secondBeat = true;       // used to seed rate array so we startup with reasonable BPM


void interruptSetup(){     
  // Initializes Timer2 to throw an interrupt every 2mS.
  TCCR2A = 0x02;     // DISABLE PWM ON DIGITAL PINS 3 AND 11, AND GO INTO CTC MODE
  TCCR2B = 0x06;     // DON'T FORCE COMPARE, 256 PRESCALER 
  OCR2A = 0X7C;      // SET THE TOP OF THE COUNT TO 124 FOR 500Hz SAMPLE RATE
  TIMSK2 = 0x02;     // ENABLE INTERRUPT ON MATCH BETWEEN TIMER2 AND OCR2A
  sei();             // MAKE SURE GLOBAL INTERRUPTS ARE ENABLED      
} 


// THIS IS THE TIMER 2 INTERRUPT SERVICE ROUTINE. 
// Timer 2 makes sure that we take a reading every 2 miliseconds
ISR(TIMER2_COMPA_vect){                         // triggered when Timer2 counts to 124
    cli();                                      // disable interrupts while we do this
    Signal = analogRead(pulsePin);              // read the Pulse Sensor 
    sampleCounter += 2;                         // keep track of the time in mS with this variable
    int N = sampleCounter - lastBeatTime;       // monitor the time since the last beat to avoid noise

//  find the peak and trough of the pulse wave
    if(Signal < thresh && N > (IBI/5)*3){       // avoid dichrotic noise by waiting 3/5 of last IBI
        if (Signal < T){                        // T is the trough
            T = Signal;                         // keep track of lowest point in pulse wave 
         }
       }
      
    if(Signal > thresh && Signal > P){          // thresh condition helps avoid noise
        P = Signal;                             // P is the peak
       }                                        // keep track of highest point in pulse wave
    
  //  NOW IT'S TIME TO LOOK FOR THE HEART BEAT
  // signal surges up in value every time there is a pulse
if (N > 250){                                   // avoid high frequency noise
  if ( (Signal > thresh) && (Pulse == false) && (N > (IBI/5)*3) ){        
    Pulse = true;                               // set the Pulse flag when we think there is a pulse
    digitalWrite(blinkPin,HIGH);                // turn on pin 13 LED
    IBI = sampleCounter - lastBeatTime;         // measure time between beats in mS
    lastBeatTime = sampleCounter;               // keep track of time for next pulse
         
         if(firstBeat){                         // if it's the first time we found a beat, if firstBeat == TRUE
             firstBeat = false;                 // clear firstBeat flag
             return;                            // IBI value is unreliable so discard it
            }   
         if(secondBeat){                        // if this is the second beat, if secondBeat == TRUE
            secondBeat = false;                 // clear secondBeat flag
               for(int i=0; i<=9; i++){         // seed the running total to get a realisitic BPM at startup
                    rate[i] = IBI;                      
                    }
            }
          
    // keep a running total of the last 10 IBI values
    word runningTotal = 0;                   // clear the runningTotal variable    

    for(int i=0; i<=8; i++){                // shift data in the rate array
          rate[i] = rate[i+1];              // and drop the oldest IBI value 
          runningTotal += rate[i];          // add up the 9 oldest IBI values
        }
        
    rate[9] = IBI;                          // add the latest IBI to the rate array
    runningTotal += rate[9];                // add the latest IBI to runningTotal
    runningTotal /= 10;                     // average the last 10 IBI values 
    BPM = 60000/runningTotal;               // how many beats can fit into a minute? that's BPM!
    QS = true;                              // set Quantified Self flag 
    // QS FLAG IS NOT CLEARED INSIDE THIS ISR
    }                       
}

  if (Signal < thresh && Pulse == true){     // when the values are going down, the beat is over
      digitalWrite(blinkPin,LOW);            // turn off pin 13 LED
      Pulse = false;                         // reset the Pulse flag so we can do it again
      amp = P - T;                           // get amplitude of the pulse wave
      thresh = amp/2 + T;                    // set thresh at 50% of the amplitude
      P = thresh;                            // reset these for next time
      T = thresh;
     }
  
  if (N > 2500){                             // if 2.5 seconds go by without a beat
      thresh = 512;                          // set thresh default
      P = 512;                               // set P default
      T = 512;                               // set T default
      lastBeatTime = sampleCounter;          // bring the lastBeatTime up to date        
      firstBeat = true;                      // set these to avoid noise
      secondBeat = true;                     // when we get the heartbeat back
     }
  
  sei();                                     // enable interrupts when youre done!
}// end isr

Thanks again for taking a look at this

Looks like it is working

Had a code error when compiled but realized that I needed to add the interupt code. Then all worked.

Speedbrake:
Then all worked.

Good to know, I took my best guess as to what you wanted it to do.

Mark the thread as solved if there’s nothing more to it.

Hello guys, Can i ask some questions regarding this Pulse Sensor? I need some help regarding my project on Pulse Sensor.

I am an Mechanical Engineering undergraduate and i have no experience in Arduino. I am learning from basic now.

Questions: I have paste the Pulse Sensor code (version 1.1) with the interrupt code without changing anything. I successfully upload it into the Arduino chipboard, but the pulse sensor wouldn’t work. May i know what should i edit in the code?

I herewith attached my arduino code. Thank you very much. :smiley: :smiley: :smiley:

/*
>> Pulse Sensor Amped 1.1 <<
This code is for Pulse Sensor Amped by Joel Murphy and Yury Gitman
    www.pulsesensor.com 
    >>> Pulse Sensor purple wire goes to Analog Pin 0 <<<
Pulse Sensor sample aquisition and processing happens in the background via Timer 2 interrupt. 2mS sample rate.
PWM on pins 3 and 11 will not work when using this code, because we are using Timer 2!
The following variables are automatically updated:
Signal :    int that holds the analog signal data straight from the sensor. updated every 2mS.
IBI  :      int that holds the time interval between beats. 2mS resolution.
BPM  :      int that holds the heart rate value, derived every beat, from averaging previous 10 IBI values.
QS  :       boolean that is made true whenever Pulse is found and BPM is updated. User must reset.
Pulse :     boolean that is true when a heartbeat is sensed then false in time with pin13 LED going out.

This code is designed with output serial data to Processing sketch "PulseSensorAmped_Processing-xx"
The Processing sketch is a simple data visualizer. 
All the work to find the heartbeat and determine the heartrate happens in the code below.
Pin 13 LED will blink with heartbeat.
If you want to use pin 13 for something else, adjust the interrupt handler
It will also fade an LED on pin fadePin with every beat. Put an LED and series resistor from fadePin to GND.
Check here for detailed code walkthrough:
http://pulsesensor.myshopify.com/pages/pulse-sensor-amped-arduino-v1dot1

Code Version 02 by Joel Murphy & Yury Gitman  Fall 2012
This update changes the HRV variable name to IBI, which stands for Inter-Beat Interval, for clarity.
Switched the interrupt to Timer2.  500Hz sample rate, 2mS resolution IBI value.
Fade LED pin moved to pin 5 (use of Timer2 disables PWM on pins 3 & 11).
Tidied up inefficiencies since the last version. 
*/


//  VARIABLES
int pulsePin = 0;                 // Pulse Sensor purple wire connected to analog pin 0
int blinkPin = 13;                // pin to blink led at each beat
int fadePin = 5;                  // pin to do fancy classy fading blink at each beat
int fadeRate = 0;                 // used to fade LED on with PWM on fadePin


// these variables are volatile because they are used during the interrupt service routine!
volatile int BPM;                   // used to hold the pulse rate
volatile int Signal;                // holds the incoming raw data
volatile int IBI = 600;             // holds the time between beats, the Inter-Beat Interval
volatile boolean Pulse = false;     // true when pulse wave is high, false when it's low
volatile boolean QS = false;        // becomes true when Arduoino finds a beat.


void setup(){
  pinMode(blinkPin,OUTPUT);         // pin that will blink to your heartbeat!
  pinMode(fadePin,OUTPUT);          // pin that will fade to your heartbeat!
  Serial.begin(115200);             // we agree to talk fast!
  interruptSetup();                 // sets up to read Pulse Sensor signal every 2mS 
   // UN-COMMENT THE NEXT LINE IF YOU ARE POWERING The Pulse Sensor AT LOW VOLTAGE, 
   // AND APPLY THAT VOLTAGE TO THE A-REF PIN
   //analogReference(EXTERNAL);   
}



void loop(){
  sendDataToProcessing('S', Signal);     // send Processing the raw Pulse Sensor data
  if (QS == true){                       // Quantified Self flag is true when arduino finds a heartbeat
        fadeRate = 255;                  // Set 'fadeRate' Variable to 255 to fade LED with pulse
        sendDataToProcessing('B',BPM);   // send heart rate with a 'B' prefix
        sendDataToProcessing('Q',IBI);   // send time between beats with a 'Q' prefix
        QS = false;                      // reset the Quantified Self flag for next time    
     }
  
  ledFadeToBeat();
  
  delay(20);                             //  take a break
}


void ledFadeToBeat(){
    fadeRate -= 15;                         //  set LED fade value
    fadeRate = constrain(fadeRate,0,255);   //  keep LED fade value from going into negative numbers!
    analogWrite(fadePin,fadeRate);          //  fade LED
  }


void sendDataToProcessing(char symbol, int data ){
    Serial.print(symbol);                // symbol prefix tells Processing what type of data is coming
    Serial.println(data);                // the data to send culminating in a carriage return
  }

//interrupt code ~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.~.


volatile int rate[10];                    // array to hold last ten IBI values
volatile unsigned long sampleCounter = 0;          // used to determine pulse timing
volatile unsigned long lastBeatTime = 0;           // used to find IBI
volatile int P =512;                      // used to find peak in pulse wave, seeded
volatile int T = 512;                     // used to find trough in pulse wave, seeded
volatile int thresh = 512;                // used to find instant moment of heart beat, seeded
volatile int amp = 100;                   // used to hold amplitude of pulse waveform, seeded
volatile boolean firstBeat = true;        // used to seed rate array so we startup with reasonable BPM
volatile boolean secondBeat = false;      // used to seed rate array so we startup with reasonable BPM


void interruptSetup(){     
  // Initializes Timer2 to throw an interrupt every 2mS.
  TCCR2A = 0x02;     // DISABLE PWM ON DIGITAL PINS 3 AND 11, AND GO INTO CTC MODE
  TCCR2B = 0x06;     // DON'T FORCE COMPARE, 256 PRESCALER 
  OCR2A = 0X7C;      // SET THE TOP OF THE COUNT TO 124 FOR 500Hz SAMPLE RATE
  TIMSK2 = 0x02;     // ENABLE INTERRUPT ON MATCH BETWEEN TIMER2 AND OCR2A
  sei();             // MAKE SURE GLOBAL INTERRUPTS ARE ENABLED      
} 


// THIS IS THE TIMER 2 INTERRUPT SERVICE ROUTINE. 
// Timer 2 makes sure that we take a reading every 2 miliseconds
ISR(TIMER2_COMPA_vect){                         // triggered when Timer2 counts to 124
  cli();                                      // disable interrupts while we do this
  Signal = analogRead(pulsePin);              // read the Pulse Sensor 
  sampleCounter += 2;                         // keep track of the time in mS with this variable
  int N = sampleCounter - lastBeatTime;       // monitor the time since the last beat to avoid noise

    //  find the peak and trough of the pulse wave
  if(Signal < thresh && N > (IBI/5)*3){       // avoid dichrotic noise by waiting 3/5 of last IBI
    if (Signal < T){                        // T is the trough
      T = Signal;                         // keep track of lowest point in pulse wave 
    }
  }

  if(Signal > thresh && Signal > P){          // thresh condition helps avoid noise
    P = Signal;                             // P is the peak
  }                                        // keep track of highest point in pulse wave

  //  NOW IT'S TIME TO LOOK FOR THE HEART BEAT
  // signal surges up in value every time there is a pulse
  if (N > 250){                                   // avoid high frequency noise
    if ( (Signal > thresh) && (Pulse == false) && (N > (IBI/5)*3) ){        
      Pulse = true;                               // set the Pulse flag when we think there is a pulse
      digitalWrite(blinkPin,HIGH);                // turn on pin 13 LED
      IBI = sampleCounter - lastBeatTime;         // measure time between beats in mS
      lastBeatTime = sampleCounter;               // keep track of time for next pulse

      if(secondBeat){                        // if this is the second beat, if secondBeat == TRUE
        secondBeat = false;                  // clear secondBeat flag
        for(int i=0; i<=9; i++){             // seed the running total to get a realisitic BPM at startup
          rate[i] = IBI;                      
        }
      }

      if(firstBeat){                         // if it's the first time we found a beat, if firstBeat == TRUE
        firstBeat = false;                   // clear firstBeat flag
        secondBeat = true;                   // set the second beat flag
        sei();                               // enable interrupts again
        return;                              // IBI value is unreliable so discard it
      }   


      // keep a running total of the last 10 IBI values
      word runningTotal = 0;                  // clear the runningTotal variable    

      for(int i=0; i<=8; i++){                // shift data in the rate array
        rate[i] = rate[i+1];                  // and drop the oldest IBI value 
        runningTotal += rate[i];              // add up the 9 oldest IBI values
      }

      rate[9] = IBI;                          // add the latest IBI to the rate array
      runningTotal += rate[9];                // add the latest IBI to runningTotal
      runningTotal /= 10;                     // average the last 10 IBI values 
      BPM = 60000/runningTotal;               // how many beats can fit into a minute? that's BPM!
      QS = true;                              // set Quantified Self flag 
      // QS FLAG IS NOT CLEARED INSIDE THIS ISR
    }                       
  }

  if (Signal < thresh && Pulse == true){   // when the values are going down, the beat is over
    digitalWrite(blinkPin,LOW);            // turn off pin 13 LED
    Pulse = false;                         // reset the Pulse flag so we can do it again
    amp = P - T;                           // get amplitude of the pulse wave
    thresh = amp/2 + T;                    // set thresh at 50% of the amplitude
    P = thresh;                            // reset these for next time
    T = thresh;
  }

  if (N > 2500){                           // if 2.5 seconds go by without a beat
    thresh = 512;                          // set thresh default
    P = 512;                               // set P default
    T = 512;                               // set T default
    lastBeatTime = sampleCounter;          // bring the lastBeatTime up to date        
    firstBeat = true;                      // set these to avoid noise
    secondBeat = false;                    // when we get the heartbeat back
  }

  sei();                                   // enable interrupts when youre done!
}// end isr