2020-11-05 16:41:56 +08:00
|
|
|
//
|
|
|
|
// OpCommonUtils.hpp
|
|
|
|
// MNN
|
|
|
|
//
|
|
|
|
// Created by MNN on 2020/03/08.
|
|
|
|
// Copyright © 2018, Alibaba Group Holding Limited
|
|
|
|
//
|
|
|
|
|
2020-03-08 10:20:18 +08:00
|
|
|
#ifndef OpCommonUtils_hpp
|
|
|
|
#define OpCommonUtils_hpp
|
|
|
|
#include <MNN/Tensor.hpp>
|
2020-11-05 16:41:56 +08:00
|
|
|
#include "TensorUtils.hpp"
|
2020-03-08 10:20:18 +08:00
|
|
|
namespace MNN {
|
2020-03-09 18:02:01 +08:00
|
|
|
struct Op;
|
2020-03-08 10:20:18 +08:00
|
|
|
class MNN_PUBLIC OpCommonUtils {
|
|
|
|
public:
|
2020-11-05 16:41:56 +08:00
|
|
|
static void broastCastComputeDim(int* dims, int* stride, int* iStride0, int* iStride1, const Tensor* input0,
|
|
|
|
const Tensor* input1, const Tensor* output);
|
2020-03-09 18:02:01 +08:00
|
|
|
static std::vector<std::tuple<int, int, int>> computeReduceDims(const std::vector<Tensor*>& inputs, const Op* op);
|
2020-11-05 16:41:56 +08:00
|
|
|
static void unravelIndexHelper(std::vector<int32_t>& coordinate, const std::vector<int32_t>& mod, int size,
|
|
|
|
int indice);
|
|
|
|
static int computeStride(int32_t* strides, const int* shape, int length);
|
|
|
|
static void* blobData(const Op* op);
|
|
|
|
|
|
|
|
static bool canBlitFast(const Tensor::InsideDescribe::Region& region, const Tensor* dest, int pack = 4);
|
|
|
|
static void turnToPackRegion(const Tensor::InsideDescribe::Region& region, Tensor::InsideDescribe::Region& c4Region,
|
|
|
|
const Tensor* dest, int pack = 4);
|
|
|
|
|
|
|
|
// Inside - Axis - Outside
|
|
|
|
typedef std::tuple<int, int, int> SPLITS;
|
|
|
|
static bool canBlitFast(const Tensor::InsideDescribe::Region& region, const SPLITS& srcSplits,
|
|
|
|
const SPLITS& dstSplits, int pack = 4);
|
|
|
|
static void turnToPackRegion(const Tensor::InsideDescribe::Region& region, Tensor::InsideDescribe::Region& c4Region,
|
|
|
|
const SPLITS& srcSplits, const SPLITS& dstSplits, int pack = 4);
|
2021-04-08 15:34:23 +08:00
|
|
|
static bool opNeedContent(int type, int index);
|
|
|
|
|
|
|
|
// For lowp CPU Backend
|
|
|
|
static bool opCompabilityForLowp(const Op* op);
|
|
|
|
static std::pair<bool,DataType> getQuantInfo(const std::vector<Tensor*>& inputs);
|
2021-06-11 17:17:13 +08:00
|
|
|
|
|
|
|
// sparse common functions
|
|
|
|
static void statisticWeightSparsity(size_t& weightNNZElement, size_t& weightBlockNumber, const float* data, size_t h, size_t l, int sparseBlockOC);
|
|
|
|
static void fillRandValueAsSparsity(size_t& weightNNZElement, size_t& weightBlockNumber, float* data, int oc, int reduceDimLength, float sparsity, int sparseBlockOC);
|
|
|
|
|
|
|
|
static bool checkAllZeros(const float* source, size_t rowDimLength, int blockRow, int blockCol);
|
|
|
|
|
|
|
|
|
2020-03-08 10:20:18 +08:00
|
|
|
};
|
2020-11-05 16:41:56 +08:00
|
|
|
} // namespace MNN
|
2020-03-08 10:20:18 +08:00
|
|
|
|
|
|
|
#endif
|