2018-08-31 02:11:44 -05:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#include "RiaWeightedGeometricMeanCalculator.h"
|
2018-09-05 08:11:03 -05:00
|
|
|
#include <cmath>
|
2018-08-31 02:11:44 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-08-31 02:11:44 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
TEST( RiaWeightedGeometricMeanCalculator, BasicUsage )
|
2018-08-31 02:11:44 -05:00
|
|
|
{
|
|
|
|
{
|
|
|
|
RiaWeightedGeometricMeanCalculator calc;
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_DOUBLE_EQ( 0.0, calc.aggregatedWeight() );
|
|
|
|
EXPECT_DOUBLE_EQ( 0.0, calc.weightedMean() );
|
2018-08-31 02:11:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
RiaWeightedGeometricMeanCalculator calc;
|
|
|
|
|
2020-11-06 03:46:38 -06:00
|
|
|
std::vector<double> values{ 30.0, 60.0 };
|
|
|
|
std::vector<double> weights{ 1.5, 3.5 };
|
2018-08-31 02:11:44 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( size_t i = 0; i < values.size(); i++ )
|
2018-08-31 02:11:44 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
calc.addValueAndWeight( values[i], weights[i] );
|
2018-08-31 02:11:44 -05:00
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
double expectedValue = std::pow( std::pow( 30.0, 1.5 ) * std::pow( 60.0, 3.5 ), 1 / ( 1.5 + 3.5 ) );
|
2018-08-31 02:11:44 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_DOUBLE_EQ( 5.0, calc.aggregatedWeight() );
|
|
|
|
EXPECT_NEAR( expectedValue, calc.weightedMean(), 1e-10 );
|
2018-08-31 02:11:44 -05:00
|
|
|
}
|
|
|
|
}
|
2018-09-03 02:56:06 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-09-03 02:56:06 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
TEST( RiaWeightedGeometricMeanCalculator, BigValues )
|
2018-09-03 02:56:06 -05:00
|
|
|
{
|
|
|
|
RiaWeightedGeometricMeanCalculator calc;
|
|
|
|
|
2020-11-06 03:46:38 -06:00
|
|
|
std::vector<double> values{ 3000000.0, 6000000.0, 1250000, 2200000 };
|
|
|
|
std::vector<double> weights{ 1.5, 3.5, 7, 5 };
|
2018-09-03 02:56:06 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( size_t i = 0; i < values.size(); i++ )
|
2018-09-03 02:56:06 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
calc.addValueAndWeight( values[i], weights[i] );
|
2018-09-03 02:56:06 -05:00
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
double expectedValue = std::pow( std::pow( 3000000.0, 1.5 ) * std::pow( 6000000.0, 3.5 ) *
|
|
|
|
std::pow( 1250000.0, 7 ) * std::pow( 2200000.0, 5 ),
|
|
|
|
1 / ( 1.5 + 3.5 + 7 + 5 ) );
|
2018-09-03 02:56:06 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_DOUBLE_EQ( 17.0, calc.aggregatedWeight() );
|
|
|
|
EXPECT_NEAR( expectedValue, calc.weightedMean(), 1e-8 );
|
2018-09-03 02:56:06 -05:00
|
|
|
}
|