Definition 6.1.1 (Initial-value problem (scalar))
A scalar first-order initial-value problem (IVP ) is
u ′ ( t ) = f ( t , u ( t ) ) , a ≤ t ≤ b , u ( a ) = u 0 . \begin{split}
u'(t) &= f(t,u(t)), \qquad a \le t \le b, \\
u(a) &=u_0.
\end{split} u ′ ( t ) u ( a ) = f ( t , u ( t )) , a ≤ t ≤ b , = u 0 . We call t t t the independent variable and u u u the dependent variable . If u ′ = f ( t , u ) = g ( t ) + u h ( t ) u'=f(t,u)=g(t)+u h(t) u ′ = f ( t , u ) = g ( t ) + u h ( t ) , the differential equation is linear ; otherwise, it is nonlinear .
A solution of an initial-value problem is a function u ( t ) u(t) u ( t ) that makes both u ′ ( t ) = f ( t , u ( t ) ) u'(t)=f\bigl(t,u(t)\bigr) u ′ ( t ) = f ( t , u ( t ) ) and u ( a ) = u 0 u(a)=u_0 u ( a ) = u 0 true equations.
When t t t is meant to be time, sometimes we write u ˙ \dot{u} u ˙ (read “u-dot”) instead of u ′ u' u ′ .
Suppose u ( t ) u(t) u ( t ) is the size of a population at time t t t . We idealize by allowing u u u to take any real (not just integer) value. If we assume a constant per capita birth rate (births per unit population per unit time), then
d u d t = k u , u ( 0 ) = u 0 \frac{d u}{d t} = k u, \qquad u(0)=u_0 d t d u = k u , u ( 0 ) = u 0 for some k > 0 k>0 k > 0 . The solution of this linear equation is u ( t ) = e k t u 0 u(t)=e^{kt}u_0 u ( t ) = e k t u 0 , which is exponential growth.
A more realistic model would cap the growth due to finite resources. Suppose the death rate is proportional to the size of the population, indicating competition. Then
d u d t = k u − r u 2 , u ( 0 ) = u 0 . \frac{d u}{d t} = ku - ru^2, \qquad u(0)=u_0. d t d u = k u − r u 2 , u ( 0 ) = u 0 . This is the logistic equation . Although crude, it is still useful in population models. The solution relevant for population models has the form
u ( t ) = k / r 1 + ( k r u 0 − 1 ) e − k t . u(t) = \frac{k/r}{ 1 + \left( \frac{k}{r u_0} - 1 \right) e^{-k t} }. u ( t ) = 1 + ( r u 0 k − 1 ) e − k t k / r . For k , r , u 0 > 0 k,r,u_0>0 k , r , u 0 > 0 , the solution smoothly varies from the initial population u 0 u_0 u 0 to a finite population, equal to k / r k/r k / r , that has been limited by competition.
Linear problems can be solved in terms of integrals. Defining the integrating factor ρ ( t ) = exp [ ∫ − h ( t ) d t ] \rho(t) = \exp\bigl[\int -h(t)\, dt \bigr] ρ ( t ) = exp [ ∫ − h ( t ) d t ] , the solution is derived from
ρ ( t ) u ( t ) = u 0 + ∫ a t ρ ( s ) g ( s ) d s . \rho(t) u(t) = u_0 + \int_a^t \rho(s) g(s) \, ds. ρ ( t ) u ( t ) = u 0 + ∫ a t ρ ( s ) g ( s ) d s . In many cases, however, the necessary integrals cannot be done in closed form. Some nonlinear ODE s, such as separable equations, may also be solvable with a short formula, perhaps with difficult integrations. Most often, though, there is no analytic formula available for the solution.
An ODE may have higher derivatives of the unknown solution present. For example, a second-order ordinary differential equation is often given in the form u ′ ′ ( t ) = f ( t , u , u ′ ) u''(t)=f\bigl(t,u,u'\bigr) u ′′ ( t ) = f ( t , u , u ′ ) . A second-order IVP requires two conditions at the initial time in order to specify a solution completely. As we will see in IVP systems , we are always able to reformulate higher-order IVP s in a first-order form, so we will deal with first-order problems exclusively.
6.1.1 Numerical solutions ¶ Example 6.1.2 (Solving an
IVP )
Example 6.1.2 The OrdinaryDiffEq
package offers solvers for IVP s. Let’s use it to define and solve an initial-value problem for u ′ = sin [ ( u + t ) 2 ] u'=\sin[(u+t)^2] u ′ = sin [( u + t ) 2 ] over t ∈ [ 0 , 4 ] t \in [0,4] t ∈ [ 0 , 4 ] , such that u ( 0 ) = − 1 u(0)=-1 u ( 0 ) = − 1 .
Because many practical problems come with parameters that are fixed within an instance but varied from one instance to another, the syntax for IVP s includes a input argument p
that stays fixed throughout the solution. Here we don’t want to use that argument, but it must be in the definition for the solver to work.
Tip
To create an initial-value problem for u ( t ) u(t) u ( t ) , you must supply a function that computes u ′ u' u ′ , an initial value for u u u , and the endpoints of the interval for t t t . The t t t interval should be defined as (a,b)
, where at least one of the values is a float.
f(u, p, t) = sin((t + u)^2) # defines du/dt, must include p argument
u₀ = -1.0 # initial value
tspan = (0.0, 4.0) # t interval
With the data above we define an IVP problem object and then solve it. Here we tell the solver to use the Tsit5
method, which is a good first choice for most problems.
using OrdinaryDiffEq
ivp = ODEProblem(f, u₀, tspan)
sol = solve(ivp, Tsit5());
The resulting solution object can be shown using plot
.
using Plots
plot(sol;
label="solution", legend=:bottom,
xlabel="t", ylabel=L"u(t)",
title=L"u'=\sin((t+u)^2)")
The solution also acts like any callable function that can be evaluated at different values of t t t .
sol(1.0) = -0.7903205813665345
Under the hood, the solution object holds some information about how the values and plot are produced:
15×2 Matrix{Float64}:
0.0 -1.0
0.0867807 -0.93483
0.241035 -0.856617
0.464665 -0.805668
0.696832 -0.793614
1.00862 -0.789925
1.37461 -0.718601
1.70407 -0.476837
1.93572 -0.29033
2.17184 -0.294994
2.4843 -0.483948
2.69425 -0.654121
3.27049 -1.1783
3.62534 -1.51729
4.0 -1.88086
The solver initially finds approximate values of the solution (second column above) at some automatically chosen times (first column above). To compute the solution at other times, the object performs an interpolation on those values. This chapter is about how the discrete t t t and u u u values are computed. For now, just note how we can extract them from the solution object.
scatter!(sol.t, sol.u, label="discrete values")
Example 6.1.2 Let’s use it to define and solve an initial-value problem for u ′ = sin [ ( u + t ) 2 ] u'=\sin[(u+t)^2] u ′ = sin [( u + t ) 2 ] over t ∈ [ 0 , 4 ] t \in [0,4] t ∈ [ 0 , 4 ] , such that u ( 0 ) = − 1 u(0)=-1 u ( 0 ) = − 1 . To create an initial-value problem for u ( t ) u(t) u ( t ) , you must create an ode
with a function that computes u ′ u' u ′ and an initial condition for u u u . Then you create a solution by calling solve
with a time interval.
Tip
Most real ODE problems contain parameters that are constant during the solution but that can change from one problem instance to the next. Accordingly, we define the ODE function below to accept a third argument, p
, which is a vector of parameters. We always include this argument for consistency, even when there are no parameters.
ivp = ode;
ivp.ODEFcn = @(t, u, p) sin((t + u)^2);
ivp.InitialTime = 0;
ivp.InitialValue = -1;
sol = solve(ivp, 0, 4);
The resulting solution object has fields Time
and Solution
that contain the approximate values of the solution at automatically chosen times in the interval you provided.
clf
plot(sol.Time, sol.Solution, '-o')
xlabel("t")
ylabel("u(t)")
title(("Solution of an IVP"));
You might want to know the solution at particular times other than the ones selected by the solver. That requires an interpolation, which is done by solutionFcn
.
u = solutionFcn(ivp, 0, 10);
u(0:5)
Example 6.1.2 Let’s use solve_ivp
from scipy.integrate
to define and solve an initial-value problem for u ′ = sin [ ( u + t ) 2 ] u'=\sin[(u+t)^2] u ′ = sin [( u + t ) 2 ] over t ∈ [ 0 , 4 ] t \in [0,4] t ∈ [ 0 , 4 ] , such that u ( 0 ) = − 1 u(0)=-1 u ( 0 ) = − 1 .
To create an initial-value problem for u ( t ) u(t) u ( t ) , you must supply a function that computes u ′ u' u ′ , an initial value for u u u , and the endpoints of the interval for t t t . The t t t interval should be defined as (a,b)
, where at least one of the values is a float.
f = lambda t, u: sin((t + u) ** 2)
tspan = [0.0, 4.0]
u0 = [-1.0]
Note above that even though this is a problem for a scalar function u ( t ) u(t) u ( t ) , we had to set the initial condition as a “one-dimensional vector.”
from scipy.integrate import solve_ivp
sol = solve_ivp(f, tspan, u0)
The resulting solution object has fields t
and y
that contain the values of the independent and dependent variables, respectively; those field names are the same regardless of what we use in our own codes.
print("t shape:", sol.t.shape)
print("u shape:", sol.y.shape)
plot(sol.t, sol.y[0, :], "-o")
xlabel("$t$"), ylabel("$u(t)$")
title(("Solution of $u' = sin((t+u)^2)$"));
t shape: (10,)
u shape: (1, 10)
You can see above that the solution was not computed at enough points to make a smooth graph. There is a way to request output at times of your choosing.
sol = solve_ivp(f, tspan, u0, t_eval=linspace(0, 4, 200))
plot(sol.t, sol.y[0, :], "-")
xlabel("$t$"), ylabel("$u(t)$")
title(("Solution of $u' = sin((t+u)^2)$"));
Another option is to enable interpolation to evaluate the solution anywhere after the fact:
sol = solve_ivp(f, tspan, u0, dense_output=True)
for t in linspace(0, 4, 6):
print(f"u({t:.2f}) = {sol.sol(t)[0]:.4f}")
u(0.00) = -1.0000
u(0.80) = -0.8122
u(1.60) = -0.6204
u(2.40) = -0.4320
u(3.20) = -1.1139
u(4.00) = -1.8822
6.1.2 Existence and uniqueness ¶ There are simple IVP s that do not have solutions at all possible times.
Example 6.1.3 (Finite-time singularity)
Example 6.1.3 The equation u ′ = ( u + t ) 2 u'=(u+t)^2 u ′ = ( u + t ) 2 gives us some trouble.
f(u, p, t) = (t + u)^2
ivp = ODEProblem(f, 1.0, (0.0, 1.0))
sol = solve(ivp, Tsit5());
┌ Warning: At t=0.7853839417697203, dt was forced below floating point epsilon 1.1102230246251565e-16, and step error estimate = 42.16290621054672. Aborting. There is either an error in your model specification or the true solution is unstable (or the true solution can not be represented in the precision of Float64).
└ @ SciMLBase ~/.julia/packages/SciMLBase/XzPx0/src/integrator_interface.jl:623
The warning message we received can mean that there is a bug in the formulation of the problem. But if everything has been done correctly, it suggests that the solution may not exist past the indicated time. This is a possibility in nonlinear ODE s.
plot(sol, label="";
xlabel=L"t", yaxis=(:log10, L"u(t)"),
title="Finite-time blowup")
Example 6.1.3 The equation u ′ = ( u + t ) 2 u'=(u+t)^2 u ′ = ( u + t ) 2 gives us some trouble.
ivp = ode;
ivp.ODEFcn = @(t, u, p) (t + u)^2;
ivp.InitialTime = 0;
ivp.InitialValue = 1;
sol = solve(ivp, 0, 1);
Warning: Failure at t=7.853789e-01. Unable to meet integration tolerances without reducing the step size below the smallest value allowed (1.776357e-15) at time t.
The warning message we received can mean that there is a bug in the formulation of the problem. But if everything has been done correctly, it suggests that the solution may not exist past the indicated time. This is a possibility in nonlinear ODE s.
clf
semilogy(sol.Time, sol.Solution)
xlabel("t")
ylabel("u(t)")
title(("Finite-time blowup"));
Example 6.1.3 The equation u ′ = ( u + t ) 2 u'=(u+t)^2 u ′ = ( u + t ) 2 gives us some trouble.
Tip
It’s a good idea to check sol.success
after calling solve_ivp
. If it’s False
, the solution may not be reliable.
f = lambda t, u: (t + u) ** 2
sol = solve_ivp(f, [0.0, 1.0], [1.0])
if not sol.success:
print(sol.message)
Required step size is less than spacing between numbers.
The warning message we received can mean that there is a bug in the formulation of the problem. But if everything has been done correctly, it suggests that the solution may not exist past the indicated time. This is a possibility in nonlinear ODE s.
semilogy(sol.t, sol.y[0, :])
xlabel("$t$")
ylabel("$u(t)$")
title(("Blowup in finite time"));
We can also produce an IVP that has more than one solution.
The following standard theorem gives us a condition that is easy to check and guarantees that a unique solution exists. But it is not the most general possible such condition, so there are problems with a unique solution that it cannot detect. We state the theorem without proof.
Theorem 6.1.1 (Existence and uniqueness)
If the derivative ∂ f ∂ u \frac{\partial f}{\partial u} ∂ u ∂ f exists and ∣ ∂ f ∂ u ∣ \left|\frac{\partial f}{\partial u}\right| ∣ ∣ ∂ u ∂ f ∣ ∣ is bounded by a constant L L L for all a ≤ t ≤ b a\le t \le b a ≤ t ≤ b and all u u u , then the initial-value problem (6.1.1) has a unique solution for t ∈ [ a , b ] t\in [a,b] t ∈ [ a , b ] .
6.1.3 Conditioning of first-order IVP s ¶ In a numerical context we have to be concerned about the conditioning of the IVP . There are two key items in (6.1.1) that we might consider to be the data of the initial-value ODE problem: the function f ( t , u ) f(t,u) f ( t , u ) , and the initial value u 0 u_0 u 0 . It’s easier to discuss perturbations to numbers than to functions, so we will focus on the effect of u 0 u_0 u 0 on the solution, using the following theorem that we give without proof. Happily, its conditions are identical to those in Theorem 6.1.1 .
Theorem 6.1.2 (Dependence on initial value)
If the derivative ∂ f ∂ u \frac{\partial f}{\partial u} ∂ u ∂ f exists and ∣ ∂ f ∂ u ∣ \left|\frac{\partial f}{\partial u}\right| ∣ ∣ ∂ u ∂ f ∣ ∣ is bounded by a constant L L L for all a ≤ t ≤ b a\le t \le b a ≤ t ≤ b and all u u u , then the solution u ( t ; u 0 + δ ) u(t;u_0+\delta) u ( t ; u 0 + δ ) of u ′ = f ( t , u ) u'=f(t,u) u ′ = f ( t , u ) with initial condition u ( 0 ) = u 0 + δ u(0)=u_0+\delta u ( 0 ) = u 0 + δ satisfies
∥ u ( t ; u 0 + δ ) − u ( t ; u 0 ) ∥ ∞ ≤ ∣ δ ∣ e L ( b − a ) \left\|u(t;u_0+\delta)-u(t;u_0)\right\|_\infty \le |\delta| e^{L(b-a)} ∥ u ( t ; u 0 + δ ) − u ( t ; u 0 ) ∥ ∞ ≤ ∣ δ ∣ e L ( b − a ) for all sufficiently small ∣ δ ∣ |\delta| ∣ δ ∣ .
Numerical solutions of IVP s have errors, and those errors can be seen as perturbations to the solution. Theorem 6.1.2 gives an upper bound of e L ( b − a ) e^{L(b-a)} e L ( b − a ) on the infinity norm (i.e., pointwise) absolute condition number of the solution with respect to perturbations at an initial time. However, the upper bound may be a terrible overestimate of the actual sensitivity for a particular problem.
Example 6.1.5 (Conditioning of an
IVP )
Example 6.1.5 Consider the ODE s u ′ = u u'=u u ′ = u and u ′ = − u u'=-u u ′ = − u . In each case we compute ∂ f / ∂ u = ± 1 \partial f/\partial u = \pm 1 ∂ f / ∂ u = ± 1 , so the condition number bound from Theorem 6.1.2 is e b − a e^{b-a} e b − a in both problems. However, they behave quite differently. In the case of exponential growth, u ′ = u u'=u u ′ = u , the bound is the actual condition number.
t = range(0, 3, length=800)
u = @. exp(t) * 1
lower, upper = @. exp(t) * 0.7, @. exp(t) * 1.3
plot(t, u;
l=:black, ribbon=(lower, upper),
leg=:none, xlabel=L"t", ylabel=L"u(t)",
title="Exponential divergence of solutions")
But with u ′ = − u u'=-u u ′ = − u , solutions actually get closer together with time.
u = @. exp(-t) * 1
lower, upper = @. exp(-t) * 0.7, @. exp(-t) * 1.3
plot(t, u;
l=:black, ribbon=(lower, upper),
leg=:none, xlabel=L"t", ylabel=L"u(t)",
title="Exponential convergence of solutions")
In this case the actual condition number is one, because the initial difference between solutions is the largest over all time. Hence the exponentially growing bound e b − a e^{b-a} e b − a is a gross overestimate.
Example 6.1.5 Consider the ODE s u ′ = u u'=u u ′ = u and u ′ = − u u'=-u u ′ = − u . In each case we compute ∂ f / ∂ u = ± 1 \partial f/\partial u = \pm 1 ∂ f / ∂ u = ± 1 , so the condition number bound from Theorem 6.1.2 is e b − a e^{b-a} e b − a in both problems. However, they behave quite differently. In the case of exponential growth, u ′ = u u'=u u ′ = u , the bound is the actual condition number.
clf
for u0 = [0.7, 1, 1.3] % initial values
fplot(@(t) exp(t) * u0, [0, 3]), hold on
end
xlabel('t')
ylabel('u(t)')
title(('Exponential divergence of solutions'));
But with u ′ = − u u'=-u u ′ = − u , solutions actually get closer together with time.
clf
for u0 = [0.7, 1, 1.3] % initial values
fplot(@(t) exp(-t) * u0, [0, 3]), hold on
end
xlabel('t')
ylabel('u(t)')
title(('Exponential convergence of solutions'));
In this case the actual condition number is one, because the initial difference between solutions is the largest over all time. Hence the exponentially growing bound e b − a e^{b-a} e b − a is a gross overestimate.
Example 6.1.5 Consider the ODE s u ′ = u u'=u u ′ = u and u ′ = − u u'=-u u ′ = − u . In each case we compute ∂ f / ∂ u = ± 1 \partial f/\partial u = \pm 1 ∂ f / ∂ u = ± 1 , so the condition number bound from Theorem 6.1.2 is e b − a e^{b-a} e b − a in both problems. However, they behave quite differently. In the case of exponential growth, u ′ = u u'=u u ′ = u , the bound is the actual condition number.
t = linspace(0, 3, 200)
u = array([exp(t) * u0 for u0 in [0.7, 1, 1.3]])
plot(t, u.T)
xlabel("$t$")
ylabel("$u(t)$")
title(("Exponential divergence of solutions"));
But with u ′ = − u u'=-u u ′ = − u , solutions actually get closer together with time.
t = linspace(0, 3, 200)
u = array([exp(-t) * u0 for u0 in [0.7, 1, 1.3]])
plot(t, u.T)
xlabel("$t$")
ylabel("$u(t)$")
title(("Exponential convergence of solutions"));
In this case the actual condition number is one, because the initial difference between solutions is the largest over all time. Hence, the exponentially growing upper bound e b − a e^{b-a} e b − a is a gross overestimate.
In general, solutions can diverge from, converge to, or oscillate around the original trajectory in response to perturbations. We won’t fully consider these behaviors and their implications for numerical methods again until a later chapter.
6.1.4 Exercises ¶ ✍ For each IVP , determine whether the problem satisfies the conditions of Theorem 6.1.2 ). If so, determine the smallest possible value for L L L .
(a) f ( t , u ) = 3 u , 0 ≤ t ≤ 1 f(t,u) = 3 u,\; 0 \le t \le 1 f ( t , u ) = 3 u , 0 ≤ t ≤ 1
(b) f ( t , u ) = − t sin ( u ) , 0 ≤ t ≤ 5 f(t,u) = -t \sin(u),\; 0 \le t \le 5 f ( t , u ) = − t sin ( u ) , 0 ≤ t ≤ 5
(c) f ( t , u ) = − ( 1 + t 2 ) u 2 , 1 ≤ t ≤ 3 f(t,u) = -(1+t^2) u^2,\; 1 \le t \le 3 f ( t , u ) = − ( 1 + t 2 ) u 2 , 1 ≤ t ≤ 3
(d) f ( t , u ) = u , 0 ≤ t ≤ 1 f(t,u) = \sqrt{u},\; 0 \le t \le 1 f ( t , u ) = u , 0 ≤ t ≤ 1
⌨ For each ODE in the preceding problem, assume that u u u is initially equal to 1 on the given interval. Solve the resulting IVP with solve
and make a plot of the solution.
✍ Use an integrating factor to find the solution of each problem in analytic form.
(a) u ′ = − t u , 0 ≤ t ≤ 5 , u ( 0 ) = 2 u' = -t u,\ 0 \le t \le 5,\ u(0) = 2 u ′ = − t u , 0 ≤ t ≤ 5 , u ( 0 ) = 2
(b) u ′ − 3 u = e − 2 t , 0 ≤ t ≤ 1 , u ( 0 ) = 5 u' - 3 u = e^{-2t},\ 0 \le t \le 1,\ u(0) = 5 u ′ − 3 u = e − 2 t , 0 ≤ t ≤ 1 , u ( 0 ) = 5
✍ Consider the IVP u ′ = u 2 u'=u^2 u ′ = u 2 , u ( 0 ) = α u(0)=\alpha u ( 0 ) = α .
(a) Does Theorem 6.1.1 apply to this problem?
(b) Show that u ( t ) = α / ( 1 − α t ) u(t) = \alpha/(1-\alpha t) u ( t ) = α / ( 1 − α t ) is a solution of the IVP .
(c) Does this solution necessarily exist for all t ∈ [ 0 , 1 ] t\in[0,1] t ∈ [ 0 , 1 ] ?
⌨ Using solve
, compute solutions x ( t ) x(t) x ( t ) to the logistic equation with harvesting,
x ′ = k ( S − x ) ( x − M ) , 0 ≤ t ≤ 10 , x' = k (S-x)(x-M), \qquad 0\le t \le 10, x ′ = k ( S − x ) ( x − M ) , 0 ≤ t ≤ 10 , with k = S = 1 k=S=1 k = S = 1 and M = 0.25 M=0.25 M = 0.25 , for the initial conditions x ( 0 ) = 0.9 M x(0)=0.9M x ( 0 ) = 0.9 M , 1.1 M 1.1M 1.1 M , 1.5 M 1.5M 1.5 M , 0.9 S 0.9S 0.9 S , 1.1 S 1.1S 1.1 S , 3 S 3S 3 S . Show all the solutions together on one plot with 0 ≤ x ≤ 3 0\le x \le 3 0 ≤ x ≤ 3 . (Note: One of the solutions will throw a warning and fail to reach t = 10 t=10 t = 10 , but you can plot it anyway.)
⌨ (a) Using solve
, solve the IVP u ′ = u cos ( u ) + cos ( 4 t ) u'=u\cos(u) + \cos(4t) u ′ = u cos ( u ) + cos ( 4 t ) , 0 ≤ t ≤ 10 0\le t \le 10 0 ≤ t ≤ 10 , u ( 0 ) = u 0 u(0) = u_0 u ( 0 ) = u 0 for u 0 = − 2 , − 1.5 , − 1 , … , 1.5 , 2 u_0 = -2,-1.5,-1,\ldots,1.5,2 u 0 = − 2 , − 1.5 , − 1 , … , 1.5 , 2 . Plot all the solutions on a single graph.
(b) All of the solutions in part (a) eventually settle into one of two periodic oscillations. To two digits of accuracy, find the value of u 0 u_0 u 0 in ( − 1 , 1 ) (-1,1) ( − 1 , 1 ) at which the selected long-term solution changes. (This will take repeated trials, narrowing down the range for u 0 u_0 u 0 each time.)
⌨ Experimental evidence (see Newton et al. (1981) ) shows that a 300-mg oral dose of caffeine, such as might be found in a large mug of drip-brewed coffee, creates a concentration of about 8 μ g \mu{\rm g} μ g /mL in blood plasma. This boost is followed by first-order kinetics with a half-life of about 6 hours (although this rate can vary a great deal from person to person). We can model the caffeine concentration due to one drink taken over half an hour via
x ′ ( t ) = − k x + C ( t ) , x ( 0 ) = 0 , x'(t) = -kx + C(t),\quad x(0)=0, x ′ ( t ) = − k x + C ( t ) , x ( 0 ) = 0 , where k = log ( 2 ) / 6 k=\log(2)/6 k = log ( 2 ) /6 and
C ( t ) = { 16 , 0 ≤ t ≤ 0.5 , 0 , t > 0.5. C(t) =
\begin{cases}
16, & 0\le t \le 0.5, \\
0, & t > 0.5.
\end{cases} C ( t ) = { 16 , 0 , 0 ≤ t ≤ 0.5 , t > 0.5. Use solve
to make a plot of the caffeine concentration for 12 hours. Then change k = log ( 2 ) / 8 k=\log(2)/8 k = log ( 2 ) /8 (half-life of 8 hours) and plot the solution again.
⌨ A reasonable model of the velocity v ( t ) v(t) v ( t ) of a skydiver is
d v d t = − g + k m v 2 , v ( 0 ) = 0 , \frac{dv}{dt} = -g + \frac{k}{m}v^2, \qquad v(0)=0, d t d v = − g + m k v 2 , v ( 0 ) = 0 , where g = 9.8 m/sec 2 g=9.8 \text{ m/sec}^2 g = 9.8 m/sec 2 is gravitational acceleration, m m m is the mass of the skydiver with parachute, and k k k quantifies the effect of air resistance. At the US Air Force Academy, a training jump starts at about 1200 m and has k = 0.4875 k=0.4875 k = 0.4875 for t < 13 t<13 t < 13 and k = 29.16 k=29.16 k = 29.16 or t ≥ 13 t\ge 13 t ≥ 13 . (This is an oversimplification; see Meade & Struthers (1999) .)
(a) Solve the IVP for v v v for an 80-kg cadet for t ∈ [ 0 , 200 ] t\in [0,200] t ∈ [ 0 , 200 ] , and plot the solution.
(b) The total distance fallen up to time t t t is ∫ 0 t v ( s ) d s \displaystyle\int_0^t v(s)\, ds ∫ 0 t v ( s ) d s . Use Function 5.7.1 to calculate and plot the altitude of the cadet as a function of time.
(c) In part (b), you should have found that the altitude becomes negative. Use Function 4.4.2 to determine accurately when the cadet reaches the ground.