ClassificationKNN Predict
Libraries:
      Statistics and Machine Learning Toolbox / 
      Classification
   
Description
The ClassificationKNN Predict block classifies observations using a nearest
      neighbor classification object (ClassificationKNN) for multiclass
      classification.
Import a trained classification object into the block by specifying the name of a workspace variable that contains the object. The input port x receives an observation (predictor data), and the output port label returns a predicted class label for the observation. The optional output score returns the predicted class scores or posterior probabilities. The optional output cost returns the expected classification costs.
Examples
Predict Class Labels Using ClassificationKNN Predict Block
Train a nearest neighbor classification model, and then use the ClassificationKNN Predict block for label prediction.
Ports
Input
Predictor data, specified as a row or column vector of one observation.
The variables in x must have the same order as the predictor variables that trained the model specified by Select trained machine learning model.
Data Types: single | double | half | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point
Output
Predicted class label, returned as a scalar. The predicted class is the class that
              minimizes the expected classification cost. For more details, see the Algorithms
              section of the predict object function.
Data Types: single | double | half | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point | enumerated
Predicted class scores or posterior probabilities, returned as a row vector of
              size 1-by-k, where k is the number of classes in
              the nearest neighbor model. The classification score Score(i)
              represents the posterior probability that the observation in x
              belongs to class i.
To check the order of the classes, use the ClassNames
              property of the nearest neighbor model specified by Select trained machine
                learning model.
Dependencies
To enable this port, select the check box for Add output port for predicted class scores on the Main tab of the Block Parameters dialog box.
Data Types: single | double | half | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point
Expected classification costs, returned as a row vector of size
                1-by-k, where k is the number of classes in
              the nearest neighbor model. The classification cost Cost(i)
              represents the cost of classifying the observation in x to class
                i.
To check the order of the classes, use the ClassNames
              property of the nearest neighbor model specified by Select trained machine
                learning model.
Dependencies
To enable this port, select the check box for Add output port for expected classification cost on the Main tab of the Block Parameters dialog box.
Data Types: single | double | half | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point
Parameters
Main
Specify the name of a workspace variable that contains a ClassificationKNN object.
When you train the model by using fitcknn, the following restrictions apply:
- The predictor data cannot include categorical predictors ( - logical,- categorical,- char,- string, or- cell). If you supply training data in a table, the predictors must be numeric (- doubleor- single). Also, you cannot use the- CategoricalPredictorsname-value argument. To include categorical predictors in a model, preprocess them by using- dummyvarbefore fitting the model.
- The value of the - ScoreTransformname-value argument cannot be- "invlogit"or an anonymous function.
Programmatic Use
| Block Parameter: TrainedLearner | 
| Type: workspace variable | 
| Values: ClassificationKNNobject | 
| Default: 'knnMdl' | 
Select the check box to include the output port score in the ClassificationKNN Predict block.
Programmatic Use
| Block Parameter: ShowOutputScore | 
| Type: character vector | 
| Values: 'off' | 'on' | 
| Default: 'off' | 
Select the check box to include the output port cost in the ClassificationKNN Predict block.
Programmatic Use
| Block Parameter: ShowOutputCost | 
| Type: character vector | 
| Values: 'off' | 'on' | 
| Default: 'off' | 
Data Types
Fixed-Point Operational Parameters
Specify the rounding mode for fixed-point operations. For more information, see Rounding Modes (Fixed-Point Designer).
Block parameters always round to the nearest representable value. To control the rounding of a block parameter, enter an expression into the mask field using a MATLAB® rounding function.
Programmatic Use
| Block Parameter: RndMeth | 
| Type: character vector | 
| Values: "Ceiling" | "Convergent" | "Floor" | "Nearest" | "Round" | "Simplest" |
                        "Zero" | 
| Default: "Floor" | 
Specify whether overflows saturate or wrap.
| Action | Rationale | Impact on Overflows | Example | 
|---|---|---|---|
| Select this check box
                                ( | Your model has possible overflow, and you want explicit saturation protection in the generated code. | Overflows saturate to either the minimum or maximum value that the data type can represent. | The maximum value that the  | 
| Clear this check box
                                ( | You want to optimize the efficiency of your generated code. You want to avoid overspecifying how a block handles out-of-range signals. For more information, see Troubleshoot Signal Range Errors (Simulink). | Overflows wrap to the appropriate value that the data type can represent. | The maximum value that the  | 
Programmatic Use
| Block Parameter: SaturateOnIntegerOverflow | 
| Type: character vector | 
| Values: "off" | "on" | 
| Default: "off" | 
Select this parameter to prevent the fixed-point tools from overriding the data type you specify for the block. For more information, see Use Lock Output Data Type Setting (Fixed-Point Designer).
Programmatic Use
| Block Parameter: LockScale | 
| Type: character vector | 
| Values: "off" | "on" | 
| Default: "off" | 
Data Type
Specify the data type for the label output. The type can be
            inherited, specified as an enumerated data type, or
            expressed as a data type object such as Simulink.NumericType. 
The supported data types depend on the labels used in the model specified by Select trained machine learning model.
- If the model uses numeric or logical labels, the supported data types are - Inherit: Inherit via back propagation(default),- double,- single,- half,- int8,- uint8,- int16,- uint16,- int32,- uint32,- int64,- uint64,- boolean, fixed point, and a data type object.
- If the model uses nonnumeric labels, the supported data types are - Inherit: auto(default),- Enum: <class name>, and a data type object.
When you select an inherited option, the software behaves as follows:
- Inherit: Inherit via back propagation(default for numeric and logical labels) — Simulink® automatically determines the Label data type of the block during data type propagation (see Data Type Propagation (Simulink)). In this case, the block uses the data type of a downstream block or signal object.
- Inherit: auto(default for nonnumeric labels) — The block uses an autodefined enumerated data type variable. For example, suppose the workspace variable name specified by Select trained machine learning model is- myMdl, and the class labels are- class 1and- class 2. Then, the corresponding label values are- myMdl_enumLabels.class_1and- myMdl_enumLabels.class_2. The block converts the class labels to valid MATLAB identifiers by using the- matlab.lang.makeValidNamefunction.
For more information about data types, see Control Data Types of Signals (Simulink).
Click the Show data type assistant
    button  to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
 to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
Programmatic Use
| Block Parameter: LabelDataTypeStr | 
| Type: character vector or string | 
| Values: "Inherit: Inherit via back
                        propagation"|"Inherit: auto"|"double"|"single"|"half"|"int8"|"uint8"|"int16"|"uint16"|"int32"|"uint32"|"int64"|"uint64"|"boolean"|"fixdt(1,16,0)"|"fixdt(1,16,2^0,0)"|"Enum: <class name>"|"<data type
                        expression>" | 
| Default: "Inherit: Inherit via
                        back propagation"(for numeric and logical labels) |"Inherit: auto"(for nonnumeric labels) | 
Specify the lower value of the label output range that Simulink checks.
Simulink uses the minimum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as software-in-the-loop (SIL) mode or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Label data type Minimum parameter does not saturate or clip the actual label output signal. To do so, use the Saturation (Simulink) block instead.
Dependencies
You can specify this parameter only if the model specified by Select trained machine learning model uses numeric labels.
Programmatic Use
| Block Parameter: LabelOutMin | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the upper value of the label output range that Simulink checks.
Simulink uses the maximum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as SIL or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Label data type Maximum parameter does not saturate or clip the actual label output signal. To do so, use the Saturation (Simulink) block instead.
Dependencies
You can specify this parameter only if the model specified by Select trained machine learning model uses numeric labels.
Programmatic Use
| Block Parameter: LabelOutMax | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the data type for the score output. The type can be
            inherited, specified directly, or expressed as a data type object such as
                Simulink.NumericType.
When you select Inherit: auto, the block uses a rule that
            inherits a data
            type.
For more information about data types, see Control Data Types of Signals (Simulink).
Click the Show data type assistant
    button  to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
 to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
Programmatic Use
| Block Parameter: ScoreDataTypeStr | 
| Type: character vector or string | 
| Values: "Inherit: auto"|"double"|"single"|"half"|"int8"|"uint8"|"int16"|"uint16"|"int32"|"uint32"|"int64"|"uint64"|"boolean"|"fixdt(1,16,0)"|"fixdt(1,16,2^0,0)"|"<data type expression>" | 
| Default: "Inherit:
                    auto" | 
Specify the lower value of the score output range that Simulink checks.
Simulink uses the minimum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as software-in-the-loop (SIL) mode or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Score data type Minimum parameter does not saturate or clip the actual score output. To do so, use the Saturation (Simulink) block instead.
Programmatic Use
| Block Parameter: ScoreOutMin | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the upper value of the score output range that Simulink checks.
Simulink uses the maximum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as SIL or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Score data type Maximum parameter does not saturate or clip the actual score output. To do so, use the Saturation (Simulink) block instead.
Programmatic Use
| Block Parameter: ScoreOutMax | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the data type for the internal untransformed scores. The type can be inherited, specified directly, or expressed as a data type object such as Simulink.NumericType.
When you select Inherit: auto, the block uses a rule that inherits a data type.
For more information about data types, see Control Data Types of Signals (Simulink).
Click the Show data type assistant
    button  to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
 to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
Dependencies
You can specify this parameter only if the model specified by Select trained
                    machine learning model uses a score transformation other than
                    "none" (default, same as "identity").
- If the model uses no score transformations ( - "none"or- "identity"), then you can specify the score data type by using Score data type.
- If the model uses a score transformation other than - "none"or- "identity", then you can specify the data type of untransformed raw scores by using this parameter. To specify the data type of transformed scores, use Score data type.
You can change the score transformation option by specifying the
                    ScoreTransform name-value argument during training, or by
                modifying the ScoreTransform property after training.
Programmatic Use
| Block Parameter: RawScoreDataTypeStr | 
| Type: character vector | 
| Values: "Inherit: auto"|"double"|"single"|"half"|"int8"|"uint8"|"int16"|"uint16"|"int32"|"uint32"|"int64"|"uint64"|"boolean"|"fixdt(1,16,0)"|"fixdt(1,16,2^0,0)"|"<data type expression>" | 
| Default: "Inherit: auto" | 
Specify the lower value of the untransformed score range that Simulink checks.
Simulink uses the minimum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as software-in-the-loop (SIL) mode or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Raw score data type Minimum parameter does not saturate or clip the actual untransformed score signal.
Programmatic Use
| Block Parameter: RawScoreOutMin | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the upper value of the untransformed score range that Simulink checks.
Simulink uses the maximum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as SIL or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Raw score data type Maximum parameter does not saturate or clip the actual untransformed score signal.
Programmatic Use
| Block Parameter: RawScoreOutMax | 
| Type: character vector | 
| Values: "[]"|
                    scalar | 
| Default: "[]" | 
Specify the data type for the cost output. The type can be inherited, specified directly, or expressed as a data type object such as Simulink.NumericType.
When you select Inherit: auto, the block uses a rule that inherits a data type.
For more information about data types, see Control Data Types of Signals (Simulink).
Click the Show data type assistant
    button  to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
 to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
Programmatic Use
| Block Parameter: CostDataTypeStr | 
| Type: character vector or string | 
| Values: "Inherit: auto"|"double"|"single"|"half"|"int8"|"uint8"|"int16"|"uint16"|"int32"|"uint32"|"int64"|"uint64"|"boolean"|"fixdt(1,16,0)"|"fixdt(1,16,2^0,0)"|"<data type expression>" | 
| Default: "Inherit: auto" | 
Specify the lower value of the cost output range that Simulink checks.
Simulink uses the minimum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as software-in-the-loop (SIL) mode or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Estimated cost data type Minimum parameter does not saturate or clip the actual cost signal. To do so, use the Saturation (Simulink) block instead.
Programmatic Use
| Block Parameter: CostOutMin | 
| Type: character vector | 
| Values: "[]"| scalar | 
| Default: "[]" | 
Specify the upper value of the cost output range that Simulink checks.
Simulink uses the maximum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as SIL or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
The Estimated cost data type Maximum parameter does not saturate or clip the actual cost signal. To do so, use the Saturation (Simulink) block instead.
Programmatic Use
| Block Parameter: CostOutMax | 
| Type: character vector | 
| Values: "[]"| scalar | 
| Default: "[]" | 
Specify the data type of the distance metric. The type can be inherited, specified
              directly, or expressed as a data type object such as
                Simulink.NumericType.
When you select Inherit: auto, the block uses a rule
              that inherits a data type.
For more information about data types, see Control Data Types of Signals (Simulink).
Click the Show data type assistant
    button  to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
 to display the Data Type Assistant,
    which helps you set the data type attributes. For more information, see Specify Data Types Using Data Type Assistant (Simulink).
Tips
The Distance data type parameter specifies the data type of
                the distance metric for the nearest neighbor search method. For more information,
                see the Distance name-value
                argument of the fitcknn function.
Programmatic Use
| Block Parameter: DistanceDataTypeStr | 
| Type: character vector | 
| Values: 'Inherit: auto'|'double'|'single'|'half'|'int8'|'uint8'|'int16'|'uint16'|'int32'|'uint32'|'int64'|'uint64'|'boolean'|'fixdt(1,16,0)'|'fixdt(1,16,2^0,0)'|'<data type expression>' | 
| Default: 'Inherit:
                  auto' | 
Specify the lower value of the distance metric's internal variable range checked by Simulink.
Simulink uses the minimum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as software-in-the-loop (SIL) mode or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
Note
The Distance data type Minimum parameter does not saturate or clip the actual distance metric signal.
Programmatic Use
| Block Parameter: DistanceOutMin | 
| Type: character vector | 
| Values: '[]'|
                  scalar | 
| Default: '[]' | 
Specify the upper value of the distance metric's internal variable range checked by Simulink.
Simulink uses the maximum value to perform:
- Parameter range checking for some blocks (see Specify Minimum and Maximum Values for Block Parameters (Simulink)). 
- Simulation range checking (see Specify Signal Ranges (Simulink) and Enable Simulation Range Checking (Simulink)). 
- Optimization of the code that you generate from the model. This optimization can remove algorithmic code and affect the results of some simulation modes, such as SIL or external mode. For more information, see Optimize using the specified minimum and maximum values (Embedded Coder). 
Note
The Distance data type Maximum parameter does not saturate or clip the actual distance metric signal.
Programmatic Use
| Block Parameter: DistanceOutMax | 
| Type: character vector | 
| Values: '[]'|
                  scalar | 
| Default: '[]' | 
Block Characteristics
| Data Types | 
 | 
| Direct Feedthrough | 
 | 
| Multidimensional Signals | 
 | 
| Variable-Size Signals | 
 | 
| Zero-Crossing Detection | 
 | 
More About
The data types of internal model parameters are
        synchronized to the data type of the enabled score output port. If the
            score output port is not enabled, the model parameter data types
        are synchronized to other internal data types.
Alternative Functionality
You can use a MATLAB Function block with the predict object function of a nearest neighbor classification object (ClassificationKNN). For an example, see Predict Class Labels Using MATLAB Function Block.
When deciding whether to use the ClassificationKNN Predict block in the
        Statistics and Machine Learning Toolbox™ library or a MATLAB Function block with the predict function, consider the
        following:
- If you use the Statistics and Machine Learning Toolbox library block, you can use the Fixed-Point Tool (Fixed-Point Designer) to convert a floating-point model to fixed point. 
- Support for variable-size arrays must be enabled for a MATLAB Function block with the - predictfunction.
- If you use a MATLAB Function block, you can use MATLAB functions for preprocessing or post-processing before or after predictions in the same MATLAB Function block. 
Extended Capabilities
C/C++ Code Generation
 Generate C and C++ code using Simulink® Coder™.
Fixed-Point Conversion
Design and simulate fixed-point systems using Fixed-Point Designer™. 
Version History
Introduced in R2022b
See Also
Blocks
- ClassificationSVM Predict | ClassificationTree Predict | ClassificationEnsemble Predict | ClassificationNeuralNetwork Predict
Functions
Objects
Topics
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Website auswählen
Wählen Sie eine Website aus, um übersetzte Inhalte (sofern verfügbar) sowie lokale Veranstaltungen und Angebote anzuzeigen. Auf der Grundlage Ihres Standorts empfehlen wir Ihnen die folgende Auswahl: .
Sie können auch eine Website aus der folgenden Liste auswählen:
So erhalten Sie die bestmögliche Leistung auf der Website
Wählen Sie für die bestmögliche Website-Leistung die Website für China (auf Chinesisch oder Englisch). Andere landesspezifische Websites von MathWorks sind für Besuche von Ihrem Standort aus nicht optimiert.
Amerika
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)

