slow complex<double>'s with g++
Brian Budge
brian.budge@gmail.com
Fri Mar 3 19:25:00 GMT 2006
Hmmmm, yeah... I guess it shouldn't make an 8.5 time difference.
You're right, it should be a smaller difference. The squaring is 2
muls and an add vs 4 muls and 2 adds, so it should be less than twice
as fast when you include the other portion.
The instruction ordering might be more optimal also.
8.5 times though... weird.
Brian
On 3/3/06, Greg Buchholz <greg@sleepingsquirrel.org> wrote:
> Brian Budge wrote:
> > It may be that I'm missing something, but you appear to be computing
> > different things...
> >
> > Zi = 2.0*Zr*Zi + Ci;
> > Zr = Tr - Ti + Cr;
> >
> > vs
> >
> > Z = Z*Z + C;
> >
> > No doubt the 2.0 makes a difference...
>
> Hmm. I don't get what you are saying. Squaring a complex number
> like a+ib you get...
>
> (a+ib) * (a+ib)
> a*a + iab + iab - b*b
> (a*a - b*b) + i2ab
>
> ...Are you saying a multiplication instead of an addition is the cause?
> Yes, the C version is a little more optimized, but I was surprised at
> the factor of 8.5 time difference for gcc-4.1pre021006. I guess I
> expecting something small, say a 20-50% slowdown. And you get all of
> the speed back if you just use "-ffast-math". Maybe I'm just surprised
> that the optimizations that "-ffast-math" turns on do such a good job.
>
> Greg Buchholz
>
>
More information about the Gcc-help
mailing list