WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Polynomberechnung

 

Rossi

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 22.06.2009, 14:26     Titel: Polynomberechnung
  Antworten mit Zitat      
Hallo, ich hab da ein Problem mit einer Hausaufgabe.
Ich soll ein Polynom 4. Grades mit Matlab berechnen und hab aber nur 4 Punkte gegeben wie kann ich das machen?
Das Polynom ist in der Allgemeinenform:
p(x)=x^4+ax^3+bx^2+cx+d
gegeben.

Wäre nett wenn mir jemand helfen könnte!

Gruß


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.432
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 22.06.2009, 14:56     Titel:
  Antworten mit Zitat      
Ich nehme mal an, "4 Punkte" bedeutet 4 x-y-Paare.

Also 4 Gleichungen:
y1 = x1^4 + a x1^3 + b x1^2 + c x1 + d
etc.

vektorisiert:
y = x^4+a*x^3+b*x^2+c*x+d*1
wobei x und y (Spalten-) Vektoren mit 4 Komponenten sind.

Als Gleichungssystem in coeff = [a;b;c;d] umschreiben:
[x^3, x^2, x, ones(size(x))] coeff = y-x^4

Lösung in MATLAB:
Code:
coeff = [x.^3, x.^2, x, ones(size(x))] \ (y-x.^4)


P.S.: Sicher, dass der Koeffizient von x^4 nicht variabel ist? Dann wirds ein wenig anders.
Private Nachricht senden Benutzer-Profile anzeigen
 
Gast



Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 22.06.2009, 15:05     Titel:
  Antworten mit Zitat      
Ja x^4 hat keine Koeffizienten.

Kannst du das noch etwas genauer schreiben ???
Komm irgendwie nicht wirklich weiter, trotz deiner Hilfe.
 
Rossi

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 22.06.2009, 15:39     Titel:
  Antworten mit Zitat      
Durch die Punkte mit Koordinaten Y(X) verläuft der Graph eines Polynoms
p4(x) = x^4 +a3x^3 +a2x^2 +a1x+a0. Berechnen Sie sämtliche Nullstellen
von p4.

Und die werte von Y =
-1,20002923979867
0,446406651712947
-0,904448956623005
5,20622322367738

und von X=
-1,90116007577299
-0,808803046863297
0,0938821981000902
1,23299713464910


Danke
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.432
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 23.06.2009, 13:23     Titel:
  Antworten mit Zitat      
Hallo,

viel mehr kann ich eigentlich nicht schreiben, ohne dass ich die komplette Lösung poste. Und das wird kaum Sinn der Übung sein.

Zur Nullstellensuche empfehle ich fzero mit geeigneten Startwerte (die leicht zu finden sind, da die y-Werte zwischen 2 Stützstellen immer das Vorzeichen wechseln, dazwischen folglich eine Nullstelle sein muss).

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
Blubberin
Forum-Newbie

Forum-Newbie


Beiträge: 1
Anmeldedatum: 23.06.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 23.06.2009, 13:42     Titel:
  Antworten mit Zitat      
Also mich würde die Antwort auch interessieren weil habe es auch probiert bekomme es aber nicht hin
da wäre der lösungsweg wirklich interessant.
Und ich finde den kann man ruhig raus geben sind hier ja nicht im kindergarten
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.432
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 23.06.2009, 14:23     Titel:
  Antworten mit Zitat      
Wie gesagt, der Lösungsweg steht im Grunde schon da.

Im Kindergarten bekommt man beigebracht, (mit gewisser Hilfestellung) selbständig zu arbeiten Wink Aber da wir ja nicht im Kindergarten sind:

Code:
x = [-1.90116007577299; -0.808803046863297; 0.0938821981000902; 1.23299713464910];
y = [-1.20002923979867; 0.446406651712947; -0.904448956623005; 5.20622322367738];

coeff = [x.^3, x.^2, x, ones(size(x))] \ (y - x.^4);

fctn = @(x) x.^4 + polyval(coeff, x);
z = zeros(1,4);
z(1) = fzero(fctn, -3);
z(2) = fzero(fctn, -1.2);
z(3) = fzero(fctn, -0.5);
z(4) = fzero(fctn, 0.5)

xi = linspace(-3, 3);
plot(x, y, 'bo', xi, fctn(xi), 'b-', z, fctn(z), 'r*')
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

Du kannst Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.
Du kannst Dateien in diesem Forum posten
Du kannst Dateien in diesem Forum herunterladen
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.