3#if _MSC_VER >= 1900 && defined(_M_X64)
6#include "DefinitionsAI.h"
24 class FL_EXPORT CValidationImageExtractor;
28 class CClassEqualizerBase;
31 class CClassEqualizerForTensorImages;
34 class CClassEqualizerForTensorImagesWithMaskLabels;
37 class FL_EXPORT CTensorImages :
public CTensor<T>
51 CTensorImages(
const CTensorImages<T>& tsr,
bool bDeepCopy =
true);
53 virtual ~CTensorImages();
55 virtual const CResult GetBinaryData(Base::CFLData& fldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
56 virtual const CResult GetBinaryData(Base::CFLData* pFldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
58 virtual const CResult SetBinaryData(
const Base::CFLData& fldBinary, int64_t* pI64Offset =
nullptr)
override;
59 virtual const CResult SetBinaryData(
const Base::CFLData* pFldBinary, int64_t* pI64Offset =
nullptr)
override;
61 virtual const CResult Create(
const std::vector<int64_t>& vctShape,
bool bOrderByDesc =
true,
bool bCudaAllocation =
true)
override;
62 virtual const CResult Create(
const std::initializer_list<int64_t>& ilShape,
bool bOrderByDesc =
true,
bool bCudaAllocation =
true)
override;
63 virtual const CResult Create(
const Base::CFLImage& fli,
bool bNormalize =
true, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
64 virtual const CResult Create(
const Base::CFLImage* pFli,
bool bNormalize =
true, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
65 virtual const CResult Create(
const Base::CFLImage* pFli,
const std::vector<int64_t>& vctNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
66 virtual const CResult Create(
const Base::CFLImage& fli,
const std::vector<int64_t>& vctNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
67 virtual const CResult Create(
const Base::CFLImage* pFli,
const std::initializer_list<int64_t>& ilNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
68 virtual const CResult Create(
const Base::CFLImage& fli,
const std::initializer_list<int64_t>& ilNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool* pBAbort =
nullptr);
71 virtual const CResult Create(
const wchar_t* pWcFilePath,
const std::vector<int64_t>& vctNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0.,
bool bRecursive =
false, ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear);
72 virtual const CResult Create(
const wchar_t* pWcFilePath,
const std::initializer_list<int64_t>& ilNewSize, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0.,
bool bRecursive =
false, ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear);
74 virtual const CResult
Assign(
const CTensor<T>& tsr,
bool bDeepCopy =
true)
override;
75 virtual const CResult
Assign(
const CTensor<T>* pTsr,
bool bDeepCopy =
true)
override;
77 virtual const CResult
Assign(
const CTensorImages<T>& tsr,
bool bDeepCopy =
true);
78 virtual const CResult
Assign(
const CTensorImages<T>* pTsr,
bool bDeepCopy =
true);
80 virtual const CResult
Append(
const Base::CFLImage* pFli, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool *pBAbort =
nullptr);
81 virtual const CResult
Append(
const Base::CFLImage& fli, EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises,
bool bROIExtraction =
false,
bool bNormalize =
true,
const Base::CMultiVar<T>& mvBlankColor = 0., ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear, std::atomic<int32_t>* pI32CurrentPreparingTensorIndex =
nullptr,
bool *pBAbort =
nullptr);
83 virtual const CResult
Append(
const wchar_t* pWcFilePath,
bool bRecursive =
false);
85 virtual const CResult
Clear()
override;
87 virtual const CResult SetSourceImage(
const Base::CFLImage& fliSourceImage);
88 virtual const CResult SetSourceImage(
const Base::CFLImage* pFliSourceImage);
89 virtual const Base::CFLImage* GetSourceImage()
const;
91 virtual const CResult SetSourceImagePath(
const wchar_t* pWcsSourceImagePath);
92 virtual const wchar_t* GetSourceImagePath()
const;
94 virtual const CResult EnableRecursiveLoad(
bool bRecursive);
95 virtual bool IsRecursiveLoadEnabled()
const;
97 virtual const CResult SetTensorShape(
const std::vector<int64_t>& vctTensorShape);
98 virtual const CResult SetTensorShape(
const std::initializer_list<int64_t>& ilTensorShape);
99 virtual const std::vector<int64_t> GetTensorShape()
const;
101 virtual const CResult SetResizeMethod(EResizeMethod eResizeMethod = EResizeMethod_ScaleAllAxises);
104 virtual const CResult EnableROIExtraction(
bool bROIExtraction =
false);
105 virtual bool IsROIExtractionEnabled()
const;
107 virtual const CResult EnableNormalization(
bool bNormalize =
true);
108 virtual bool IsNormalizationEnabled()
const;
110 virtual const CResult SetBlankColor(Base::CMultiVar<T>& mvBlankColor = 0.);
111 virtual const Base::CMultiVar<T> GetBlankColor()
const;
113 virtual const CResult SetInterpolationMethod(ImageProcessing::EInterpolationMethod eInterpolationMethod = ImageProcessing::EInterpolationMethod_Bilinear);
114 virtual ImageProcessing::EInterpolationMethod GetInterpolationMethod()
const;
116 virtual const CResult Initialize();
118 virtual const CResult EnableTrainingMode(
bool bMode,
bool bRecursively =
true)
override;
120 virtual const CResult ClearBatchFromMemory();
121 virtual const CResult ClearBatchIndices();
122 virtual const CResult SelectBatchIndices(
const std::vector<int64_t>& vctBatchIndices);
123 virtual const CResult SetBatchParameters(
const CTensor<T>& tsr)
override;
124 virtual const CResult SetBatchParameters(
const CTensorImages<T>& tsr);
126 virtual CTensorImages<T>& Evaluate()
override;
127 virtual CTensorImages<T>& Forward()
override;
128 virtual CComputationalBase<T>* Clone()
const override;
130 virtual const CResult Swap(CComputationalBase<T>& cbSwap)
override;
132 virtual int64_t GetBatchSize()
const;
134 virtual const CResult LoadTensor(
const std::vector<int64_t>& vctBatchIndices);
135 virtual const CResult LoadTensor(
const std::initializer_list<int64_t>& ilBatchIndices);
137 virtual int64_t GetTensorImageTotalROIPageCount()
const;
138 virtual int64_t GetTensorImageTotalPageCount()
const;
139 virtual bool IsCreatedWithImagePath()
const;
141 virtual int32_t GetResultLabelCategoryCount()
const;
142 virtual const CResult GetResultLabelCategoryClassNum(int64_t i64Index, int32_t& i32ClassNum)
const;
143 virtual const CResult GetResultLabelCategoryClassNum(int64_t i64Index, int32_t* pI32ClassNum)
const;
144 virtual const CResult GetResultLabelCategoryClassNames(int64_t i64Index, Base::CFLArray<Base::CFLString<wchar_t>>& flaClassNames)
const;
145 virtual const CResult GetResultLabelCategoryClassNames(int64_t i64Index, Base::CFLArray<Base::CFLString<wchar_t>>* pFlaClassNames)
const;
147 virtual const CResult ConvertClassNumToLabel(
bool bIncludingClassName =
true);
148 virtual const CResult ConvertLabelToClassNum(
bool bIncludingClassName =
true);
150 virtual const std::vector<int32_t>& GetLabelIndices(int64_t i64Index)
const;
152 virtual const CResult AddDefaultClass(int32_t i32ClassNum,
const Base::CFLString<wchar_t>& flsClassName);
153 virtual const CResult ClearDefaultClass();
154 virtual const CResult RemoveDefaultClass(int32_t i32ClassNum);
155 virtual const CResult RemoveDefaultClass(
const Base::CFLString<wchar_t>& flsClassName);
157 virtual const Base::CFLArray<int32_t> GetDefaultClassNum()
const;
158 virtual const Base::CFLArray<Base::CFLString<wchar_t>> GetDefaultClassName()
const;
160 virtual int64_t GetTensorImageTotalLabelCount()
const;
162 virtual const CResult EnableLog(
bool bLog =
true);
163 virtual bool IsLogEnabled()
const;
165 virtual const CResult SetClassNames(
const Base::CFLArray<Base::CFLString<wchar_t>>& flaClassNames);
166 virtual const CResult SetClassNames(
const Base::CFLArray<Base::CFLString<wchar_t>>* pFlaClassNames);
167 virtual const CResult AddClassNames(
const Base::CFLString<wchar_t>& flsClassName);
169 virtual const Base::CFLArray<Base::CFLString<wchar_t>> GetClassNames()
const;
170 virtual const CResult ClearClassNames();
172 virtual const CResult SetTilingMode(ETilingMode eImageTilingMode = ETilingMode_NoTiling_Fit);
175 static EImageType GetExtenstion(
const wchar_t* pWcsImagePath);
176 static const CResult ExtractClassNumClassName(
const Base::CFLString<wchar_t>& flsFigureName, Base::CFLString<wchar_t>& flsClassNum, Base::CFLString<wchar_t>& flsClassName);
178 virtual const CResult EnableNoLabelMode(
bool bNoLabelMode =
false);
179 virtual bool IsNoLabelModeEnable();
182 DeclareGetClassType();
183 SupportToDuplicateObject(CTensorImages, *
this);
185 virtual const CResult ApplyDefaultLabels();
186 virtual const CResult DecodeLabels(
const wchar_t* pWcsImagePath, Base::CFLImage* pFli =
nullptr);
187 virtual const CResult ExtractLabelInfo(
const wchar_t* pWcsName, int32_t i32PageIndex, int32_t i32FigureIndex);
188 virtual const CResult AddLabel(
const wchar_t* pWcsName, Foundation::CFLFigure* pFlfLabel,
bool bFile =
false);
189 virtual const CResult AddLabel(std::pair<int32_t, Base::CFLString<wchar_t>>& prLabelInfo);
190 virtual int32_t GetClassNameOffset(int32_t i32ClassNum, Base::CFLString<wchar_t>& flsName,
bool bRemoveSeparator =
true)
const;
192 virtual bool IsValidLabel(
const wchar_t* pWcsLabel)
const;
193 virtual const CResult RemoveExtension(
const wchar_t* pWcsName, Base::CFLString<wchar_t>& flsNewName);
194 virtual const CResult MakeDistribution();
196 virtual const CResult IsValidImageFormat(EImageType eImageType)
const;
198 virtual const CResult InitializeTilingData(int64_t i64ModelSize,
bool bClear =
true);
199 virtual const CResult ExtractTilingRegion(
const std::vector<int64_t>& vctBatchIndices,
const Base::CFLImage* pFliSrc, Base::CFLImage* pFliDst);
202 Foundation::CFLFigureArray m_flfaLabels;
203 CLabelData& m_ldLabels;
205 std::vector<Base::CFLString<wchar_t>>& m_vctFileList;
206 std::vector<int64_t>& m_vctPageCount;
207 std::vector<int64_t>& m_vctCumulativePageCount;
208 std::vector<int64_t>& m_vctBatchIndices;
210 std::vector<int64_t>& m_vctImageSize;
213 bool m_bROIExtraction;
215 Base::CMultiVar<T> m_mvBlankColor;
216 ImageProcessing::EInterpolationMethod m_eInterpolationMethod;
218 Base::CFLArray<int32_t> m_flaDefaultClassNum;
219 Base::CFLArray<Base::CFLString<wchar_t>> m_flaDefaultClassName;
221 std::vector<std::tuple<int32_t, int32_t>>& m_vctPage;
222 std::vector<std::vector<std::pair<int32_t, Base::CFLString<wchar_t>>>>& m_vct2LabelInfo;
224 int64_t m_i64TotalPageCount;
225 int64_t m_i64TotalLabelCount;
226 bool m_bCreatedWithImagePath;
229 bool m_bClearFigures;
231 bool m_bClearParameters;
232 bool m_bClearClassName;
235 Base::CFLImage* m_pFliSourceImage;
236 const wchar_t* m_pWcsSourceImagePath;
239 std::vector<int64_t>& m_vctTensorShape;
240 int64_t m_i64BatchSize;
243 Base::CFLArray<Base::CFLString<wchar_t>> m_flaClassNames;
247 std::vector<int64_t>& m_vctSliceSize;
248 std::vector<int64_t>& m_vctLastSlicePositionX;
249 std::vector<int64_t>& m_vctLastSlicePositionY;
250 std::vector<int64_t>& m_vctSliceRowCount;
251 std::vector<int64_t>& m_vctSliceColCount;
252 std::vector<int64_t>& m_vctAccumulateSliceCount;
253 std::vector<std::pair<int64_t, int64_t>>& m_vctFileSize;
258 friend class CValidationImageExtractor;
261 friend class CClassEqualizerBase;
264 friend class CClassEqualizerForTensorImages;
267 friend class CClassEqualizerForTensorImagesWithMaskLabels;
270 DeclareGetSignletonObject(CTensorImages);
273 #define CCGFTensorImages(...) (*(new CTensorImages<float>(__VA_ARGS__)))
274 #define CCGDTensorImages(...) (*(new CTensorImages<double>(__VA_ARGS__)))
276 typedef CTensorImages<float> CTensorImagesF;
277 typedef CTensorImages<double> CTensorImagesD;
ETilingMode
Definition DefinitionsAIModel.h:75
@ ETilingMode_BothAxesTiling_NoFit
Definition DefinitionsAIModel.h:95
@ ETilingMode_NoTiling_NoFit
Definition DefinitionsAIModel.h:80
@ ETilingMode_NoTiling_Fit
Definition DefinitionsAIModel.h:85
@ ETilingMode_SingleAxisTiling_ProportionalFit
Definition DefinitionsAIModel.h:90
EResizeMethod
Definition DefinitionsImgProcBase.h:213
@ Assign
Set the value of CGUIPropertyItemView3DFigure to the specified figure.
@ Clear
Clear all the figure objects.