Skip to main content

PWR044: Avoid unnecessary floating-point data conversions involving constants

Issue

Mixing float type value with double type constants results in unnecessary data conversions.

Actions

Instead of the double constant, explicitly specify a float constant by appending the constant with f.

Relevance

According to the C/C++ standard, binary operators (+, -, *, /, %, <, >, <=, >=, ==, !=) involving a float value and a double constant can often result in unnecessary data conversions: the float value is first promoted to a double, then the binary operator is evaluated. Most of the time this is not the intended behavior.

Code example

Have a look at the following code:

__attribute__((const)) float example(float a) {
return a * 2.2;
}

During the evaluation of the expression a * 2.2, the following happens:

  • First, the floating point in variable a is promoted from float to double;

  • Second, multiplication is performed using doubles;

  • And third, the resulting value is converted back to float.

In this particular example, there are two unnecessary conversions: one is promoting a to double, and the other is promoting the result of multiplication a * 2.2 back to float. The solution is to use a float constant 2.2f instead of the double constant 2.2.

__attribute__((const)) float example(float a) {
return a * 2.2f;
}

References