aboutsummaryrefslogtreecommitdiff
path: root/tests/validation/fixtures/ElementWiseUnaryFixture.h
diff options
context:
space:
mode:
Diffstat (limited to 'tests/validation/fixtures/ElementWiseUnaryFixture.h')
-rw-r--r--tests/validation/fixtures/ElementWiseUnaryFixture.h15
1 files changed, 9 insertions, 6 deletions
diff --git a/tests/validation/fixtures/ElementWiseUnaryFixture.h b/tests/validation/fixtures/ElementWiseUnaryFixture.h
index f414daf8f7..f8e0dfa75e 100644
--- a/tests/validation/fixtures/ElementWiseUnaryFixture.h
+++ b/tests/validation/fixtures/ElementWiseUnaryFixture.h
@@ -55,17 +55,20 @@ protected:
template <typename U>
void fill(U &&tensor, int i, DataType data_type)
{
+ using FloatType = typename std::conditional < std::is_same<T, half>::value || std::is_floating_point<T>::value, T, float >::type;
+ using FloatDistributionType = typename std::conditional<std::is_same<T, half>::value, arm_compute::utils::uniform_real_distribution_fp16, std::uniform_real_distribution<FloatType>>::type;
+
switch(_op)
{
case ElementWiseUnary::EXP:
{
- std::uniform_real_distribution<> distribution(-1.0f, 1.0f);
+ FloatDistributionType distribution{ FloatType(-1.0f), FloatType(1.0f) };
library->fill(tensor, distribution, i);
break;
}
case ElementWiseUnary::RSQRT:
{
- std::uniform_real_distribution<> distribution(1.0f, 2.0f);
+ FloatDistributionType distribution{ FloatType(1.0f), FloatType(2.0f) };
library->fill(tensor, distribution, i);
break;
}
@@ -82,7 +85,7 @@ protected:
}
case DataType::F32:
{
- std::uniform_real_distribution<float> distribution(-2.0f, 2.0f);
+ FloatDistributionType distribution{ FloatType(-2.0f), FloatType(2.0f) };
library->fill(tensor, distribution, i);
break;
}
@@ -99,19 +102,19 @@ protected:
}
case ElementWiseUnary::LOG:
{
- std::uniform_real_distribution<> distribution(0.0000001f, 100.0f);
+ FloatDistributionType distribution{ FloatType(0.0000001f), FloatType(100.0f) };
library->fill(tensor, distribution, i);
break;
}
case ElementWiseUnary::SIN:
{
- std::uniform_real_distribution<> distribution(-100.00f, 100.00f);
+ FloatDistributionType distribution{ FloatType(-100.00f), FloatType(100.00f) };
library->fill(tensor, distribution, i);
break;
}
case ElementWiseUnary::ROUND:
{
- std::uniform_real_distribution<> distribution(100.0f, -100.0f);
+ FloatDistributionType distribution{ FloatType(100.0f), FloatType(-100.0f) };
library->fill(tensor, distribution, i);
break;
}