ReplaceAll and ReplaceRepeated Strange Behavior
- To: mathgroup at smc.vnet.net
 - Subject: [mg111460] ReplaceAll and ReplaceRepeated Strange Behavior
 - From: blamm64 <blamm64 at charter.net>
 - Date: Mon, 2 Aug 2010 07:04:48 -0400 (EDT)
 
Given the expression:
eff = (L*(-L*mu+dm*Pi*Cos[b]))/(dm*Pi*(dm*Pi*mu+L*Cos[b]))
After this I enter
eff /. {dm*Pi -> L/Tan[a]}
and get a result that does not, for a reason I cannot fathom and
believe to be a bug, replace one instance of dm*Pi. The result of the
evaluation yields
L*(-L*mu+L*Cos[b]*Cot[a])/(dm*Pi*(L*Cos[b]+L*mu*Cot[a]))
Precisely the same result occurs with eff //.{dm*Pi->L/Tan[a]}
Why is the one remaining dm*Pi not replaced with L/Tan[a]?
In fact, when define manually define eff1 as
eff1 = (L*(-L*mu + L*Cos[b]*Cot[b]))/(dm*Pi*(L*Cos[b]+L*mu*Cot[a]))
which is as you can see the result of the first ReplaceAll execution,
and then enter
eff1 /. {dm*Pi->L/Tan[a]}
Mathematica returns eff1 unaltered!
Now, I say this is a bug, so of course I'm probably missing something
and it isn't a bug.  I have to jump through syntactic hoops to get the
'right' answer:
FullSimplify[eff /.{dm*Pi->L/Tan[a]}]/.{dm*Pi->L/Tan[a]}//FullSimplify
and FullSimplify[eff /. {dm*Pi->L/Tan[a]} does no good either.
It is not at all obvious to me what I might be missing with such an
apparently simple replacement.
By the way, how do you guys copy input or output from Mathematica
notebook into this usergroup window?  I had to do all this by hand,
copy it from here into a notebook, and execute the notebook cells just
to make sure I was getting it correct.  I ran across this originally
when I was constructing a simple notebook for doing some Acme power
screw calculations.
-Brian Lamm
(Windows XP x64 Version 2003 SP2, Mathematica 7.0.1)