Skip to content

Latest commit

 

History

History
70 lines (51 loc) · 4.43 KB

README.md

File metadata and controls

70 lines (51 loc) · 4.43 KB

Blood pressure and heart rate measurement using smartphone video camera

Last modified: 2023.02.06

스마트폰 비디오 카메라를 활용한 혈압, 심박수 측정


광적용맥파(Photoplethysmogram, 이하 PPG)의 원리를 이용하여 스마트폰으로 심박수와 혈압을 측정할 수 있는
방법에 대해서 연구를 진행했었습니다. 연구 목표로는 애플워치나 갤럭시 워치 등 고가의 웨어러블 디바이스를
구매해야한다는 단점에서 벗어나 누구나 손쉽게 헬스케어 서비스를 받을 수 있게하자는 목표로 진행하였습니다.
본 연구에서는 PPG 신호의 원리를 스마트폰 카메라에 적용하여 알고리즘을 구현하였으며
보다 높은 정확도 향상을 목적으로 직접 다양한 실험을 통해 최적의 BPF(Band-Pass Filter)를 설계하였습니다.
심박수는 DC성분 제거 > BPF > Fourier transform > Amplitude(진폭)을 계산하여 심박수를 검출하였고
혈압의 경우 실험을 통해 혈압과 I_Tsys(min(R값), SBP(수축기 혈압)와 연관), I_Tdia(max(R값), DBP(이완기 혈압)와 연관),
I_S(Scale, I_Tdia-I_Tsys) 사이의 회귀식을 도출하여 검출하였습니다.

WHAT IS PPG?

PPG 신호는 웨어러블 기기, 병원용 맥박 측정기 등 다양하게 사용되고 있는데요.
피부에 빛을 쏠 때 혈류량에 따라 흡수되는 빛의 양이 달라지는 원리에 기반하고 있습니다.

신체는 심장박동에 의하여 생성된 압력에 의해 혈관 내에서 혈액의 흐름이 생기게되며
심장박동이 발생할 때마다 압력은 신체의 말단 모세혈관까지 작용하여 이는 손가락 끝의 혈관까지도 압력이 작용합니다.
손가락 끝 모세혈관의 동맥 혈액은 세포조직으로 혈액을 공급하고, 정맥으로 들어가서 다시 심장으로 돌아가는데요.
결국, 심장박동에 동기되어 손가락 끝 혈관에서의 동맥혈량이 증가하고 줄어드는 것이 계속 반복됩니다.

동맥에 피가 많이 흐를 때는 동맥혈에서 더 많은 빛을 흡수하고 동맥에 적게 흐를 때에는 혈관에서 상대적으로 빛이 덜 흡수되는
흡수량의 추이를 통해 심박수와 혈압을 측정하는 방식입니다.

SMARTPHONE VIDEO CAMERA

위의 영상이 스마트폰 비디오 카메라로 촬영한 동영상입니다.
촬영하는 원리는 스마트폰의 플래시를 활성화한채로 플래시부분과 카메라 센서를 동시에 손가락으로 감싸 영상을 촬영합니다.
영상을 보시면 빨간 배경에 반복적으로 살짝 어두워졌다가 밝아지기를 반복하는 패턴이 보입니다!
해당 영상을 frame별로 분할한 뒤 R값을 계산하여 PPG 신호를 구현하였습니다.

HEART RATE MEASUREMENT

심박수를 측정하는 원리는 크게 4단계로 이루어집니다.

  1. Average red intensity per frame - frame 당 평균 R값(Red)을 계산합니다.
  2. Peak detection algorithm - 주기적으로 나타나는 뾰족한 peak를 찾아냅니다.
  3. R-R interval(RRI) - Peak 사이의 시간 간격을 의미하는 RRI를 계산합니다.
  4. 60/RRI - 구한 RRI를 사용하여 심박수(Heart rate) = 60/RRI 로 계산합니다.

BLOOD PRESSURE MEASUREMENT

혈압을 측정하는 원리는 크게 3단계로 이루어집니다.

  1. Average red intensity per frame - frame 당 평균 R값(Red)을 계산합니다.
  2. MAX 값을 I_Tdia, MIN 값을 I_Tsys, range를 I_S로 계산합니다.
  3. 사전 실험으로 도출한 회귀식에 대입하여 혈압을 계산합니다.
SBP(수축기 혈압) = -0.599*I_Tsys - 0.656*I_S + 249.942
DBP(이완기 혈압) = -0.212*I_Tdia - 0.251*I_S + 153.211