If you dont already have one, you can buy ProtoCentral MAX30001 ECG and Respiration/Bio-Impedance Breakout Board here.
MAX30001 is a single-lead ECG monitoring IC which has built-in R-R detection and several other features that make it perfect for a wearable single-lead ECG application.
Several new features on this chip make it ideal for wearable applications. First is the low power consumption - just 85 uW of power and can work from 1.1 V onwards ! Also of interest is the fact that it can work with only two chest electrodes without the need for a third right-leg drive (DRL) electrode.
The best feature of this chip though is the built-in R-R detection algorithm which can measure the time between successive peaks of the QRS complex of the ECG. This means that heart-computation comes right out of the box without any microcontroller-side code requirement. Heart-rate computation just got a lot easier !!
- MAX30001 single channel integrated front-end (AFE) chip
- Single-lead ECG monitoring ( three electrodes, optional right leg drive)
- Capable of measuring respiration
- Clinical-Grade ECG and BioZ AFE with High Resolution
- Inbuilt R-R detection and Pace detection
- Flexibility for 2 or 3 electrode measurements
- ADC Resolution is 18 bits
- High DC Offset range of ±650mV(excellent tolerance to motion artifacts)
- Onboard 3.3V voltage regulator for low noise.
- Onboard logic level translators for Arduino interface.
- ProtoCentral MAX30001 ECG and Respiration/Bio-Impedance Breakout Board
- Straight pin headers
- 2-electrode ECG connector with stereo connector
- 10x disposable ECG stick-on electrodes
- /software - Arduino library and example sketches.
- /hardware - All Eagle hardware design files
If you have bought the breakout the connection with the Arduino board is as follows:
MAX30001 pin label | Arduino Connection | Pin Function |
---|---|---|
MISO | D12 | Slave out |
MOSI | D11 | Slave in |
SCK | D13 | Serial clock |
CS0 | D7 | Slave select |
FCLK | NC | External clock(32KHz) |
INT1 | D2 | Interrupt |
INT2 | NC | Interrupt |
3V3 | Supply | Board which supports 3.3V and 1.8V |
VCC | Supply 5V | 5V |
GND | Gnd |
If you have correctly installed the libraries, the example sketeches should now be available from within Arduino.
Download the Arduino Sketch here for this board here.
Open up your Arduino IDE and run the Arudino sketch (.ino) file in the archive that you downloaded. Your Arduino should now be programmed to read the ecg data and sending over the USB-UART.
The GUI for visualizing the ECG and Respiration as well as parameters like Heart rate and Respiration rate is written in Processing, based on Java and is cross-compilable across platforms.
Java 8 is required on all platforms for running the processing-based GUI application. You can download Java for your platform from the Official Java website.
You can download and install ProtoCentral OpenView from here.
Once you have opened OpenView, make sure to select "MAX30001 breakout" under the "Board" dropdown.
A 2-electrode cable along with a standard stereo jack is provided along with the shield to connect the electrodes to the board. The electrode input connector is highlighted in the below picture.
The other side of the electrode connector would connect to snap-on electrodes attached to the body. For testing purposes, you can use an ECG simulator to provide inputs to the board.
Warning: When connecting the electodes to the body, it is safer to disconnect the mains power source to the Arduino. For example, if you are using the Arduino along with a laptop, disconnecting the battery charger from the laptop would be a safe option.
This product is open source! Both, our hardware and software are open source and licensed under the following licenses:
All hardware is released under the CERN-OHL-P v2 license.
Copyright CERN 2020.
This source describes Open Hardware and is licensed under the CERN-OHL-P v2.
You may redistribute and modify this documentation and make products using it under the terms of the CERN-OHL-P v2 (https:/cern.ch/cern-ohl). This documentation is distributed WITHOUT ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING OF MERCHANTABILITY, SATISFACTORY QUALITY AND FITNESS FOR A PARTICULAR PURPOSE. Please see the CERN-OHL-P v2 for applicable conditions
All software is released under the MIT License(http://opensource.org/licenses/MIT).
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
All documentation is released under Creative Commons Share-alike 4.0 International.
You are free to:
- Share — copy and redistribute the material in any medium or format
- Adapt — remix, transform, and build upon the material for any purpose, even commercially. The licensor cannot revoke these freedoms as long as you follow the license terms.
Under the following terms:
- Attribution — You must give appropriate credit, provide a link to the license, and indicate if changes were made. You may do so in any reasonable manner, but not in any way that suggests the licensor endorses you or your use.
- ShareAlike — If you remix, transform, or build upon the material, you must distribute your contributions under the same license as the original.
Please check LICENSE.md for detailed license descriptions.