FLImaging 6.10.14.2
Evaluator.h
1#pragma once
2
3#if _MSC_VER >= 1900 && defined(_M_X64)
4
5#include "ComputationalGraphObjectDetection.h"
6#include "ComputationalGraphMaskRCNN.h"
7#include "Tensor.h"
8#include <atomic>
9
10namespace FLImaging
11{
12 namespace AI
13 {
14 template <typename T>
15 class CComputationalGraph;
16
17 template <typename T>
18 class CComputationalGraphPlaceholder;
19
20 template<typename T>
21 class CBackendEvaluatorBase;
22
23 template<typename T>
24 class CBackendEvaluatorForObjectDetection;
25
26 template<typename T>
27 class CBackendEvaluatorForInstanceSegmentation;
28
29 template <typename T>
30 class FL_EXPORT CEvaluator : public CAlgorithmAIBase
31 {
32 public:
33 enum EModelType
34 {
35 EModelType_Classifier = 0,
36 EModelType_SemanticSegmentation,
37 EModelType_ObjectDetection,
38 EModelType_InstanceSegmentation,
39 EModelType_AnomalyDetection,
40 EModelType_SuperResolution,
41 EModelType_DenoisingDiffusion,
42 };
43
44 CEvaluator();
45 CEvaluator(const CEvaluator<T>& evaluator);
46 CEvaluator(const CEvaluator<T>* pEvaluator);
47 virtual ~CEvaluator();
48
49 virtual const CResult Assign(const CEvaluator<T>& evaluator);
50 virtual const CResult Assign(const CEvaluator<T>* pEvaluator);
51
52 virtual const CResult Clear();
53
54 virtual const CResult Initialize();
55 virtual bool IsInitialized() const;
56
57 virtual const CResult SetFunction(const CComputationalGraph<T>* pCgEvaluationLayer);
58 virtual const CComputationalGraph<T>& GetFunction() const;
59
60 virtual const CResult SetGPUIndices(const std::vector<int32_t>& vctGPUIndices);
61 virtual const CResult SetGPUIndices(const Base::CFLArray<int32_t>& flaGPUIndices);
62 virtual const CResult SetGPUIndices(const Base::CFLArray<uint32_t>& flaGPUIndices);
63 virtual const std::vector<int32_t>& GetGPUIndices() const;
64
65 virtual const CResult SetModelType(EModelType eModelType = EModelType_Classifier);
66 virtual EModelType GetModelType();
67
68 virtual const CResult SetMemoryLimitRatio(double f64MemoryLimitRatio = 1.);
69 virtual double GetMemoryLimitRatio() const;
70
71 virtual const CResult SetSamplingStep(int32_t i32TotalSamplingStep = 1000);
72 virtual int32_t GetSamplingStep() const;
73
74 virtual const CResult Evaluate(Base::CFLArray<int32_t>* pFlaIterationFeedback = nullptr, bool* pBStopImmediatedly = nullptr, std::vector<bool>* pVctEvaluatedIndex = nullptr);
75
76 virtual const CTensor<T>* GetResultEvaluation() const;
77 virtual const std::vector<std::vector<std::vector<std::tuple<CObjectBox<float>, float, int64_t>>>>* GetResultBox() const;
78 virtual const CInstanceSegmentationResult<T>* GetInstanceSegmentationResult() const;
79 virtual int64_t GetTotalIteration() const;
80 virtual int64_t GetActualTotalBatchSize() const;
81
82 virtual const Base::CFLArray<uint32_t> GetInvolvedDeviceIndices() const;
83
84 DeclareGetClassType();
85 SupportToDuplicateAbstractObject(CEvaluator<T>);
86
87 protected:
88 virtual const CResult CopyBatchParams(bool bDifferent);
89 virtual CBackendEvaluatorBase<T>* CreateNewBackendEvaluator();
90
91 protected:
92 std::vector<int32_t>& m_vctGPUIndices;
93 std::vector<int32_t>& m_vctDeviceIndices;
94 std::vector<int32_t>& m_vctDeviceInUse;
95 std::vector<int32_t>& m_vctPrevDeviceIndices;
96
97 CComputationalGraph<T>* m_pCgEvaluationLayer;
98 CTensor<T> m_tsrResult;
99
100 std::vector<CComputationalGraph<T>*>& m_vctFunctions;
101
102 bool m_bGPUDevice;
103 bool m_bDifferent;
104 bool m_bInitialized;
105 int64_t m_i64InitialBatch;
106
107 int32_t m_i32DeviceCount;
108
109 int64_t m_i64ActualMiniBatchSize;
110 int64_t m_i64TotalIteration;
111 int64_t m_i64TotalIterationPerDevice;
112 int64_t m_i64TotalBatchSize;
113 int64_t m_i64CurrentIteration;
114
115 std::vector<CBackendEvaluatorBase<T>*>& m_vctEvaluator;
116 EModelType m_eModelType;
117 EModelType m_ePrevModelType;
118
119 std::vector<std::vector<std::vector<std::tuple<CObjectBox<float>, float, int64_t>>>>& m_vct3BoxResult;
120 CInstanceSegmentationResult<T> m_instanceSegmentationResult;
121
122 double m_f64MemoryLimitRatio;
123 double m_f64PrevMemoryLimitRatio;
124
125 int32_t m_i32TotalSamplingStep;
126 private:
127 template<typename T>
128 friend class CBackendEvaluatorBase;
129
130 template<typename T>
131 friend class CBackendEvaluatorForObjectDetection;
132
133 template<typename T>
134 friend class CBackendEvaluatorForInstanceSegmentation;
135
136 template<typename T>
137 friend class CBackendEvaluatorForDenoisingDiffusion;
138 };
139
140
141 typedef CEvaluator<float> CEvaluatorF;
142 typedef CEvaluator<double> CEvaluatorD;
143 }
144}
145
146#endif
Processing unit AI class required by algorithm.
Definition AlgorithmAIBase.h:27
Definition AlgorithmAIBase.h:18
@ Assign
Set the value of CGUIPropertyItemView3DFigure to the specified figure.
Definition DefinitionsGUIView3D.h:2798
@ Clear
Clear all the figure objects.
Definition DefinitionsGUI.h:2092