Click here to show toolbars of the Web Online Help System: show toolbars |
MIL_ID ContextOrResultPatId, | //in |
MIL_INT Index, | //in |
MIL_INT64 ControlType, | //in |
MIL_DOUBLE ControlValue | //in |
This function allows you to control a setting of a Pattern Matching context, at least one (or all) of the models contained therein, or a Pattern Matching result buffer. These settings control the execution of MpatFind() operations. Most of the control type settings can be inquired using MpatInquire().
Changing certain control type settings might require preprocessing of the Pattern Matching context again, using MpatPreprocess(). To know if the Pattern Matching context needs to be preprocessed, call MpatInquire() with M_PREPROCESSED, after adjusting all required control types.
Any value that you provide to the MIL Pattern Matching module (for example, position and width) must be specified in the pixel coordinate system, even if the target image is calibrated.
You can change the search region at any time without preprocesing the Pattern Matching context again (for example, when tracking an object, the search region could be changed before each call to MpatFind()).
Specifies the Pattern Matching context or Pattern Matching result buffer whose settings you want to modify. The Pattern Matching context or result buffer must have been previously allocated on the system using MpatAlloc() or MpatAllocResult(), respectively.
Specifies to control a Pattern Matching context, an individual model, or a Pattern Matching result buffer. Set this parameter to one of the following values:
![]() |
|||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Description | ||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Applies the specified control setting to all models, if a Pattern Matching context is specified. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Controls a general setting of a specified Pattern Matching context, if one is specified. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Controls a general setting of a Pattern Matching result buffer when ContextOrResultPatId is a result buffer. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the index of the individual model to control, if a Pattern Matching context is specified. |
Specifies the setting to change.
See the Parameter associations section for possible values that can be specified.
Specifies the setting's new value.
See the Parameter associations section for possible values that can be specified.
The tables below list possible values for the ControlType and ControlValue parameters.
The following control type and control value allows you specify general settings for a Pattern Matching context. For controlling general context settings, the Index parameter must be set to M_CONTEXT.
![]() |
|||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Description | ||||||||||||||||||||||||||||||||||||||
ControlValue | |||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the search mode to use when performing an MpatFind() operation. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_FIND_ALL_MODELS. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to search for all the specified models in the target image using their own search settings. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to search for the best occurrences of any model in the target image, using the search settings from the first model in the Pattern Matching context. |
The following control types and control values allow you to control the settings for an individual model or all models in a Pattern Matching context. For controlling the settings of one or all models, the Index parameter must be set to the model index of a specific model in the Pattern Matching context or to M_ALL, respectively.
![]() |
|||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Description | ||||||||||||||||||||||||||||||||||||||
ControlValue | |||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the acceptance level. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the acceptance level, as a percentage. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the required positional accuracy. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a high accuracy (typically ± 0.05 pixels). |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a low accuracy (typically ± 0.20 pixels). |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a medium accuracy (typically ± 0.10 pixels). |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the certainty level. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the certainty level, as a percentage. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the maximum expected number of occurrences of a model in a target image. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to look for all matches that are greater than or equal to the acceptance level. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the maximum number of occurrences for which to look in the target image. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the X-offset of the model's reference position, relative to the model origin. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the X-offset of the model's reference position relative to the model origin, in pixels. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the Y-offset of the model's reference position, relative to the model origin. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the Y-offset of the model's reference position relative to the model origin, in pixels. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether to use angle refinement mode, as well as sets the score to use for this mode. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_DISABLE. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to disable the angle refinement mode. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the minimum score. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the nominal search angle at which to search for occurrences of the model. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default value; the default value is 0.0. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the nominal search angle, in degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the required precision with which to find the angle of the occurrence. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_DISABLE. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the angle accuracy equals the tolerance. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the angle accuracy, in degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the lower limit for the angular range, relative to the nominal search angle (set using M_SEARCH_ANGLE). INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default value. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the angle in a clockwise rotation, in degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the upper limit for the angular range, relative to the nominal search angle (set using M_SEARCH_ANGLE). INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default value. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the angle in a counter-clockwise rotation, in degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the type of interpolation to use when rotating the model to perform the search at an angle. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_NEAREST_NEIGHBOR. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that bicubic interpolation is used when rotating the model. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that bilinear interpolation is used when rotating the model. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that nearest-neighbor interpolation is used when rotating the model. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether to perform calculations specific to angular-range search strategies. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to disable the angular search mode. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to enable the angular search mode. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the full range of degrees within which the pattern in the target image can be rotated from a model at a specific angle and still meet the acceptance level. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default value; the default value is 5.0 degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the tolerance will be automatically determined based on an analysis of the model. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the step angle, in degrees. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the X-offset of the specified model's search region. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the X-coordinate of the top-left corner of the target image. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the X-coordinate, relative to the pixel coordinate system, of where to start the search. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the Y-offset of the specified model's search region. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the Y-coordinate of the top-left corner of the target image. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the Y-coordinate, relative to the pixel coordinate system, of where to start the search. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the width of the search region. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_ALL. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use the width of the full image. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the width, in pixels. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the height of the search region. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_ALL. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use the height of the full image. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the height, in pixels. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the required search speed when using MpatFind(). INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a high search speed. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a low search speed. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a medium search speed. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a very high search speed. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies a very low search speed. |
The following control types and control values are for advanced users of the Pattern Matching module. If the default settings do not satisfy the requirements of your application, these control types and control values can be used to fine tune the model's search settings. The default settings typically provide the best results for most search operations. To gain a clearer understanding of how the search algorithm works, see the The pattern matching algorithm (for advanced users) section of Chapter 7: Pattern matching.
For these control types, the Index parameter must be set to the model index of a specific model in the Pattern Matching context or M_ALL.
![]() |
|||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Description | ||||||||||||||||||||||||||||||||||||||
ControlValue | |||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the coarse search acceptance threshold level to use for rejecting candidate model peaks at low resolution levels. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to determine the coarse search acceptance threshold level automatically. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the coarse search acceptance threshold level. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the number of extra candidates to consider. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the default value; the default value is 0. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the number of extra candidates. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether to use fast peak finding. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use preprocessing to decide if fast peak finding is appropriate. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies not to use fast peak finding. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use fast peak finding. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the resolution level for the initial stage (lowest resolution) of the search. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_AUTO_SIZE_BASED. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to automatically determine the first level based on an analysis of the model contents. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to automatically determine the first level based on the model size. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the first level, where MaxLevel is the maximum possible level. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the resolution level for the final stage (highest resolution) of the search. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the last level automatically. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the last level, where MaxLevel is the maximum possible level. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the maximum number of returned peaks after an initial search at the first level for occurrences of multiple models, or a single model with circular overscan data (that is, M_AUTO_MODEL or M_REGULAR_MODEL with M_CIRCULAR_OVERSCAN). INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to limit the returned number of peaks for optimal performance. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies all occurrences that pass the model acceptance threshold should be returned. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the minimum separation (in X) between two models in order for them to be considered distinct. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the minimum separation to 75% of the model width (Param3 of MpatDefine()) when creating a M_REGULAR_MODEL. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the minimum separation. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the minimum separation (in Y) between two models in order for them to be considered distinct. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets the minimum separation to 75% of the model height ( Param4 of MpatDefine()) when creating a M_REGULAR_MODEL). |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies the minimum separation. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether all or every second pixel in the model is used in the correlation during the high resolution stage of the search. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to automatically establish the model step. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use all model pixels. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies to use every second model pixel (in both the X and Y directions). |
The following control types and control values settings can be specified for a Pattern Matching result buffer. For controlling the settings of a Pattern Matching result buffer, the Index parameter must be set to M_GENERAL.
![]() |
|||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Description | ||||||||||||||||||||||||||||||||||||||
ControlValue | |||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether to return results in pixels or world units. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_ACCORDING_TO_CALIBRATION. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that results are returned in world units if the result was calculated on an image associated with a camera calibration context; otherwise, it specifies that results are returned in pixel units. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that results are returned in pixel units, with respect to the pixel coordinate system. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that results are returned in world units, with respect to the relative coordinate system. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether to save the values of the sums used to compute the normalized correlation result for each model occurrence. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the sums are not saved. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the sums are saved. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Sets whether the pyramidal representation of the target buffer is kept in the result buffer or generated each time MpatFind() is called. INQ |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Same as M_ENABLE. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the pyramidal representation of the target buffer is generated each time MpatFind() is called. |
||||||||||||||||||||||||||||||||||||||
![]() ![]() |
Specifies that the pyramidal representation of the target buffer is kept in the result buffer. |
void MpatControlInt64
(MIL_ID
ContextOrResultPatId, MIL_INT Index,
MIL_INT64 ControlType,
MIL_INT64 ControlValue)
Parameters
ContextOrResultPatId See ContextOrResultPatId of the main function for a description. Index See Index of the main function for a description. ControlType See ControlType of the main function for a description. ControlValue See ControlValue of the main function for a description. |
void MpatControlDouble
(MIL_ID
ContextOrResultPatId, MIL_INT Index,
MIL_INT64 ControlType,
MIL_DOUBLE ControlValue)
Parameters
ContextOrResultPatId See ContextOrResultPatId of the main function for a description. Index See Index of the main function for a description. ControlType See ControlType of the main function for a description. ControlValue See ControlValue of the main function for a description. |
Header | Include mil.h. |
Library | Use mil.lib; milpat.lib. |
DLL | Requires mil.dll; milpat.dll. |