www.vorkurse.de
Ein Projekt von vorhilfe.de
Die Online-Kurse der Vorhilfe

E-Learning leicht gemacht.
Hallo Gast!einloggen | registrieren ]
Startseite · Mitglieder · Teams · Forum · Wissen · Kurse · Impressum
Forenbaum
^ Forenbaum
Status Mathe-Vorkurse
  Status Organisatorisches
  Status Schule
    Status Wiederholung Algebra
    Status Einführung Analysis
    Status Einführung Analytisc
    Status VK 21: Mathematik 6.
    Status VK 37: Kurvendiskussionen
    Status VK Abivorbereitungen
  Status Universität
    Status Lerngruppe LinAlg
    Status VK 13 Analysis I FH
    Status Algebra 2006
    Status VK 22: Algebra 2007
    Status GruMiHH 06
    Status VK 58: Algebra 1
    Status VK 59: Lineare Algebra
    Status VK 60: Analysis
    Status Wahrscheinlichkeitst

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
Forum "Mathematica" - Funktionsübergabe an NMinimize
Funktionsübergabe an NMinimize < Mathematica < Mathe-Software < Mathe < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "Mathematica"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

Funktionsübergabe an NMinimize: Frage (überfällig)
Status: (Frage) überfällig Status 
Datum: 16:18 Di 12.12.2006
Autor: Egon26

Ich habe diese Frage in keinem Forum auf anderen Internetseiten gestellt.

Hallo zusammen,

ich bin absoluter Mathematica Newbie und habe folgendes Problem.

Eingabe:

[mm] H={{x^2 + y^2, 0}, {0, x^2 + y^2}}; [/mm]

CalculateError[H_] := Module[{i},
TotError = 0;
For[i = 1, i = Length[H],
       TotError += Sqrt((Eigensystem[H]MB1, [mm] i-i)^2); [/mm]
(i++);
];

NMinimize[CalculateError[H], {x, y}, Method -> "SimulatedAnnealing"]

Ausgabe:

NMinimize::nnum: The function value Null is not a number at {x, y} = {-0.936293, 0.280416}.

Warum übernimmt NMinimize hier die Funktion nicht?

Ich würde mich über jede Hilfe sehr freuen!

Egon

        
Bezug
Funktionsübergabe an NMinimize: Fkt gibt keinen Wert zurück
Status: (Mitteilung) Reaktion unnötig Status 
Datum: 09:17 Mo 08.01.2007
Autor: Peter_Pein

Hallo Egon,

ich habe deine Frage erst zu spät gesehen....

Der Formeleditor hat deine Eingabe ziemlich verwurschtelt, aber es ist auch so zu sehen, dass CalculateError[] keinen Wert zurück gibt.

Vermutung: H = {{x^2 + y^2, 0}, {0, x^2 + y^2}};

Ich würde vorschlagen, die Funktion folgendermaßen zu programmieren:

 CalculateError[h_]:=Norm[Eigenvalues[h]-Range[Length[h]]];

(war das gemeint?)

Falls du auf das prozedurale Zeug (For, Do, While...) nicht verzichten möchtest, solltest du dir die Hilfe (in diesem Fall zu For) durchlesen.

In Mathematica het der Befehl die Form
For[start, test, incr, body].

Beachte insbesondere die Verwendung von Kommata! Es kann nicht klappen, C-Syntax in Mathematica einzugeben. Außerdem ist die Reihenfolge der einzelnen Abschnitte eine andere als in deiner bisherigen Erfahrung.

Deine For-"Schleife" wird genau dann ausgeführt, wenn die Länge von H 1 ist.

Des weiteren Frage ich mich, warum du i als lokale Variable deklarierst, und
TotError nicht.

Funktionen werden Sqrt[...] aufgerufen, nicht Sqrt(...).

Also:
1:  CalculateError[H_] := Module[{i,TotError = 0},
2: For[i = 1, i <= Length[H], i++,
3:        TotError += Sqrt[(Eigensystem[H][[1, i]]-i)^2]
4:      ];
5:   TotError] 

wäre eine prozedurale Herangehensweise (die in diesem Fall ineffizient ist, weil  Eigensystem zwei mal aufgerufen wird).

Nun ist das gesuchte Minimum jedoch ein Kreis. Deshalb würde ich vorschlagen, grad(CalculateError[H])=0 zu bestimmen:

[mm]\text{Reduce}[D[\text{CalculateError}[H], \{\{x, y\}\}] \text{==} 0, \{x, y\}, \text{Reals}]}[/mm]

ergibt:

[mm](-\sqrt{2}
Viel Spaß beim Lernen von Mathematica,
Peter



Bezug
Ansicht: [ geschachtelt ] | ^ Forum "Mathematica"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.vorkurse.de
[ Startseite | Mitglieder | Teams | Forum | Wissen | Kurse | Impressum ]