123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259 |
- /***********************************************************
- * File generated by the HALCON-Compiler hcomp version 20.11
- * Usage: Interface to C++
- *
- * Software by: MVTec Software GmbH, www.mvtec.com
- ***********************************************************/
- #ifndef HCPP_HCOMPONENTTRAINING
- #define HCPP_HCOMPONENTTRAINING
- namespace HalconCpp
- {
- // Represents an instance of a training result for the component-based matching.
- class LIntExport HComponentTraining : public HHandle
- {
- public:
- // Create an uninitialized instance
- HComponentTraining():HHandle() {}
- // Copy constructor
- HComponentTraining(const HComponentTraining& source) : HHandle(source) {}
- // Copy constructor
- HComponentTraining(const HHandle& handle);
- // Create HComponentTraining from handle, taking ownership
- explicit HComponentTraining(Hlong handle);
- bool operator==(const HHandle& obj) const
- {
- return HHandleBase::operator==(obj);
- }
- bool operator!=(const HHandle& obj) const
- {
- return HHandleBase::operator!=(obj);
- }
- protected:
- // Verify matching semantic type ('component_training')!
- virtual void AssertType(Hphandle handle) const;
- public:
- // Deep copy of all data represented by this object instance
- HComponentTraining Clone() const;
- /*****************************************************************************
- * Operator-based class constructors
- *****************************************************************************/
- // train_model_components: Train components and relations for the component-based matching.
- explicit HComponentTraining(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, HRegion* ModelComponents, const HTuple& ContrastLow, const HTuple& ContrastHigh, const HTuple& MinSize, const HTuple& MinScore, const HTuple& SearchRowTol, const HTuple& SearchColumnTol, const HTuple& SearchAngleTol, const HString& TrainingEmphasis, const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- // train_model_components: Train components and relations for the component-based matching.
- explicit HComponentTraining(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, HRegion* ModelComponents, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const HString& TrainingEmphasis, const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- // train_model_components: Train components and relations for the component-based matching.
- explicit HComponentTraining(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, HRegion* ModelComponents, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const char* TrainingEmphasis, const char* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- #ifdef _WIN32
- // train_model_components: Train components and relations for the component-based matching.
- explicit HComponentTraining(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, HRegion* ModelComponents, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const wchar_t* TrainingEmphasis, const wchar_t* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- #endif
- /***************************************************************************
- * Operators *
- ***************************************************************************/
- // Prepare a component model for matching based on trained components.
- HComponentModel CreateTrainedComponentModel(double AngleStart, double AngleExtent, const HTuple& MinContrastComp, const HTuple& MinScoreComp, const HTuple& NumLevelsComp, const HTuple& AngleStepComp, const HString& OptimizationComp, const HTuple& MetricComp, const HTuple& PregenerationComp, HTuple* RootRanking) const;
- // Prepare a component model for matching based on trained components.
- HComponentModel CreateTrainedComponentModel(double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const HString& OptimizationComp, const HString& MetricComp, const HString& PregenerationComp, Hlong* RootRanking) const;
- // Prepare a component model for matching based on trained components.
- HComponentModel CreateTrainedComponentModel(double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const char* OptimizationComp, const char* MetricComp, const char* PregenerationComp, Hlong* RootRanking) const;
- #ifdef _WIN32
- // Prepare a component model for matching based on trained components.
- HComponentModel CreateTrainedComponentModel(double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const wchar_t* OptimizationComp, const wchar_t* MetricComp, const wchar_t* PregenerationComp, Hlong* RootRanking) const;
- #endif
- // Free the memory of a component training result.
- void ClearTrainingComponents() const;
- // Return the relations between the model components that are contained in a training result.
- HRegion GetComponentRelations(Hlong ReferenceComponent, const HTuple& Image, HTuple* Row, HTuple* Column, HTuple* Phi, HTuple* Length1, HTuple* Length2, HTuple* AngleStart, HTuple* AngleExtent) const;
- // Return the relations between the model components that are contained in a training result.
- HRegion GetComponentRelations(Hlong ReferenceComponent, const HString& Image, double* Row, double* Column, double* Phi, double* Length1, double* Length2, double* AngleStart, double* AngleExtent) const;
- // Return the relations between the model components that are contained in a training result.
- HRegion GetComponentRelations(Hlong ReferenceComponent, const char* Image, double* Row, double* Column, double* Phi, double* Length1, double* Length2, double* AngleStart, double* AngleExtent) const;
- #ifdef _WIN32
- // Return the relations between the model components that are contained in a training result.
- HRegion GetComponentRelations(Hlong ReferenceComponent, const wchar_t* Image, double* Row, double* Column, double* Phi, double* Length1, double* Length2, double* AngleStart, double* AngleExtent) const;
- #endif
- // Return the initial or model components in a certain image.
- HRegion GetTrainingComponents(const HTuple& Components, const HTuple& Image, const HString& MarkOrientation, HTuple* Row, HTuple* Column, HTuple* Angle, HTuple* Score) const;
- // Return the initial or model components in a certain image.
- HRegion GetTrainingComponents(const HString& Components, const HString& Image, const HString& MarkOrientation, double* Row, double* Column, double* Angle, double* Score) const;
- // Return the initial or model components in a certain image.
- HRegion GetTrainingComponents(const char* Components, const char* Image, const char* MarkOrientation, double* Row, double* Column, double* Angle, double* Score) const;
- #ifdef _WIN32
- // Return the initial or model components in a certain image.
- HRegion GetTrainingComponents(const wchar_t* Components, const wchar_t* Image, const wchar_t* MarkOrientation, double* Row, double* Column, double* Angle, double* Score) const;
- #endif
- // Modify the relations within a training result.
- void ModifyComponentRelations(const HTuple& ReferenceComponent, const HTuple& ToleranceComponent, const HTuple& PositionTolerance, const HTuple& AngleTolerance) const;
- // Modify the relations within a training result.
- void ModifyComponentRelations(const HString& ReferenceComponent, const HString& ToleranceComponent, double PositionTolerance, double AngleTolerance) const;
- // Modify the relations within a training result.
- void ModifyComponentRelations(const char* ReferenceComponent, const char* ToleranceComponent, double PositionTolerance, double AngleTolerance) const;
- #ifdef _WIN32
- // Modify the relations within a training result.
- void ModifyComponentRelations(const wchar_t* ReferenceComponent, const wchar_t* ToleranceComponent, double PositionTolerance, double AngleTolerance) const;
- #endif
- // Deserialize a component training result.
- void DeserializeTrainingComponents(const HSerializedItem& SerializedItemHandle);
- // Serialize a component training result.
- HSerializedItem SerializeTrainingComponents() const;
- // Read a component training result from a file.
- void ReadTrainingComponents(const HString& FileName);
- // Read a component training result from a file.
- void ReadTrainingComponents(const char* FileName);
- #ifdef _WIN32
- // Read a component training result from a file.
- void ReadTrainingComponents(const wchar_t* FileName);
- #endif
- // Write a component training result to a file.
- void WriteTrainingComponents(const HString& FileName) const;
- // Write a component training result to a file.
- void WriteTrainingComponents(const char* FileName) const;
- #ifdef _WIN32
- // Write a component training result to a file.
- void WriteTrainingComponents(const wchar_t* FileName) const;
- #endif
- // Adopt new parameters that are used to create the model components into the training result.
- HRegion ClusterModelComponents(const HImage& TrainingImages, const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- // Adopt new parameters that are used to create the model components into the training result.
- HRegion ClusterModelComponents(const HImage& TrainingImages, const char* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- #ifdef _WIN32
- // Adopt new parameters that are used to create the model components into the training result.
- HRegion ClusterModelComponents(const HImage& TrainingImages, const wchar_t* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- #endif
- // Inspect the rigid model components obtained from the training.
- HRegion InspectClusteredComponents(const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- // Inspect the rigid model components obtained from the training.
- HRegion InspectClusteredComponents(const char* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- #ifdef _WIN32
- // Inspect the rigid model components obtained from the training.
- HRegion InspectClusteredComponents(const wchar_t* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold) const;
- #endif
- // Train components and relations for the component-based matching.
- HRegion TrainModelComponents(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, const HTuple& ContrastLow, const HTuple& ContrastHigh, const HTuple& MinSize, const HTuple& MinScore, const HTuple& SearchRowTol, const HTuple& SearchColumnTol, const HTuple& SearchAngleTol, const HString& TrainingEmphasis, const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- // Train components and relations for the component-based matching.
- HRegion TrainModelComponents(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const HString& TrainingEmphasis, const HString& AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- // Train components and relations for the component-based matching.
- HRegion TrainModelComponents(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const char* TrainingEmphasis, const char* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- #ifdef _WIN32
- // Train components and relations for the component-based matching.
- HRegion TrainModelComponents(const HImage& ModelImage, const HRegion& InitialComponents, const HImage& TrainingImages, Hlong ContrastLow, Hlong ContrastHigh, Hlong MinSize, double MinScore, Hlong SearchRowTol, Hlong SearchColumnTol, double SearchAngleTol, const wchar_t* TrainingEmphasis, const wchar_t* AmbiguityCriterion, double MaxContourOverlap, double ClusterThreshold);
- #endif
- };
- // forward declarations and types for internal array implementation
- template<class T> class HSmartPtr;
- template<class T> class HHandleBaseArrayRef;
- typedef HHandleBaseArrayRef<HComponentTraining> HComponentTrainingArrayRef;
- typedef HSmartPtr< HComponentTrainingArrayRef > HComponentTrainingArrayPtr;
- // Represents multiple tool instances
- class LIntExport HComponentTrainingArray : public HHandleBaseArray
- {
- public:
- // Create empty array
- HComponentTrainingArray();
- // Create array from native array of tool instances
- HComponentTrainingArray(HComponentTraining* classes, Hlong length);
- // Copy constructor
- HComponentTrainingArray(const HComponentTrainingArray &tool_array);
- // Destructor
- virtual ~HComponentTrainingArray();
- // Assignment operator
- HComponentTrainingArray &operator=(const HComponentTrainingArray &tool_array);
- // Clears array and all tool instances
- virtual void Clear();
- // Get array of native tool instances
- const HComponentTraining* Tools() const;
- // Get number of tools
- virtual Hlong Length() const;
- // Create tool array from tuple of handles
- virtual void SetFromTuple(const HTuple& handles);
- // Get tuple of handles for tool array
- virtual HTuple ConvertToTuple() const;
- protected:
- // Smart pointer to internal data container
- HComponentTrainingArrayPtr *mArrayPtr;
- };
- }
- #endif
|