Operator Reference

set_spyset_spySetSpySetSpyset_spy (Operator)

set_spyset_spySetSpySetSpyset_spy — Control of the HALCON Debugging Tools.

Signature

set_spy( : : Class, Value : )

Herror set_spy(const char* Class, const char* Value)

Herror T_set_spy(const Htuple Class, const Htuple Value)

void SetSpy(const HTuple& Class, const HTuple& Value)

static void HSystem::SetSpy(const HString& Class, const HTuple& Value)

static void HSystem::SetSpy(const HString& Class, const HString& Value)

static void HSystem::SetSpy(const char* Class, const char* Value)

static void HSystem::SetSpy(const wchar_t* Class, const wchar_t* Value)   ( Windows only)

static void HOperatorSet.SetSpy(HTuple classVal, HTuple value)

static void HSystem.SetSpy(string classVal, HTuple value)

static void HSystem.SetSpy(string classVal, string value)

def set_spy(class_val: str, value: Union[str, int, float]) -> None

Description

The operator set_spyset_spySetSpySetSpyset_spy is the HALCON debugging tool. This tool allows the flexible control of the input and output data of HALCON-operators - in graphical as well as in textual form. The data control is activated by using

set_spy(::'mode','on':)set_spy("mode","on")SetSpy("mode","on")SetSpy("mode","on")set_spy("mode","on"),

and deactivated by using

set_spy(::'mode','off':)set_spy("mode","off")SetSpy("mode","off")SetSpy("mode","off")set_spy("mode","off").

The debugging tool can further be activated with the help of the environment variable HALCONSPY. The definition of this variable corresponds to calling up 'mode'"mode""mode""mode""mode" and 'on'"on""on""on""on".

The following control modes (ClassClassClassclassValclass) can be tuned using ValueValueValuevaluevalue:

ClassClassClassclassValclass = 'operator'"operator""operator""operator""operator"

When a routine is called, its name and the names of its parameters will be given (in TRIAS notation).

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'input_control'"input_control""input_control""input_control""input_control"

When a routine is called, the names and values of the input control parameters will be given.

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'output_control'"output_control""output_control""output_control""output_control"

When a routine is called, the names and values of the output control parameters are given.

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'parameter_values'"parameter_values""parameter_values""parameter_values""parameter_values"

Additional information on 'input_control'"input_control""input_control""input_control""input_control" and 'output_control'"output_control""output_control""output_control""output_control": indicates how many values per parameter shall be displayed at most (maximum tuple length of the output).

ValueValueValuevaluevalue: tuple length (integer)

Default: 4

ClassClassClassclassValclass = 'db'"db""db""db""db"

Information concerning the 4 relations in the HALCON-database. This is especially valuable in looking for forgotten clear_objclear_objClearObjClearObjclear_obj.

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'time'"time""time""time""time"

Processing time of the operator

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'log_file'"log_file""log_file""log_file""log_file"

Spy can hereby divert the text output into a file having been opened with open_file.

ValueValueValuevaluevalue: a file handle (see open_fileopen_fileOpenFileOpenFileopen_file)

ClassClassClassclassValclass = 'error'"error""error""error""error"

If 'error'"error""error""error""error" is activated and an internal error occurs, spy will show the internal procedures (file/line) concerned.

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

ClassClassClassclassValclass = 'internal'"internal""internal""internal""internal"

If 'internal'"internal""internal""internal""internal" is activated, spy will display the internal procedures and their parameters (file/line) while an HALCON-operator is processed.

ValueValueValuevaluevalue: 'on'"on""on""on""on" or 'off'"off""off""off""off".

Default: 'off'"off""off""off""off".

Each output starts with the thread handle, followed by a global counter that marks the order of the outputs. In multi-threaded applications, this information can be used to assign the output to individual user threads and to reconstruct the chronological sequence.

Attention

Note that under Windows the output on stdout works only in combination with a console application.

Execution Information

  • Multithreading type: exclusive (runs in parallel only with independent operators).
  • Multithreading scope: global (may be called from any thread).
  • Processed without parallelization.

Parameters

ClassClassClassclassValclass (input_control)  string HTuplestrHTupleHtuple (string) (string) (HString) (char*)

Control mode

Default: 'mode' "mode" "mode" "mode" "mode"

List of values: 'db'"db""db""db""db", 'error'"error""error""error""error", 'input_control'"input_control""input_control""input_control""input_control", 'internal'"internal""internal""internal""internal", 'log_file'"log_file""log_file""log_file""log_file", 'mode'"mode""mode""mode""mode", 'operator'"operator""operator""operator""operator", 'output_control'"output_control""output_control""output_control""output_control", 'parameter_values'"parameter_values""parameter_values""parameter_values""parameter_values", 'time'"time""time""time""time"

ValueValueValuevaluevalue (input_control)  string HTupleUnion[str, int, float]HTupleHtuple (string / integer / real) (string / int / long / double) (HString / Hlong / double) (char* / Hlong / double)

State of the control mode to be set.

Default: 'on' "on" "on" "on" "on"

Suggested values: 'on'"on""on""on""on", 'off'"off""off""off""off", 1, 2, 3, 4, 5, 10, 50, 0.0, 1.0, 2.0, 5.0, 10.0

Example (C)

/* init spy: Setting of the wished control modi */
set_spy("mode","on");
set_spy("operator","on");
set_spy("input_control","on");
set_spy("output_control","on");
/* calling of program section, that will be examined */
set_spy("mode","off");  

Result

The operator set_spyset_spySetSpySetSpyset_spy returns the value 2 ( H_MSG_TRUE) if the parameters are correct. Otherwise an exception is raised.

Possible Predecessors

reset_obj_dbreset_obj_dbResetObjDbResetObjDbreset_obj_db

See also

get_spyget_spyGetSpyGetSpyget_spy, query_spyquery_spyQuerySpyQuerySpyquery_spy

Module

Foundation