dharr

Dr. David Harrington

9102 Reputation

22 Badges

21 years, 229 days
University of Victoria
Professor or university staff
Victoria, British Columbia, Canada

Social Networks and Content at Maplesoft.com

Maple Application Center
I am a retired professor of chemistry at the University of Victoria, BC, Canada. My research areas are electrochemistry and surface science. I have been a user of Maple since about 1990.

MaplePrimes Activity


These are replies submitted by dharr

@mmcdara You are pobably right, but the OP titled the question with "first oder ode", which I took at face value.

@salim-barzani OK, I understand. Here's how to automate the substitutions. But it is not a solution. Each of your pdes needs some individual attention, to find independent equations. For most cases, the expx in f are the same exps that survive after substituting into the pde, but if thay get messed up, then one needs to work harder, as here. I don't know the general solution to this issue. It may be that simplification with side relations can work; I'll give this some more thought.

Dr.D-pde.mw

I guess my alien powers have deserted me!

@salim-barzani If you only want the variables, and not the more complicated expression, use indets(something, name).

I think this is what you are asking, but if it is not, please be more specific about what you want.

@mmcdara I'm not sure of the point you are making. If it is just that you have to be careful of branch cut issues, I agree. In this case the solve strategy I used to answer the OP works - if both solutions had been real there would have been less of a problem.

(Strangely, the worksheet is not displaying, in a way I haven't seen before.)

Download DE_solve.mw

Perhaps the simplified solution is not correct? When I substitute in, I don't find everything zero. The nonzero equation is very similar to the rifsimp expression, but with 4 instead of 8.

restart:

with(DETools):with(PDEtools):declare(z(x,y)):

z(x, y)*`will now be displayed as`*z

PDE1 := y*diff(z(x,y), x$3) - x*diff(z(x,y),x,y$2) = diff(z(x,y),y$2) - y*diff(z(x,y), y);

y*(diff(diff(diff(z(x, y), x), x), x))-x*(diff(diff(diff(z(x, y), x), y), y)) = diff(diff(z(x, y), y), y)-y*(diff(z(x, y), y))

PDE2 := 2*x*y*diff(z(x,y),x$3)*diff(z(x,y),x,y$2) + x*(diff(z(x,y),x$3))^2 + x*y^2*(diff(z(x,y),x,y$2))^2 = 0;

2*x*y*(diff(diff(diff(z(x, y), x), x), x))*(diff(diff(diff(z(x, y), x), y), y))+x*(diff(diff(diff(z(x, y), x), x), x))^2+x*y^2*(diff(diff(diff(z(x, y), x), y), y))^2 = 0

PDE3 := y*diff(z(x,y),x,y$2) - x*w(x,y) + 2*x^2*y*z(x,y)^2 = 0;

y*(diff(diff(diff(z(x, y), x), y), y))-x*w(x, y)+2*x^2*y*z(x, y)^2 = 0

PDE4 := diff(z(x,y), y$2) - y*diff(z(x,y),y) + 2*x^2*y*w(x,y)^2 = x*w(x,y);

diff(diff(z(x, y), y), y)-y*(diff(z(x, y), y))+2*x^2*y*w(x, y)^2 = x*w(x, y)

sys := [PDE1, PDE2, PDE3, PDE4]:

Should simplify to

simple := {diff(z(x,y), x$3) = 0, diff(z(x,y),x,y) = 0, diff(z(x,y),y$2) = y*diff(z(x,y),y), w(x,y) = 2*x*y*z(x,y)^2};

 

{diff(diff(diff(z(x, y), x), x), x) = 0, diff(diff(z(x, y), x), y) = 0, diff(diff(z(x, y), y), y) = y*(diff(z(x, y), y)), w(x, y) = 2*x*y*z(x, y)^2}

eval(sys, simple);

[0 = 0, 0 = 0, 0 = 0, 8*x^4*y^3*z(x, y)^4 = 2*x^2*y*z(x, y)^2]

dsubs(simple,sys);

[0 = 0, 0 = 0, 0 = 0, 8*x^4*y^3*z(x, y)^4 = 2*x^2*y*z(x, y)^2]

rif := rifsimp(sys, [[w], [z]], indep = [x,y]);

table( [( Case ) = [[z(x, y)*(8*z(x, y)^2*y^2*x^2-1) = 0, diff(z(x, y), x), "false split"]], ( Solved ) = [w(x, y) = 0, z(x, y) = 0] ] )

 

NULL

Download demo_question.mw

@mmcdara But you have ode := diff(phi(x), x) : sqrt(1-phi(x)): instead of ode := diff(phi(x), x) = sqrt(1-phi(x)): Then the numeric one does agree with one of the two solutions.

@mmcdara Very nice, vote up. You probably meant B[j[]] not B[j] (as for theta).

@salim-barzani If you need to, you can use assuming n::posint to assume n is a positive integer, assuming n::positive or assuming n>0 for n positive.

Does simplify give you what you want?

In general, Maple will not assume n is a positive integer unless you tell it. (Not needed here, though.)

Internally z is Float(16,-3); op(0,z) gives Float and op(z) gives 16,-3. lprint(z) gives .16e-1, which I assume is some sort of canonical form.

So the 0.016 is just for display. While it might be possible to recreate that display routine, probably sprinf gives you the ultimate in control for this.

@scottwr For inner nested loops, use print for the things you want to see. So in this case just use print(x*y) instead of x*y. 

@mmcdara That was my comment. In the paper they condense products of subscripted symbols into single subscripted symbols, where the new subscripts are the set union of the subscripts of the factors. After looking further at the paper, I think it is a bad idea to do this since one loses information.

@Carl Love True, but the standard way to abbreviate input for anything nontrivial would be with diff_table. For example

declare(u(x));
U:=diff_table(u(x));

then U[x,x] is used to abbreviate diff(u(x),x,x) and U[] for u(x).

@FZ Sorry, I don't understand what they are doing.

@FZ Please expand the image. As far as I can see, they use the first integral, which didn't work for your case unless you know the form for the integrating factor.

First 23 24 25 26 27 28 29 Last Page 25 of 99