How do I solve an ODE of the form y'=ay^3 +by^2 +cy +d?

2 Ansichten (letzte 30 Tage)
Gabriel Baranoski
Gabriel Baranoski am 25 Jan. 2022
Kommentiert: Jon am 26 Jan. 2022
I have a vector, for example "pn" of size (20,1). Each point of data describes a coeffecient of y to the power of 20 minus that data point indices (made from the polyfit function in matlab).
For example, pn(15,1) = 5 translates to 5y^5
This defines a large polynomial which looks similar to the title example.
I know that the ODE I have is of the form y'=ay^19 + by^18 +cy^17 +...+gy +h
how can i solve this ode to make a plot of y as a function of t?
I know about the ODE functions like ode45 etc, but I'm not sure how to use them with my ode form.
Thanks!
  1 Kommentar
James Tursa
James Tursa am 25 Jan. 2022
Bearbeitet: James Tursa am 25 Jan. 2022
Can you verify that the form has y's in the polynomial and not x's or t's? And do you have numeric initial conditions?

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Jon
Jon am 25 Jan. 2022
The ode solvers, e.g. ode45 require a function handle which will evaluate the current value of the derivative given the current state. So define your function for example as:
fun = @(y)polyval(pn,y)

Weitere Antworten (1)

Gabriel Baranoski
Gabriel Baranoski am 26 Jan. 2022
Hey so I ended up figuring it out. This is my code to solve the ODE below:
FK=polyfit(MFPs(:,1),MFPs(:,2),20);
tspan = [0 :0.05:50];
x0 = 0;
[t,v]=ode45(@(t,v) ((FK(1)*v^20) + (FK(2)*v^19) + (FK(3)*v^18) + (FK(4)*v^17) + (FK(5)*v^16) + (FK(6)*v^15) + (FK(7)*v^14) + (FK(8)*v^13) + (FK(9)*v^12) + (FK(10)*v^11) + (FK(11)*v^10) + (FK(12)*v^9) + (FK(13)*v^8) + (FK(14)*v^7) + (FK(15)*v^6) + (FK(16)*v^5) + (FK(17)*v^4) + (FK(18)*v^3) + (FK(19)*v^2) + (FK(20)*v) + (FK(21)) - FR - (Y*(v^2)))/M ,tspan,x0);
plot (app.UIAxes,t,v*3.6);
There are a few terms included there that change the ODE from how i originally stated, but this solves the ode accurately.
Maybe theres a way to reduce the ode solve command but I'm not to sure how.
  4 Kommentare
Gabriel Baranoski
Gabriel Baranoski am 26 Jan. 2022
oh okay, great thanks!
Jon
Jon am 26 Jan. 2022
Great, glad you got it working. Good luck with your project

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Programming finden Sie in Help Center und File Exchange

Produkte


Version

R2021b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by