Contec CMS50E 血氧仪 导出PPG、心率、血氧数据

2023-11-11 15:30

本文主要是介绍Contec CMS50E 血氧仪 导出PPG、心率、血氧数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Contec CMS50E 血氧仪 导出PPG、心率、血氧数据

介绍

通过HID接口实时接收Contec CMS50E串口数据,获取PPG原始信号、心率、SPO2数据并保存。您可以使用原始PPG信号执行进一步的数据分析,包括比较rPPG算法的准确性,训练深度学习网络等等。

Contec CMS50E 血氧仪

用法

  1. 安装python3和相应的pip程序。

  2. 在shell中输入:pip3 Install hidapi安装hidapi

  3. 在电脑上启动智能设备助手软件(通常可以通过血氧仪包装盒附带的U盘安装,也可以咨询客服获取)。

在这里插入图片描述

  1. 把手指放在血氧计上,打开它,然后把它插到电脑上。确保它运行良好,也就是说,在进入下一步之前,您可以在计算机软件上看到曲线变化。

  2. 在设备管理器中检查血氧仪的硬件id(我的设备是VENDOR_ID = 0x28E9, PRODUCT_ID = 0x028A)。修改程序中PPG文件的存放路径,保证数据能够正确存放。

  3. 运行脚本cms50e_hid.py加载数据并保存为csv文件。

代码

import time
import hid
import csv'''
This program is used to extract data information from the Contec CMS50E, 
including PPG signals, Heart rate signals, and SPO2 signals.
Before use, you need to determine the hardware ID of the CMS50E after connected to the computer.
'''# Delay the start time of data collection, ready to start collecting data
def delay_start(delay_time):print("Start recording in...")for i in range(delay_time):print(delay_time - i)time.sleep(1)def collect_data(device, csvFileName):# Initialize datacheck_bit = 0data_update_bit = 0status_bit = 0PPG_bit = 0HR_bit = 0SPO2_bit = 0data_count = 0with open(csvFileName, 'w', newline='') as file:writer = csv.writer(file)writer.writerow(['Count', 'PPG', 'HR', 'SPO2'])delay_start(3)start_time = time.time()while True:data = device.read(18)# hex_data = []# for i in range(len(data)):#     hex_data.append(hex(data[i]))# print(hex_data)print(data)current_time = time.time()time_count = current_time - start_timeif time_count > stop_time:break# Parse the received datafor i in range(3):check_bit = data[0 + 6*i]data_update_bit = data[1 + 6*i]status_bit = data[2 + 6*i]# while data_update_bit==1, Update HR and SPO2if data_update_bit == 0:PPG_bit = data[3 + 6*i]elif data_update_bit == 1:HR_bit = data[3 + 6 * i]SPO2_bit = data[4 + 6 * i]# Save PPG, HR, SPO2 in csvwith open(csvFileName, 'a', newline='') as file:writer = csv.writer(file)writer.writerow([str(data_count), str(PPG_bit), str(HR_bit), str(SPO2_bit)])data_count = data_count + 1if __name__ == '__main__':# ParametersVENDOR_ID = 0x28E9PRODUCT_ID = 0x028AcsvPath = 'G:/Project/Fatigue/data/myDataset/test/'csvFileName = csvPath + 'Output1' + '.csv'stop_time = 70device = hid.device()device.open(VENDOR_ID, PRODUCT_ID)print("Opening the device")collect_data(device, csvFileName)

规范

  • 设备的“采样频率”为60Hz。
  • 血氧仪每秒向PC发送60个数据,每个数据包含6字节,不同的数据用0xeb分隔。
  • 当第二个字节为0时,血氧仪处于采集PPG信号阶段,此时第四个字节的数据为PPG信号;当第二个字节为1时,血氧仪处于更新数据显示阶段,此时第四个字节的数据为心率值,第五个字节的数据为SPO2。数据大约每秒更新一次。

结果

PPG信号波形(前10s)
在这里插入图片描述

更多

更多详细信息请见GitHub仓库:https://github.com/SunHaixin0324/CMS50E_PPG_loader

这篇关于Contec CMS50E 血氧仪 导出PPG、心率、血氧数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/391054

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

SpringBoot+EasyPOI轻松实现Excel和Word导出PDF

《SpringBoot+EasyPOI轻松实现Excel和Word导出PDF》在企业级开发中,将Excel和Word文档导出为PDF是常见需求,本文将结合​​EasyPOI和​​Aspose系列工具实... 目录一、环境准备与依赖配置1.1 方案选型1.2 依赖配置(商业库方案)二、Excel 导出 PDF

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并