mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-08 23:23:01 -06:00
d36bf92b55
* Use regression curve icon in grid cross plot * #10481 Use ceil and floor when adjusting precision for ranges
77 lines
2.1 KiB
C++
77 lines
2.1 KiB
C++
#include "gtest/gtest.h"
|
|
|
|
#include "RiaNumericalTools.h"
|
|
|
|
TEST( RiaNumericalTools, LogTenFunctions )
|
|
{
|
|
{
|
|
// Negative values will return zero
|
|
double value = -0.0015;
|
|
|
|
auto exponentCeil = RiaNumericalTools::computeTenExponentCeil( value );
|
|
EXPECT_EQ( 0.0f, exponentCeil );
|
|
|
|
auto exponentFloor = RiaNumericalTools::computeTenExponentFloor( value );
|
|
EXPECT_EQ( 0.0f, exponentFloor );
|
|
}
|
|
|
|
{
|
|
double value = 0.15;
|
|
|
|
auto exponentCeil = RiaNumericalTools::computeTenExponentCeil( value );
|
|
EXPECT_EQ( 0.0f, exponentCeil );
|
|
|
|
auto exponentFloor = RiaNumericalTools::computeTenExponentFloor( value );
|
|
EXPECT_EQ( -1.0f, exponentFloor );
|
|
}
|
|
|
|
{
|
|
double value = 1.5;
|
|
|
|
auto exponentCeil = RiaNumericalTools::computeTenExponentCeil( value );
|
|
EXPECT_EQ( 1.0f, exponentCeil );
|
|
|
|
auto exponentFloor = RiaNumericalTools::computeTenExponentFloor( value );
|
|
EXPECT_EQ( 0.0f, exponentFloor );
|
|
}
|
|
|
|
{
|
|
double value = 15;
|
|
|
|
auto exponentCeil = RiaNumericalTools::computeTenExponentCeil( value );
|
|
EXPECT_EQ( 2.0f, exponentCeil );
|
|
|
|
auto exponentFloor = RiaNumericalTools::computeTenExponentFloor( value );
|
|
EXPECT_EQ( 1.0f, exponentFloor );
|
|
}
|
|
}
|
|
|
|
TEST( RiaNumericalTools, RoundToSignificant )
|
|
{
|
|
struct TestValues
|
|
{
|
|
double value;
|
|
double expectedCeil;
|
|
double expectedFloor;
|
|
};
|
|
|
|
TestValues testValues[] = {
|
|
{ -0.00152, -0.0015, -0.0016 },
|
|
{ -15, -15, -15 },
|
|
{ -159, -150, -160 },
|
|
{ 0.02, 0.02, 0.02 },
|
|
{ 152, 160.0, 150.0 },
|
|
{ 1520, 1600.0, 1500.0 },
|
|
{ 15913, 16000.0, 15000.0 },
|
|
};
|
|
|
|
for ( const auto& testValue : testValues )
|
|
{
|
|
auto valueCeil = RiaNumericalTools::roundToNumSignificantDigitsCeil( testValue.value, 2 );
|
|
EXPECT_EQ( testValue.expectedCeil, valueCeil );
|
|
|
|
auto valueFloor = RiaNumericalTools::roundToNumSignificantDigitsFloor( testValue.value, 2 );
|
|
EXPECT_EQ( testValue.expectedFloor, valueFloor );
|
|
}
|
|
}
|