Herzfrequenz/Pulsesensor SE050: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
Zeile 148: Zeile 148:
*'''Die konkrete Messunsicherheit mit Matlab berechnen'''
*'''Die konkrete Messunsicherheit mit Matlab berechnen'''


<div style="width:1100px; height:170px; overflow:scroll; border: hidden">
<div style="width:1100px; height:500px; overflow:scroll; border: hidden">
<syntaxhighlight lang="cpp" style="border: none; background-color: #EFF1C1; font-size:larger">
<syntaxhighlight lang="cpp" style="border: none; background-color: #EFF1C1; font-size:larger">
%% Daten aus dem Workspace abrufen
%% Daten aus dem Workspace abrufen

Version vom 13. Juli 2024, 17:35 Uhr

Abb. 1: Herzfrequenz/Pulsesensor SE050
Autor: Weiran Wang
Studiengang: Business and Systems Engineering
Modul: BSE-M-2-1.03, Hausarbeit in Angewandte Informatik gehalten von Prof. Dr.-Ing. Schneider
Semester: Sommersemester 2024
Abgabetermin: 28.07.2024

Einführung

Aufgabenstellung

Messen Sie die die Herzfrequenz am Ohrläppchen oder Finger in Herzschlag pro Minute (BPM).

  • Thema/Fragestellung: Messung der Herzfrequenz mit dem Pulsesensor SE050
  • Hypothese: Herzfrequenz kann fehlerfrei gemessen werden.
  • Einordnung in den Lehrplan

Projektbeschreibung

Tabelle 2: Materialliste
# Anzahl Material
1 1 PC mit MATLAB/Simulink R2023b
2 1 Pulsesensor SE050
3 1 Arduino Uno R3
4 1 Streckbrett
5 ? Jumper Kabel, männlich/männlich, 20 cm

Beschreibung Funktionsweise der verwendeten Hard- und Software

  • Arduino Uno R3

Arduino Uno R3 ist ein Open-Source-Mikrocontroller-Entwicklungsboard, das von der Firma Arduino entwickelt und produziert wurde. Es integriert viele wichtige Komponenten. Zu den Hauptkomponenten gehören der Atmega328P-Mikrocontroller, eine externe Quarzquelle zur Bereitstellung einer hohen Taktfrequenz, ein Upload-Gerät, das aus einer USB-Schnittstelle und einem Atmega16U2-Signalumwandlungsmodul besteht, eine Reset-Taste zum Neustarten von Programmen sowie zwei Reihen von Schnittstellen zur Verbindung von Peripheriegeräten. Da ein Mikrocontroller der AVR-Serie verwendet wird, unterstützt das Arduino-Board eine Vielzahl von Funktionen wie digitale Ein-/Ausgabe, analoge Ein-/Ausgabe, Timer/Zähler und Interrupts, die die grundlegenden Anforderungen eingebetteter Systeme erfüllen.

  • Pulsesensor SE050

Pulse Sensor ist ein Open-Source-Hardwareprojekt, das von Joel Murphy und Yury Gitman entwickelt wurde. Aus den verfügbaren Informationen und durch direkte Beobachtung lässt sich erkennen, dass der Pulse Sensor eine runde Leiterplatte (PCB) ist, die verschiedene Komponenten integriert. Zu den wichtigsten Komponenten gehören der Lichtsensor „APDS-9008“ und eine grüne LED von „Kingbright“. Diese beiden Komponenten ermöglichen die Photoplethysmographie (PPG)-Technologie. Genauer gesagt, sendet die grüne LED Licht auf die Haut, wobei ein Teil des Lichts vom Blut absorbiert und ein Teil vom Gewebe reflektiert wird und auf den „APDS-9008“-Lichtsensor trifft. Durch die Erkennung der durch den Blutfluss verursachten Änderungen dieser Lichtstrahlen kann die Herzfrequenz gemessen werden.

  • LCD Modul 16x02 I2C
  • Simulink R2023b

Um die Analyse von Sensordaten zu erleichtern, werden Matlab & Simulink verwendet. Darüber hinaus muss zur Unterstützung von Arduino-Projekten das Plugin „Simulink Support Package for Arduino Hardware“ heruntergeladen und installiert werden. Durch die Verwendung des Simulink Support Package for Arduino Hardware können Entwickler effektiv RCP (Rapid Control Prototyping) durchführen, wodurch der Entwurfs- und Validierungsprozess von Steuerungssystemen beschleunigt wird. Konkret ermöglicht der Einsatz dieses Plugins, dass Modelle, die auf Arduino-Funktionen basieren, in Maschinencode umgewandelt und auf die Arduino-Entwicklungsplatine hochgeladen werden. Anschließend können die Ausgaberesultate der Arduino-Entwicklungsplatine in Echtzeit in Simulink beobachtet werden.


Technische Daten

Messbereich unbekannt
Versorgungsspannung 3.3 V oder 5.0 V
Versorgungsstrom < 4 mA
Ausgangssignaltyp Analogsignal
Ausgangssignalbereich 0.3 V .. VCC V
Getriebe Kunststtoff
Arbeitstemperatur -40 °C .. +85 °C
Abmessungen ∅ = 15.8 mm ; δ = 3.6 mm

Pinbelegung

Pin Belegung Signal
1 Signal Analogsignal (0.3 V .. 5 V)
2 Versorgungsspannung VCC 5 V
3 Masse (GND) 0 V

Versuchsaufbau und Durchführung

Versuchsaufbau

Abb. 2: Schaltplan
Abb. 3: Externe Lichtquellen isolierender Pulse Sensor
Abb. 4: Messdaten des Stillstands
Abb. 5: Anschlussplan
Abb. 6: Foto des Versuchsaufbaus

Der Versuchsaufbau wird durch einen Schaltplan (Abb. 2), Anschlussplan (Abb. 3) und Foto des Aufbaus (Abb. 4) dokumentiert.

Versuchsdurchführung

Modelleinstellungen: Arduino Uno, Solver: Fixed-step, discrete, Abtastrate: 0,001 s

Abb. 5: Simulink-Modell

Das Modell zur Datenverarbeitung wurde gemäß Abb. 5 in Simulink aufgebaut. Die Messdaten wurden aufgezeichnet. Ein Video der Versuchsdurchführung findet sich hier.


  • Erste Modellierung

Pulse Sensor verwendet die PPG-Technologie. Während des Betriebs des Geräts wird das Pulssignal synchron und kontinuierlich mit den Pulsschwingungen ausgegeben. Daher reicht es aus, den Zeitraum dieses Schwingungssignals zu bestimmen, um die momentane Herzfrequenz zu ermitteln.

Beim Erstellen des Modells muss das Analog Input-Block verwendet werden, um die Ausgangsabtastung des Pulse Sensors vom Arduino UNO R3 zu erhalten und in ein Digitalsignal umzuwandeln.

Aus dem Datenblatt des Mikrocontrollers Atmega328P geht hervor, dass die ADC-Umwandlungszeit maximal 260 µs beträgt, während das Abtastintervall 67 µs beträgt. Daher beträgt die gesamte A/D-Umwandlungszeit 327 µs und ist somit kleiner als 1 ms. Daher kann die Systemabtastuhr in Simulink mit discretem Fixed-step auf 0,001 s fest eingestellt werden.

Beobachtungen zeigen, dass bei jedem Herzschlag ein höherer und ein niedrigerer Peak im Signal auftreten. Der höhere Peak repräsentiert den Herzschlag, während der niedrigere Peak aufgrund der Struktur der Blutgefäße entsteht. In diesem Projekt kann der niedrigere Peak ignoriert werden. Daher kann ein Filter, der aus einem Constant-Block und einem Relational Operator-Block besteht, verwendet werden, um die höheren Peaks zu erhalten. Der Wert des Constant-Blockes wird auf 2 gesetzt. Es reicht aus, das Zeitintervall der ansteigenden Flanke des Signals, das den Schwellenwert von "2" überschreitet, zu erkennen und die Umrechnungsformel zu verwenden, um die momentane Herzfrequenz zu berechnen.

Da das Herzfrequenzmessgerät, bestehend aus dem Pulse Sensor und dem Arduino UNO R3, während des Signalwandlungsprozesses einige Fehler verursachen kann, ist es notwendig, die Messfehler des Geräts zu bestimmen und zu analysieren, ob diese Fehler die Herzfrequenzmessung negativ beeinflussen können.


  • Vorläufige Bewertung der Messunsicherheit

Da die Herzfrequenz eine nicht kontrollierbare Variable ist, kann im Messdesign kein bestimmter Wert als Referenzstandard festgelegt werden. Daher kann das Messgerät nur vor der Herzfrequenzmessung, wenn die Herzfrequenz null ist, kalibriert werden. Externe Lichtquellen isolierender Pulse Sensor(Abb. 3) zeigt den auf dem Tisch ruhenden Pulse Sensor, der von externen Lichtquellen abgeschirmt ist. Die Erfassung der Ausgangsspannung des Pulse Sensors in diesem Zustand sollte im Laufe der Zeit einen relativ stabilen Wert nahe VCC/2 zeigen.

Messdaten des Stillstands (Abb. 4) zeigen die Daten innerhalb von zwei Minuten. Die Messwerte schwanken zwischen 2,44 V und 2,54 V, ohne große Abweichungen. Diese Schwankungen können durch externe elektromagnetische Störungen, sensorinterne Geräusche und ADC-Quantisierungsrauschen verursacht werden. Daher können die im Diagramm dargestellten zufälligen Fehler als Standardunsicherheit Typ A kategorisiert werden.


  • Die konkrete Messunsicherheit mit Matlab berechnen
%% Daten aus dem Workspace abrufen
Daten = simout;    

%% Datenverarbeitung
n = length(Daten);             % Die Anzahl der Daten ermitteln
RE = mean(Daten);                   % Den Durchschnitt berechnen
sE = std(Daten);               % Die Standardabweichung berechnen

%% Die Paramete aus Atmega328p-Datenblatt
Aufloesung = 10;                            % Aufloesung10 bit
v_ref = 5;                      % Referenz Spannung, Einheit : V
lsb = v_ref / (2^Aufloesung);   % MindestaufloesungEinheit: V

% Jede Fehlerquelle EinheitLSB
absolute_genauigkeit_lsb = 3.5;  % Absolute Genauigkeit, maximal
inl_lsb = 1.5;        % Integraler nichtlinearer Fehler, Maximum
dnl_lsb = 0.7;  % Differenzieller Nichtlinearitätsfehler, maximal
gain_error_lsb = 3.5;              % Verstärkungsfehler, maximal
offset_error_lsb = 3.5;                       % Offsetfehler, max.

%% Fehlerquelle in Spannung umrechnen (Einheit: V)
absolute_genauigkeit = absolute_genauigkeit_lsb * lsb; 
inl_error = inl_lsb * lsb;
dnl_error = dnl_lsb * lsb;
gain_error = gain_error_lsb * lsb;
offset_error = offset_error_lsb * lsb;

%% Berechnen Standardunsicherheit Typ A
alpha = 1-0.6827;
p = 1-(alpha/2);
t = tinv(p,n-1); 
uA = t*sE/sqrt(n); 

%% Berechnen die Standardunsicherheit Typ B
uB = sqrt(absolute_genauigkeit^2 + inl_error^2 + dnl_error^2 + gain_error^2 + offset_error^2 );

%% Berechnen Standardunsicherheit Typ C
uC = sqrt((uA)^2+(uB)^2);  

%% Berechnen absolute Messunsicherheit 
k  = 2; % Vertrauensfaktor (Vertrauensniveau 0.9545)
uAbs = k*uC; % absolute Messunsicherheit 

%% Vollständige Messergebnis
disp(['Vollständige Messergebnis: U = ',num2str(RE),' ± ',num2str(uAbs),' V '])


Versuchsbeobachtung

Abb. 6: Darstellung des Rohsignals des IR-Entfernungssensors (rote Kurve)
Abb. 7: Darstellung von dynamischen Messwerten des IR-Entfernungssensors

Das Signal des Sensors weist alle 40 ms systematische Ausreisser auf (vgl. Abb. 6, rote Kurve).

Auswertung

Die Messhypothese wurde verworfen. Der Sensor weist systematische Messwertausreisser auf.

Die Ausreisser lassen sich mit einem Signalfilter eliminieren. Hierzu eignet sich ein Rangordnungsfilter (z. B. Median-Filter). Das Filter wird hierzu auf eine Fensterbreite von 30 Werten eingestellt. Das zufriedenstellende Filterergebnis für statische Werte zeigt Abb. 6 als blaue Kurve. Es konnte mit dynamische Werten verifiziert werden (vgl. Abb. 7). Das Datenblatt ([2, S. 6]) belegt die Messungen und bezeichnet die Messausreisser als "instabile Ausgabe" für maximal 5 ms alle 40 ms. Mit 50 Werten erhöht sich die Filterwirkung, es entsteht jedoch ein Delay von 10 ms. Mit 10 Werten ist die Filterwirkung zu gering.

Zusammenfassung und Ausblick

  • Zusammenfassung der Kapitel 1-4
  • Diskussion der Ergebnisse
  • Ausblick
  • Selbstreflexion/Lessons learned

Ergebnisvideo

Binden Sie hier Ihr Ergebnisvideo ein.

Anleitung: Videos im Wiki einbinden

Lernzielkrontrolle

Beantworten Sie in Ihrem Artikel die Lernzielkontrollfragen.

Literatur

Zitieren Sie nach DIN ISO 690:2013-10.

Anhang

  • Datenblätter
  • Simulink-Modell
  • Originaldateien (PAP, Schaltplan,... )

→ zurück zum Hauptartikel: BSE Angewandte Informatik SoSe24 | Hausarbeit SoSe24