Weighted Sample Time
Support calculations involving sample time
Libraries:
      Simulink / 
      Signal Attributes
   
Description
The Weighted Sample Time block outputs a weighted sample time, weighted sample rate, or mathematically adjusted weighted sample time, depending on settings of the Operation and Weight value parameters and the execution context of the function outputs.
You specify the block operation by using the Operation parameter.
The sample time used to derive the output depends on whether the block is used within a periodic or aperiodic (or triggered) execution context. For a periodic execution context, the block uses the sample time of the model. For an aperiodic or triggered execution context, the block uses the sample time of the discrete signal.
Use the Weight value parameter to specify the sample time weight
        factor. If the weight value, w, is 1, that value does
        not appear in the equation on the block icon.
Tip
You can use the
                Weighted Sample Time and Weighted Sample Time Math
            blocks to extract the sample time from a Simulink® signal. Set the Operation parameter to
                Ts Only and the Weight value
            parameter to 1.0. With this configuration, the block outputs the
            sample time of the input signal.
The block computes its output by using the precedence rules for MATLAB® operators. For example, if the Operation parameter is set
        to +, the block calculates the output by using this expression:
u + (Ts * w)
If the Operation parameter is set to /, the block
        calculates the output by using this expression:
(u / Ts) / w)
For more information, see Operator Precedence.
Examples
This example shows how to add the sample time value to a signal using the Weighted Sample Time Math block.

Using the Weighted Sample Time block, you can see the sample time of this model is 0.2. When you set the Operation parameter to + and the Weight value to 1 on the Weighted Sample Time Math block, the block adds the sample time value of 0.2 to the input signal. When you set the Weight value to 3 in the Weighted Sample Time Math1 block, the block adds Ts*3 to the input signal, thus increasing each value by 0.6.
Ports
Input
Specify input signal as a scalar, vector, or matrix.
Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point
Output
Depending on settings of the Operation and Weight value parameters and the execution context of the function that contains the block, the block outputs a weighted sample time, weighted sample rate, or mathematically adjusted weighted sample time.
- Weighted sample time – When used in a periodic function, the weighted sample time is the sample time of an input signal times the value specified for the Weight value parameter ( - Ts * w). When used in an aperiodic or triggered function, the weighted sample time is the elapsed time since the last execution times the weight value.
- Weighted sample rate – When used in a periodic function, the weighted sample rate is the reciprocal of the weighted sample time ( - 1/(Ts * w)). The weighted sample rate is not relevant when the block is used in an aperiodic function.
- Mathematically adjusted weighted sample time – The block adds the value of an input signal - uto, subtracts- ufrom, or multiplies or divides- uby a weighted sample time.
The sample time used to derive the output and the data type of the output depend on whether the block is used within a periodic or aperiodic (or triggered) execution context.
| Execution Context of Block | Sample Time Used to Derive Output | Data Type of Output Signal | 
|---|---|---|
| Periodic | Sample time of the model | 
 | 
| Aperiodic or triggered | Elapsed time since the last execution | 
 | 
Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | Boolean | fixed point
Parameters
Main
Specify the operation to use for adjusting the value of the input signal. For example,
							if you specify the + operation, the block
							adds the weighted sample time to the value of the input signal. The
							value 1/Ts Only is not relevant when you use
							the block in an aperiodic function.
Programmatic Use
| Block Parameter: TsampMathOp | 
| Type: character vector | 
| Values: '+' | '-' | '*' | '/' | 'Ts Only' | '1/Ts
										Only' | 
| Default: 'Ts Only' | 
Enter the weight for the sample time as a real-valued scalar. The block multiplies the
            sample time of the input signal by the value that you specify. For example, if you use
            the block in a periodic function of a model that has a sample time of
                0.2 and you specify a weight value of 3, the
            weighted sample time is 0.6.
Programmatic Use
| Block Parameter: weightValue | 
| Type: character vector | 
| Values: real-valued scalar | 
| Default: 1.0 | 
Select whether to adjust the sample time by applying online calculations or by applying offline scaling. This option applies only for fixed-point and integer operations. The block disregards it for floating-point data types.
| Result of Ts * w | Output Data Type of Two Modes | Block Execution | 
|---|---|---|
| Power of 2 (positive or negative) or an integer value | The same when Output data type is set to Inherit: Inherit
                                via internal rule | Equally efficient in both modes | 
| Not a power of 2 and not an integer value | Different | More efficient for the offline scaling mode | 
Note
When the Implement using parameter is not enabled, operations default to online calculations.
Dependencies
To enable this parameter, set Operation to * or /.
Programmatic Use
| Block Parameter: TsampMathImp | 
| Type: character vector | 
| Values: 'Online Calculations' | 'Offline Scaling Adjustment' | 
| Default: 'Online Calculations' | 
Signal Attributes
Specify the data type for the block output signal.
Programmatic Use
| Block Parameter: OutDataTypeStr | 
| Type: character vector | 
| Values: 'Inherit: Inherit via
                        internal rule'|'Inherit: Inherit via back
                        propagation'|double|single|int8|uint8|int16|uint16|int32|uint32|int64|uint64|fixdt(1,16,0)|fixdt(1,16,20,0)|'<data type expression>' | 
| Default: 'Inherit: Inherit via
                        internal rule' | 
Specify the rounding mode for fixed-point operations. For more information, see Rounding Modes (Fixed-Point Designer).
Block parameters round to the nearest representable value. To control the rounding of a block parameter, enter an expression by using a MATLAB rounding function in the mask field.
Dependencies
To enable this parameter, set the Operation parameter to
                    +, -,
                    *, or /. If you set the
                    Operation to * or
                    /, you must also set the  Implement
                    using parameter to Online
                Calculations.
Programmatic Use
| Block Parameter: RndMeth | 
| Type: character vector | 
| Values: 'Ceiling' | 'Convergent' | 'Floor' | 'Nearest' | 'Round' | 'Simplest' |
                        'Zero' | 
| Default: 'Floor' | 
Specify whether integer overflows saturate or wrap.
| Goal | Action | Overflow Behavior | Example | 
|---|---|---|---|
| Model has possible overflow conditions and you want explicit saturation protection in the generated code. | Select check box ( | Saturate to the minimum or maximum value that the data type can represent. | The maximum value that the  | 
| You want to optimize generated code. You want to avoid overspecifying how a block handles out-of-range signals. For more information, see Troubleshoot Signal Range Errors. | Clear check box  ( | Wrap overflows to the appropriate value that is representable by the data type. | The maximum value that the  | 
When you select Saturate on integer overflow, saturation applies to every internal operation on the block, not just the output, or result. When the code generator detects that overflow is not possible, it does not produce saturation code.
Dependencies
To enable this parameter, set the Operation parameter to
                    +, -,
                    *, or /. If you set
                    Operation to * or
                    /, you must also set the  Implement
                    using parameter to Online
                Calculations.
Programmatic Use
| Block Parameter: SaturateOnIntegerOverflow | 
| Type: character vector | 
| Values: 'off' | 'on' | 
| Default: 'off' | 
Select how you would like to specify the data type properties of the Output data type. You can choose:
- Inherit— Specify a rule for inheriting a data type, for example,- Inherit: Same as input.
- Built in— Specify a built-in data type, for example,- double.
- Fixed point— Specify the fixed-point attributes of the data type.
- Expression— Specify an expression that evaluates to a valid data type, for example,- fixdt(1,16).
For more information, see Specify Data Types Using Data Type Assistant.
Specify whether the fixed-point data is signed or unsigned. Signed data can represent positive and negative values, but Unsigned data represents positive values only. For more information, see Specify Data Types Using Data Type Assistant.
Specify the method for scaling your fixed-point data to avoid overflow conditions and minimize quantization errors. For more information, see Specify Data Types Using Data Type Assistant.
Dependencies
To enable this parameter, set Mode to Fixed point
Specify the bit size of the word that holds the quantized integer as a positive integer from 2 to 128. For more information, see Specify Data Types Using Data Type Assistant.
Dependencies
To enable this parameter, set Mode to Fixed point.
Specify the fraction length of the fixed-point data type as a positive or negative integer scalar.
Dependencies
To enable this parameter, set Mode to Fixed point and Scaling to Binary point.
Specify slope for the fixed-point data type. For more information, see Specifying a Fixed-Point Data Type.
Dependencies
To enable this parameter, set Scaling to
                                                  Slope and bias.
Specify bias for the fixed-point data type as any real number. For more information, see Specifying a Fixed-Point Data Type.
Dependencies
To enable this parameter, set Scaling to
                                                  Slope and bias.
Select the data type override mode for this signal. You can select:
- Inherit— Inherits the data type override setting specified for the model.
- Off— Ignores the data type override setting specified for the model and uses the fixed-point data type you specify.
Dependencies
To enable this parameter, set Mode to Built in or Fixed point. For more information, see Specify Data Types Using Data Type Assistant.
Block Characteristics
| Data Types | 
 | 
| Direct Feedthrough | 
 | 
| Multidimensional Signals | 
 | 
| Variable-Size Signals | 
 | 
| Zero-Crossing Detection | 
 | 
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 before R2006aThe Weighted Sample Time block now supports:
- Additional output types - double
- single
- int8
- uint8
- int16
- uint16
- int32
- uint32
- int64
- uint64
- fixdt(1,16,0)
- fixdt(1,16,20,0)
 
- Fixed pointas a new option to the Mode parameter, which enables the fixed-point parameters:- Signedness 
- Scaling 
- Word length 
- Slope 
- Bias 
- Data type override 
 
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)
