Modellierung und Simulation - Programmstrukturen: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Keine Bearbeitungszusammenfassung |
Keine Bearbeitungszusammenfassung |
||
| Zeile 139: | Zeile 139: | ||
</source> | </source> | ||
|} | |} | ||
== Aufgabe 5.3 - Programmiergrundlagen - Funktionen == | |||
== | |||
[[Datei:MuS findeAusreisser.jpg|thumb|rigth|450px|Abb. 1: Ausreisser in einer verrauschten Messung]] | [[Datei:MuS findeAusreisser.jpg|thumb|rigth|450px|Abb. 1: Ausreisser in einer verrauschten Messung]] | ||
# Schreiben Sie die Funktion <code>simuliereAussreisser.m</code>, welche normalverteilte Spannungen (Mittelwert: 5 V, Standardabweichung: 10 V) simuliert. | |||
# Die x-Achse Bildet die Zeit. Nehmen Sie den Index (1, 2, 3,...) in s. | |||
# Bauen Sie zufällig einen Ausreißer in das Datenarray Spannung von 20 V ein. | |||
# Zeigen Sie das Ergebnis entsprechend Abb. 1. Eine graue Gerade bildet den Mittelwert, die Messwerte sind tote Punkte und der Ausreißer ist blau eingekreist. | |||
# Speichern Sie die Variablen <code>Zeit</code> und <code>Spannung</code> in der Datei <code>Messdaten.mat<(code>. | |||
# Werten Sie den Quelltext mit Header, Kommentaren und Hilfe auf. | |||
{| role="presentation" class="wikitable mw-collapsible mw-collapsed" | {| role="presentation" class="wikitable mw-collapsible mw-collapsed" | ||
| <strong>simuliereAussreisser.m</strong> | | <strong>simuliereAussreisser.m</strong> | ||
| Zeile 166: | Zeile 170: | ||
save('Messdaten','Zeit',"Spannung") | save('Messdaten','Zeit',"Spannung") | ||
</source> | </source> | ||
|} | |||
== Local Indexing == | |||
Version vom 24. April 2026, 05:34 Uhr
| Autor: | Prof. Dr.-Ing. Schneider |
| Termin: | 24.04.2025 |
Aufgabe 5.1 - Programmiergrundlagen - Schleifen und Bedingungen
- Schreiben Sie ein MATLAB®-Skript, das mit Hilfe einer
for-Schleife die Summe der Zahlen von 1 bis 100000 berechnet (z. B.n=n+1). - Schreiben Sie ein MATLAB®-Skript, das mit Hilfe einer
while-Schleife die Summe die Zahlen von 1 bis 100000 berechnet. - Schreiben Sie ein MATLAB®-Skript, das
- Einen Vektor X mit 10000 Zufallszahlen zwischen 0 und 1 erzeugt.
- Mit Hilfe einer
for-Schleife den Index des ersten Elementes in X berechnet, das > 0.9 ist (falls ein solches existiert) und diesen Index in der Variablen speichert. - Mit Hilfe einer while-Schleife den Index des ersten Elementes in X berechnet, das< 0.1 ist (falls ein solches existiert) und diesen Index in der Variablen speichert.
- Mit Hilfe von „ logical indexing" das erste Element findet, das echt zwischen 0.5 und 0.55 liegt (falls ein solches existiert) und diesen Index in der Variablen speichert.
Nützliche Befehle: for, if, while, break
| Musterlösung 5.1 |
%% Aufgabe 5.1 - Schleifen und Bedingungens
clear all
%(a)
Summe1 = 0;
for i=0:1:100000
Summe1 = Summe1+i;
end
%(b)
Summe2 = 0;
i = 0;
while i<=100000
Summe2 = Summe2+i;
i = i+1;
end
clear all
%(c)
VektorX = rand(1,10000);
%Element finden, welches >0.9 ist
for i=1:1:10000
if(VektorX(i)>0.9)
x1 = i;
break;
end
end
%Element finden, welches <0.1 ist
i=1;
while i<=10000
if(VektorX(i)<0.1)
x2 = i;
break;
end
i = i+1;
end
%Element finden, welches zwischen 0.5 und 0.55 liegt
%% Möglichkeit 1: Schleife
for i=1:1:10000
if(VektorX(i)>=0.50 && VektorX(i)<=0.55)
x3 = i;
break;
end
end
%% Möglichkeit 2: logical indexing
Logic_Vek = VektorX >= 0.50 & VektorX <= 0.55;
x3_new = find(Logic_Vek,1);
|
Aufgabe 5.2 - Programmiergrundlagen - Funktionen
- Recherchieren Sie den Begriff „MATLAB function" und informieren Sie sich, was man darunter versteht.
- Schreiben Sie das MATLAB®-Skript aus Aufgabe 5.1.3 zu einer MATLAB®-Function mit dem Namen
analyseum, die- als Eingabeargument die Zahl n bekommt und dann
- einen Vektor mit n Zufallszahlen zwischen 0 und 1 erzeugt
- Anschließend soll die Funktion genau die Werte und wie in Aufgabe 4.4.3 berechnen und diese als Rückgabewerte zurückliefern.
- Machen Sie sich anhand der Funktion
analysemit dem Setzen von „Breakpoints" und dem MATLAB®-Debugger vertraut.
- Schreiben Sie ein kurzes Matlab Skript, mit dem Sie die Funktion
analyseaufrufen. Springen Sie dabei mit einem Breakpoint in die Funktion.
Nützliche Befehle: function
| Musterlösung 5.2.1 - Funktion |
%% Aufgabe 5.2 - Funktionen
function[x1 x2 x3] = analyse(n)
VektorX = rand(1,n);
%Element finden, welches >0.9 ist
for i=1:1:10000
if(VektorX(i)>0.9)
x1 = i;
break;
end
end
%Element finden, welches <0.1 ist
i=1;
while i<=10000
if(VektorX(i)<0.1)
x2 = i;
break;
end
i = i+1;
end
%Element finden, welches zwischen 0.5 und 0.55 liegt
Logic_Vek = VektorX >= 0.50 & VektorX <= 0.55;
x3 = find(Logic_Vek);
if ~isempty(x3)
x3 = x3(1);
else
x3 = 0;
end
end
|
| Musterlösung 5.2.4 - Startskript |
%% Skript testAnalyse ruft die Funktion auf.
n = 1000;
%dbstop in analyse
[x1 x2 x3] = analyse(n)
|
Aufgabe 5.3 - Programmiergrundlagen - Funktionen

- Schreiben Sie die Funktion
simuliereAussreisser.m, welche normalverteilte Spannungen (Mittelwert: 5 V, Standardabweichung: 10 V) simuliert. - Die x-Achse Bildet die Zeit. Nehmen Sie den Index (1, 2, 3,...) in s.
- Bauen Sie zufällig einen Ausreißer in das Datenarray Spannung von 20 V ein.
- Zeigen Sie das Ergebnis entsprechend Abb. 1. Eine graue Gerade bildet den Mittelwert, die Messwerte sind tote Punkte und der Ausreißer ist blau eingekreist.
- Speichern Sie die Variablen
ZeitundSpannungin der DateiMessdaten.mat<(code>. - Werten Sie den Quelltext mit Header, Kommentaren und Hilfe auf.
simuliereAussreisser.m
clear all; close all; clc
Messwerte = randn(5)+10 % Zufallszahlen mit dem Mittelwert 10
Spannung = Messwerte(:)'
Zeit = 1:length(Spannung)
%% Ausreisser einbauen
Index = randi(length(Spannung))
Spannung(Index)=20;
plot(Zeit, Spannung,'r.')
hold on
ylim([0,20])
yline(10) % Wahrer Wert
plot(Zeit(Index),Spannung(Index),'bo')
legend('Messwerte','Wahrer Wert','Ausreisser')
save('Messdaten','Zeit',"Spannung")
Local Indexing
→ MATLAB® Befehlsübersicht
→ zurück zum Hauptartikel: BSE Modellierung und Simulation - SoSe26