3#if _MSC_VER >= 1900 && defined(_M_X64)
5#include "ComputationalGraph.h"
11 enum EUpsampleMode : int32_t
13 EUpsampleMode_Nearest = 0,
14 EUpsampleMode_Bilinear,
15 EUpsampleMode_Bicubic,
19 class FL_EXPORT CComputationalGraphUpsample :
public CComputationalGraph<T>
22 CComputationalGraphUpsample();
25 CComputationalGraphUpsample(
const CComputationalGraphUpsample<T>& cg);
28 CComputationalGraphUpsample(
const CComputationalBase<T>& cbOperand, T tScaleX, T tScaleY, EUpsampleMode eMode = EUpsampleMode_Nearest,
bool bAlignCorner =
false);
29 CComputationalGraphUpsample(
const CComputationalBase<T>& cbOperand, int64_t i64Width, int64_t i64Height, EUpsampleMode eMode = EUpsampleMode_Nearest,
bool bAlignCorner =
false);
31 virtual ~CComputationalGraphUpsample();
33 virtual CTensor<T>& Forward()
override;
34 virtual CTensor<T>* Backward()
override;
35 virtual CComputationalBase<T>* Clone()
const override;
36 virtual const std::vector<int64_t>& GetEstimatedShape(
bool bRecursive =
true)
const override;
38 virtual const CResult PrintNodeParamInfo()
const override;
40 virtual const CResult GetBinaryData(Base::CFLData& fldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
41 virtual const CResult GetBinaryData(Base::CFLData* pFldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
43 virtual const CResult SetBinaryData(
const Base::CFLData& fldBinary, int64_t* pI64Offset =
nullptr)
override;
44 virtual const CResult SetBinaryData(
const Base::CFLData* pFldBinary, int64_t* pI64Offset =
nullptr)
override;
47 DeclareGetClassType();
48 SupportToDuplicateObjectWithoutCreateNewObject(CComputationalGraphUpsample, *
this);
50 virtual const CResult Upsample(
const CTensor<T>* pTsrInput, CTensor<T>* pTsrResult, EUpsampleMode eMode);
51 virtual const CResult Derivative(
bool bAddGradients);
53 virtual const CResult UpsampleNearest(
const CTensor<T>* pTsrX, CTensor<T>* pTsrY);
54 virtual const CResult UpsampleBilinear(
const CTensor<T>* pTsrX, CTensor<T>* pTsrY);
55 virtual const CResult UpsampleBicubic(
const CTensor<T>* pTsrX, CTensor<T>* pTsrY);
57 virtual const CResult DerivativeNearest(
const CTensor<T>* pTsrDy, CTensor<T>* pTsrDx);
58 virtual const CResult DerivativeBilinear(
const CTensor<T>* pTsrDy, CTensor<T>* pTsrDx);
59 virtual const CResult DerivativeBicubic(
const CTensor<T>* pTsrDy, CTensor<T>* pTsrDx);
66 EUpsampleMode m_eMode;
70 DeclareGetSignletonObject(CComputationalGraphUpsample);
73 #define CCGFUpsample(...) (*(new CComputationalGraphUpsample<float>(__VA_ARGS__)))
74 #define CCGDUpsample(...) (*(new CComputationalGraphUpsample<double>(__VA_ARGS__)))
76 #define CCGTUpsample(T, ...) (*(new CComputationalGraphUpsample<T>(__VA_ARGS__)))