/******************************************************************************** * Copyright (c) 2023 CEA-List * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License 2.0 which is available at * http://www.eclipse.org/legal/epl-2.0. * * SPDX-License-Identifier: EPL-2.0 * ********************************************************************************/ #include <algorithm> #include <string> #include <vector> #include "aidge/operator/MatMul.hpp" #include "aidge/utils/Types.h" #include "aidge/utils/ErrorHandling.hpp" const std::string Aidge::MatMul_Op::Type = "MatMul"; void Aidge::MatMul_Op::computeOutputDims() { if (!getInput(0) || !getInput(1)) { AIDGE_THROW_OR_ABORT(std::runtime_error, "Missing input. Cannot compute output dimensions for MatMul Operator."); } if (getInput(0)->empty() && getInput(1)->empty()) { // both inputs are scalar mOutputs[0]->resize({}); } else if (!getInput(0)->empty() && !getInput(1)->empty()) { std::vector<std::size_t> dims0 = getInput(0)->dims(); std::vector<std::size_t> dims1 = getInput(1)->dims(); if (dims0.size() == 1) { dims0.insert(dims0.cbegin(), 1); } if (dims1.size() == 1) { dims1.push_back(1); } const std::size_t dims_size = std::max(dims0.size(), dims1.size()); if (dims0.size() > dims1.size()) { dims1.insert(dims1.cbegin(), dims0.begin(), dims0.end() - dims1.size()); } else if (dims1.size() > dims0.size()) { dims0.insert(dims0.cbegin(), dims1.begin(), dims1.end() - dims0.size()); } AIDGE_ASSERT(dims0[dims_size-1] == dims1[dims_size-2], "Incompatible matrices sizes."); std::vector<std::size_t> outDims = std::vector<std::size_t>(dims_size-2, 1); for (std::size_t i = 0; i < dims_size-2; ++i) { AIDGE_ASSERT((dims0[i] == dims1[i]) || (dims0[i] == 1) || (dims1[i] == 1), "Bad vector dimension."); outDims[i] = std::max(dims0[i], dims1[i]); } // keep second-to-last dimension of dims0 if (dims0.size() > 1) outDims.push_back(dims0[dims_size-2]); // keep last dimension of dims1 if (dims1.size() > 1) outDims.push_back(dims1[dims_size-1]); mOutputs[0]->resize(outDims); } }