Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Problem with BOOST_CHECK_CLOSE_FRACTION

I'm using the Boost::Test library, and I am trying to check if an actual percent value is close to the expected value:

BOOST_CHECK_CLOSE_FRACTION(
    items[i].ExpectedPercent,
    items[i].ActualCount / totalCount,
    0.05);

For some reason this check fails even when the values are close enough:

difference between items[i].ExpectedPercent{0.40000000000000002}
   and items[i].ActualCount / totalReturned{0.42999999999999999}
                                    exceeds 0.050000000000000003

Is this a problem with Boost or a problem with how I am using Boost?

like image 234
iano Avatar asked Jan 21 '10 23:01

iano


2 Answers

After some testing, it turns out that the documentation for BOOST_CHECK_CLOSE_FRACTION is incorrect. The tolerance should be specified as a fraction of the expected value.

So, TFAE:

BOOST_CHECK(abs(x - y) < (min(x, y) * 0.1));
BOOST_CHECK_CLOSE(x, y, 10);
BOOST_CHECK_CLOSE_FRACTION(x, y, 0.1);
like image 141
iano Avatar answered Oct 11 '22 03:10

iano


It is a problem with how you are using boost.

The last argument is a percent tolerance, not an absolute variance value. 5% of 0.4 is 0.02.

like image 21
Omnifarious Avatar answered Oct 11 '22 03:10

Omnifarious