dsolve unable to find a solution

10 views (last 30 days)
Sam K
Sam K on 8 Apr 2018
Commented: Walter Roberson on 8 Apr 2018
Hi, I need to find a solution for the differential equation (image attached), where theta, gamma and M are parameters. I am trying to solve the equations using dsolve (code attached). It returns an error "Warning: Unable to find explicit solution." Am I doing something wrong or should I use a different ode solver for this equation? Please help! Thanks!

Accepted Answer

Sam K
Sam K on 8 Apr 2018
Sorry about the confusion about the notation. The superscript "T" in my model is not the transpose. The notation denotes the type of source in my model, which is irrelevant to my question here. So, please ignore the superscript "T".
  2 Comments
Walter Roberson
Walter Roberson on 8 Apr 2018
In any case you have QT multiplied by something in the image but evaluated at something instead of multiplied in the code.
Walter Roberson
Walter Roberson on 8 Apr 2018
>> syms theta lambda M
>> a = (1 - theta/exp(lambda*M));
>> syms Q(t)
>> eqn = diff(Q,t) == Q*a;
cond = Q(0) == 400;
qSol(t) = dsolve(eqn,cond)
qSol(t) =
400*exp(-t*exp(-M*lambda)*(theta - exp(M*lambda)))

Sign in to comment.

More Answers (2)

Walter Roberson
Walter Roberson on 8 Apr 2018
Your image shows Q transpose multiplied by something, but your function has Q evaluated at something not multiplied.

Sam K
Sam K on 8 Apr 2018
Edited: Sam K on 8 Apr 2018
Hi walter,
Thank you for helping me out with this. I see your point. I guess that is part of my confusion on how to write the code. My equation for Q, as shown in the picture, is: dQ/dt = Q*a, where a is the parameters in the parentheses. I need to plot this equation based on the initial value of Q. I thought dsolve would be a good solver, but I must be doing something wrong with the code since I am a newbie to Matlab coding. Should I change the code as follows:
a = (1 - theta/exp(lambda*M));
syms Q(t) a
eqn = diff(Q,t) == Q*a;
cond = Q(0) == 400;
qSol(t) = dsolve(eqn,cond);

Categories

Find more on Mathematics in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!