Matlab - Fehler

Aus Physik
Wechseln zu: Navigation, Suche

In jeder Programmiersprache, so auch in Matlab, gibt es eine Reihe von Fehlermöglichkeiten, die dazu führen, dass das Programm scheinbar ordnungsgemäß beendet wird. Trotzdem ist das Ergebnis falsch oder zumindest entspricht es nicht den Erwartungen. Einige dieser Fehler sind lustig, andere für Anfänger oft verblüffend.

Sie können hier zu einer Sammlung und Beschreibung dieser Fehler beitragen, da ich glaube, dass man daraus sehr viel lernen kann.

Verwechslung von : und ;

Ein Plot der Funktion f(x) = sin(π x) im Intervall [-1,1] wurde mit folgendem Code versucht:

x = [-1;0.05;1]; y = sin(pi*x); plot(x,y)

Falsche Darstellung

Dabei wurden die Zeichen ; und : verwechselt. Der richtige Code müsste daher so lauten:

x = [-1:0.05:1]; y = sin(pi*x); plot(x,y)

Richtige Darstellung

Der Grund, das Matlab hier keine Fehlermitteilung liefert, liegt darin, dass zwar für das gewünschte Ziel ein falscher Befehl verwendet wurde, dieser Befehl aber eine korrekte Syntax hat:

x = [-1;0.05;1]   Spaltenvektor    [-1
                                     0.05
                                     1]
x = [-1,0.05,1]   Zeilenvektor     [-1 0.05 1]
x = [-1:0.05:1]   Bereich von bis  [-1 -0.95 -0.9 ... 0.9 0.95 1]

Überprüfung von Übergabeparametern

Aufgabenstellung

Es soll eine MATLAB-Funktion test geschrieben werden, die für den zweiten Inputparameter einen Defaultwert von 5 setzt und zwar für den Fall wenn dieser nicht übergeben wird oder wenn er leer [] ist.

Mögliche Lösungen

  • Zwei getrennte bedingte Anweisungen, wobei die Variable nargin dabei als Zähler für die Anzahl der übergebenen Inputparameter fungiert.
function r = test(a,b)
bd = 5; % Defaultwert für b
if nargin < 2, b = bd; end
if isempty(b), b = bd; end
r = a + b;
Fehler: Vertauschung der beiden bedingten Anweisungen
if isempty(b), b = bd; end
if nargin < 2, b = bd; end
  • Zwei gekoppelte bedingte Anweisungen
function r = test(a,b)
bd = 5; % Defaultwert für b
if nargin < 2
  b = bd;
elseif isempty(b)
  b = bd;
end
r = a + b;
Fehler: Vertauschung der beiden bedingten Anweisungen
if isempty(b)
  b = bd;
elseif nargin < 2
  b = bd;
end
  • Lösung mit einer bedingten Anweisung unter Verwendung des Befehls or in seiner "short circuit" Version ||
function r = test(a,b)
bd = 5; % Defaultwert für b
if nargin < 2 || isempty(b), b = bd; end
r = a + b;
Fehler: Verwendung des normalen or Befehls |
if nargin < 2 | isempty(b), b = bd; end
Fehler: Falsche Verwendung des if-Befehls
if nargin < 2 || if isempty(b), b = bd; end
if nargin < 2, b = bd; || if isempty(b), b = bd; end
Fehler: Falsche Verwendung von isempty
if nargin < 2 || isempty, b = bd; end
  • Alternative für nargin mit Hilfe des Befehls exist
function r = test(a,b)
bd = 5; % Defaultwert für b
if ~exist('b','var') || isempty(b), b = bd; end
r = a + b;
  • Ergänzung um eine Fehlermitteilung
function r = test(a,b)
bd = 5; % Defaultwert für b
if nargin < 1 || isempty(a), error('a muss übergeben werden!'); end
if nargin < 2 || isempty(b), b = bd; end
r = a + b;
  • Lösung mit variabler Inputliste, wobei varargin eine Zelle mit allen Inputparametern ist.
function r = test(varargin)
bd = 5;
a = varargin{1};
if nargin < 2 || isempty(varargin{2})
  b = bd;
else
  b = varargin{2};
end
r = a + b;

Aufruf

Nach Fertigstellung der Funktion kann man sie in folgender Weise aufrufen:

x = 1; y = 2;
r = test(x);      % b Default
r = test(x,[]);   % b Default
r = test(x,3);    % b = 3
r = test(x,y);    % b = 2

Nicht möglich ist folgender Aufruf

r = test(x,b);    % FALSCH!

da das aufrufende Programm die Variable b nicht kennt (verschiedene Workspaces)

Lieblingsfehler

Unter sanfter Vernachlässigung aller Informationen wurde das Problem so gelöst:

function r = test(a,b)
if nargin < 3, b = 5; end
b = input('Bitte geben sie b ein: ');
r = a + b;

Das Programm produziert keine Fehlermitteilung, überschreibt aber in der zweiten Zeile eine eventuelle Übergabe für b mit dem Wert 5 um diesen dann in der dritten Zeile mit einer Eingabe des Benutzers zu überschreiben.

Umsetzung von Funktionen

Die Umsetzung einer simplen Funktion

g(x) = \frac{1}{\sqrt{2\pi}\sigma} \exp(\frac{(x-x_{0})^2}{2\sigma^2})