setParameterValue
Syntax
Description
Examples
This example shows a wheel axle architecture model with instance-specific parameters exposed in System Composer™. These parameters are defined as model arguments on the Simulink® reference model used as a model behavior linked to two System Composer components. You can change the values of these parameters independently on each reference component.
To add parameters to the architecture model or components, use the Parameter Editor. To remove these parameters, delete them from the Parameter Editor.
Open the architecture model of the wheel axle mAxleArch to interact with the parameters on the reference components using the Property Inspector.
model = systemcomposer.openModel("mAxleArch");Look up the Component objects for the RightWheel and LeftWheel components.
rightWheelComp = lookup(model,Path="mAxleArch/RightWheel"); leftWheelComp = lookup(model,Path="mAxleArch/LeftWheel");
Get the parameter names for the RightWheel component. Since the LeftWheel component is linked to the same reference model mWheel, the parameters are the same on the LeftWheel component.
paramNames = rightWheelComp.getParameterNames
paramNames = 1×3 string
    "Diameter"    "Pressure"    "Wear"
Get the Pressure parameter on the RightWheel component architecture.
paramPressure = rightWheelComp.Architecture.getParameter(paramNames(2));
Display the value type for the Pressure parameter.
paramPressure.Type
ans = 
  ValueType with properties:
           Name: 'Pressure'
       DataType: 'double'
     Dimensions: '[1  1]'
          Units: 'psi'
     Complexity: 'real'
        Minimum: ''
        Maximum: ''
    Description: ''
          Owner: [1×1 systemcomposer.arch.Architecture]
          Model: [1×1 systemcomposer.arch.Model]
           UUID: '47c2446a-f6b0-4710-9a73-7ed25d1671c4'
    ExternalUID: ''
Get the RightWheel component parameter values.
for i = 1:length(paramNames) paramName = paramNames(i) [paramValue,paramUnits,isDefault] = rightWheelComp.getParameterValue(paramNames(i)) end
paramName = "Diameter"
paramValue = '16'
paramUnits = 'in'
isDefault = logical
   1
paramName = "Pressure"
paramValue = '31'
paramUnits = 'psi'
isDefault = logical
   0
paramName = "Wear"
paramValue = '0.25'
paramUnits = 'in'
isDefault = logical
   1
Get the LeftWheel component parameter values.
for i = 1:length(paramNames) paramName = paramNames(i) [paramValue,paramUnits,isDefault] = leftWheelComp.getParameterValue(paramNames(i)) end
paramName = "Diameter"
paramValue = '16'
paramUnits = 'in'
isDefault = logical
   1
paramName = "Pressure"
paramValue = '32'
paramUnits = 'psi'
isDefault = logical
   1
paramName = "Wear"
paramValue = '0.25'
paramUnits = 'in'
isDefault = logical
   1
First, check the evaluated RightWheel parameters.
for i = 1:length(paramNames) paramName = paramNames(i) [paramValue,paramUnits] = rightWheelComp.getEvaluatedParameterValue(paramNames(i)) end
paramName = "Diameter"
paramValue = 16
paramUnits = 'in'
paramName = "Pressure"
paramValue = 31
paramUnits = 'psi'
paramName = "Wear"
paramValue = 0.2500
paramUnits = 'in'
Check the evaluated LeftWheel parameters.
for i = 1:length(paramNames) paramName = paramNames(i) [paramValue,paramUnits] = leftWheelComp.getEvaluatedParameterValue(paramNames(i)) end
paramName = "Diameter"
paramValue = 16
paramUnits = 'in'
paramName = "Pressure"
paramValue = 32
paramUnits = 'psi'
paramName = "Wear"
paramValue = 0.2500
paramUnits = 'in'
Set the parameter value and unit for the PSI parameter on the LeftWheel component.
First, check the current values for the pressure on LeftWheel.
[paramValue,paramUnits,isDefault] = leftWheelComp.getParameterValue("Pressure")paramValue = '32'
paramUnits = 'psi'
isDefault = logical
   1
Update the values for the pressure on LeftWheel.
leftWheelComp.setParameterValue("Pressure","34") [paramValue,paramUnits,isDefault] = leftWheelComp.getParameterValue("Pressure")
paramValue = '34'
paramUnits = 'psi'
isDefault = logical
   0
Revert the Pressure parameter on LeftWheel to its default value.
leftWheelComp.resetParameterToDefault("Pressure")Check the reverted values for the pressure on LeftWheel.
[paramValue,paramUnits,isDefault] = leftWheelComp.getParameterValue("Pressure")paramValue = '32'
paramUnits = 'psi'
isDefault = logical
   1
Promote the Pressure parameter on the LeftWheel component.
addParameter(model.Architecture,Path="mAxleArch/LeftWheel",Parameters="Pressure");
Get the promoted Pressure parameter from the root architecture of the mAxleArch model.
pressureParam = model.Architecture.getParameter("LeftWheel.Pressure");Adjust the value of the promoted Pressure parameter.
pressureParam.Value = "30";
pressureParampressureParam = 
  Parameter with properties:
      Name: "LeftWheel.Pressure"
     Value: '30'
      Type: [1×1 systemcomposer.ValueType]
    Parent: [1×1 systemcomposer.arch.Architecture]
      Unit: 'psi'
Get the source parameter from which the Pressure parameter is promoted.
sourceParam = getParameterPromotedFrom(pressureParam)
sourceParam = 
  Parameter with properties:
      Name: 'Pressure'
     Value: '30'
      Type: [1×1 systemcomposer.ValueType]
    Parent: [1×1 systemcomposer.arch.Component]
      Unit: 'psi'
Reset the value of the promoted Pressure parameter to the default value in the source parameter.
resetToDefault(pressureParam); pressureParam
pressureParam = 
  Parameter with properties:
      Name: "LeftWheel.Pressure"
     Value: '32'
      Type: [1×1 systemcomposer.ValueType]
    Parent: [1×1 systemcomposer.arch.Architecture]
      Unit: 'psi'
Delete the promoted parameter.
destroy(pressureParam)
Add a new Muffler component to the mAxleArch architecture model.
topModel = systemcomposer.loadModel("mAxleArch"); mufflerComp = addComponent(topModel.Architecture,"Muffler");
Add the parameter noiseReduction to the Muffler component.
noiseReduce = addParameter(mufflerComp.Architecture,"noiseReduction");Set the default Unit value for the NoiseReduction parameter.
valueTypeNoise = noiseReduce.Type;
valueTypeNoise.Units = "dB";Set the Value property for the noiseReduction parameter.
noiseReduce.Value = "30";View the properties of the noiseReduction parameter.
noiseReduce
noiseReduce = 
  Parameter with properties:
      Name: "noiseReduction"
     Value: '30'
      Type: [1×1 systemcomposer.ValueType]
    Parent: [1×1 systemcomposer.arch.Architecture]
      Unit: 'dB'
Rearrange the mAxleArch architecture model to view all components.
Simulink.BlockDiagram.arrangeSystem("mAxleArch");Delete the Muffler component.
destroy(mufflerComp)
Save the updated models.
model = systemcomposer.loadModel("mWheelArch");
save(model)
save(topModel)Input Arguments
Architectural element, specified as a systemcomposer.arch.Architecture, systemcomposer.arch.Component, or systemcomposer.arch.VariantComponent object.
Architectural instance, specified as a systemcomposer.analysis.ArchitectureInstance or systemcomposer.analysis.ComponentInstance object.
Parameter name, specified as a character vector or string.
Example: "GainArg"
Data Types: char | string
Parameter value, specified as a character vector or string.
Data Types: char | string
Units of parameter, specified as a character vector or string. You can change the units of a parameter only if the value type specifies a unit.
Data Types: char | string
More About
| Term | Definition | Application | More Information | 
|---|---|---|---|
| Architecture | A System Composer™ architecture represents a system of components and how they interface with each other structurally and behaviorally. | Different types of architectures describe different aspects of systems. You can use views to visualize a subset of components in an architecture. You can define parameters on the architecture level using the Parameter Editor. | |
| Root | A root is at the top of an architecture hierarchy. A root architecture has a boundary defined by its architecture ports that surround the system of interest. | The root architecture has a system boundary surrounding your architecture model. You can add architecture ports that define interfaces across the boundary. | |
| Model | A System Composer model is the file that contains architectural information, such as components, ports, connectors, interfaces, and behaviors. | Perform operations on a model including extracting root-level architecture, applying profiles, linking interface data dictionaries, or generating instances from model architecture. A System Composer model is stored as an SLX file. | Create Architecture Model with Interfaces and Requirement Links | 
| Component | A component is a replaceable part of a system that fulfills a clear function in the context of an architecture. A component defines an architectural element, such as a function, another system, hardware, software, or other conceptual entity. A component can also be a subsystem or subfunction. | Represented as a block, a component is a part of an architecture model that can be separated into reusable artifacts. Transfer information between components with port interfaces using the Interface Editor, and parameters using the Parameter Editor. | |
| Port | A port is a node on a component or architecture that represents a point of interaction with its environment. A port permits the flow of information to and from other components or systems. | Component ports are interaction points on the component to other components. Architecture ports are ports on the boundary of the system, whether the boundary is within a component or the overall architecture model. The root architecture has a boundary defined by its ports. | |
| Connector | Connectors are lines that provide connections between ports. Connectors describe how information flows between components or architectures. | A connector allows two components to interact without defining the nature of the interaction. Set an interface on a port to define how the components interact. | 
| Term | Definition | Application | More Information | 
|---|---|---|---|
| Reference component | A reference component is a component whose definition is a separate architecture model, Simulink® behavior model, or Simulink subsystem behavior. A reference component represents a logical hierarchy of other compositions. | You can synchronize and reuse reference components as Reference Component blocks. Model references are Simulink models. FMU components are components that link to Functional Mockup Unit (FMU) files. Subsystem references are Simulink subsystems. Architecture references are System Composer architecture models or subsystems. | |
| Parameter | A parameter is an instance-specific value of a value type. | Parameters are available for architectures and components that are part of the architecture model. Parameters are also available for components linked to model, subsystem, or architecture references that specify model arguments. You can specify independent values for a parameter on each component. | |
| Subsystem component | A subsystem component is a Simulink subsystem that is part of the parent System Composer architecture model. | Add Simulink subsystem behavior to a component to author a subsystem component in System Composer. You cannot synchronize and reuse subsystem components as Reference Component blocks because the component is part of the parent model. | |
| State chart | A state chart diagram demonstrates the state-dependent behavior of a component throughout its state lifecycle and the events that can trigger a transition between states. | Add Stateflow® chart behavior to describe a component using state machines. You cannot synchronize and reuse Stateflow chart behaviors as Reference Component blocks because the component is part of the parent model. | 
Version History
Introduced in R2022a
See Also
Tools
Blocks
Objects
Functions
- addParameter|- getParameter|- getParameterPromotedFrom|- resetToDefault|- getEvaluatedParameterValue|- getParameterNames|- getParameterValue|- setUnit|- resetParameterToDefault
Topics
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)