From 772862dfaf3be06340216ace02c0106e46ac50bc Mon Sep 17 00:00:00 2001 From: Colin Xu Date: Fri, 10 Jan 2025 09:45:39 +0800 Subject: [PATCH] Optimize CPU and Memory performance for Resize linear mode parser Revise based on reviewer comments. Rebase to develop HEAD. Signed-off-by: Colin Xu --- src/onnx/parse_resize.cpp | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/src/onnx/parse_resize.cpp b/src/onnx/parse_resize.cpp index 1cf61db6739..45fdc8f2b80 100644 --- a/src/onnx/parse_resize.cpp +++ b/src/onnx/parse_resize.cpp @@ -99,24 +99,21 @@ calc_neighbor_points(const std::vector>>& v if(n_bits >= std::numeric_limits::digits) { - throw std::runtime_error("Shape dimension " + std::to_string(n_bits) + " exceeds " + - std::to_string(std::numeric_limits::digits)); + MIGRAPHX_THROW("PARSE_RESIZE: Shape dimension " + std::to_string(n_bits) + " exceeds " + + std::to_string(std::numeric_limits::digits)); } for(std::size_t val = 0; val < (std::size_t{1} << n_bits); val++) { std::bitset::digits> bits_val = val; std::vector indices(n_bits); - transform( - range(m_elements), std::back_inserter(vec_ind), [&](const std::size_t& i_element) { - transform(vvv_ind, - range(n_bits), - indices.begin(), - [&](const auto& vv_ind, const std::size_t& bit) { - return vv_ind[bits_val[bit]][i_element]; - }); - return in_s.index(indices); - }); + transform(range(m_elements), std::back_inserter(vec_ind), [&](std::size_t i_element) { + transform( + vvv_ind, range(n_bits), indices.begin(), [&](const auto& vv_ind, std::size_t bit) { + return vv_ind[bits_val[bit]][i_element]; + }); + return in_s.index(indices); + }); } return vec_ind;