Ряд Тейлора против численного решения нелинейного ДЭ в клене - PullRequest
0 голосов
/ 30 декабря 2018

Я хочу построить два графика: числовое решение для DE и ряд Тейлора для заданного DE.У меня

de := diff(y(x), x$2) = x+y(x)-y(x)^2;
cond := y(0) = -1, (D(y))(0) = 1;
stp := 0.1e-1;
a, b := -5, 30;
numpts := floor((b-a)/stp+1);
p := dsolve({cond, de}, y(x), numeric, stepsize = stp, output = listprocedure); 

График eval дает странную вертикальную линию, в то время как я ожидаю получить график, который, кажется, колеблется как x -> ∞.Для серии Taylor я пробовал f:=[seq(taylor(y(x),x=i,n),i=-5..30 by stp)];, но, похоже, это не сработает.Что я могу с этим сделать?Почему мой сюжет отличается от ожидаемого?

1 Ответ

0 голосов
/ 31 декабря 2018
restart;
kernelopts(version);

    Maple 2018.0, X86 64 LINUX, Mar 9 2018, Build ID 1298750

de := diff(y(x), x$2) = x+y(x)-y(x)^2:
cond := y(0) = -1, (D(y))(0) = 1:
stp := 0.1e-1:
a, b := -5, 30:
numpts := floor((b-a)/stp+1):

p := dsolve({cond, de}, y(x), numeric, stepsize = stp,
            output = listprocedure):

Y:=eval(y(x),p);

                Y := proc(x)  ...  end;

plot(Y, 0..20);

enter image description here

Order:=10:
S := convert(rhs(dsolve({cond, de}, {y(x)}, series)),polynom);

plot([S, Y(x)], x=0..1.5);

enter image description here

Order:=40:
S := convert(rhs(dsolve({cond, de}, {y(x)}, series)),polynom):

plot([S, Y(x)], x=0..2.0);

enter image description here

...