Hi, I have a function as
Z = (T-Tp)*lambdam*u + ((p*(h^2)*gammaw)/k2) + ((p^2)*(h^2)*l*alpha*r*gammac)/(D*u*C) + (ro*p*(l^2)*u*gammae)/D;
obviously, this function is composed of four terms. I want to divide Z by h (which is a positive, non-zero variable) and then take the derivative of Z with respect to h and put it equal to 0 and get h. so I write the below code:
dh = diff(Z/h,h);
h1 = solve (dh==0,h);
Now I get
h1 = (u*(C*k2*p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))^(1/2))/(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p)
but if I divide Z by h manually and enter that from the beginning, and then take the derivative, I'll get
h1 = u*((C*k2*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))/(p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)))^(1/2)
which is consistent with what I get when I do everything manually. Why this happens? what am I missing?

 채택된 답변

Torsten
Torsten 2022년 4월 9일

0 개 추천

Did you try
pretty(h1)
and/or
isequal(h1,h2)
( I named the second term h2 ) ?
I think they are equal - at least in h1 you can divide
(C*D*gammaw*u + alpha*gammac*k2*l*p*r)
by
(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p)
to get rid of the quotient .

댓글 수: 9

Sherwin
Sherwin 2022년 4월 9일
편집: Sherwin 2022년 4월 9일
I ran the isequal function and I got 0. If you look at them they are not equal. the first one has a sqrt just on the numerator but in the second one the whole fraction is under sqrt and I am sure that the second one is correct.
h1 = (u*(C*k2*p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)*
(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))^(1/2))/
(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p)
= u*(C*k2*p)^(1/2)*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)^(1/2)*
(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D)^(1/2)/
((alpha*gammac*k2*l*r*p + C*gammaw*u*D)*p)
= u*(C*k2)^(1/2)*p^(1/2)*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)^(1/2)*
(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D)^(1/2)/
((alpha*gammac*k2*l*r*p + C*gammaw*u*D)*p)
= u*(C*k2)^(1/2)*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D)^(1/2)/
(p*(alpha*gammac*k2*l*r*p + C*gammaw*u*D))^(1/2)
= u*((C*k2*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))/
(p*(alpha*gammac*k2*l*r*p + C*gammaw*u*D)))^(1/2)
Sherwin
Sherwin 2022년 4월 9일
편집: Sherwin 2022년 4월 9일
Thank you so much for your help. However, when I run isequal on your first term:
(u*(C*k2*p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)*gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))^(1/2))/(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p)
and your last term:
u*((C*k2*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))/(p*(alpha*gammac*k2*l*r*p + C*gammaw*u*D)))^(1/2)
I still get 0!!! I don't know what I am missing here.
What happens if you use isAlways instead?
syms t
expression1 = sin(t).^2+cos(t).^2;
expression2 = 1;
isAlways(expression1 == expression2)
ans = logical
1
Torsten
Torsten 2022년 4월 10일
Steven Lord is right: isAlways instead of isequal has to be used.
Take a look at
Test Symbolic Expressions for Equality
under
for the difference between the two.
Sherwin
Sherwin 2022년 4월 10일
편집: Sherwin 2022년 4월 10일
isAlways returns 0 as well. Do you get 1 when you run this?
h1 = (u*(C*k2*p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))^(1/2))/(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p);
h2 = u*((C*k2*(gammae*p*ro*l^2 + T*lambdam*D - Tp*lambdam*D))/(p*(C*D*gammaw*u + alpha*gammac*k2*l*p*r)))^(1/2);
isAlways(h1==h2)
Torsten
Torsten 2022년 4월 10일
편집: Torsten 2022년 4월 10일
Do you get 1 when you run this?
No. Maybe cancellation of
(alpha*gammac*k2*l*r*p^2 + C*gammaw*u*D*p)^(1/2)
makes that the two terms are not always the same.
But I wouldn't agonize over this. Sometimes humans are still more clever than Symbolic Toolboxes.
Sherwin
Sherwin 2022년 4월 10일
But you see that they are equal, right?
Torsten
Torsten 2022년 4월 10일
Under certain assumptions.
When I "show" that h1 = h2, I use e.g. (a*b)^(1/2) = a^(1/2)*b^(1/2). This only holds if a,b are real (not complex) numbers and non-negative.
I suspect that if such assumptions are necessary, MATLAB does not classify two expressions as equal.
But that's a question for the programmers of the symbolic toolbox - I cannot answer it.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

태그

질문:

2022년 4월 9일

댓글:

2022년 4월 10일

Community Treasure Hunt

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

Start Hunting!

Translated by