メインコンテンツ

Use Design Evolution Manager with Fixed-Point Tool

This example shows how to use the Design Evolution Manager app to manage different design versions while using the Fixed-Point Tool and the Lookup Table Optimizer to convert a floating-point model to use fixed-point data types. Although this example demonstrates how to convert models to use fixed-point data types, you can use the Design Evolution Manager app to organize and analyze any work in which you create different versions of files in your design.

In this example, the Fixed-Point Tool creates many versions of a design, including:

  • The original floating-point model

  • The model prepared for fixed-point conversion

  • Various fixed-point versions of the model

Managing, analyzing, and moving between the different versions of a design can be challenging. The Design Evolution Manager app helps you to organize different versions of the same design, understand the relationships between different versions, compare different versions, and store and review notes and data about the versions.

This example shows how to:

  1. Convert your model files into a project.

  2. Create an evolution tree to visually organize the different versions of your design that you store in evolutions.

  3. Store a snapshot of the initial state of the files in the project by creating a baseline evolution.

  4. Convert the model to use fixed-point data types, and create evolutions to store snapshots of the design and notes you take at key points in the design process.

  5. Compare evolutions and review your notes to understand changes that were made to the model, then choose which version of the design best meets your requirements.

  6. Generate a report that summarizes the evolution tree.

Open Project

To use the Design Evolution Manager app, all of your design files must be in a single project.

Open the DEM_FPT_Example project. This project contains the controller_subsystem and controller_harness models. In this example, you convert the controller_subsystem model to fixed point and use the controller_harness model for testing.

Create New Evolution Tree

An evolution tree is a visual representation of a collection of related versions of files. Create a new evolution tree to track different versions of your design, stored as evolutions, created during conversion to fixed point.

1. On the Project tab, in the Tools section, click Design Evolution Manager.

2. In the Create New Evolution Tree dialog box, under Evolution Tree Name, enter Convert Controller to Fixed Point. Optionally, you can also enter notes under Evolution Tree Notes.

3. Click Create to continue.

The Design Evolution Manager app creates a new evolution tree. The Tree Browser pane shows the Convert Controller to Fixed Point evolution tree in the current project. The active icon in the Status column indicates that this evolution tree is active.

The evolution tree contains the Baseline evolution, which is a copy of all files in the project in their current state. The Baseline evolution is locked by default to prevent you from making changes to project files in this evolution. When you update the evolution tree, the Design Evolution Manager app creates a new child evolution under the Baseline evolution to record your changes.

Prepare Model for Fixed-Point Conversion

Use the Fixed-Point Tool to prepare the controller_subsystem model for conversion to fixed point.

1. From the project, open the controller_harness model.

2. Open the Fixed-Point Tool. On the Simulink® Apps tab, under Code Generation, click Fixed-Point Tool.

3. In the tool, select New > Optimized Fixed-Point Conversion.

4. Under System Under Design (SUD), select controller_subsystem as the system to convert to fixed point.

5. In the toolstrip, click Prepare.

6. When the preparation checks are complete, save the changes to the controller_subsystem and controller_harness models.

Create Evolution

Use the Design Evolution Manager app to create a new evolution for the prepared model.

1. In the Design Evolution Manager app, click the Update Tree button. Because the Baseline evolution is locked, the Design Evolution Manager creates the Untitled evolution as a child of the Baseline evolution to record the changes made to project files in the previous step.

2. In the Property Inspector pane, name the new evolution Prepared.

3. On the evolution tree, select the connector between the Baseline evolution and the Prepared evolution. The File Explorer pane shows that the controller_subsystem.slx and controller_harness.slx model files changed.

4. In the Property Inspector pane, in the Notes field, add a note that these file changes are the result of running the preparation step in the Fixed-Point Tool.

Inspect Changes Between Evolutions

Use the Comparison Tool to compare the version of the files in the Baseline evolution to the version of the files stored in the Prepared evolution.

1. Select the connector between the Baseline and Prepared evolutions.

2. In the File Explorer pane, select the controller_subsystem.slx file. Click Compare Files.

The Comparison Tool launches. The version of the model stored in the Baseline evolution is in orange, and the version of the model stored in the Prepared evolution is in blue. The comparison shows that the Exp block, which is not supported for fixed-point conversion, was isolated during the prepare step in the Fixed-Point Tool.

3. In the Design Evolution Manager app, select the Prepared evolution. In the Property Inspector pane, add a note indicating that the Exp block has been isolated and needs to be replaced.

4. Now that the system is prepared for fixed-point conversion and the changes have been verified, lock the evolution to prevent any further changes from being recorded to the Prepared evolution. In the evolution tree, select the Prepared evolution, then click Lock Evolution in the toolstrip.

Convert to Fixed-Point and Store in Evolution

Use the Fixed-Point Tool to convert the controller model to fixed point. Then, use the Design Evolution Manager app to track your work.

1. In the Fixed-Point Tool, from the Workflow Browser pane, click Setup.

2. In the right pane, under Signal Tolerances, set Relative Tolerance for the Sum:1 and Sum1:1 signals to 0.15.

3. Click Optimize Data Types.

The Fixed-Point Tool determines optimized fixed-point data types for the controller_subsystem based on the specified tolerances. The best solution found has a cost of 528. The Fixed-Point Tool applies this solution to the controller_subsystem model.

4. To open the Simulation Data Inspector, click Compare. Visually confirm that the solution meets the specified tolerances for the logged signals.

5. Save the changes to the model.

6. In the Design Evolution Manager app, click the Update Tree button to record these changes to a new Untitled evolution, which is a child of the Prepared evolution.

7. Name the new evolution Converted 15%.

8. Add a note to the evolution that the total cost of this design is 424.

Add Conversion Script to the Evolution

In addition to storing the fixed-point version of the model in an evolution, you can also add a copy of the script that the Fixed-Point Tool used to convert the model to fixed point to the Converted 15% evolution you just created.

1. Export the fixed-point conversion script. In the Fixed-Point Tool, click Export Script.

The Fixed-Point Tool exports fxpOptimizationScript.m to the base workspace.

2. Add fxpOptimizationScript.m to the project.

4. In the Design Evolution Manager app, click the Update Tree button.

5. Confirm that the file was added to the evolution. Select the connector between the Prepared evolution and the Converted 15% evolution.

The File Explorer pane shows that the fxpOptimizationScript.m file was added and that the controller_harness.slx and controller_subsystem.slx model files were changed between the Prepared and Converted 15% evolutions.

5. Lock the Converted 15% evolution.

Create Branch in Evolution Tree to Explore Different Fixed-Point Types

Next, try the optimized fixed-point conversion workflow with a larger tolerance. Use the version of the files saved in the Prepared evolution. Then, run the optimization process again and track your work in a new branch in the evolution tree.

1. Return to the floating-point version of the design after it was prepared for fixed-point conversion. In the Design Evolution Manager app, select the Prepared evolution. Click Get Evolution.

The dialog box indicates that retrieving this evolution removes the fixed point conversion script, which was not present in the Prepared evolution, from the active project area.

2. Click OK to continue.

The files in the project are now the version of the design files when you prepared them with the Fixed-Point Tool. The shape of the evolution tree changes to show that the next evolution you create will be a child of the Prepared evolution.

3. Use the Fixed-Point Tool to convert the controller_subsystem to fixed point. This time, set the Relative Tolerance for both of the logged signals to 0.20.

Because you loaded the version of the model files from the Prepared evolution, you do not need to run the prepare step in the Fixed-Point Tool again.

4. Click Optimize Data Types to run the conversion.

The best solution found has a total cost of 400.

5. Save the changes to the model.

6. Save this version of the design in a new evolution named Converted 20%.

7. Export the fixed-point conversion script and add it to the evolution you just created.

8. Lock the Converted 20% evolution.

9. Add a note to the Converted 20% evolution that the total cost of this version of the design is 400.

Compare Alternate Versions of Design

The final step of fixed-point conversion is to replace the Exp block with a lookup table approximation. The fixed-point versions of the design stored in the Converted 15% and Converted 20% evolutions both produce acceptable results, with the logged signals meeting all specified tolerances. You can review your notes to confirm that the costs of these designs are 528 and 400, respectively. Because the Converted 20% version of the design has a lower cost, choose this branch of the evolution tree to continue your design work.

Replace Unsupported Block with Lookup Table and Save in Evolution

From the Converted 20% version of the design, replace the Exp block with a lookup table approximation.

1. Get the Converted 20% evolution into your active project area and open the controller_harness model.

2. In the model, navigate to the blue exponential subsystem under controller_harness > Model (controller_subsystem) > Exp. Select the Exp block.

Exp-block-isolated.png

3. Open the Lookup Table Optimizer. On the Simulink Apps tab, under Code Generation, click Lookup Table Optimizer.

4. In the Lookup Table Optimizer, select Simulink block or subsystem. Click Next.

5. Confirm that the Simulink block path is controller_subsystem/Exp/ReplicaOfSource. Click Collect Current Values from Model, then click Next.

6. Click Optimize, then click Next.

7. Click Replace Original Function.

The tool replaces the Exp block with a lookup table approximation.

8. Save the changes to the model.

9. In the Design Evolution Manager app, click the Update Tree button to create a new Untitled evolution as a child of the Converted 20% evolution. Name this new evolution Exp Replaced.

10. Select the connector between the Converted 20% evolution and the Exp Replaced evolution. Add a note that you used the Lookup Table Optimizer to replace the Exp block with an optimized lookup table approximation.

Review Design Process

The Design Evolution Manager app shows the complete design process. The evolution tree represents the design decisions visually. You can select individual evolutions or connectors to review changes made during the design process and any notes you recorded.

Generate Report

To generate a PDF report that summarizes the evolution tree, click the Generate Report button. Enter a title for the report and a name for the PDF file, then click Generate.

Close Project

Close the project. On the Project tab, in the Close section, click Close Project. Alternatively, at the Command Line, enter:

proj = currentProject;
close(proj);

See Also

Fixed-Point Tool (Fixed-Point Designer) | Lookup Table Optimizer (Fixed-Point Designer)

Related Topics