nlhwOptions
Option set for nlhw
Description
opt = nlhwOptionsnlhw. Use dot notation
to customize the option set, if needed.
opt = nlhwOptions(Name,Value)Name,Value pair
arguments. The options that you do not specify retain their default
value.
Examples
Create estimation option set for nlhw to view estimation progress, use the Levenberg-Marquardt search method, and set the maximum iteration steps to 50. 
opt = nlhwOptions; opt.Display = 'on'; opt.SearchMethod = 'lm'; opt.SearchOptions.MaxIterations = 50;
Load data and estimate the model.
load iddata3
sys = nlhw(z3,[4 2 1],idSigmoidNetwork,idPiecewiseLinear,opt);Create an options set for nlhw where:
- Initial conditions are estimated from the estimation data. 
- Subspace Gauss-Newton least squares method is used for estimation. 
opt = nlhwOptions('InitialCondition','estimate','SearchMethod','gn');
Name-Value Arguments
Specify optional pairs of arguments as
      Name1=Value1,...,NameN=ValueN, where Name is
      the argument name and Value is the corresponding value.
      Name-value arguments must appear after other arguments, but the order of the
      pairs does not matter.
    
      Before R2021a, use commas to separate each name and value, and enclose 
      Name in quotes.
    
Example: nlhwOptions('InitialCondition','estimate')
Handling of initial conditions during estimation using nlhw,
specified as the comma-separated pair consisting of InitialCondition and
one of the following:
- 'zero'— The initial conditions are set to zero.
- 'estimate'— The initial conditions are treated as independent estimation parameters.
Estimation progress display setting, specified as the comma-separated
pair consisting of 'Display' and one of the following:
- 'off'— No progress or results information is displayed.
- 'on'— Information on model structure and estimation results are displayed in a progress-viewer window.
Option to normalize estimation data, specified as
                                true or false. If
                                Normalize is true, then the
                            algorithm uses the method specified in
                                NormalizationOptions to normalize the
                            data.
Because saturation, deadzone, and piecewise-linear nonlinearities are
                            physically meaningful, you must use caution to take normalization into
                            account when specifying initial values. However, even when
                                Normalize is true, the software automatically
                            disables normalization for these nonlinearities when you set the
                            property NormalizationOptions.NormalizationMethod
                            to 'auto'. 
Option set for configuring normalization, specified as the options
                            shown in the following table. The first option,
                                NormalizationMethod, determines which method
                            the algorithm uses. The default option is 'auto'. In
                            general, for idnlhw models, a setting of
                                'auto' is equivalent to a setting of
                                'center'. However, if your model includes any of
                            the nonlinearity estimators that have physically meaningful
                                parameters—idSaturation,
                                idDeadzone, and
                            idPiecewiseLinear—a setting of
                                'auto' results in the software disabling
                            normalization for those estimators.
Except for 'medianiqr', each specific method in
                                NormalizationMethod has an associated
                            configuration option, such as CenterMethodType when
                            you specify the 'center' method. For more
                            information about these methods, see the MATLAB® function normalize.
| Method or Method Option | Value | Description | Default | 
|---|---|---|---|
| NormalizationMethod | 'auto' | Set method automatically. | 
 (equivalent
                                                to
                                                either The
                                                   | 
| 'center' | Center data to have mean 0. | ||
| 'zscore' | z-score with mean 0 and standard deviation 1. | ||
| 'norm' | 2-norm. | ||
| 'scale' | Scale by standard deviation. | ||
| 'range' | Rescale range of data to [min,max]. | ||
| 'medianiqr' | Center and scale data to have median 0 and interquartile scale of 1. | ||
| 
 | 'mean' | Center to have mean 0. | 'mean' | 
| 'median' | Center to have median 0. | ||
| 
 | 'std' | Center and scale to have mean 0 and standard deviation 1. | 'std' | 
| 'robust' | Center and scale to have median 0 and median absolute deviation 1. | ||
| 
 | 'std' | Scale by standard deviation. | 'std' | 
| 'mad' | Scale by median absolute deviation. | ||
| 'iqr' | Scale by interquartile range. | ||
| 'first' | Scale by first element of data. | ||
| 
 | Positive real value | p-norm, where p is a positive integer. | 2 | 
| 
 | 2-element row vector | Rescale range of data to an interval of the form [a b], wherea<b. | [0 1] | 
Weighting of prediction error in multi-output model estimations,
specified as the comma-separated pair consisting of 'OutputWeight' and
one of the following:
- 'noise'— Optimal weighting is automatically computed as the inverse of the estimated noise variance. This weighting minimizes- det(E'*E), where- Eis the matrix of prediction errors. This option is not available when using- 'lsqnonlin'as a- 'SearchMethod'.
- A positive semidefinite matrix, - W, of size equal to the number of outputs. This weighting minimizes- trace(E'*E*W/N), where- Eis the matrix of prediction errors and- Nis the number of data samples.
Options for regularized estimation of model parameters, specified
as the comma-separated pair consisting of 'Regularization' and
a structure with fields:
| Field Name | Description | Default | 
|---|---|---|
| Lambda | Bias versus variance tradeoff constant, specified as a nonnegative scalar. | 0— Indicates no regularization. | 
| R | Weighting matrix, specified as a vector of nonnegative scalars
or a square positive semi-definite matrix. The length must be equal
to the number of free parameters in the model, np.
Use thenparamscommand to determine
the number of model parameters. | 1— Indicates a value ofeye(np). | 
| Nominal | The nominal value towards which the free parameters are pulled during estimation, specified as one of the following: 
 | 'zero' | 
To specify field values in Regularization,
create a default nlhwOptions set and modify the
fields using dot notation. Any fields that you do not modify retain
their default values.
opt = nlhwOptions; opt.Regularization.Lambda = 1.2; opt.Regularization.R = 0.5*eye(np);
Regularization is a technique for specifying model flexibility constraints, which reduce uncertainty in the estimated parameter values. For more information, see Regularized Estimates of Model Parameters.
Numerical search method used for iterative parameter estimation, specified as the one of the values in the following table.
| SearchMethod | Description | 
|---|---|
| 'auto' | Automatic method selection  A combination of the
                                line search algorithms,  | 
| 'gn' | Subspace Gauss-Newton least-squares search Singular
                                values of the Jacobian matrix less than
                                     | 
| 'gna' | Adaptive subspace Gauss-Newton search Eigenvalues
                                less than  | 
| 'lm' | Levenberg-Marquardt least squares search Each
                                parameter value is  This algorithm requires Optimization Toolbox™ software. | 
| 'grad' | Steepest descent least-squares search | 
| 'lsqnonlin' | Trust-region-reflective algorithm of  This algorithm requires Optimization Toolbox software. | 
| 'patternsearch' | Solver for nonlinearities without well-defined gradients You can use the  | 
| 'fmincon' | Constrained nonlinear solvers You can use the
                                sequential quadratic programming (SQP) and trust-region-reflective
                                algorithms of the  
 | 
Option set for the search algorithm, specified as the comma-separated
                            pair consisting of 'SearchOptions' and a search
                            option set with fields that depend on the value of
                                SearchMethod.
SearchOptions Structure When SearchMethod is Specified
        as 'gn', 'gna', 'lm',
            'grad', or 'auto'
| Field Name | Description | Default | ||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Tolerance | Minimum percentage difference between the current value
of the loss function and its expected improvement after the next iteration,
specified as a positive scalar. When the percentage of expected improvement
is less than  | 1e-5 | ||||||||||||||||||||||||||||||
| MaxIterations | Maximum number of iterations during loss-function minimization, specified as a positive
                        integer. The iterations stop when  Setting
                             Use
                             | 20 | ||||||||||||||||||||||||||||||
| Advanced | Advanced search settings, specified as a structure with the following fields: 
 
 | |||||||||||||||||||||||||||||||
SearchOptions Structure When SearchMethod Is Specified
        as 'lsqnonlin'
| Field Name | Description | Default | 
|---|---|---|
| FunctionTolerance | Termination tolerance on the loss function that the software minimizes to determine the estimated parameter values, specified as a positive scalar. The
                        value of  | 1e-5 | 
| StepTolerance | Termination tolerance on the estimated parameter values, specified as a positive scalar. The value of  | 1e-6 | 
| MaxIterations | Maximum number of iterations during loss-function minimization, specified as a positive
                        integer. The iterations stop when  The value of
                             | 20 | 
SearchOptions Structure When
        SearchMethod Is Specified as
        'patternsearch'
| Field Name | Description | Default | 
|---|---|---|
| Algorithm | 
 
 For algorithm details, see How Pattern Search Polling Works (Global Optimization Toolbox) and Nonuniform Pattern Search (NUPS) Algorithm (Global Optimization Toolbox). For examples of algorithm effects, see Explore patternsearch Algorithms (Global Optimization Toolbox) and Explore patternsearch Algorithms in Optimize Live Editor Task (Global Optimization Toolbox). | 'nups' | 
| FunctionTolerance | Termination tolerance on the loss function that the software minimizes to determine the estimated parameter values, specified as a positive scalar. | 1e-6 | 
| StepTolerance | Termination tolerance on the estimated parameter values, specified as a positive scalar. | 1e-6 | 
| MaxIterations | Maximum number of iterations during loss
                    function minimization, specified as a positive
                    integer. The iterations stop when
                     | '100*numberOfVariables', wherenumberOfVariablesis the number of problem
                    variables | 
| UseParallel | Option to enable or disable parallel processing for improved performance, specified as a logical scalar. | 0 | 
SearchOptions Structure When SearchMethod Is Specified
    as 'fmincon'
| Field Name | Description | Default | 
|---|---|---|
| Algorithm | 
 
 For more information about the algorithms, see Constrained Nonlinear Optimization Algorithms (Optimization Toolbox) and Choosing the Algorithm (Optimization Toolbox). | 'sqp' | 
| FunctionTolerance | Termination tolerance on the loss function that the software minimizes to determine the estimated parameter values, specified as a positive scalar. | 1e-6 | 
| StepTolerance | Termination tolerance on the estimated parameter values, specified as a positive scalar. | 1e-6 | 
| MaxIterations | Maximum number of iterations during loss function minimization, specified as a positive
            integer. The iterations stop when  | 100 | 
To specify field values in SearchOptions, create a
                            default nlhwOptions set and modify the fields using
                            dot notation. Any fields that you do not modify retain their default
                            values.
opt = nlhwOptions; opt.SearchOptions.MaxIterations = 50; opt.SearchOptions.Advanced.RelImprovement = 0.5;
Additional advanced options, specified as the comma-separated
pair consisting of 'Advanced' and a structure with
fields:
| Field Name | Description | Default | 
|---|---|---|
| ErrorThreshold | Threshold for when to adjust the weight of large errors from
quadratic to linear, specified as a nonnegative scalar. Errors larger
than ErrorThresholdtimes the estimated standard
deviation have a linear weight in the loss function. The standard
deviation is estimated robustly as the median of the absolute deviations
from the median of the prediction errors, divided by 0.7. If your
estimation data contains outliers, try settingErrorThresholdto1.6. | 0— Leads to a purely quadratic loss
function. | 
| MaxSize | Maximum number of elements in a segment when input-output data is split into segments, specified as a positive integer. | 250000 | 
To specify field values in Advanced, create
a default nlhwOptions set and modify the fields
using dot notation. Any fields that you do not modify retain their
default values.
opt = nlhwOptions; opt.Advanced.ErrorThreshold = 1.2;
Output Arguments
Option set for nlhw, returned as an nlhwOptions option
set.
Version History
Introduced in R2015aYou can now set the SearchMethod property to
      'patternsearch' to estimate a system that has a nonlinearity without a
    well-defined gradient. You can change the default option set for this search algorithm using the
      SearchOptions property. This method requires Global Optimization Toolbox software.
The names of some estimation and analysis options were changed in R2018a. Prior names still work.
See Also
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.
Web サイトの選択
Web サイトを選択すると、翻訳されたコンテンツにアクセスし、地域のイベントやサービスを確認できます。現在の位置情報に基づき、次のサイトの選択を推奨します:
また、以下のリストから Web サイトを選択することもできます。
最適なサイトパフォーマンスの取得方法
中国のサイト (中国語または英語) を選択することで、最適なサイトパフォーマンスが得られます。その他の国の MathWorks のサイトは、お客様の地域からのアクセスが最適化されていません。
南北アメリカ
- América Latina (Español)
- Canada (English)
- United States (English)
ヨーロッパ
- 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)