UV-Sensor UVM30A: Unterschied zwischen den Versionen
Zeile 197: | Zeile 197: | ||
Zuletzt erfolgt die Berechnung der kombinierten Standardunsicherheit Typ C die anhand einer Messung erfolgt und hier erläutert wird: | Zuletzt erfolgt die Berechnung der kombinierten Standardunsicherheit Typ C die anhand einer Messung erfolgt und hier erläutert wird: | ||
<div class="mw-collapsible mw-collapsed"> | <div class="mw-collapsible mw-collapsed"> | ||
Hier ist der Matlab-Code: | |||
<div style="width:700px; height:700px; overflow:scroll; border: hidden"> | |||
<syntaxhighlight lang="cpp" style="border: none; background-color: #EFF1C1; font-size:larger"> | |||
%**************************************************************** | |||
% Hochschule Hamm-Lippstadt * | |||
%**************************************************************** | |||
% Modul : BerechnungderStandardunsicherheit.m * | |||
% * | |||
% Datum : 15.07.2024 * | |||
% * | |||
% Funktion : Berechnung der Standarunsicherheiten und * | |||
% der Abweichungen vom Messergebnis * | |||
% * | |||
% Implementation : MATLAB 2023b * | |||
% * | |||
% Req. Toolbox : Statistics and Machine Learning Toolbox * | |||
% * | |||
% Author : Oliver Scholze * | |||
% * | |||
% Bemerkung : - * | |||
% * | |||
% Letzte Änderung : 15.07.2024 * | |||
% * | |||
%% Messdaten laden | |||
load('Vertrauensbereich.mat'); | |||
data = gefiltertes_Signal.data; % Annahme: gefiltertes_Signal.data ist die 3D-Matrix mit den Messwerten | |||
% Messwerte in mV (falls nötig, hier anpassen) | |||
Rm = gefiltertes_Signal.data(1,1,:); | |||
% Anzahl der Messwerte bestimmen | |||
n = numel(Rm); % Anzahl der Messungen | |||
%% Bester Schätzwert des Widerstandes berechnen | |||
R = mean(Rm(:)); % Mittelwert der Messwerte | |||
%% Empirische Standardabweichung bestimmen | |||
s = std(Rm(:)); | |||
%% Standardunsicherheit Typ A bestimmen | |||
p = normcdf(R+s, R, s) - normcdf(R-s, R, s); % Vertrauensniveau | |||
nu = n - 1; % Freiheitsgrade | |||
%% t-Quantil berechnen | |||
t = tinv((1+p)/2, nu); | |||
disp(['t-Faktor: t = ', num2str(t)]); | |||
%% Unsicherheit Typ A | |||
uA = s * t / sqrt(n); | |||
%% Standardunsicherheit Typ B bestimmen (angenommen) | |||
uB = 105.56; % Angenommener Wert für Unsicherheit Typ B | |||
%% Kombinierte Standardunsicherheit Typ C bestimmen | |||
uC = sqrt(uA^2 + uB^2); % Unsicherheit Typ C | |||
%% Grad des Vertrauens bestimmen | |||
k = 2; % Vertrauensfaktor | |||
%% Absolute Messunsicherheit bestimmen | |||
uAbs = k * uC; % Absolute Messunsicherheit | |||
%% Relative Messunsicherheit berechnen (%) | |||
uRel = (uAbs / R) * 100; | |||
%% Ergebnisdarstellung | |||
figure; | |||
yline(R, 'Color', 'k'); | |||
xlim([0 3200]) | |||
hold on; | |||
plot([0 n], [R+uC R+uC], '--b', [0 n], [R-uC R-uC], '--b'); | |||
plot(1:n, reshape(Rm, 1, [])); % Um die Daten zu plotten, in einen Vektor umformen | |||
% Beschriftungen hinzufügen | |||
xlabel('Anzahl der Messwerte'); | |||
ylabel('Ausgangsspannung in mV'); | |||
title(['Messergebnis (Mittelwert = ', num2str(R), ', Unsicherheit = \pm', num2str(uC), ' mV)']); | |||
% Legende erstellen | |||
legend({'Mittelwert', 'Unsicherheit Typ C'}, 'Location', 'northwest'); | |||
</syntaxhighlight> | |||
</div> | |||
<br clear=all> | |||
</div> | </div> | ||
Version vom 15. Juli 2024, 17:17 Uhr
Autor: | Oliver Scholze |
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
Der Sensor im UVM30A ist ein photodetektiver Sensor, der UV-Licht im Bereich von 200 nm bis 370 nm erfasst. Dieser photodetektiver Sensor besteht aus einem Halbleitermaterial, das bei Bestrahlung mit UV-Licht Elektronen freisetzt. Diese freigesetzten Elektronen erzeugen einen elektrischen Strom, der proportional zur Intensität des einfallenden UV-Lichts ist, diese wird auch als photoelektrischer Effekt bezeichnet. Dieser Strom wird dann in eine analoge Spannung umgewandelt, die vom Sensor ausgegeben wird. Die analoge Ausgangsspannung wird mithilfe des Diagramms, aus dem Datenblatt, in einen UV-Index umgewandelt.
Aufgabenstellung
Messen Sie Intensität eines gegebenen ultravioletten Lichts. Zeigen Sie auf dem Display an, welchem UV Index die Intensität entspricht.
Anforderungen | |||||||||||||||||||||||||||
|
- Thema/Fragestellung: Messung der UV-Intensität erfolgt mit dem Sensor UVM30A.
- Hypothese: Die Wellenlängen lassen sich im Bereich von 200 nm-370 nm fehlerfrei messen.
- Einordnung in den Lehrplan Für die Aufgabe werden Inhalte aus der Vorlesung Angewandte Informatik und Signalverarbeitende Systeme benötigt, da somit die Implementierung/ Durchführung und die Bewertung des Ergebnisses erfolgen kann.
Projektbeschreibung
# | Anzahl | Material |
---|---|---|
1 | 1 | PC mit MATLAB/Simulink R2023b |
2 | 1 | UV-Sensor - UVM30A |
3 | 1 | Arduino Uno R3 |
4 | 1 | Streckbrett |
5 | 5 | Jumper Kabel, männlich/männlich, 20 cm |
5 | 1 | LCD-Display mit I2C |
Beschreibung Funktionsweise der verwendeten Hard- und Software
- Arduino Uno R3: Der Arduino Uno R3 ist das Herzstück des Systems und dient als Mikrocontroller.
- UVM30A: Der Sensor erzeugt ein elektrisches Signal, dessen Spannung von der Intensität der UV-Strahlung abhängt, die auf den Sensor trifft.
- Simulink R2023b: Erstellung des Programms zur Ansteuerung und Auswertung der angeschlossenen Hardware (UVM30A und LCD Display).
- LCD-Display mit I2C: Das LCD-Display wird verwendet, um die gemessenen UV-Intensitätswerte anzuzeigen.
- Steckbrett: Ein Steckbrett dient zum schnellen und flexiblen Aufbau und Testen von elektronischen Schaltungen ohne Löten.
- Jumperkabel: Jumperkabel werden verwendet, um Verbindungen zwischen verschiedenen Komponenten auf einem Steckbrett oder zwischen einem Steckbrett und einem Arduino herzustellen.
Technische Daten
Messbereich | 200-370 nm |
Versorgungsspannung | 3 V .. 5 V |
Versorgungsstrom | 0.06 mA, maximal 0.1 mA |
Genauigkeit | +-1 UV Index |
Gewicht | 13 g |
Getriebe | Kunststtoff |
Arbeitstemperatur | -20 °C .. +85 °C |
Abmessungen | 34 mm x 13 mm x 7 mm |
Pinbelegung
Pin | Belegung | Signal |
---|---|---|
1 | Versorgungsspannung VCC | 5 V |
2 | Analoger Ausgang | 0 V .. 1.16 V |
3 | Masse (GND) | 0 V |
Versuchsaufbau und Durchführung
Versuchsaufbau
Implementierung in Simulink
Umwandlung der Ausgangsspannung in einen UV-Index
Für die Umwandlung wird eine Kennlinie benötigt, um die Beziehung zwischen der analogen Ausgangsspannung und der UV-Intensität zu beschreiben. Diese Kennlinie wird mithilfe der vom Hersteller gegebenen Daten erstellt und ist notwendig, um die Messwerte korrekt zu interpretieren. Für die Interpretation wird Simulink eine 1D-Lookuptabel verwendet, welche die unten genannten Werte enthält:
Der Versuchsaufbau wird durch einen Schaltplan (Abb. 2), Anschlussplan (Abb. 3) und Foto des Aufbaus (Abb. 4) dokumentiert.
Verwendete Toolbox: DSP System Toolbox, Simulink Support Package für Arduino Hardware
Versuchsdurchführung
Referenzwert
Als Referenz werden Wetterdaten verwendet aus der die UV-Intensität hervorgeht, um die Kalibrierung des UVM30A durchzuführen. Diese Daten sind präzise und werden regelmäßig gewartet und überprüft, um die Genauigkeit zu gewährleisten.
Das Modell zur Datenverarbeitung wurde gemäß Abb. 5 in Simulink aufgebaut. Die Messdaten wurden aufgezeichnet. Ein Video der Versuchsdurchführung findet sich hier.
Modelleinstellungen: Arduino Uno, Solver: Fixed-step, discrete, Abtastrate: 0,001 s
Messprozess und Messunsicherheit
Standardunsicherheit Typ B
Der verwendete Arduino UNO R3 hat einen 10-Bit ADU und eine Referenzspannung von 5V. Daraus ergibt sich eine Quantisierungsstufe von:
Der maximale Quantisierungsfehler beträgt somit:
Um den tatsächlichen Fehler berechnen zu können, muss die Standardunsicherheit Typ B des Sensors mithilfe von MATLAB ermittelt werden. Dabei wird geprüft, wie viel Spannung der Messunsicherheit eines UV-Index entspricht. Aus der Kennlinie geht hervor, dass die Umwandlung nahezu linear ist, jedoch nicht vollständig den Anforderungen entspricht. Daher wird zunächst die Differenz zwischen den Spannungswerten berechnet und der Mittelwert dieser Differenzen als Grundlage für die Messunsicherheit verwendet.
Hier ist der MATLAB-Code für die Berechnung des Mittelwerts:
Dadurch ergibt sich eine kombinierte Standardunsicherheit von:
Der tatsächliche Fehler dieser Messung unter Berücksichtigung der Messunsicherheit des UV-Sensors und des Quantisierungsfehlers des 10-Bit AD-Wandlers beträgt etwa 105.56 mV.
Standardunsicherheit TYP A und C
Zuletzt erfolgt die Berechnung der kombinierten Standardunsicherheit Typ C die anhand einer Messung erfolgt und hier erläutert wird:
Hier ist der Matlab-Code:
Versuchsbeobachtung
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.
Lernzielkontrollfragen |
|
Literatur
Zitieren Sie nach DIN ISO 690:2013-10. https://www.wiltronics.com.au/wp-content/uploads/datasheets/ARD2-2062.pdf
Anhang
- Datenblätter
- Simulink-Modell
- Originaldateien (PAP, Schaltplan,... )
→ zurück zum Hauptartikel: BSE Angewandte Informatik SoSe24 | Hausarbeit SoSe24