MNN/source/backend/arm82/Arm82WinogradOptFunc.hpp

35 lines
956 B
C++

//
// Arm82WinogradOptFunc.hpp
// MNN
//
// Created by MNN on 2018/10/08.
// Copyright © 2018, Alibaba Group Holding Limited
//
#if defined(__ANDROID__) || defined(__aarch64__)
#ifndef Arm82WinogradOptFunc_hpp
#define Arm82WinogradOptFunc_hpp
#include "Arm82Backend.hpp"
namespace MNN {
class Arm82WinogradFunction {
public:
typedef void (*TransformFunc)(const FLOAT16* srcBlock, FLOAT16* dstStart, size_t srcStep, size_t dstStep);
typedef void (*Int8TransFunc)(const int8_t* srcBlock, int8_t* dstStart, size_t srcStep, size_t dstStep);
/*Use the generator with interp 0.5*/
static TransformFunc chooseSourceTransform(int k, int w);
static TransformFunc chooseDestTransform(int k, int h);
static Int8TransFunc chooseInt8SourceTransform(int k, int w);
static TransformFunc chooseInt8DestTransform(int k, int h);
};
int Arm82MNNGetConvTileNumber();
} // namespace MNN
#endif /* Arm82WinogradOptFunc_hpp */
#endif