105 lines
2.4 KiB
Python
105 lines
2.4 KiB
Python
|
import queue
|
||
|
|
||
|
import cv2
|
||
|
import numpy as np
|
||
|
|
||
|
from RespirationRateDetector import RespirationRateDetector
|
||
|
from params import args
|
||
|
import matplotlib.pyplot as plt
|
||
|
|
||
|
|
||
|
def main():
|
||
|
cap = cv2.VideoCapture(0) # 使用摄像头
|
||
|
video_fs = cap.get(5)
|
||
|
|
||
|
detector = RespirationRateDetector(args)
|
||
|
|
||
|
frames = []
|
||
|
|
||
|
text = ["calculating..."]
|
||
|
font = cv2.FONT_HERSHEY_SIMPLEX
|
||
|
# face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
|
||
|
|
||
|
resps = queue.Queue()
|
||
|
|
||
|
fig, ax = plt.subplots()
|
||
|
line, = ax.plot([], [])
|
||
|
plt.ion()
|
||
|
plt.show()
|
||
|
|
||
|
xdata = []
|
||
|
ydata = []
|
||
|
|
||
|
last = 0
|
||
|
|
||
|
while True:
|
||
|
ret, frame = cap.read()
|
||
|
|
||
|
frames.append(frame)
|
||
|
|
||
|
if len(frames) == 300:
|
||
|
|
||
|
Resp, RR_FFT, RR_PC, RR_CP, RR_NFCP = detector.detect_respiration_rate(frames, video_fs)
|
||
|
|
||
|
Resp[0] = last
|
||
|
|
||
|
for res in Resp:
|
||
|
resps.put(res)
|
||
|
|
||
|
last = Resp[-1]
|
||
|
|
||
|
text.clear()
|
||
|
text.append('RR-FFT: {:.2f} bpm'.format(RR_FFT))
|
||
|
text.append('RR-PC: {:.2f} bpm'.format(RR_PC))
|
||
|
text.append('RR-CP: {:.2f} bpm'.format(RR_CP))
|
||
|
text.append('RR-NFCP: {:.2f} bpm'.format(RR_NFCP))
|
||
|
frames = []
|
||
|
# 去除列表最前面的100个元素
|
||
|
# frames=frames[50:]
|
||
|
|
||
|
if not resps.empty():
|
||
|
|
||
|
resp = resps.get()
|
||
|
# 更新线的数据
|
||
|
ydata.append(resp)
|
||
|
|
||
|
else:
|
||
|
ydata.append(0)
|
||
|
|
||
|
if len(xdata) == 0:
|
||
|
xdata.append(1)
|
||
|
else:
|
||
|
xdata.append(xdata[-1] + 1)
|
||
|
|
||
|
if len(xdata) > 600:
|
||
|
xdata.pop(0)
|
||
|
ydata.pop(0)
|
||
|
|
||
|
# 生成时间序列
|
||
|
t = np.linspace(xdata[0] / video_fs, xdata[-1] / video_fs, len(ydata))
|
||
|
|
||
|
line.set_data(t, ydata) # 使用时间序列作为x轴
|
||
|
|
||
|
# 更新坐标轴的范围
|
||
|
ax.set_xlim(t[0], t[-1])
|
||
|
|
||
|
ax.set_ylim(min(0, min(ydata)) - 0.5 * abs(min(ydata)), 1.5 * max(ydata))
|
||
|
# 更新图表的显示
|
||
|
plt.draw()
|
||
|
plt.pause(0.01)
|
||
|
|
||
|
for i, t in enumerate(text):
|
||
|
cv2.putText(frame, t, (10, 60 + i * 20), font, 0.6, (0, 255, 0), 2)
|
||
|
cv2.imshow('Respiration Rate Detection', frame)
|
||
|
key = cv2.waitKey(1) & 0xFF
|
||
|
if key == ord('q'):
|
||
|
break
|
||
|
|
||
|
cap.release()
|
||
|
cv2.destroyAllWindows()
|
||
|
plt.close()
|
||
|
|
||
|
|
||
|
if __name__ == '__main__':
|
||
|
main()
|