Previous: Debugger-Kommandos, Nach oben: Fehlersuche [Inhalt][Index]
Standardwert: false
Hat die Optionsvariable debugmode den Wert true, wird der 
Maxima-Debugger gestartet, wenn ein Programmfehler auftritt.  Nach der 
Unterbrechung des Programms kann der Debugger genutzt werden.  Siehe das Kapitel
Debugger-Kommandos für eine Liste der Kommandos des Debuggers.
Der Maxima-Debugger behandelt keine Lisp-Programmfehler.
Standardwert: false
Hat refcheck den Wert true, gibt Maxima eine Meldung aus, wenn
einer Variablen zum ersten Mal ein Wert zugewiesen wird.
Standardwert: false
Der Optionsvariablen setcheck kann eine Liste mit den Namen von Variablen
zugewiesen werden.  Dies können auch indizierte Variablen sein.  Immer wenn 
einer der Variablen mit den Operatoren : oder :: ein Wert 
zugewiesen wird, gibt Maxima eine Meldung aus, die den Namen der Variablen und 
den zugewiesenen Wert enthält.
setcheck kann den Wert all oder true erhalten.  In diesem
Fall wird für alle Variablen eine Meldung ausgegeben.
Jede Zuweisung an setcheck initialisert eine neue Liste mit Variablen. 
Vorherige Zuweisungen werden überschrieben.
Die Auswertung der Namen der Variablen muss mit dem
Quote-Operator ' unterdrückt werden, wenn den Variablen
bereits Werte zugewiesen wurden.  Haben zum Beispiel die Variablen x,
y und z Werte, dann werden die Variablen mit dem folgenden Befehl
angegeben:
setcheck: ['x, 'y, 'z]$
Es wird keine Meldung ausgegeben, wenn eine Variable sich selbst zugewiesen
wird, zum Beispiel X: 'X.
Standardwert: false
Hat setcheckbreak den Wert true, startet Maxima den Debugger, 
wenn einer Variablen, die in der Liste setcheck enthalten ist, ein
Wert zugewiesen wird.  Die Unterbrechung wird noch vor der Zuweisung des Wertes
ausgeführt.  Die Variable setval enhält den Wert, der zugewiesen 
werden soll.  Dieser Variablen kann ein anderer Wert zugewiesen werden.
Enthält den Wert, der einer Variable zugewiesen werden soll, wenn die 
Zuweisung mit der Optionsvariablen setcheckbreak unterbrochen wurde. 
setval kann ein anderer Wert zugewiesen werden.
Siehe auch setcheck und setcheckbreak.
Sammelt Statistiken über die Ausführungszeiten von Funktionen.  Die 
Argumente f_1, …, f_n sind die Namen von Funktionen zu denen 
Statistiken gesammelt werden.  time(g) fügt die Funktion g der 
Liste an Funktionen hinzu, zu denen Informationen gesammelt werden.
timer(all) fügt alle nutzerdefinierten Funktionen, die in der 
Informationsliste functions enthalten sind, der Liste der Funktionen
hinzu, über die Informationen gesammelt werden.
Wird timer() ohne Argumente aufgerufen, wird eine Liste der Funktionen
zurückgeben, über die Informationen gesammelt werden.
Maxima misst die Zeit, die eine Funktion für die Ausführung benötigt. 
timer_info gibt eine Statistik für alle Funktionen zurück, für die 
die Ausführungszeiten gemessen werden.  Die Statistik enthält die 
durchschnittliche Ausführungszeit der Funktionen und die Anzahl der Aufrufe 
der Funktionen.  Mit der Funktion untimer wird die Aufzeichnung der 
Ausführungszeiten beendet.
timer wertet die Argumente nicht aus.  Daher werden im Folgenden
f(x) := x^2$ g:f$ timer(g)$ für die Funktion f keine 
Ausführungszeiten aufgezeichnet.
Wird für die Funktion f mit dem Kommando trace(f) der Ablauf
verfolgt, hat das Kommando timer(f) keinen Effekt.  Für eine Funktion
können nicht gleichzeitig Ausführungszeiten aufgezeichnet und der Ablauf
verfolgt werden.
Siehe auch timer_devalue.
untimer beendet die Aufzeichnung von Informationen zur Ausführungszeit
für die Funktionen f_1, …, f_n.
Wird untimer ohne Argument aufgerufen, wird die Aufzeichnung für alle
Funktionen beendet.
Die aufgezeichneten Informationen zu einer Funktion f können mit dem
Kommando timer_info(f) auch dann abgerufen werden, wenn zuvor mit dem 
Kommando untimer(f) die Aufzeichnung für die Funktion f beendet 
wurde.  Jedoch werden die aufgezeichneten Informationen für die Funktion 
f nicht mit dem Kommando timer_info() angezeigt.  Das Kommando
timer(f) setzt alle aufgezeichneten zurück und startet die Aufzeichnung
für die Funktion erneut.
Standardwert: false
Hat timer_devalue den Wert true, subtrahiert Maxima bei der
Aufzeichnung der Ausführungszeiten die Zeiten, welche eine Funktion in anderen
Funktionen verbringt.  Ansonsten enthalten die aufgezeichneten Zeiten auch die
Ausführungszeiten der Funktionen, die aufgerufen werden.
Siehe auch timer und timer_info.
Gibt eine Tabelle mit den aufgezeichneten Informationen über die Ausführungszeiten der Funktionen f_1, …, f_n zurück. Wird kein Argument angegeben, werden Informationen für alle Funktionen angezeigt, zu denen Informationen aufgezeichnet sind.
Die Tabelle enthält die Namen der Funktionen, die Ausführungszeit pro 
Aufruf, die Anzahl der Aufrufe, die gesamte Zeit und die gctime-Zeit. 
Die gctime-Zeit bedeutet "Garbage Collection Time".
Die Daten, die von der Funktion timer_info angezeigt werden, können 
auch mit der Funktion get erhalten werden:
get(f, 'calls); get(f, 'runtime); get(f, 'gctime);
Siehe auch timer.
Startet die Ablaufverfolgung für die Funktionen f_1, …, f_n. 
Mit dem Kommando trace(g) kann eine weitere Funktion hinzugefügt 
werden.
trace(all) startet die Ablaufverfolgung für alle nutzerdefinierten
Funktionen, die in der Informationsliste functions enthalten sind.
Das Kommando trace() zeigt eine Liste aller Funktionen für die eine
Ablaufverfolgung gestartet wurde.
Mit der Funktion untrace wird die Ablaufverfolgung beendet.  Siehe auch
trace_options.
trace wertet die Argumente nicht aus. 
Die Ablaufverfolgung kann für eine Funktion f nicht gestartet werden,
wenn für die Funktion bereits mit der Funktion timer Informationen 
über die Ausführungszeiten gesammelt werden.
Setzt Optionen für die Ablaufverfolgung einer Funktion f. Bereits vorliegende Optionen werden ersetzt.
trace_options(f) setzt alle Optionen auf die Standardwerte 
zurück.
Die Optionen sind:
noprintGebe keine Meldung beim Eintritt in eine oder dem Austritt aus einer Funktion aus.
breakSetze eine Unterbrechnung vor dem Eintritt in eine Funktion und nach dem
Austritt aus einer Funktion.  Siehe break.
lisp_printZeige die Argumente und Rückgabewerte in der Lisp-Syntax an.
infoGebe -> true beim Eintritt in und Austritt aus einer Funktion aus.
errorcatchCatch errors, giving the option to signal an error, retry the function call, or specify a return value.
Es können bedingte Optionen für die Ablaufverfolgung definiert werden.  Dazu
wird eine Option zusammen mit einer Aussagefunktion angegeben.  Die Argumente 
der Aussagefunktion für eine bedingte Option sind immer 
[level, direction, function, item].  level ist die Rekursionstiefe
der Funktion, direction enthält die Werte enter oder 
exit, function ist der Name der Funktion und item ist eine 
Liste der Argumente oder der Rückgabewert beim Verlassen der Funktion.
Dies ist ein Beispiel für eine Ablaufverfolgung ohne Bedingungen:
(%i1) ff(n) := if equal(n, 0) then 1 else n * ff(n - 1)$ (%i2) trace (ff)$ (%i3) trace_options (ff, lisp_print, break)$ (%i4) ff(3);
In diesem Fall wird eine Aussagefunktion für eine bedingte Ablaufverfolgung angegeben:
(%i5) trace_options (ff, break(pp))$
(%i6) pp (level, direction, function, item) := block (print (item),
    return (function = 'ff and level = 3 and direction = exit))$
(%i7) ff(6);
Beendet die Ablaufverfolgung für die Funktionen f_1, …, f_n. 
Das Kommando untrace() beendet die Ablaufverfolgung für alle 
Funktionen.
untrace gibt eine Liste der Funktionen zurück, für die die 
Ablaufverfolgung beendet wurde.
Previous: Debugger-Kommandos, Nach oben: Fehlersuche [Inhalt][Index]