From ca89be0188474acb3e14009003d060fe5b3685f2 Mon Sep 17 00:00:00 2001 From: Wanming Lin Date: Wed, 17 Jul 2024 17:05:43 +0800 Subject: [PATCH] [WebNN EP] Add outputDataType option for the ArgMax/ArgMin ops --- .../providers/webnn/builders/impl/argmax_min_op_builder.cc | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/onnxruntime/core/providers/webnn/builders/impl/argmax_min_op_builder.cc b/onnxruntime/core/providers/webnn/builders/impl/argmax_min_op_builder.cc index f8b77b6350a76..1330a3e354871 100644 --- a/onnxruntime/core/providers/webnn/builders/impl/argmax_min_op_builder.cc +++ b/onnxruntime/core/providers/webnn/builders/impl/argmax_min_op_builder.cc @@ -50,6 +50,11 @@ Status ArgMaxMinOpBuilder::AddToModelBuilderImpl(ModelBuilder& model_builder, options.set("axes", axes); options.set("keepDimensions", keep_dims == 1); options.set("selectLastIndex", select_last_index == 1); + // TODO: use WebNN's opSupportLimits API to check the backend's supported output data types. + // If the backend doesn't support int64 output, we should use default int32 output data type + // then do a type casting (int32 -> int64) for the output. Refer to the CoreML EP for how to + // support int64 output. + options.set("outputDataType", "int64"); emscripten::val output = emscripten::val::object(); const auto& op_type = node.OpType();