Optimization question

Optimization question

Hi,

Under what conditions, if any, will (current versions of) ifort assume associativity of arithmatic when working with floating point variables, and optimize away corrections such as those found in the Kahan summation algorithm: ( http://en.wikipedia.org/wiki/Compensated_summation )

i.e. Does the compiler assume associativity of arithmatic by default? When -O3 is passed? Is there a way to turn it off, if it's on?

Thanks,

Zaak

3 posts / 0 new
Last post
For more complete information about compiler optimizations, see our Optimization Notice.

The default will break Kahan summation except at -O0.  I would suggest setting "-assume protect_parens" so you will not require O0.  -fp-model source|precise also ought to work.

If the compiler ignored parentheses consistently (but in violation of the standard) the Kahan summation would collapse into an ordinary sum with no Kahan corrections, but with correct results at lower accuracy.

Thanks Tim,

Good to know.

Leave a Comment

Please sign in to add a comment. Not a member? Join today