Document float-to-qfloat16's rounding more carefully
Having just spent another afternoon wrapping my head around why this code is correct, I chose to save the next person (quite possibly me) faced with it the slowest half of the effort that went into doing so. This amends commit d3ff95dcb84861e8f42b480910d822b4ca8715b1 Change-Id: If0fcd2fb1fff5e99b1046d07039169e928fda9e4 Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io> Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
This commit is contained in:
parent
df0b092d08
commit
76bdbeb862
@ -1,6 +1,6 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2021 The Qt Company Ltd.
|
||||
** Copyright (C) 2022 The Qt Company Ltd.
|
||||
** Copyright (C) 2016 by Southwest Research Institute (R)
|
||||
** Contact: http://www.qt-project.org/legal
|
||||
**
|
||||
@ -275,8 +275,12 @@ inline qfloat16::qfloat16(float f) noexcept
|
||||
if (mantissa) // keep nan from truncating to inf
|
||||
mantissa = qMax(1U << shift, mantissa);
|
||||
} else {
|
||||
// round half to even
|
||||
// Round half to even. First round up by adding one in the most
|
||||
// significant bit we'll be discarding:
|
||||
mantissa += round;
|
||||
// If the last bit we'll be keeping is now set, but all later bits are
|
||||
// clear, we were at half and shouldn't have rounded up; decrement will
|
||||
// clear this last kept bit. Any later set bit hides the decrement.
|
||||
if (mantissa & (1 << shift))
|
||||
--mantissa;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user