3#if _MSC_VER >= 1900 && defined(_M_X64)
5#include "DefinitionsAI.h"
6#include "ComputationalGraph.h"
7#include "ComputationalGraphPlaceholder.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"
25 class CInternalMaskRCNNParameters;
28 class FL_EXPORT CInstanceSegmentationResult
31 CInstanceSegmentationResult();
32 ~CInstanceSegmentationResult();
35 std::vector<CTensor<T>>& vctTsrBoxes;
36 std::vector<CTensor<T>>& vctTsrLabels;
37 std::vector<CTensor<T>>& vctTsrScores;
38 std::vector<CTensor<T>>& vctTsrMasks;
42 class FL_EXPORT CComputationalGraphMaskRCNN :
public CComputationalGraph<T>
45 CComputationalGraphMaskRCNN();
48 CComputationalGraphMaskRCNN(
const CComputationalGraphMaskRCNN<T>& cg);
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);
56 virtual ~CComputationalGraphMaskRCNN();
58 virtual CTensor<T>& Forward()
override;
59 virtual CTensor<T>* Backward()
override;
60 virtual CComputationalBase<T>* Clone()
const override;
62 virtual const std::vector<int64_t>& GetEstimatedShape(
bool bRecursive =
true)
const override;
64 virtual const CResult SetForegroundIoUThreshold(T tForegroundIoUThreshold);
65 virtual T GetForegroundIoUThreshold()
const;
67 virtual const CResult SetBackgroundIoUThreshold(T tBackgroundIoUThreshold);
68 virtual T GetBackgroundIoUThreshold()
const;
70 virtual const CResult SetImageWidth(int64_t i64ImageWidth);
71 virtual int64_t GetImageWidth()
const;
73 virtual const CResult SetImageHeight(int64_t i64ImageHeight);
74 virtual int64_t GetImageHeight()
const;
76 virtual const CResult SetNMSType(ENonMaximumSuppressionType eNMS);
77 virtual int64_t GetNMSType()
const;
79 virtual const CResult SetNMSIoUThreshold(T tNMSIoUThreshold);
80 virtual T GetNMSIoUThreshold()
const;
82 virtual const CResult SetObjectnessThreshold(T tObjectnessThreshold);
83 virtual T GetObjectnessThreshold()
const;
85 virtual const CResult SetDetectionPerBatch(int64_t i64DetectionPerBatch);
86 virtual int64_t GetDetectionPerBatch()
const;
88 virtual const CResult SetSamplerResultBoxCount(int64_t i64SamplerResultBoxCount);
89 virtual int64_t GetSamplerResultBoxCount()
const;
91 virtual const CResult SetSamplerPositiveFraction(T tSamplerPositiveFraction);
92 virtual T GetSamplerPositiveFraction()
const;
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;
101 virtual const CInstanceSegmentationResult<T>* GetMaskRCNNInferenceResult()
const;
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);
106 DeclareGetClassType();
107 SupportToDuplicateObjectWithoutCreateNewObject(CComputationalGraphMaskRCNN, *
this);
109 virtual const CResult PrintNodeParamInfo()
const;
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;
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;
117 virtual int64_t GetRequiredDedicatedMemory(
bool bTraining =
false,
bool bRecursively =
true, int64_t i64BatchSize = 1)
const override;
118 virtual int64_t GetOperandIndexForNextBatchSize()
const override;
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();
126 virtual CInternalMaskRCNNParameters<T>& GetMaskRCNNParameters()
const;
128 CBackendBCEWithLogistLoss<T> m_backendBCELoss;
129 CBackendMultiScaleRoIAlign<T> m_backendRoIAlign;
130 CBackendLabel<T> m_backendLabel;
133 T m_tFasterRCNNBoxLoss;
134 T m_tFasterRCNNScoreLoss;
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;
144 CTensor<T> m_tsrMaskTargetSelectedBuffer;
145 CTensor<T> m_tsrMaskLogistSelectedBuffer;
146 CTensor<T> m_tsrMaskLogistSelectedDxBuffer;
148 std::vector<CTensor<T>>& m_vctTsrTargetMasks;
149 CTensor<T> m_tsrTargetMasksBuffer;
151 bool m_bBackwardEnabled;
153 DeclareGetSignletonObject(CComputationalGraphMaskRCNN);
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__)))
Definition AlgorithmAIBase.h:18
@ Clear
Clear all the figure objects.
Definition DefinitionsGUI.h:2101