set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info (Operator)
set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info
— Set AOP information for operators.
Signature
void SetAopInfo(const HTuple& OperatorName, const HTuple& IndexName, const HTuple& IndexValue, const HTuple& InfoName, const HTuple& InfoValue)
static void HSystem::SetAopInfo(const HTuple& OperatorName, const HTuple& IndexName, const HTuple& IndexValue, const HString& InfoName, const HTuple& InfoValue)
static void HSystem::SetAopInfo(const HString& OperatorName, const HString& IndexName, const HString& IndexValue, const HString& InfoName, Hlong InfoValue)
static void HSystem::SetAopInfo(const char* OperatorName, const char* IndexName, const char* IndexValue, const char* InfoName, Hlong InfoValue)
static void HSystem::SetAopInfo(const wchar_t* OperatorName, const wchar_t* IndexName, const wchar_t* IndexValue, const wchar_t* InfoName, Hlong InfoValue)
(
Windows only)
static void HOperatorSet.SetAopInfo(HTuple operatorName, HTuple indexName, HTuple indexValue, HTuple infoName, HTuple infoValue)
static void HSystem.SetAopInfo(HTuple operatorName, HTuple indexName, HTuple indexValue, string infoName, HTuple infoValue)
static void HSystem.SetAopInfo(string operatorName, string indexName, string indexValue, string infoName, int infoValue)
Description
HALCON supports a mechanism to adapt the behavior of automatic
parallelization of image processing operators (AOP) to the machine's
hardware capability. The
information for this adaption can be obtained by the operator
optimize_aopoptimize_aopOptimizeAopOptimizeAopoptimize_aop
and can also be partly read by the operator
set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info
.
To address specific AOP information the operator's optimization data
is indexed within
a 3-ary hierarchy that can be obtained by query_aop_infoquery_aop_infoQueryAopInfoQueryAopInfoquery_aop_info
. The
three hierarchy stages are indexed by the operator name, passed in
OperatorNameOperatorNameOperatorNameoperatorNameoperator_name
, the iconic type, and
a parameter string value denoting a special mode or method supported by
the indexed operator. The latter two indices are passed by
IndexNameIndexNameIndexNameindexNameindex_name
and IndexValueIndexValueIndexValueindexValueindex_value
. IndexNameIndexNameIndexNameindexNameindex_name
holds the dimension
identifier whereas IndexValueIndexValueIndexValueindexValueindex_value
addresses the index as returned
in query_aop_infoquery_aop_infoQueryAopInfoQueryAopInfoquery_aop_info
. It is also possible to address multiple indices
on the same stage to set a specific information value to multiple knowledge
sets. Omitting an index name or passing an empty string as index value
addresses this stage in all. E.g., passing ''"""""""" to
OperatorNameOperatorNameOperatorNameoperatorNameoperator_name
, the tuple ['iconic_type','iconic_type']["iconic_type","iconic_type"]["iconic_type","iconic_type"]["iconic_type","iconic_type"]["iconic_type","iconic_type"] to
IndexNameIndexNameIndexNameindexNameindex_name
, and the tuple ['byte','uint2']["byte","uint2"]["byte","uint2"]["byte","uint2"]["byte","uint2"] to
IndexValueIndexValueIndexValueindexValueindex_value
addresses all operators processing byte or uint2
images.
set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info
sets the specific information parts of an operator's
AOP knowledge passed in InfoValueInfoValueInfoValueinfoValueinfo_value
. The scope of information is
specified by InfoNameInfoNameInfoNameinfoNameinfo_name
and supports the following:
- 'max_threads'"max_threads""max_threads""max_threads""max_threads"
sets the maximum allowed thread number
this operator is allowed to run with the specified iconic type and
parameter value.
- 'split_level'"split_level""split_level""split_level""split_level"
sets the allowed data
split levels of the automatic parallelization for this operator, the
specified iconic type and parameter value. Possible levels are
'split_tuple'"split_tuple""split_tuple""split_tuple""split_tuple", 'split_channel'"split_channel""split_channel""split_channel""split_channel",
'split_domain'"split_domain""split_domain""split_domain""split_domain", and 'split_partial'"split_partial""split_partial""split_partial""split_partial".
Attention
set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info
modifies the AOP system knowledge. These modifications
will also be stored by write_aop_knowledgewrite_aop_knowledgeWriteAopKnowledgeWriteAopKnowledgewrite_aop_knowledge
. It is advisable to
have a backup knowledge file before modifying the system knowledge.
Execution Information
- Multithreading type: exclusive (runs in parallel only with independent operators).
- Multithreading scope: local (may only be called from the same thread in which the window, model, or tool instance was created).
- Processed without parallelization.
Parameters
OperatorNameOperatorNameOperatorNameoperatorNameoperator_name
(input_control) string(-array) →
HTupleMaybeSequence[Union[str, int]]HTupleHtuple (string / integer) (string / int / long) (HString / Hlong) (char* / Hlong)
Operator to set information to
Default:
''
""
""
""
""
IndexNameIndexNameIndexNameindexNameindex_name
(input_control) string(-array) →
HTupleMaybeSequence[Union[str, int]]HTupleHtuple (string / integer) (string / int / long) (HString / Hlong) (char* / Hlong)
Further specific index
Default:
''
""
""
""
""
Suggested values:
'iconic_type'"iconic_type""iconic_type""iconic_type""iconic_type", ['iconic_type','parameter:0']["iconic_type","parameter:0"]["iconic_type","parameter:0"]["iconic_type","parameter:0"]["iconic_type","parameter:0"]
IndexValueIndexValueIndexValueindexValueindex_value
(input_control) string(-array) →
HTupleMaybeSequence[Union[str, int]]HTupleHtuple (string / integer) (string / int / long) (HString / Hlong) (char* / Hlong)
Further specific address
Number of elements:
IndexName == IndexValue
Default:
''
""
""
""
""
Suggested values:
'byte'"byte""byte""byte""byte", ['uint2','']["uint2",""]["uint2",""]["uint2",""]["uint2",""]
InfoNameInfoNameInfoNameinfoNameinfo_name
(input_control) string →
HTuplestrHTupleHtuple (string) (string) (HString) (char*)
Scope of information
Default:
'max_threads'
"max_threads"
"max_threads"
"max_threads"
"max_threads"
Suggested values:
'max_threads'"max_threads""max_threads""max_threads""max_threads", 'model'"model""model""model""model"
InfoValueInfoValueInfoValueinfoValueinfo_value
(input_control) integer(-array) →
HTupleMaybeSequence[int]HTupleHtuple (integer) (int / long) (Hlong) (Hlong)
AOP information value
Result
set_aop_infoset_aop_infoSetAopInfoSetAopInfoset_aop_info
returns 2 (
H_MSG_TRUE)
if all parameters are correct.
If necessary, an exception is raised.
Module
Foundation