uint_fast16_t infOrNaN = expF64UI( uiA ) == 0x7FF;
uint_fast16_t subnormalOrZero = expF64UI( uiA ) == 0;
bool sign = signF64UI( uiA );
+ bool fracZero = fracF64UI( uiA ) == 0;
+ bool isNaN = isNaNF64UI( uiA );
+ bool isSNaN = softfloat_isSigNaNF64UI( uiA );
return
- ( sign && infOrNaN && fracF64UI( uiA ) == 0 ) << 0 |
- ( sign && !infOrNaN && !subnormalOrZero ) << 1 |
- ( sign && subnormalOrZero && fracF64UI( uiA ) ) << 2 |
- ( sign && subnormalOrZero && fracF64UI( uiA ) == 0 ) << 3 |
- ( !sign && infOrNaN && fracF64UI( uiA ) == 0 ) << 7 |
- ( !sign && !infOrNaN && !subnormalOrZero ) << 6 |
- ( !sign && subnormalOrZero && fracF64UI( uiA ) ) << 5 |
- ( !sign && subnormalOrZero && fracF64UI( uiA ) == 0 ) << 4 |
- ( isNaNF64UI( uiA ) && softfloat_isSigNaNF64UI( uiA )) << 8 |
- ( isNaNF64UI( uiA ) && !softfloat_isSigNaNF64UI( uiA )) << 9;
+ ( sign && infOrNaN && fracZero ) << 0 |
+ ( sign && !infOrNaN && !subnormalOrZero ) << 1 |
+ ( sign && subnormalOrZero && !fracZero ) << 2 |
+ ( sign && subnormalOrZero && fracZero ) << 3 |
+ ( !sign && infOrNaN && fracZero ) << 7 |
+ ( !sign && !infOrNaN && !subnormalOrZero ) << 6 |
+ ( !sign && subnormalOrZero && !fracZero ) << 5 |
+ ( !sign && subnormalOrZero && fracZero ) << 4 |
+ ( isNaN && isSNaN ) << 8 |
+ ( isNaN && !isSNaN ) << 9;
}