Curve
Approximate one-dimensional function
Libraries:
      AUTOSAR Blockset / 
      Classic Platform / 
      Library Routines / 
      Interpolation
   
Description
The Curve block performs one-dimensional interpolated table lookup, including index searches. The table is a sampled representation of a function. Breakpoint sets relate the input values to positions in the table. You can also use the Prelookup and Prelookup Using Curve blocks together to perform the same operations as this block.
If you select the AUTOSAR 4.x code replacement library (CRL) for your AUTOSAR model, code generated from this block is replaced with the AUTOSAR library routine that you configure in the block parameters dialog box.
Ports
Input
Real-valued inputs to the u1 port.
When the Targeted Routine Library is set to IFX
                (fixed-point) the valid data types for the values of
                u1 are: int8, uint8,
                int16, uint16, and fixed-point data
              types.
When the Targeted Routine Library is set to IFL
                (floating-point) the only valid data type for the values of
                u1 is single.
Example: 0:10
Data Types: single | int8 | uint8 | int16 | uint16 | fixed point
Output
Output generated by looking up or estimating table values based on the input values. If the inputs match the index values of breakpoint sets, the curve block provides a table value as output. If the block inputs do not match index values in breakpoint sets, but are within range, the block performs the interpolation method you selected and provides an estimated value from the table values as output.
When the Targeted Routine Library is set to IFX
                (fixed-point) the valid data types for the values of
                Port_1 are: int8, uint8,
                int16, uint16, and fixed-point data
              types.
When the Targeted Routine Library is set to IFL
                (floating-point) the data type for the values of
                Port_1 must be single.
Data Types: single | int8 | uint8 | int16 | uint16 | fixed point
Parameters
If you select the AUTOSAR 4.x code replacement library (CRL) for your model, code generated from this block is replaced from the selected AUTOSAR routine library. This parameter enables you to choose either fixed-point (IFX) or floating-point (IFL) code replacement and validation checks.
This parameter reflects the name of the AUTOSAR code replacement library (CRL) routine used to replace the code generated by this block. The naming convention includes the targeted routine library, interpolation method, and block type. This parameter is reference-only and must not be edited.
When the Targeted Routine Library is set to IFX
              (fixed-point) the value defaults to Ifx_IntIpoCur.
When the Targeted Routine Library is set to IFL
              (floating-point) the value defaults to
            Ifl_IntIpoCur.
Table Specification
From the list, select:
- Table and breakpoints— Specify the table data and breakpoints. Selecting this option enables these parameters:- Table data 
- Breakpoints specification 
- Breakpoints 
- Edit table and breakpoints 
 
- Lookup table object— Use an existing lookup table (- Simulink.LookupTable) object. Selecting this option enables the Name field and the Edit table and breakpoints button.
Programmatic Use
| Block Parameter: DataSpecification | 
| Type: character vector | string | 
| Values: "Table and breakpoints" | "Lookup table object" | 
| Default: "Table and breakpoints" | 
Enter the name of the lookup table (Simulink.LookupTable)
              object.
Dependencies
To enable this parameter, set Data specification to
                  Lookup table object.
Programmatic Use
| Block Parameter: LookupTableObject | 
| Type: character vector | 
| Values: name of a Simulink.LookupTableobject | 
| Default: '[]' | 
Enter the table of output values.
During simulation, the matrix must be one-dimensional. However, during block
              diagram editing, you can enter an empty matrix (specified as []) or
              an undefined workspace variable. This technique lets you postpone specifying a
              correctly dimensioned matrix for the table data and continue editing the block
              diagram. 
Dependencies
To enable this parameter, set Data specification to
                  Table and breakpoints.
Programmatic Use
| Block Parameter: Table | 
| Type: character vector | 
| Values: matrix of table values | 
| Default: '[1 2 4]' | 
Specify whether to enter data as explicit breakpoints or as parameters that generate evenly spaced breakpoints.
- To specify breakpoint data, set this parameter to - Explicit valuesand enter breakpoint data in the text box next to the Breakpoints parameters.
- To specify parameters that generate evenly spaced breakpoints, set this parameter to - Even spacingand enter values for the First point and Spacing parameters for each dimension of breakpoint data. The block calculates the number of points to generate from the table data.
Dependencies
To enable this parameter, set Data specification to
                  Table and breakpoints.
Programmatic Use
| Block Parameter: BreakpointsSpecification | 
| Type: character vector | string | 
| Values: "Explicit values" | "Even spacing" | 
| Default: "Explicit values" | 
Specify the breakpoint data explicitly or as evenly-spaced breakpoints, based on the value of the Breakpoints specification parameter.
- If you set Breakpoints specification to - Explicit values, enter the breakpoint set that corresponds to each dimension of table data in each Breakpoints row. For each dimension, specify breakpoints as a 1-by-n or n-by-1 vector whose values are strictly monotonically increasing.
- If you set Breakpoints specification to - Even spacing, enter the parameters First point and Spacing in each Breakpoints row to generate evenly-spaced breakpoints in the respective dimension. Your table data determines the number of evenly spaced points.
Dependencies
To enable this parameter, set Data specification to
                  Table and breakpoints and Breakpoints
                  specification to Explicit values.
Programmatic Use
| Block Parameter: BreakpointsForDimension1 | 
| Type: character vector | 
| Values: 1-by-n or n-by-1 vector of monotonically increasing values | 
| Default: '[10, 22, 31]' | 
Specify the first point in your evenly spaced breakpoint data as a real-valued,
              finite, or scalar. This parameter is available when you set the Breakpoints
                specification to Even spacing.
Dependencies
To enable this parameter, set Data specification to
                  Table and breakpoints and Breakpoints
                  specification to Even spacing.
Programmatic Use
| Block Parameter: BreakpointsForDimension1FirstPoint | 
| Type: character vector | 
| Values: real-valued, finite, scalar | 
| Default: '1' | 
Specify the spacing between points in your evenly-spaced breakpoint data.
Dependencies
To enable this parameter, set Data specification to
                  Table and breakpoints and Breakpoints
                  specification to Even spacing.
Programmatic Use
| Block Parameter: BreakpointsForDimension1Spacing | 
| Type: character vector | 
| Values: positive, real-valued, finite, scalar | 
| Default: '1' | 
Click this button to open the Lookup Table Editor. You can then edit the object and save the new values for the object.
Algorithm
Select Evenly spaced points, Linear search,
              or Binary search. Each search method has speed advantages in
              different circumstances:
- For evenly spaced breakpoint sets (for example, 10, 20, 30, and so on), you achieve optimal speed by selecting - Evenly spaced pointsto calculate table indices. This algorithm uses only the first two breakpoints of a set to determine the offset and spacing of the remaining points.- Note - When using the - Simulink.LookupTableobject to specify table data and the Breakpoints Specification parameter of the referenced- Simulink.LookupTableobject is set to- Even spacing, set the Index search method to- Evenly spaced points.
- For unevenly spaced breakpoint sets, follow these guidelines: - If input signals do not vary significantly between time steps, selecting - Linear searchand Begin index search using previous index result produces the best performance.
- If input signals jump more than one or two table intervals per time step, selecting - Binary searchproduces the best performance.
 
A suboptimal choice of an index search method can lead to slow performance of models that rely heavily on lookup tables.
The generated code stores only the first breakpoint, the spacing, and the number of breakpoints when:
- The breakpoint data is not tunable. 
- The index search method is - Evenly spaced points.
Programmatic Use
| Block Parameter: IndexSearchMode | 
| Type: character vector | string | 
| Values: "Binary search" | "Evenly spaced points" | "Linear
                  search" | 
| Default: "Linear search" | 
Select this check box when you want the block to start its search using the index found at the previous time step. For inputs that change slowly with respect to the interval size, enabling this option can improve performance. Otherwise, the linear search and binary search methods can take longer, especially for large breakpoint sets.
Dependencies
To enable this parameter, set Index search method to
                  Linear search or Binary
                  search.
Programmatic Use
| Block Parameter: BeginIndexSearchUsingPreviousIndexResult | 
| Type: character vector | string | 
| Values: "off" | "on"  | 
| Default: "off" | 
When an input falls between breakpoint values, the block interpolates the output value by using neighboring breakpoints. For more information, see Interpolation Methods.
Programmatic Use
| Block Parameter: InterpMode | 
| Type: character vector | string | 
| Values: "Linear point-slope" | "Flat"  | 
| Default: "Linear point-slope" | 
Specify the rounding mode for fixed-point lookup table calculations that occur during simulation or execution of code generated from the model.
This option does not affect rounding of block parameter values. Simulink™ rounds such values to the nearest representable integer value.
Dependencies
This parameter is visible only when set to Round.
                Integer rounding is not supported for AUTOSAR 4.x and host libraries for SIL testing
                and is hidden by default. To enable SIL workflows while using the AUTOSAR 4.x code
                replacement library, change this setting to Zero.
Programmatic Use
| Block Parameter: RndMode | 
| Type: character vector | string | 
| Values: "Round" | "Zero" | 
| Default: "Zero" | 
Data Types
Specify the table data type. The block validates that the selected types are
              compatible with the targeted routine specified by Targeted Routine
                Library.
When Targeted Routine Library is set to IFL
                (floating-point) then the only valid data type is
                single.
When the Targeted Routine Library is set to IFX
                (fixed-point) you can set the table data type to:
- Rules that inherit a data type: - Inherit: Same as outputand- Inherit: Inherit from 'Table data'.
- One of these built-in data types: - int8,- uint8,- int16,- uint16.
- The name of a data type object, for example, a - Simulink.NumericTypeobject.
- An expression that evaluates to a data type. For example, the software provides these common fixed-point data type expressions: - fixdt(1,16),- fixdt(1,16,0), or- fixdt(1,16,2^0,0).
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.
 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.
Tip
Specify a table data type different from the output data type in these cases:
- Lower memory requirement for storing table data that uses a smaller type than the output signal. 
- Sharing of prescaled table data between two Map blocks that have different output data types. 
- Sharing of custom storage table data in the generated code for blocks that have different output data types. 
Dependencies
To enable this tab, on the Table Specification tab, set
                  Data Specification to Table and
                  breakpoints.
Programmatic Use
| Block Parameter: TableDataTypeStr | 
| Type: character vector | string | 
| Values: "Inherit: Inherit from 'Table data'" | "Inherit: Same as output" |
                    "single" | "int8" | "uint8" | "int16" | "uint16" | "fixdt(1,16)" |
                    "fixdt(1,16,0)" | "fixdt(1,16,2^0,0)" | "<data type
                  expression>" | 
| Default: "Inherit: Same as output" | 
Extended Capabilities
C/C++ Code Generation
 Generate C and C++ code using Simulink® Coder™.
Version History
Introduced in R2019aInteger rounding mode is set to "Zero"
                                and hidden by default because only "Zero" is
                                supported for AUTOSAR 4.x and host libraries for SIL testing.
Starting in 25a, the AUTOSAR code replacement library supports AUTOSAR schema versions
        after AUTOSAR 4.0. To use the latest AUTOSAR routines, in the model Configuration Parameters
        dialog box in the Code Generation > Interface pane, specify Code replacement libraries as
            AUTOSAR 4.x.
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.
Seleziona un sito web
Seleziona un sito web per visualizzare contenuto tradotto dove disponibile e vedere eventi e offerte locali. In base alla tua area geografica, ti consigliamo di selezionare: .
Puoi anche selezionare un sito web dal seguente elenco:
Come ottenere le migliori prestazioni del sito
Per ottenere le migliori prestazioni del sito, seleziona il sito cinese (in cinese o in inglese). I siti MathWorks per gli altri paesi non sono ottimizzati per essere visitati dalla tua area geografica.
Americhe
- 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)
