Problem 1: 2.2.7: With (Detools) : With (Plots)
Problem 1: 2.2.7: With (Detools) : With (Plots)
Problem 1: 2.2.7: With (Detools) : With (Plots)
Problem 1: 2.2.7
Find the fixed points, determine their stability, for
d
x( t ) = cos x − ex
dt
> plot(cos(x) - exp(x),x = -5*Pi..Pi,y=-2..2);
A closed-form analytical solution is not available, since it would require the integration of
1
.
e − cos x
x
Problem 2: 2.2.8
We seek a dynamical system yielding the given flow. A possible answer is given by
d x( t )
= ( x + 1 )2 x( x − 2 )
dt
> eqp2 := diff(x(t),t) = (x(t)+1)^2 * x(t) * (x(t)-2):
initconds2 :=
[[x(0)=-1.5],[x(0)=-1],[x(0)=-0.8],[x(0)=0],[x(0)=1.2],
[x(0)=2],[x(0)=2.001]]:
DEplot(eqp2,x(t),t=0..5,x=-2..3,initconds2,linecolor=black);
This is one of many possible answers; others are obtained by multiplying the vector field by g( x ),
where g is positive except possibly at one or more of the fixed points.
Problem 3: 2.2.10 - Fixed Points
We seek examples of first-order dynamical systems dx/dt = f(x) satisfying certain
conditions:
(a) Every real number is a fixed point:
dx
=0
dt
(b) Every integer is a fixed point, and there are no others:
dx
= sin( π x )
dt
(c) There are no examples in which there are exactly three fixed points, and all are stable. In fact,
we cannot even have two stable fixed points adjacent to each other. This is easily seen by
drawing a picture; but we can also argue as follows: Suppose x_1 and x_2 are two adjacent fixed
points. Then, from the assumptions that f(x) is continuous, and that f(x) is nonzero between x_1
and x_2 (there are no fixed points between x_1 and x_2), we must have that f(x) has one sign
between x_1 and x_2. Suppose without loss of generality that f(x)>0 in this interval. Then for
any initial condition x_0 in this interval, the solution must be increasing (dx/dt > 0), and must
approach x_2 as t → ∞, consistent with the assumption that x_2 is stable. However, this
contradicts the assumption that x_1 is stable, since we can choose the initial point x_0 as close to
(but above) x_1 as we like.
(d) An equation with no fixed points is
dx
=1
dt
(e) A simple example of an equation with precisely 100 fixed points is
dx
= ( x − 1 )( x − 2 ) .. ( x − 99 )( x − 100 )
dt
Problem 4: 2.2.13 - Skydiver
> m := 'm': g := 'g': k := 'k':
eqp3 := diff(v(t),t) = g - k*v(t)^2/m;
d k v( t )2
eqp3 := v( t ) = g −
dt m
The command odeadvisor indicates the solution method for this first-order ODE.
> odeadvisor(eqp3);
[ _quadrature ]
( −1 )
To find the solution, we separate variables, and integrate; the integration of ( a2 − v2 ) (where
gm
a= ) is best performed using partial fractions. Maple can also solve this equation
k
analytically:
dsolve(eqp3);
⎛ g m k ( t + _C1 ) ⎞
tanh⎜⎜ ⎟⎟ g m k
⎝ m ⎠
v( t ) =
k
mg
In fact, this solution is only valid if m, g and k are all positive, and if − < v( t ). It seems
k
that Maple automatically made these assumptions; in this case they are justified, but this example
shows that in general Maple's analytical solutions are not always reliable: do the calculations by
hand, and show your working! (you can use Maple to check, if you like). That is, the solution
produced by Maple is only the general solution for a < v( 0 ) (the problem is to take care with
absolute value signs ...). We can find the particular solution satisfying the initial condition
v( 0 ) = 0:
> solp3 := rhs(dsolve({eqp3,v(0)=0}));
⎛ gmk t⎞
tanh⎜⎜ ⎟⎟ g m k
⎝ m ⎠
solp3 :=
k
Now we can use Maple to find the asymptotic behaviour:
> limit(solp3,t=infinity);
⎛ gmk t⎞
tanh⎜⎜ ⎟⎟ g m k
⎝ m ⎠
lim
t→∞ k
Evidently, now (finally!) Maple is concerned about the sign of the variables. Let's try specifying
that all variables are positive:
> limit(solp3,t=infinity) assuming (g>0,m>0,k>0);
gmk
k
This gives the correct terminal velocity. We can write the formula for v( t ) in terms of the
terminal velocity V:
vsol := simplify(subs(m=k*V^2/g,solp3)) assuming (k>0,V>0);
⎛tg⎞
vsol := tanh⎜⎜ ⎟⎟ V
⎝ V ⎠
dv
This answer is much more easily obtained by the graphical method. We plot against v
dt
(choosing some values of the variables):
g := 10: m := 0.1: k := 1:
plot(g - k*v*v/m,v=-1.5..1.5);
m := 'm': g := 'g': k := 'k':
> s3 := value(student[changevar](tau=t*g/V,s2,tau));
> s := subs(tau=t*g/V,s3);
⌠
⎮ ⎛tg⎞
s2 := ⎮tanh ⎜⎜ ⎟⎟ V dt
⎮
⎮ ⎝ V ⎠
⌡
V2 ln( cosh( τ ) )
s3 :=
g
⎛ ⎛ t g ⎞⎞
V2 ln⎜⎜ cosh⎜⎜ ⎟⎟ ⎟⎟
⎝ ⎝ V ⎠⎠
s :=
g
> g := 32.2: t := 116: s; dist := 31400-2100;
solve(s=dist,V);
⎛ ⎛ 3735.2 ⎞ ⎞
0.03105590062 V2 ln⎜⎜ cosh⎜⎜ ⎟⎟ ⎟⎟
⎝ ⎝ V ⎠⎠
dist := 29300
-252.5862069
In the command solve, Maple attempts an analytical solution; in this case it gets it wrong (I'm not
sure why; but the given value is the average velocity computed previously, which cannot also be
the terminal velocity). For a problem with purely floating-point solutions, we should use fsolve
(and look for the positive solution):
Vterm := fsolve(s=dist,V,V=0..infinity);
Vterm := 265.6854815
From this value of the terminal velocity, we can compute the drag constant k. Note that the
weight (in pounds) is mg.
weight := 261.2:
kdrag := solve(sqrt(weight/k)=Vterm,k);
kdrag := 0.003700305037
> m := 'm': g := 'g': k := 'k': s := 's': t := 't':
> DEplot(diff(x(t),t)=a*k_1*x(t)-km_1*x(t)^2,x(t),t=0..5,x=-0.2..
2,[[x(0)=-0.0],[x(0)=0.1],[x(0)=0.7],[x(0)=1.7]],linecolor=blac
k);
For a ≤ 0, there is a unique fixed point at x = 0, which is stable; for a < 0 this is found by linear
stability analysis (since f'(0) = a < 0), while for a = 0, linear stability analysis does not prove
stability (decay towards the origin is slower than exponential - see the next problem), but a look at
the plot of −x3 shows that the origin is stable.
If 0 < a, there are three fixed points, at x = 0, x = − a and x = a . Now f'(0) = a is positive, so
the origin is unstable, while the other two fixed points are stable, with f' = −2 a. This is also
apparent from the graphs.
>
Problem 7: 2.4.9 - Critical slowing down
Reset variables:
x0 := 'x0':
> eqp7 := diff(x(t),t) = - x(t)^3;
d
eqp7 := x( t ) = −x( t )3
dt
Find the analytical solution with arbitrary initial condition:
xsa := dsolve({eqp7,x(0)=x0},x(t)) assuming x0>0;
xsb := dsolve({eqp7,x(0)=x0},x(t)) assuming x0<0;
xsz := dsolve({eqp7,x(0)=0},x(t));
1
xsa := x( t ) =
1
2t+
x02
1
xsb := x( t ) = −
1
2t+
x02
xsz := x( t ) = 0
> limit(xsa,t=infinity);
limit(xsb,t=infinity);
lim x( t ) = 0
t→∞
lim x( t ) = 0
t→∞
So the solutions approach zero for arbitrary initial conditions; however, the decay is proportional
1
to , not exponential.
t
dx
We plot the solutions of this equation and of = −x on the same graph:
dt
lineq := diff(x(t),t) = -x(t):
linsoln := dsolve({lineq,x(0)=10},x(t));
critsoln := dsolve({eqp7,x(0)=10},x(t));
( −t )
linsoln := x( t ) = 10 e
1
critsoln := x( t ) =
1
2t+
100
> plot([rhs(linsoln),rhs(critsoln)],t=0..10);
dx
Note that the solution to = −x3 decays much more rapidly initially, but then slows down once
dt
x < 1.
Problem 8: 2.5.1 - Reaching origin in finite time
The origin x = 0 is a stable fixed point for any real 0 < c. We plot a few representative vector
fields:
> plot(-x^(1/2),x=0..2,tickmarks=[0,0]);
plot(-x^1,x=0..4,-4..0.5,tickmarks=[0,0]);
plot(-x^2,x=0..2,y=-4..0.5,tickmarks=[0,0]);
We know that for c = 1, the decay towards the origin is exponential, and x approaches 0
asymptotically. When 1 < c, the decay is slower than exponential, as we derived in Problem 7.
So the only possibility for the solution to decay to zero in finite time is for c < 1.
The time taken from x = 1 to x = 0 is
T = int(-1/x^c,x=1..0);
⎛ ( −c + 1 )
− 1 ⎞⎟
⎜ x
T = −⎜ lim − ⎟
⎝ x → 0+ c−1 ⎠
When 1 < c, the limit diverges; when c = 1, T is also infinite (T = −lim ln x). When c < 1, the time
is finite:
T = int(-1/x^c,x=1..0) assuming c < 1;
1
T=−
c−1
Problem 9: 2.5.2 - Blow-up
dy
We know that solutions y( t ) of = 1 + y2 blow up in finite time. Now for 1 < x, the solutions
dt
dx
x( t ) of = 1 + x10 grow more rapidly than y( t ), since x2 < x10 for 1 < x. Thus the solutions x( t )
dt
must also blow up in finite time. This is not yet a complete argument, though, since it is only
valid for 1 < x; but since 1 ≤ 1 + x10, we know that solutions beginning at any initial condition x0
will reach x = 1 at the latest at time t = 1 − x0; and since we reach x = 1 in finite time, we can then
begin the comparison with y( t ).
An alternative argument: suppose x( 0 ) = x0. The time taken to diverge (reach x = ∞) is given
by
T = Int(1/(1+x^10),x=x0..infinity);
∞
⌠
⎮ 1
T=⎮
⎮ dx
⎮ 1 + x10
⌡
x0
If this is finite for all x0, then we have finite-time blow-up. But we have
T < Int(1/(1+x^10),x=-infinity..infinity): so
Int(1/(1+x^10),x=-1..1) + 2*Int(1/(1+x^10),x=1..infinity):
and introducing appropriate comparisons, we find
T < Int(1/1,x=-1..1) + 2*Int(1/(1+x^2),x=1..infinity);
∞
⌠
⎮
1
⌠ 1
T < ⎮ 1 dx + 2 ⎮
⎮ dx
⌡ ⎮ 1 + x 2
-1 ⌡
1
Thus an estimate of the upper bound for the blow-up time for any initial condition is
> int(1,x=-1..1) + 2*int(1/(1+x^2),x=1..infinity); evalf(%);
(clearly finite)
π
2+
2
3.570796327
The actual upper bound is
int(1/(1+x^10),x=-infinity..infinity); evalf(%);
1 π
5 ⎛ π ⎞
sin⎜⎜ ⎟⎟
⎝ 10 ⎠
2.033281478
We plot some numerical solutions:
DEplot(diff(x(t),t)=1+x(t)^(10),x(t),t=0..3,x=-3..5,[[x(0)=-1.1]]
,stepsize=0.01,linecolor=black);
>