aboutsummaryrefslogtreecommitdiff
path: root/examples/gemm_tuner/CommonGemmExampleOptions.cpp
diff options
context:
space:
mode:
authorEren Kopuz <eren.kopuz@arm.com>2020-06-09 15:37:43 +0100
committerSiCong Li <sicong.li@arm.com>2020-06-18 10:18:25 +0000
commit350099ea9868aa6ec84d082fe6d5962fafc86aa4 (patch)
tree9c4be974b045155e0c5007f9c82c1ded2335c4d9 /examples/gemm_tuner/CommonGemmExampleOptions.cpp
parent6ad60af32af672f27e152bf37790cd0c0c4db696 (diff)
downloadComputeLibrary-350099ea9868aa6ec84d082fe6d5962fafc86aa4.tar.gz
COMPMID-3451: Add support for F16 in Gemm Tuner
- Comand line option added to specify F32 or F16 Change-Id: Ibd8a5c8d013a6dff601aa773e94946de1ff6e280 Signed-off-by: Eren Kopuz <eren.kopuz@arm.com> Reviewed-on: https://review.mlplatform.org/c/ml/ComputeLibrary/+/3322 Tested-by: Arm Jenkins <bsgcomp@arm.com> Reviewed-by: SiCong Li <sicong.li@arm.com> Reviewed-by: Gian Marco Iodice <gianmarco.iodice@arm.com> Reviewed-by: Georgios Pinitas <georgios.pinitas@arm.com> Comments-Addressed: Arm Jenkins <bsgcomp@arm.com>
Diffstat (limited to 'examples/gemm_tuner/CommonGemmExampleOptions.cpp')
-rw-r--r--examples/gemm_tuner/CommonGemmExampleOptions.cpp24
1 files changed, 18 insertions, 6 deletions
diff --git a/examples/gemm_tuner/CommonGemmExampleOptions.cpp b/examples/gemm_tuner/CommonGemmExampleOptions.cpp
index a93d0191b3..9e23d5596b 100644
--- a/examples/gemm_tuner/CommonGemmExampleOptions.cpp
+++ b/examples/gemm_tuner/CommonGemmExampleOptions.cpp
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2019 ARM Limited.
+ * Copyright (c) 2019-2020 ARM Limited.
*
* SPDX-License-Identifier: MIT
*
@@ -34,6 +34,7 @@ using namespace utils;
os << "N : " << common_params.N << std::endl;
os << "K : " << common_params.K << std::endl;
os << "B : " << common_params.B << std::endl;
+ os << "Data type : " << common_params.data_type << std::endl;
return os;
}
@@ -42,22 +43,33 @@ CommonGemmExampleOptions::CommonGemmExampleOptions(CommandLineParser &parser)
M(parser.add_positional_option<SimpleOption<size_t>>("M", 100)),
N(parser.add_positional_option<SimpleOption<size_t>>("N", 100)),
K(parser.add_positional_option<SimpleOption<size_t>>("K", 50)),
- B(parser.add_positional_option<SimpleOption<size_t>>("B", 1))
+ B(parser.add_positional_option<SimpleOption<size_t>>("B", 1)),
+ data_type()
{
+ const std::set<DataType> supported_data_types
+ {
+ DataType::F16,
+ DataType::F32,
+ };
+
+ data_type = parser.add_option<EnumOption<DataType>>("type", supported_data_types, DataType::F32);
+
help->set_help("Show this help message.");
M->set_help("Number of lhs matrix rows.");
N->set_help("Number of rhs matrix columns.");
K->set_help("Number of lhs matrix columns/rhs matrix rows.");
B->set_help("Batch size.");
+ data_type->set_help("Data type to use");
}
CommonGemmExampleParams consume_common_gemm_example_parameters(const CommonGemmExampleOptions &options)
{
CommonGemmExampleParams common_params;
- common_params.M = options.M->value();
- common_params.N = options.N->value();
- common_params.K = options.K->value();
- common_params.B = options.B->value();
+ common_params.M = options.M->value();
+ common_params.N = options.N->value();
+ common_params.K = options.K->value();
+ common_params.B = options.B->value();
+ common_params.data_type = options.data_type->value();
return common_params;
}
} // namespace gemm_tuner