FLImaging 6.11.5.1
ComputationalGraphMaskRCNN.h
1#pragma once
2
3#if _MSC_VER >= 1900 && defined(_M_X64)
4
5#include "DefinitionsAI.h"
6#include "ComputationalGraph.h"
7#include "ComputationalGraphPlaceholder.h"
8#include "Tensor.h"
9#include "BackendSoftmax.h"
10#include "BackendSoftmaxWithCrossEntropy.h"
11#include "BackendBCEWithLogistLoss.h"
12#include "BackendSmoothL1Loss.h"
13#include "BackendMultiScaleRoIAlign.h"
14#include "BackendLabel.h"
15#include "Tensor.h"
16#include <vector>
17#include <utility>
18#include <functional>
19
20namespace FLImaging
21{
22 namespace AI
23 {
24 template <typename T>
25 class CInternalMaskRCNNParameters;
26
27 template <typename T>
28 class FL_EXPORT CInstanceSegmentationResult
29 {
30 public:
31 CInstanceSegmentationResult();
32 ~CInstanceSegmentationResult();
33 void Clear();
34 public:
35 std::vector<CTensor<T>>& vctTsrBoxes;
36 std::vector<CTensor<T>>& vctTsrLabels;
37 std::vector<CTensor<T>>& vctTsrScores;
38 std::vector<CTensor<T>>& vctTsrMasks;
39 };
40
41 template <typename T>
42 class FL_EXPORT CComputationalGraphMaskRCNN : public CComputationalGraph<T>
43 {
44 private:
45 CComputationalGraphMaskRCNN();
46
47 protected:
48 CComputationalGraphMaskRCNN(const CComputationalGraphMaskRCNN<T>& cg);
49
50 public:
51 CComputationalGraphMaskRCNN(const CComputationalBase<T>& cgFeature, const CComputationalBase<T>& cbProposals, int64_t i64ClassCount);
52 CComputationalGraphMaskRCNN(const std::initializer_list<const CComputationalBase<T>*>& liFeatures, const CComputationalBase<T>& cbProposals, int64_t i64ClassCount);
53 CComputationalGraphMaskRCNN(const std::vector<const CComputationalBase<T>*>& vctFeatures, const CComputationalBase<T>& cbProposals, int64_t i64ClassCount);
54 CComputationalGraphMaskRCNN(const std::vector<const CComputationalBase<T>*>& vctHeadIntermediateProposalMaskGraph);
55
56 virtual ~CComputationalGraphMaskRCNN();
57
58 virtual CTensor<T>& Forward() override;
59 virtual CTensor<T>* Backward() override;
60 virtual CComputationalBase<T>* Clone() const override;
61
62 virtual const std::vector<int64_t>& GetEstimatedShape(bool bRecursive = true) const override;
63
64 virtual const CResult SetForegroundIoUThreshold(T tForegroundIoUThreshold);
65 virtual T GetForegroundIoUThreshold() const;
66
67 virtual const CResult SetBackgroundIoUThreshold(T tBackgroundIoUThreshold);
68 virtual T GetBackgroundIoUThreshold() const;
69
70 virtual const CResult SetImageWidth(int64_t i64ImageWidth);
71 virtual int64_t GetImageWidth() const;
72
73 virtual const CResult SetImageHeight(int64_t i64ImageHeight);
74 virtual int64_t GetImageHeight() const;
75
76 virtual const CResult SetNMSType(ENonMaximumSuppressionType eNMS);
77 virtual int64_t GetNMSType() const;
78
79 virtual const CResult SetNMSIoUThreshold(T tNMSIoUThreshold);
80 virtual T GetNMSIoUThreshold() const;
81
82 virtual const CResult SetObjectnessThreshold(T tObjectnessThreshold);
83 virtual T GetObjectnessThreshold() const;
84
85 virtual const CResult SetDetectionPerBatch(int64_t i64DetectionPerBatch);
86 virtual int64_t GetDetectionPerBatch() const;
87
88 virtual const CResult SetSamplerResultBoxCount(int64_t i64SamplerResultBoxCount);
89 virtual int64_t GetSamplerResultBoxCount() const;
90
91 virtual const CResult SetSamplerPositiveFraction(T tSamplerPositiveFraction);
92 virtual T GetSamplerPositiveFraction() const;
93
94 virtual T GetFasterRCNNBoxLoss() const;
95 virtual T GetFasterRCNNScoreLoss() const;
96 virtual T GetRPNBoxLoss() const;
97 virtual T GetRPNScoreLoss() const;
98 virtual T GetMaskLoss() const;
99 virtual T GetTotalLoss() const;
100
101 virtual const CInstanceSegmentationResult<T>* GetMaskRCNNInferenceResult() const;
102
103 static CComputationalBase<T>* MakeMaskRCNNHead(const std::vector<const CComputationalBase<T>*>& vctFetures, const CComputationalBase<T>& cbProposals, int64_t i64OutputSize = 7);
104 static CComputationalBase<T>* MakeMaskRCNNIntermediate(const std::vector<const CComputationalBase<T>*>& vctFetures, const CComputationalBase<T>& cgMaskRCNNHead, const CComputationalBase<T>& cbClassLogist, const CComputationalBase<T>& cbBoxRegression, const CComputationalBase<T>& cbProposals, int64_t i64OutputSize = 14);
105
106 DeclareGetClassType();
107 SupportToDuplicateObjectWithoutCreateNewObject(CComputationalGraphMaskRCNN, *this);
108 public:
109 virtual const CResult PrintNodeParamInfo() const;
110
111 virtual const CResult GetBinaryData(Base::CFLData& fldBinary, bool bSuperClass = false, int32_t i32Version = -1, bool bDumpMode = false) const override;
112 virtual const CResult GetBinaryData(Base::CFLData* pFldBinary, bool bSuperClass = false, int32_t i32Version = -1, bool bDumpMode = false) const override;
113
114 virtual const CResult SetBinaryData(const Base::CFLData& fldBinary, int64_t* pI64Offset = nullptr) override;
115 virtual const CResult SetBinaryData(const Base::CFLData* pFldBinary, int64_t* pI64Offset = nullptr) override;
116
117 virtual int64_t GetRequiredDedicatedMemory(bool bTraining = false, bool bRecursively = true, int64_t i64BatchSize = 1) const override;
118 virtual int64_t GetOperandIndexForNextBatchSize() const override;
119 protected:
120 virtual const CResult GenerateGraph(const std::vector<const CComputationalBase<T>*>& vctFeatures, const CComputationalBase<T>& cbProposals, int64_t i64ClassCount);
121 virtual const CResult MaskRCNNLoss(const CTensor<T>* pTsrMaskLogist, const std::vector<CTensor<T>>& vctTsrMaskProposal, const std::vector<CTensor<T>>& vctTsrGTMasks, const std::vector<CTensor<T>>& vctTsrGTLabels, const std::vector<std::vector<uint32_t>>& vctMatchedIndexes, CTensor<T>& tsrResultMaskLoss);
122 virtual const CResult MaskRCNNInference(const CTensor<T>* pTsrMaskLogist, const std::vector<CTensor<T>>& m_vctLabel, std::vector<CTensor<T>>& vctResultMask);
123 virtual const CResult MaskRCNNLoss_Backward(const CTensor<T>* pTsrMaskLogist, const CTensor<T>* pTsrMaskLossDy, CTensor<T>* pTsrMaskLogistDx, bool bMaskLogistAddGraident);
124 virtual const CResult CreateTargetBuffer();
125
126 virtual CInternalMaskRCNNParameters<T>& GetMaskRCNNParameters() const;
127 protected:
128 CBackendBCEWithLogistLoss<T> m_backendBCELoss;
129 CBackendMultiScaleRoIAlign<T> m_backendRoIAlign;
130 CBackendLabel<T> m_backendLabel;
131 T m_tRPNBoxLoss;
132 T m_tRPNScoreLoss;
133 T m_tFasterRCNNBoxLoss;
134 T m_tFasterRCNNScoreLoss;
135 T m_tMaskLoss;
136 T m_tTotalLoss;
137
138 CTensor<T> m_tsrMaskLogistSelected;
139 CTensor<T> m_tsrMaskTargetSelected;
140 CTensor<T> m_tsrMaskLogistDxSelected;
141 CTensor<T> m_tsrSelectedLabel;
142 CTensor<T> m_tsrMaskLogistSigmoid;
143
144 CTensor<T> m_tsrMaskTargetSelectedBuffer;
145 CTensor<T> m_tsrMaskLogistSelectedBuffer;
146 CTensor<T> m_tsrMaskLogistSelectedDxBuffer;
147
148 std::vector<CTensor<T>>& m_vctTsrTargetMasks;
149 CTensor<T> m_tsrTargetMasksBuffer;
150
151 bool m_bBackwardEnabled;
152 public:
153 DeclareGetSignletonObject(CComputationalGraphMaskRCNN);
154 };
155
156 #define CCGFMaskRCNN(...) (*(new CComputationalGraphMaskRCNN<float>(__VA_ARGS__)))
157 #define CCGDMaskRCNN(...) (*(new CComputationalGraphMaskRCNN<double>(__VA_ARGS__)))
158 #define CCGTMaskRCNN(T, ...) (*(new CComputationalGraphMaskRCNN<T>(__VA_ARGS__)))
159
160 }
161}
162
163#endif
Definition AlgorithmAIBase.h:18
@ Clear
Clear all the figure objects.
Definition DefinitionsGUI.h:2101