Represent any block selected from user-specified library of blocks
The Configurable Subsystem block represents one of a set of blocks contained in a specified library of blocks. The block's context menu lets you choose which block the configurable subsystem represents.
Configurable Subsystem blocks simplify creation of models that represent families of designs. For example, suppose that you want to model an automobile that offers a choice of engines. To model such a design, you would first create a library of models of the engine types available with the car. You would then use a Configurable Subsystem block in your car model to represent the choice of engines. To model a particular variant of the basic car design, a user need only choose the engine type, using the configurable engine block's dialog.
To create a configurable subsystem in a model, you must first create a library containing a master configurable subsystem and the blocks that it represents. You can then create configurable instances of the master subsystem by dragging copies of the master subsystem from the library and dropping them into models.
You can add any type of block to a master configurable subsystem library. Simulink® derives the port names for the configurable subsystem by making a unique list from the port names of all the choices. However, Simulink uses default port names for non-subsystem block choices.
Note that you cannot break library links in a configurable subsystem because Simulink uses those links to reconfigure the subsystem when you choose a new configuration. Breaking links would be useful only if you do not intend to reconfigure the subsystem. In this case, you can replace the configurable subsystem with a nonconfigurable subsystem that implements the permanent configuration.
To create a master configurable subsystem:
To do this, drag a copy of the Configurable Subsystem block from the Simulink Ports & Subsystems library into the library you created in the previous step.
The context menu displays a submenu listing the blocks that the subsystem can represent.
If you modify a library block that is the default block choice for a configurable subsystem, the change does not immediately propagate to the configurable subsystem. To propagate this change, do one of the following:
Change the default block choice to another block in the subsystem, then change the default block choice back to the original block.
Recreate the configurable subsystem block, including the selection of the updated block as the default block choice.
To create an instance of a configurable subsystem in a model:
The instance of the configurable system displays the icon and parameter dialog box of the block that it represents.
As with other blocks, you can use the parameter dialog box of a configurable subsystem instance to set the instance's parameters interactively and the set_param command to set the parameters from the MATLAB® command line or in a MATLAB file. If you use set_param, you must specify the full path name of the configurable subsystem's current block choice as the first argument of set_param, for example:
curr_choice = get_param('mymod/myconfigsys', 'BlockChoice'); curr_choice = ['mymod/myconfigsys/' curr_choice]; set_param(curr_choice, 'MaskValues', ...);
A configurable subsystem displays a set of input and output ports corresponding to input and output ports in the selected library. Simulink uses the following rules to map library ports to Configurable Subsystem block ports:
Map each uniquely named input/output port in the library to a separate input/output port of the same name on the Configurable Subsystem block.
Map all identically named input/output ports in the library to the same input/output ports on the Configurable Subsystem block.
Terminate any input/output port not used by the currently selected library block with a Terminator/Ground block.
This mapping allows a user to change the library block represented by a Configurable Subsystem block without having to rewire connections to the Configurable Subsystem block.
For example, suppose that a library contains two blocks A and B and that block A has input ports labeled a, b, and c and an output port labeled d and that block B has input ports labeled a and b and an output port labeled e. A Configurable Subsystem block based on this library would have three input ports labeled a, b, and c, respectively, and two output ports labeled d and e, respectively, as illustrated in the following figure.
In this example, port a on the Configurable Subsystem block connects to port a of the selected library block no matter which block is selected. On the other hand, port c on the Configurable Subsystem block functions only if library block A is selected. Otherwise, it simply terminates.
Note: A Configurable Subsystem block does not provide ports that correspond to non-I/O ports, such as the trigger and enable ports on triggered and enabled subsystems. Thus, you cannot use a Configurable Subsystem block directly to represent blocks that have such ports. You can do so indirectly, however, by wrapping such blocks in subsystem blocks that have input or output ports connected to the non-I/O ports.
Right-click a configurable subsystem and select Subsystems and Model Reference > Convert Subsystem To > Variant Subsystem.
Simulink copies the block choices of the configurable subsystem to a new variant subsystem and adds the appropriate number of inports and outports to the variant subsystem. The current block choice of the configurable subsystem is made the active variant selection.
See Variant Subsystem for more information on variant choices.
The Configurable Subsystem block accepts and outputs signals of the same types that are accepted or output by the block that it currently represents. The data types can be any that Simulink supports, including fixed-point data types.
For more information, see Data Types Supported by Simulink in the Simulink documentation.
Select the blocks you want to include as members of the configurable subsystem. You can include user-defined subsystems as blocks.
Lists of input and output ports of member blocks. In the case of multiports, you can rearrange selected port positions by clicking the Up and Down buttons.