Solving coupled differential equations
53 次查看(过去 30 天)
显示 更早的评论
I am trying to solve the following coupled differential equation:
data:image/s3,"s3://crabby-images/4dd5d/4dd5dd9c679a6c5e5af076e98fbf61d44d9c8e0c" alt=""
data:image/s3,"s3://crabby-images/4796b/4796b9b12b77b0feff367ed8df65ab20649f07c7" alt=""
The goal is to obtain analytic solutions of
and
in terms of
, and
.
data:image/s3,"s3://crabby-images/3d234/3d2344b238de8624045e62dffc143c3b8b898c3a" alt=""
data:image/s3,"s3://crabby-images/3797d/3797d8fac7149a8af07d0a4afc8339a3e052b07a" alt=""
data:image/s3,"s3://crabby-images/17c09/17c094fe5c62e23923c24d0bae0e974755cc58ee" alt=""
data:image/s3,"s3://crabby-images/6a193/6a1931d63b179045256c6eb6666ff88be3726180" alt=""
However, MATLAB doesn't seem to obtain the analytic solutions, as posted below. But I do think that we can get
and
in terms of
, and
. Is there any other way I can try to solve the problem in MATLAB (or analytically)?
data:image/s3,"s3://crabby-images/fdaec/fdaecd755dcb6852b05d080cea446fe3373dedf2" alt=""
data:image/s3,"s3://crabby-images/79a05/79a0548738a6b04b6f714de1c2200afb6266a156" alt=""
data:image/s3,"s3://crabby-images/23bb9/23bb953db337f2465ddb716b12c0936884960d41" alt=""
data:image/s3,"s3://crabby-images/17f1f/17f1ff22efa1148f06fa6b0e342b85310a863009" alt=""
data:image/s3,"s3://crabby-images/84ba4/84ba43bf25384c6d361c5994ecdda796ba15293d" alt=""
1 个评论
David Goodmanson
2023-4-23
Hi Jon,
In general there won't be an analytical solution, even if Int f(t) dt has an analytic expression. For y, you have the second order differential equation
y'' + y'(-f/f + gamma) + f^2 y = 0
(there is a similar expression for x''). This may or may not (and in most cases does not) have an analytic solution.
回答(2 个)
Sam Chak
2023-4-22
Hi @Jon
I'm unsure if the system has a general analytical solution.
In Pure Math, from the properties of a stable 2nd-order ODE, if
,
and
is monotonically increasing, then the system will converge to the origin. Perhaps, the analytical solution exists for a certain type of
.
data:image/s3,"s3://crabby-images/dfcfb/dfcfb011855a8c43c29baa6c1897e78090b48e56" alt=""
data:image/s3,"s3://crabby-images/eb3f7/eb3f7607751adf812aef622d8e4486fc8dededaa" alt=""
data:image/s3,"s3://crabby-images/aefe3/aefe3c1db9645f2ea12684419b8024d979d842d1" alt=""
data:image/s3,"s3://crabby-images/74807/74807efee02f2ff10d7424e35f59c224a64b82b5" alt=""
Here is a simple demonstration using 3 different monotonically increasing functions of
:
data:image/s3,"s3://crabby-images/ea717/ea717549702bbb62e9074825681b4cbc6f3f18a7" alt=""
Definition of state variables:
data:image/s3,"s3://crabby-images/7cac8/7cac854fcbbf4c18c8a2a282e6fb29e1cbe45f00" alt=""
data:image/s3,"s3://crabby-images/f7f8d/f7f8d39e6b55a4e7814633b0a5efaddd1ce2b295" alt=""
tspan = linspace(0, 20, 2001);
x0 = [1 0];
[t, x] = ode45(@odefcn, tspan, x0);
% Solution Plot
plot(t, x(:,1), 'linewidth', 1.5, 'color', '#528AFA'),
grid on, xlabel('t'), ylabel('x_{1}')
% Phase Portrait
plot(x(:,1), x(:,2), 'linewidth', 1.5, 'color', '#FA477A'),
grid on, xlabel('x_{1}'), ylabel('x_{2}')
function xdot = odefcn(t, x)
ft1 = tanh(t);
ft2 = t;
ft3 = t^3;
gamma = 1; % gamma > 0
xdot = zeros(2, 1);
xdot(1) = ft3*x(2); % <-- change to ft1, or ft2
xdot(2) = - ft3*x(1) - gamma*x(2); % <-- change to ft1, or ft2
end
2 个评论
Sam Chak
2023-4-22
syms y(t) x(t) gamma
sym('gamma', 'real');
assume(t > 0)
f(t) = sign(t);
eqns = [diff(y,t) == f(t)*x,
diff(x,t) == - f(t)*y - gamma*x];
sol = dsolve(eqns);
display(sol.y)
However, WolframAlpha shows that analytical solutions (click on the ODEs) exist for
and
Sam Chak
2023-4-22
编辑:Sam Chak
2023-4-22
Analytical solution:
data:image/s3,"s3://crabby-images/829ae/829aea1a20415e69a897b070efdbfc0b1308c55a" alt=""
Click on the 2nd-order ODE to see the analytical solution and plots on WolframAlpha.
Note: By the way, this ODE can be rewritten in Sturm–Liouville form. Perhaps, if your problem can be transformed to become a Sturm–Liouville problem, then the analytical solution exists.
syms y(t) gamma
gamma = 2;
Dy = diff(y,t);
eqn = diff(y,t,2) + (gamma - 1)*Dy + exp(2*t)*y == 0;
cond = [y(0)==1, Dy(0)==0];
ySol(t) = dsolve(eqn, cond)
Numerical solution:
tspan = linspace(0, 10, 1001);
x0 = [1 0];
[t, x] = ode45(@odefcn, tspan, x0);
% Solution Plot
plot(t, x(:,1), 'linewidth', 1.5, 'color', '#528AFA'),
grid on, xlabel('t'), ylabel('x_{1}')
% Phase Portrait
plot(x(:,1), exp(t).*x(:,2), 'linewidth', 1.5, 'color', '#FA477A'),
ylim([-2 2]), grid on,
xlabel({'$y_{t}$'}, 'interpreter', 'latex', 'fontsize', 16),
ylabel({'$\dot{y}_{t}$'}, 'interpreter', 'latex', 'fontsize', 16)
function xdot = odefcn(t, x)
ft = exp(t);
gamma = 2; % gamma > 0
xdot = zeros(2, 1);
xdot(1) = ft*x(2); % <-- change to ft1, or ft2
xdot(2) = - ft*x(1) - gamma*x(2); % <-- change to ft1, or ft2
end
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Calculus 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!