FLImaging 6.12.9.2
ComputationalGraphConv2D.h
1#pragma once
2
3#if _MSC_VER >= 1900 && defined(_M_X64)
4
5#include "ComputationalGraph.h"
6#include "Tensor.h"
7#include "BackendConv2D.h"
8
9#include <vector>
10
11namespace FLImaging
12{
13 namespace AI
14 {
15 template <typename T>
16 class FL_EXPORT CComputationalGraphConv2D : public CComputationalGraph<T>
17 {
18
19 protected:
20 CComputationalGraphConv2D();
21 CComputationalGraphConv2D(const CComputationalGraphConv2D<T>& cg);
22
23 public:
24 // Operand1
25 // 4th dim : Batch size
26 // 3rd dim : Channels
27 // 2nd dim : Height
28 // 1st dim : Width
29
30 // Kernel
31 // 4th dim : Num of kernels
32 // 3rd dim : Channels
33 // 2nd dim : Height
34 // 1st dim : Width
35
36 // Bias
37 // 1st dim : Num of kernels
38 CComputationalGraphConv2D(const CComputationalBase<T>& cbOperand1, const CTensor<T>& tsrKernel, int64_t i64StrideX = 1, int64_t i64StrideY = 1, int64_t i64PaddingX = 0, int64_t i64PaddingY = 0, int64_t i64DilationX = 1, int64_t i64DilationY = 1, int64_t i64GroupCount = 1);
39 virtual ~CComputationalGraphConv2D();
40
41 virtual CTensor<T>& Forward() override;
42 virtual CTensor<T>* Backward() override;
43 virtual CComputationalBase<T>* Clone() const override;
44
45 virtual const std::vector<int64_t>& GetEstimatedShape(bool bRecursive = true) const override;
46 virtual const CResult PrintNodeParamInfo() const override;
47
48 virtual const CResult GetBinaryData(Base::CFLData& fldBinary, bool bSuperClass = false, int32_t i32Version = -1, bool bDumpMode = false) const override;
49 virtual const CResult GetBinaryData(Base::CFLData* pFldBinary, bool bSuperClass = false, int32_t i32Version = -1, bool bDumpMode = false) const override;
50
51 virtual const CResult SetBinaryData(const Base::CFLData& fldBinary, int64_t* pI64Offset = nullptr) override;
52 virtual const CResult SetBinaryData(const Base::CFLData* pFldBinary, int64_t* pI64Offset = nullptr) override;
53
54 virtual int64_t GetRequiredTemporaryMemory(bool bTraining = false, bool bRecursively = true, int64_t i64BatchSize = 1, int64_t i64MemoryIndex = 0) const override;
55 virtual int64_t GetRequiredDedicatedMemory(bool bTraining = false, bool bRecursively = true, int64_t i64BatchSize = 1) const override;
56
57
58 DeclareGetClassType();
59 SupportToDuplicateObjectWithoutCreateNewObject(CComputationalGraphConv2D, *this);
60
61 protected:
62 int64_t m_i64StrideX;
63 int64_t m_i64StrideY;
64 int64_t m_i64PaddingX;
65 int64_t m_i64PaddingY;
66 int64_t m_i64DilationX;
67 int64_t m_i64DilationY;
68 int64_t m_i64GroupCount;
69
70 CTensor<T> m_tsrKernelBuffer;
71 CBackendConv2D<T> m_backendConv2D;
72
73 public:
74 DeclareGetSignletonObject(CComputationalGraphConv2D);
75 };
76
77 #define CCGFConv2D(...) (*(new CComputationalGraphConv2D<float>(__VA_ARGS__)))
78 #define CCGDConv2D(...) (*(new CComputationalGraphConv2D<double>(__VA_ARGS__)))
79
80 #define CCGTConv2D(T, ...) (*(new CComputationalGraphConv2D<T>(__VA_ARGS__)))
81 }
82}
83
84#endif
Definition AlgorithmAIBase.h:18