Einfache funktionsgleichungssystem - moeglich?



  • Sagen wir mal, die ersten Vorfaktoren der Gleichungen heissen a,b,c (in Deinem Beispiel wäre a = 3, b = 2, c = 5).
    Du willst Zeile 1 erhalten und in Zeilen 2 und 3 eine 0 konstruieren. Allgemein kannst Du das so lösen:
    Du multipliziert die Zeilen 2 und 3 mit a. Dann ziehst Du von Zeile 2 b-mal Zeile 1 und von Zeile 3 c-mal Zeile 1 ab. Dann hast Du auf jeden Fall zwei Nullen in der Spalte. Das kannst Du vom Prinzip her so weitermachen, bis Du das komplette Gleichungssystem gelöst hast.

    Wie gesagt, es ist sicher nicht besonders effektiv und es kann sein, dass bei 1000 Feldern Probleme auftreten - ich habs noch nie probiert. Aber bei 1000 Feldern würde ich generell mal behaupten, dass das dann auch keine "Einsteiger-Übung" mehr ist.



  • Ich hab das Ganze etwas anders in der Schule gelernt. Ich versuch, b und c gleich -a zu machen und dann IIa = I+II und IIIa = I + III zu rechnen. Ist IMHO einfacher und so weit ich das auf die Schnelle beurteilen kann, läuft es auch schneller.



  • DAS Standard-Verfahren zur Lösung linearer Gleichungssysteme:

    http://de.wikipedia.org/wiki/Gau%C3%9Fsches_Eliminationsverfahren



  • Bei nichtlinearen Gleichungssystemen ist es schwieriger, da approximiert man meist numerisch. Aber ich denke, dass du die Indizes nur unglücklich positioniert hast. Die sehen aus wie Exponenten. Habe neulich einige Zerlegungen in meine Matrixklasse eingebaut. Wenn du willst kann ich mal ein wenig Code posten.



  • @Michael E.: Und wie kommst Du dann (im gegebenen Beispiel) z.B. in der zweiten Zeile auf -a?

    @Mastah: Jo, er hat im ersten Posting geschrieben, dass das Indizes sind.



  • b * (-a/b) = -a



  • Dürfte aber IMHO auch was Geschwindigkeit angeht aufs selbe rauslaufen:
    Bei Dir errechnet sich z.B. der neue zweite Vorfaktor der zweiten Zeile (b2, die ersten aller Zeilen sollen jetzt mal a1, b1, c1 heissen) aus
    b2_neu = b2 * (-a) / b + a2. Bei mir ists b2_neu = b2 * a - b * a2.



  • Ich weiß nicht, was du da machst, aber ich rechne b2_neu genau so aus wie b1_neu.



  • Naja, wenn Du b1_neu = -a1 haben willst, wie Du gesagt hast, wirst Du wohl die ganze Zeile mit -a/b1 multiplizieren, oder? Also steht dann in der zweiten Zeile -a (b2* (-a)/b) (b3*(-a)/b). Dann addierst Du I+II und dann steht da 0 (b2*(-a)/b+a2) (b3*(-a)/b+a3), wobei dann (b2*(-a)/b+a2) das neue b2 ist, mit dem weitergerechnet werden muss.
    Oder anders, bevor das sinnlos ausufert: Wo siehst Du den Geschwindigkeitvorteil bei Dir? Ich sehe ihn nicht und würde ihn gerne verstehen, da beides IMHO aufs selbe rauskommt.



  • Ich bin zwar wirklich kein guter Mathematiker, aber ich versuchs jetzt mal:

    Ich schreibe nur Varablen für die Werte hin, die gegeben sind. Meine LaTeX-Kenntnisse sind sehr beschränkt, deshalb siehts auch nicht sonderlich toll aus. Zuerst meine Methode:

    $x\_1 + y\_1 + z\_1 = e\_1$ zwei Rechenschritte \\ \\ $x\_2 + y\_2 + z\_2 = e\_2$ \\ $-x\_1 - \frac{x\_1 y\_2}{x\_2} = \frac{x\_1 e\_2}{x_2}$ \\ $y\_1 + z\_1 - \frac{x\_1 (y\_2 + z\_2)}{x\_2} = \frac{x\_1 e\_2}{x\_2} + e\_1$ acht Rechenschritte \\ \\ $x\_3 + y\_3 + z\_3 = e\_3$ \\ $-x\_1 - \frac{x\_1 y\_3}{x\_3} = \frac{x\_1 e\_3}{x_3}$ \\ $y\_1 + z\_1 - \frac{x\_1 (y\_3 + z\_3)}{x\_3} = \frac{x\_1 e\_3}{x\_3} + e\_1$ \\ $\- \frac{y\_1 y\_2}{y\_3} - \frac{z\_1 y\_2}{y\_3} + \frac{(x\_1 + y\_2)(y\_3 + z\_3)}{x\_3 y\_3} = - \frac{x\_1 y\_2 e\_3}{x\_3 y\_3} - \frac{e\_1 y\_2}{y\_3}$ \\ $\- y\_1 y\_2 - z\_1 y\_2 + \frac{(x\_1 + y\_2)(y\_3 + z\_3)}{x\_3} = - \frac{x\_1 y\_2 e\_3}{x\_3} - e\_1 y_2$ \\ $\- y\_2 (y\_1 + z\_1) + \frac{(x\_1 + y\_2)(y\_3 + z\_3)}{x\_3} = - \frac{x\_1 y\_2 e\_3}{x\_3} - e\_1 y\_2$ \\ $y\_1 + z\_1 - \frac{x\_1 (y\_2 + z\_2)}{x\_2} - y\_2 (y\_1 + z\_1) - y\_2 z\_1 + \frac{(x\_1 + y\_2) (y\_3 + z\_3)}{x\_3} = \frac{x\_1 e\_2}{x\_2} + e\_1 + \frac{x\_1 y\_1 e\_3}{x\_3} - e\_1 y\_2$ vierundzwanzig Rechenschritte \end{math}

    2 + 8 + 24 + 3 (weil man noch rechte Seite durch linke Seite rechnet) ergeben 37 Rechenschritte.

    Jetzt deine Methode:

    \begin{math} $x\_1 + y\_1 + z\_1 = e\_1$ zwei Rechenschritte \\ \\ $x\_2 + y\_2 + z\_2 = e\_2$ $x\_1 (x\_2 + y\_2 + z\_2) = x\_1 e\_2$ \\ $x\_1 (x\_2 + y\_2 + z\_2) - x\_2(x\_1 + y\_1 + z\_1) = x\_1 e\_2 - x\_2 e\_1$ zehn Rechenschritte \\ \\ $x\_3 + y\_3 + z\_3 = e\_3$ $x\_1 (x\_3 + y\_3 + z\_3) = x\_1 e\_3$ \\ $x\_1 (x\_3 + y\_3 + z\_3) - x\_3(x\_1 + y\_1 + z\_1) = x\_1 e\_3 - x\_2 e\_3$ \\ $y\_2 (x\_1 (x\_3 + y\_3 + z\_3) - x\_3 (x\_1 + y\_1 + z\_1) ) = y\_2 (x\_1 e\_3 - x\_3 e\_1)$ \\ $y\_2 (x\_1 (x\_3 + y\_3 + z\_3) - x\_3 (x\_1 + y\_1 + z\_1) ) - y\_3 (x\_1 (x\_2 + y\_2 + z\_2) - x\_2(x\_1 + y\_1 + z\_1) ) = y\_2 (x\_1 e\_3 - x\_3 e\_1) - y\_3 (x\_1 e\_2 - x\_2 e\_1)$ sechsundzwanzig Rechenschritte \end{math}

    2 + 10 + 28 + 3 ergeben 41 Rechenschritte. Also ist mein Weg der schnellere.

    Alles ohne jegliches Gewähr.



  • Ich habs mir jetzt gerade auch mal was genauer angeschaut (hätte ich vielleicht besser mal direkt gemacht) und komme zwar auf eine etwas andere Anzahl Rechenschritte (kann auch daran liegen, dass ich mir nicht 100% sicher bin, ob ich Deine Darstellung richtig verstanden habe), aber Du hast in jedem Fall recht - Deine Methode ist wirklich schneller. Ich war irgendwie so auf den Vergleich von einer einzigen Teilrechnung fixiert (=engstirnig 😃 ), dass ich nicht gesehen hab, dass Deine insgesamt doch besser ist.


Anmelden zum Antworten