create_trained_component_modelT_create_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model (Operator)
Name
create_trained_component_modelT_create_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model — Vorbereiten eines Komponentenmodells für das Matching auf der Basis
trainierter Komponenten.
Warnung
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model ist veraltet und wird nur aus Gründen
der Rückwärtskompatibilität zur Verfügung gestellt.
Der Operator wird mit HALCON 26.11 entfernt.
Signatur
create_trained_component_model( : : ComponentTrainingID, AngleStart, AngleExtent, MinContrastComp, MinScoreComp, NumLevelsComp, AngleStepComp, OptimizationComp, MetricComp, PregenerationComp : ComponentModelID, RootRanking)
Herror T_create_trained_component_model(const Htuple ComponentTrainingID, const Htuple AngleStart, const Htuple AngleExtent, const Htuple MinContrastComp, const Htuple MinScoreComp, const Htuple NumLevelsComp, const Htuple AngleStepComp, const Htuple OptimizationComp, const Htuple MetricComp, const Htuple PregenerationComp, Htuple* ComponentModelID, Htuple* RootRanking)
void CreateTrainedComponentModel(const HTuple& ComponentTrainingID, const HTuple& AngleStart, const HTuple& AngleExtent, const HTuple& MinContrastComp, const HTuple& MinScoreComp, const HTuple& NumLevelsComp, const HTuple& AngleStepComp, const HTuple& OptimizationComp, const HTuple& MetricComp, const HTuple& PregenerationComp, HTuple* ComponentModelID, HTuple* RootRanking)
HComponentModel HComponentTraining::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
HComponentModel HComponentTraining::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
HComponentModel HComponentTraining::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
HComponentModel HComponentTraining::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
(
Nur Windows)
void HComponentModel::HComponentModel(const HComponentTraining& ComponentTrainingID, 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)
void HComponentModel::HComponentModel(const HComponentTraining& ComponentTrainingID, double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const HString& OptimizationComp, const HString& MetricComp, const HString& PregenerationComp, Hlong* RootRanking)
void HComponentModel::HComponentModel(const HComponentTraining& ComponentTrainingID, double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const char* OptimizationComp, const char* MetricComp, const char* PregenerationComp, Hlong* RootRanking)
void HComponentModel::HComponentModel(const HComponentTraining& ComponentTrainingID, 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)
(
Nur Windows)
HTuple HComponentModel::CreateTrainedComponentModel(const HComponentTraining& ComponentTrainingID, 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)
Hlong HComponentModel::CreateTrainedComponentModel(const HComponentTraining& ComponentTrainingID, double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const HString& OptimizationComp, const HString& MetricComp, const HString& PregenerationComp)
Hlong HComponentModel::CreateTrainedComponentModel(const HComponentTraining& ComponentTrainingID, double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const char* OptimizationComp, const char* MetricComp, const char* PregenerationComp)
Hlong HComponentModel::CreateTrainedComponentModel(const HComponentTraining& ComponentTrainingID, double AngleStart, double AngleExtent, Hlong MinContrastComp, double MinScoreComp, Hlong NumLevelsComp, double AngleStepComp, const wchar_t* OptimizationComp, const wchar_t* MetricComp, const wchar_t* PregenerationComp)
(
Nur Windows)
static void HOperatorSet.CreateTrainedComponentModel(HTuple componentTrainingID, HTuple angleStart, HTuple angleExtent, HTuple minContrastComp, HTuple minScoreComp, HTuple numLevelsComp, HTuple angleStepComp, HTuple optimizationComp, HTuple metricComp, HTuple pregenerationComp, out HTuple componentModelID, out HTuple rootRanking)
HComponentModel HComponentTraining.CreateTrainedComponentModel(double angleStart, double angleExtent, HTuple minContrastComp, HTuple minScoreComp, HTuple numLevelsComp, HTuple angleStepComp, string optimizationComp, HTuple metricComp, HTuple pregenerationComp, out HTuple rootRanking)
HComponentModel HComponentTraining.CreateTrainedComponentModel(double angleStart, double angleExtent, int minContrastComp, double minScoreComp, int numLevelsComp, double angleStepComp, string optimizationComp, string metricComp, string pregenerationComp, out int rootRanking)
public HComponentModel(HComponentTraining componentTrainingID, double angleStart, double angleExtent, HTuple minContrastComp, HTuple minScoreComp, HTuple numLevelsComp, HTuple angleStepComp, string optimizationComp, HTuple metricComp, HTuple pregenerationComp, out HTuple rootRanking)
public HComponentModel(HComponentTraining componentTrainingID, double angleStart, double angleExtent, int minContrastComp, double minScoreComp, int numLevelsComp, double angleStepComp, string optimizationComp, string metricComp, string pregenerationComp, out int rootRanking)
HTuple HComponentModel.CreateTrainedComponentModel(HComponentTraining componentTrainingID, double angleStart, double angleExtent, HTuple minContrastComp, HTuple minScoreComp, HTuple numLevelsComp, HTuple angleStepComp, string optimizationComp, HTuple metricComp, HTuple pregenerationComp)
int HComponentModel.CreateTrainedComponentModel(HComponentTraining componentTrainingID, double angleStart, double angleExtent, int minContrastComp, double minScoreComp, int numLevelsComp, double angleStepComp, string optimizationComp, string metricComp, string pregenerationComp)
def create_trained_component_model(component_training_id: HHandle, angle_start: float, angle_extent: float, min_contrast_comp: MaybeSequence[Union[int, str]], min_score_comp: MaybeSequence[float], num_levels_comp: MaybeSequence[Union[int, str]], angle_step_comp: MaybeSequence[Union[float, str]], optimization_comp: str, metric_comp: MaybeSequence[str], pregeneration_comp: MaybeSequence[str]) -> Tuple[HHandle, Sequence[int]]
def create_trained_component_model_s(component_training_id: HHandle, angle_start: float, angle_extent: float, min_contrast_comp: MaybeSequence[Union[int, str]], min_score_comp: MaybeSequence[float], num_levels_comp: MaybeSequence[Union[int, str]], angle_step_comp: MaybeSequence[Union[float, str]], optimization_comp: str, metric_comp: MaybeSequence[str], pregeneration_comp: MaybeSequence[str]) -> Tuple[HHandle, int]
Beschreibung
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model bereitet das
Trainingsergebnis, das in ComponentTrainingIDComponentTrainingIDComponentTrainingIDcomponentTrainingIDcomponent_training_id übergeben
wird, als Komponentenmodell für das Matching vor. Der
Ausgabeparameter ComponentModelIDComponentModelIDComponentModelIDcomponentModelIDcomponent_model_id ist ein Handle für dieses
Modell, der in nachfolgenden Aufrufen von
find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model verwendet wird. Im Gegensatz zu
create_component_modelcreate_component_modelCreateComponentModelCreateComponentModelcreate_component_model müssen die Modellkomponenten mit
train_model_componentstrain_model_componentsTrainModelComponentsTrainModelComponentstrain_model_components trainiert worden sein bevor
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model aufgerufen werden kann.
Die Parameter AngleStartAngleStartAngleStartangleStartangle_start und AngleExtentAngleExtentAngleExtentangleExtentangle_extent legen den
Winkelbereich für die möglichen Rotationen des Komponentenmodells im
Bild fest.
Im Wesentlichen wird intern für jede Modellkomponente ein separates
Formmodell erzeugt (siehe create_shape_modelcreate_shape_modelCreateShapeModelCreateShapeModelcreate_shape_model). Daher
entsprechen die Parameter MinContrastCompMinContrastCompMinContrastCompminContrastCompmin_contrast_comp,
MinScoreCompMinScoreCompMinScoreCompminScoreCompmin_score_comp, NumLevelsCompNumLevelsCompNumLevelsCompnumLevelsCompnum_levels_comp,
AngleStepCompAngleStepCompAngleStepCompangleStepCompangle_step_comp, OptimizationCompOptimizationCompOptimizationCompoptimizationCompoptimization_comp,
MetricCompMetricCompMetricCompmetricCompmetric_comp und PregenerationCompPregenerationCompPregenerationComppregenerationComppregeneration_comp den
Parametern in create_shape_modelcreate_shape_modelCreateShapeModelCreateShapeModelcreate_shape_model mit den folgenden
Unterschieden: Im Parameter OptimizationOptimizationOptimizationoptimizationoptimization von
create_shape_modelcreate_shape_modelCreateShapeModelCreateShapeModelcreate_shape_model kann neben einer möglichen Reduktion der
Modellpunkte auch entschieden werden, ob das Formmodell vollständig
vorab generiert wird oder nicht. Der Operator
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model bietet dagegen für die
Vorabgenerierung der Formmodelle einen separaten Parameter
PregenerationCompPregenerationCompPregenerationComppregenerationComppregeneration_comp. Ein zweiter Unterschied bezieht sich auf
den Parameter MinScoreCompMinScoreCompMinScoreCompminScoreCompmin_score_comp, der beim formbasierten Matching
nicht bereits beim Vorbereiten des Modells mit
create_shape_modelcreate_shape_modelCreateShapeModelCreateShapeModelcreate_shape_model sondern erst bei der Suche mit
find_shape_modelfind_shape_modelFindShapeModelFindShapeModelfind_shape_model übergeben wird. Beim Vorbereiten des
Komponentenmodells ist es jedoch vorteilhaft, auftretende
Rotationssymmetrien der Modellkomponenten und Ähnlichkeiten zwischen
den Modellkomponenten zu analysieren und beim Aufbau des
Komponentenmodells zu berücksichtigen. Diese Analyse kann jedoch nur
dann zu sinnvollen Ergebnissen führen, wenn der zur Suche verwendete
Wert für MinScoreCompMinScoreCompMinScoreCompminScoreCompmin_score_comp (siehe find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model)
bereits annähernd bekannt ist. Die von find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model
ermittelten Lagekoordinaten der Modellkomponenten in einem Suchbild
beziehen sich auf deren Referenzpunkt. Der Referenzpunkt einer
Modellkomponente ist festgelegt durch den Schwerpunkt der
entsprechenden von train_model_componentstrain_model_componentsTrainModelComponentsTrainModelComponentstrain_model_components in
ModelComponentsModelComponentsModelComponentsmodelComponentsmodel_components zurückgelieferten Region.
Die Parameter MinContrastCompMinContrastCompMinContrastCompminContrastCompmin_contrast_comp, NumLevelsCompNumLevelsCompNumLevelsCompnumLevelsCompnum_levels_comp,
AngleStepCompAngleStepCompAngleStepCompangleStepCompangle_step_comp und OptimizationCompOptimizationCompOptimizationCompoptimizationCompoptimization_comp können jeweils
durch die Angabe von 'auto'"auto""auto""auto""auto" automatisch ermittelt werden.
Alle komponentenspezifischen Eingabeparameter (Parameternamen enden
jeweils auf Comp) müssen entweder genau ein Element
enthalten oder dieselbe Anzahl von Elementen wie in
ComponentTrainingIDComponentTrainingIDComponentTrainingIDcomponentTrainingIDcomponent_training_id enthaltene Modellkomponenten. Im
ersten Fall wird der Wert des Eingabeparameters für alle
Modellkomponenten gleich verwendet. Im zweiten Fall wird das
jeweilige Element des Eingabeparameters für die entsprechende
Modellkomponente in ComponentTrainingIDComponentTrainingIDComponentTrainingIDcomponentTrainingIDcomponent_training_id verwendet.
Das Komponentenmodell enthält neben den einzelnen Formmodellen auch
die Information über die Art und Weise, wie die einzelnen
Modellkomponenten mit find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model relativ
zueinander gesucht werden müssen, damit die Rechenzeit während der
Suche minimal ist. Dabei werden die Komponenten durch eine
Baumstruktur repräsentiert. Zunächst wird die Komponente, die an der
Wurzel des Baumes (Wurzelkomponente) steht, gesucht. Anschließend
werden die übrigen Komponenten jeweils relativ zur Lage ihres
Vorgängers im Baum gesucht.
Die Wurzelkomponente kann bei der Suche mit find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model als
Parameter übergeben werden. Inwiefern sich eine Modellkomponente als
Wurzelkomponente eignet, hängt von verschiedenen Faktoren ab. Prinzipiell
sollte eine Modellkomponente gewählt werden, die mit hoher Wahrscheinlichkeit
im Bild wiedergefunden werden kann. Eine im Bild stark verdeckte oder
fehlende Komponente eignet sind daher nur bedingt als Wurzelkomponente. Auch
die mit der Wurzelkomponente verbundene Rechenzeit während der Suche kann als
Auswahlkriterium herangezogen werden. Eine nach diesem Kriterium sortierte
Rangfolge der Modellkomponenten wird im Parameter RootRankingRootRankingRootRankingrootRankingroot_ranking
zurückgeliefert. In diesem Parameter sind die Indizes der Modellkomponenten
nach der mit ihnen verbundenen Rechenzeit aufsteigend sortiert, d.h.
RootRankingRootRankingRootRankingrootRankingroot_ranking[0] enthält den Index der Modellkomponente, die - als
Wurzelkomponente gewählt - die schnellste Suche ermöglicht. Die in
RootRankingRootRankingRootRankingrootRankingroot_ranking ermittelte Reihenfolge stellt jedoch nur eine grobe
Abschätzung dar. Die Abschätzung setzt außerdem voraus, dass sowohl die
Bildgröße als auch der Wert des Systemparameters
'border_shape_models'"border_shape_models""border_shape_models""border_shape_models""border_shape_models" beim Aufruf von
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model und find_component_modelfind_component_modelFindComponentModelFindComponentModelfind_component_model
identisch sind.
Ausführungsinformationen
- Multithreading-Typ: reentrant (läuft parallel zu nicht-exklusiven Operatoren).
- Multithreading-Bereich: global (kann von jedem Thread aufgerufen werden).
- Wird ohne Parallelisierung verarbeitet.
Dieser Operator liefert ein Handle zurück. Es ist zu beachten, dass der Zustand einer Instanz dieses Handletyps durch bestimmte Operatoren geändert werden kann, obwohl das Handle als Eingabeparameter in diesen Operatoren verwendet wird.
Parameter
ComponentTrainingIDComponentTrainingIDComponentTrainingIDcomponentTrainingIDcomponent_training_id (input_control) component_training → HComponentTraining, HTupleHHandleHTupleHtuple (handle) (IntPtr) (HHandle) (handle)
Handle des Trainingsergebnisses.
AngleStartAngleStartAngleStartangleStartangle_start (input_control) angle.rad → HTuplefloatHTupleHtuple (real) (double) (double) (double)
Kleinste auftretende Rotation des Komponentenmodells.
Default:
-0.39
Wertevorschläge:
-3.14, -1.57, -0.79, -0.39, -0.20, 0.0
AngleExtentAngleExtentAngleExtentangleExtentangle_extent (input_control) angle.rad → HTuplefloatHTupleHtuple (real) (double) (double) (double)
Ausdehnung des Winkelbereichs.
Default:
0.79
Wertevorschläge:
6.28, 3.14, 1.57, 0.79, 0.39
Restriktion:
AngleExtent >= 0
MinContrastCompMinContrastCompMinContrastCompminContrastCompmin_contrast_comp (input_control) integer(-array) → HTupleMaybeSequence[Union[int, str]]HTupleHtuple (integer / string) (int / long / string) (Hlong / HString) (Hlong / char*)
Minimaler Kontrast der Komponenten in den Suchbildern.
Default:
'auto'
"auto"
"auto"
"auto"
"auto"
Wertevorschläge:
'auto'"auto""auto""auto""auto", 10, 20, 20, 40
Restriktion:
MinContrastComp >= 0
MinScoreCompMinScoreCompMinScoreCompminScoreCompmin_score_comp (input_control) real(-array) → HTupleMaybeSequence[float]HTupleHtuple (real) (double) (double) (double)
Minimale Bewertung der zu findenden Instanzen der
Komponenten.
Default:
0.5
Wertevorschläge:
0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0
Minimale Schrittweite:
0.01
Empfohlene Schrittweite:
0.05
Restriktion:
0 <= MinScoreComp && MinScoreComp <= 1
NumLevelsCompNumLevelsCompNumLevelsCompnumLevelsCompnum_levels_comp (input_control) integer(-array) → HTupleMaybeSequence[Union[int, str]]HTupleHtuple (integer / string) (int / long / string) (Hlong / HString) (Hlong / char*)
Maximale Anzahl von Pyramidenebenen für die
Komponenten.
Default:
'auto'
"auto"
"auto"
"auto"
"auto"
Werteliste:
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'auto'"auto""auto""auto""auto"
AngleStepCompAngleStepCompAngleStepCompangleStepCompangle_step_comp (input_control) angle.rad(-array) → HTupleMaybeSequence[Union[float, str]]HTupleHtuple (real / string) (double / string) (double / HString) (double / char*)
Schrittweite der Winkel (Auflösung) für die
Komponenten.
Default:
'auto'
"auto"
"auto"
"auto"
"auto"
Wertevorschläge:
'auto'"auto""auto""auto""auto", 0.0175, 0.0349, 0.0524, 0.0698, 0.0873
Restriktion:
AngleStepComp >= 0
OptimizationCompOptimizationCompOptimizationCompoptimizationCompoptimization_comp (input_control) string → HTuplestrHTupleHtuple (string) (string) (HString) (char*)
Art der Optimierung für die Komponenten.
Default:
'auto'
"auto"
"auto"
"auto"
"auto"
Werteliste:
'auto'"auto""auto""auto""auto", 'none'"none""none""none""none", 'point_reduction_high'"point_reduction_high""point_reduction_high""point_reduction_high""point_reduction_high", 'point_reduction_low'"point_reduction_low""point_reduction_low""point_reduction_low""point_reduction_low", 'point_reduction_medium'"point_reduction_medium""point_reduction_medium""point_reduction_medium""point_reduction_medium"
MetricCompMetricCompMetricCompmetricCompmetric_comp (input_control) string(-array) → HTupleMaybeSequence[str]HTupleHtuple (string) (string) (HString) (char*)
Art der zum Matchen der Komponenten verwendeten Metrik.
Default:
'use_polarity'
"use_polarity"
"use_polarity"
"use_polarity"
"use_polarity"
Werteliste:
'ignore_color_polarity'"ignore_color_polarity""ignore_color_polarity""ignore_color_polarity""ignore_color_polarity", 'ignore_global_polarity'"ignore_global_polarity""ignore_global_polarity""ignore_global_polarity""ignore_global_polarity", 'ignore_local_polarity'"ignore_local_polarity""ignore_local_polarity""ignore_local_polarity""ignore_local_polarity", 'use_polarity'"use_polarity""use_polarity""use_polarity""use_polarity"
PregenerationCompPregenerationCompPregenerationComppregenerationComppregeneration_comp (input_control) string(-array) → HTupleMaybeSequence[str]HTupleHtuple (string) (string) (HString) (char*)
Komplette Vorabgenerierung der Formmodelle für die
Komponenten falls 'true'"true""true""true""true".
Default:
'false'
"false"
"false"
"false"
"false"
Werteliste:
'false'"false""false""false""false", 'true'"true""true""true""true"
ComponentModelIDComponentModelIDComponentModelIDcomponentModelIDcomponent_model_id (output_control) component_model → HComponentModel, HTupleHHandleHTupleHtuple (handle) (IntPtr) (HHandle) (handle)
Handle des Komponentenmodells.
RootRankingRootRankingRootRankingrootRankingroot_ranking (output_control) integer(-array) → HTupleSequence[int]HTupleHtuple (integer) (int / long) (Hlong) (Hlong)
Reihenfolge der Modellkomponenten, die deren
Eignung als Wurzelkomponente zu fungieren ausdrückt.
Ergebnis
Sind die Parameterwerte korrekt, dann liefert
create_trained_component_modelcreate_trained_component_modelCreateTrainedComponentModelCreateTrainedComponentModelcreate_trained_component_model den Wert 2 (
H_MSG_TRUE)
.
Gegebenenfalls wird eine Fehlerbehandlung durchgeführt.
Modul
Matching