// Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include "paddle2onnx/mapper/tensor/matmul_v2.h" #include #include #include namespace paddle2onnx { REGISTER_MAPPER(matmul_v2, MatmulV2Mapper) std::string MatmulV2Mapper::GetTrans(std::vector& input_info) { std::string castd_name = helper_->AutoCast( input_info[0].name, input_info[0].dtype, P2ODataType::FP32); std::vector perm = Arange(0, input_info[0].Rank()); std::swap(perm[perm.size() - 1], perm[perm.size() - 2]); auto transpose_node = helper_->MakeNode("Transpose", {castd_name}); AddAttribute(transpose_node, "perm", perm); return transpose_node->output(0); } void MatmulV2Mapper::Opset7() { auto input_x_info = GetInput("X"); auto input_y_info = GetInput("Y"); auto output_info = GetOutput("Out"); std::string input_x = input_x_info[0].name; if (trans_x_) { input_x = GetTrans(input_x_info); } std::string input_y = input_y_info[0].name; if (trans_y_) { input_y = GetTrans(input_y_info); } auto node = helper_->MakeNode("MatMul", {input_x, input_y}); helper_->AutoCast(node->output(0), output_info[0].name, P2ODataType::FP32, input_y_info[0].dtype); } } // namespace paddle2onnx