Main Content

Use the Fixed-Point Tool to Explore Numerical Behavior

This example shows how to use the Fixed-Point Tool to compare floating-point and fixed-point data types in your model. You can use the range collection functionality to explore and troubleshoot the numerical behavior of your model for different inputs.

Open the Fixed-Point Direct Form Filter Model

Open the fxpdemo_direct_form2 model. This tutorial uses a fixed-point direct form filter implemented using fundamental building blocks such as Gain, Delay, and Sum. The model contains a Signal Generator block that supplies a square wave input to the filter.

Set Up the Model

In this tutorial, you explore the behavior of the filter for a range of signal inputs. To specify multiple simulation scenarios for range collection, define a Simulink.SimulationInput object in the base or model workspace. Define a Simulink.SimulationInput object, simIn, that specifies the amplitude of the square wave input for a range of values.

simIn(1:6) = Simulink.SimulationInput('fxpdemo_direct_form2'); 

simIn(1) = simIn(1).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','0.001');
simIn(2) = simIn(2).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','0.01');
simIn(3) = simIn(3).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','0.1');
simIn(4) = simIn(4).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','1');
simIn(5) = simIn(5).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','10');
simIn(6) = simIn(6).setBlockParameter('fxpdemo_direct_form2/Input',...
    'Amplitude','100');

To specify signal tolerances, enable signal logging at the output of the Sum1 block.

Simulink.sdi.markSignalForStreaming('fxpdemo_direct_form2/Sum1',1,'on');

Open the Fixed-Point Tool and Collect Ranges

  1. In the Apps tab of the fxpdemo_direct_form2 model, select Fixed-Point Tool.

  2. In the Fixed-Point Tool, click New > Range Collection.

  3. Under System Under Design (SUD), select fxpdemo_direct_form2.

  4. Under Range Collection Mode, select Simulation Ranges as the range collection method.

  5. Under Simulation Inputs, select the Simulink.SimulationInput object, simIn, that you defined in the base workspace.

  6. To specify tolerances for the system, under Signal Tolerances, specify tolerances for any signal in the model with signal logging enabled.

    Set the relative tolerance (Rel Tol) of the signal that you logged to 15%.

  7. Under Collect Ranges, select Double precision.

    When you collect ranges via simulation, the Fixed-Point Tool will override the data types in your model with doubles and simulate the model with instrumentation to collect minimum and maximum values for each object in your model. You can also choose to override data types with singles or scaled doubles, or use the current data type override set on the model.

  8. Click the Collect Ranges button.

    Simulink® simulates the fxpdemo_direct_form2 model six times, once for each amplitude of the input square wave specified in the Simulink.SimulationInput object. The Fixed-Point Tool automatically enables fixed-point instrumentation and overrides the data types in your model with doubles to collect a floating-point baseline.

    You can view the ranges of each simulation individually by selecting the simulation scenario in the Workflow Browser.

    Selecting the BaselineRun node in the Workflow Browser shows the merged ranges from the six simulation scenarios.

  9. Click Settings, then select Specified data types.

  10. Click Simulate with Embedded Types.

    The Fixed-Point Tool simulates the model once for each simulation scenario, using the fixed-point data types specified in the model. Selecting the EmbeddedRun node in the Workflow Browser shows the merged results from the six simulation scenarios.

    The Workflow Browser indicates that of the six simulation scenarios, only EmbeddedRun_Scenario_4 met the tolerances specified. Results with overflows are highlighted in red.

Explore Fixed-Point Behavior of the Model

  1. Select the Explore tab of the Fixed-Point Tool to investigate further. Under Numerical Issues, select Overflow, then click Execution Order.

    The Fixed-Point Tool displays only the EmbeddedRun results with overflows and sorts the list based on block execution order. In this example, the first overflow occurs in the Gain4 block.

    You can double-click on any row in the Results spreadsheet to highlight the block in the model.

  2. You can compare the fixed-point and floating-point behavior of the model for a specific simulation scenario using the Simulation Data Inspector. For example, the Fixed-Point Tool indicates that EmbeddedRun_Scenario_3 did not meet the specified tolerance. To compare this embedded run to the floating-point behavior for this simulation scenario, right-click on EmbeddedRun_Scenario_3 and select Open SDI to compare with BaselineRun_Scenario_3.

    The Simulation Data Inspector plots the logged signal associated with the output of the Sum1 block for BaselineRun_Scenario_3 and EmbeddedRun_Scenario_3, as well as their difference and the tolerance specified for this signal.

See Also

| |