问题是subst(a=b, c)
(或等效subst(b, a, c)
)只能在a
是c
的确切子表达式时才能进行替换。
ratsubst
(它参见)可以处理一些情况下,当a
不是一个确切的subexepression,但在这种情况下,它似乎并没有工作。
但我想你可以通过从另一个减去一个方程来得到你想要的结果。请注意0收益率a - c = b - d
。另请注意,我已经在另一个步骤(在%i7中)应用diff
运算符。此外,我已乘以%o7乘以r得到类似base
。
(%i1) depends (\rho,[t, r, \theta, z]); depends (V, [t, r, \theta, z]);
(%o1) [rho(t, r, theta, z)]
(%o2) [V(t, r, theta, z)]
(%i3) f_contin : diff (\rho, t) + diff (\rho*r*V[r], r)*(1/r) = 0;
drho d
r V ---- + r (-- (V)) rho + V rho
drho r dr dr r r
(%o3) ---- + ------------------------------------ = 0
dt r
(%i4) base : diff (V[b]*r*\rho, r) = 0;
drho d
(%o4) V r ---- + (-- (V)) r rho + V rho = 0
b dr dr b b
(%i5) V_sub : V[r] = V[b] + \epsilon*V[r];
(%o5) V = epsilon V + V
r r b
(%i6) subst (V_sub, f_contin);
drho drho d
(%o6) ---- + (r (epsilon V + V) ---- + r (-- (epsilon V + V)) rho
dt r b dr dr r b
+ (epsilon V + V) rho)/r = 0
r b
(%i7) %o6, nouns;
drho drho d d
(%o7) ---- + (r (epsilon V + V) ---- + r (epsilon (-- (V)) + -- (V)) rho
dt r b dr dr r dr b
+ (epsilon V + V) rho)/r = 0
r b
(%i8) expand (r*%o7 - base);
drho drho d
(%o8) r ---- + epsilon r V ---- + epsilon r (-- (V)) rho + epsilon V rho = 0
dt r dr dr r r
我想用base中给出的表达式替换%o6。即在倒数第二个表达式中将d/dr(rho * Vb * r)设置为零。 – Rhinocerotidae
即使subst(a,b,c)也不起作用。 – Rhinocerotidae
实际上,当第一个是方程时,“subst”可以有2个参数,例如, 'subst(foo = bar,myexpr)'。原来问题是OP给出的表达式不包含'base'的左边作为子表达式。 –