Inference processor

Inference processor

Uses a pre-trained data frame analytics model to infer against the data that is being ingested in the pipeline.

Table 25. Inference Options

NameRequiredDefaultDescription

model_id

yes

-

(String) The ID or alias for the trained model.

target_field

no

ml.inference.<processor_tag>

(String) Field added to incoming documents to contain results objects.

field_map

no

If defined the model’s default field map

(Object) Maps the document field names to the known field names of the model. This mapping takes precedence over any default mappings provided in the model configuration.

inference_config

no

The default settings defined in the model

(Object) Contains the inference type and its options. There are two types: regression and classification.

description

no

-

Description of the processor. Useful for describing the purpose of the processor or its configuration.

if

no

-

Conditionally execute the processor. See Conditionally run a processor.

ignore_failure

no

false

Ignore failures for the processor. See Handling pipeline failures.

on_failure

no

-

Handle failures for the processor. See Handling pipeline failures.

tag

no

-

Identifier for the processor. Useful for debugging and metrics.

  1. {
  2. "inference": {
  3. "model_id": "flight_delay_regression-1571767128603",
  4. "target_field": "FlightDelayMin_prediction_infer",
  5. "field_map": {
  6. "your_field": "my_field"
  7. },
  8. "inference_config": { "regression": {} }
  9. }
  10. }

Regression configuration options

Regression configuration for inference.

results_field

(Optional, string) The field that is added to incoming documents to contain the inference prediction. Defaults to the results_field value of the data frame analytics job that was used to train the model, which defaults to <dependent_variable>_prediction.

num_top_feature_importance_values

(Optional, integer) Specifies the maximum number of feature importance values per document. By default, it is zero and no feature importance calculation occurs.

Classification configuration options

Classification configuration for inference.

num_top_classes

(Optional, integer) Specifies the number of top class predictions to return. Defaults to 0.

num_top_feature_importance_values

(Optional, integer) Specifies the maximum number of feature importance values per document. By default, it is zero and no feature importance calculation occurs.

results_field

(Optional, string) The field that is added to incoming documents to contain the inference prediction. Defaults to the results_field value of the data frame analytics job that was used to train the model, which defaults to <dependent_variable>_prediction.

top_classes_results_field

(Optional, string) Specifies the field to which the top classes are written. Defaults to top_classes.

prediction_field_type

(Optional, string) Specifies the type of the predicted field to write. Acceptable values are: string, number, boolean. When boolean is provided 1.0 is transformed to true and 0.0 to false.

inference_config examples

  1. "inference":{
  2. "model_id":"my_model_id"
  3. "inference_config": {
  4. "regression": {
  5. "results_field": "my_regression"
  6. }
  7. }
  8. }

This configuration specifies a regression inference and the results are written to the my_regression field contained in the target_field results object.

  1. "inference":{
  2. "model_id":"my_model_id"
  3. "inference_config": {
  4. "classification": {
  5. "num_top_classes": 2,
  6. "results_field": "prediction",
  7. "top_classes_results_field": "probabilities"
  8. }
  9. }
  10. }

This configuration specifies a classification inference. The number of categories for which the predicted probabilities are reported is 2 (num_top_classes). The result is written to the prediction field and the top classes to the probabilities field. Both fields are contained in the target_field results object.

Refer to the language identification trained model documentation for a full example.

Feature importance object mapping

To get the full benefit of aggregating and searching for feature importance, update your index mapping of the feature importance result field as you can see below:

  1. "ml.inference.feature_importance": {
  2. "type": "nested",
  3. "dynamic": true,
  4. "properties": {
  5. "feature_name": {
  6. "type": "keyword"
  7. },
  8. "importance": {
  9. "type": "double"
  10. }
  11. }
  12. }

The mapping field name for feature importance (in the example above, it is ml.inference.feature_importance) is compounded as follows:

<ml.inference.target_field>.<inference.tag>.feature_importance

  • <ml.inference.target_field>: defaults to ml.inference.
  • <inference.tag>: if is not provided in the processor definition, then it is not part of the field path.

For example, if you provide a tag foo in the definition as you can see below:

  1. {
  2. "tag": "foo",
  3. ...
  4. }

Then, the feature importance value is written to the ml.inference.foo.feature_importance field.

You can also specify the target field as follows:

  1. {
  2. "tag": "foo",
  3. "target_field": "my_field"
  4. }

In this case, feature importance is exposed in the my_field.foo.feature_importance field.