| // yala is pleased to support the open source community by making ncnn available. | |
| // | |
| // | |
| // Copyright (C) 2022 yala <zhaojunchao@loongson.cn>;<junchao82@qq.com>. All rights reserved. | |
| // Licensed under the BSD 3-Clause License (the "License"); you may not use this file except | |
| // in compliance with the License. You may obtain a copy of the License at | |
| // | |
| // https://opensource.org/licenses/BSD-3-Clause | |
| // | |
| // 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. | |
| static void conv1x1s1_sgemm_lsx(const Mat& bottom_blob, Mat& top_blob, const Mat& kernel, const Mat& _bias, const Option& opt) | |
| { | |
| int w = bottom_blob.w; | |
| int h = bottom_blob.h; | |
| const int size = w * h; | |
| Mat bottom_im2col = bottom_blob; | |
| bottom_im2col.w = size; | |
| bottom_im2col.h = 1; | |
| im2col_sgemm_lsx(bottom_im2col, top_blob, kernel, _bias, opt); | |
| } | |