Thursday, 28 December 2017

c - Why does MSVS not optimize away +0?

itemprop="text">

This href="https://stackoverflow.com/questions/9314534/why-does-changing-0-1f-to-0-slow-down-performance-by-10x">question
demonstrates a very interesting phenomenon: href="http://en.wikipedia.org/wiki/Denormal_number" rel="nofollow
noreferrer">denormalized floats slow down the code more than an order of
magnitude.



The behavior is well explained in the
accepted answer.
However, there is one comment, with currently 153 upvotes, that I cannot find
satisfactory answer to:





Why isn't the compiler just dropping the +/- 0 in this case?!? –

Michael
Dorgan




Side
note: I have the impression that 0f is/must be exactly representable (furthermore - it's
binary representation must be all zeroes), but can't find such a claim in the c11
standard. A quote proving this, or argument disproving this claim, would be most
welcome. Regardless, Michael's question is the main question
here.



/>

href="http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf" rel="nofollow
noreferrer">§5.2.4.2.2





An implementation may give zero and values that are not
floating-point
numbers (such as infinities and NaNs) a sign or may leave
them
unsigned.




Answer




The compiler cannot eliminate the addition of
a floating-point positive zero because it is not an identity operation. By IEEE 754
rules, the result of adding +0. to -0. is not -0.; it is
+0.



The compiler may eliminate the subtraction
of +0. or the addition of -0. because those are identity
operations.



For example, when I compile
this:



double foo(double x) {
return x + 0.; }


with
Apple GNU C 4.2.1 using -O3 on an Intel Mac, the resulting
assembly code contains addsd LC0(%rip), %xmm0. When I compile
this:



double foo(double x) {
return x - 0.; }


there
is no add instruction; the assembly merely returns its
input.



So, it is likely the code in the original
question contained an add instruction for this
statement:



y[i] = y[i] +
0;


but contained no
instruction for this
statement:



y[i] = y[i] -
0;


However, the first
statement involved arithmetic with subnormal values in y[i], so
it was sufficient to slow down the program.



No comments:

Post a Comment

php - file_get_contents shows unexpected output while reading a file

I want to output an inline jpg image as a base64 encoded string, however when I do this : $contents = file_get_contents($filename); print ...