You can use the setLogAsSpecifiedInModel
function to override signal logging settings specified in a model. For example, you can log only the top model or only a referenced model in a model hierarchy.
Open the IterativeCounter
project. The project opens the CounterSystem
model at startup. This model contains a Model block that references the CounterAlgorithm
model. In total, four signals are marked for logging. The top model has three signals marked for logging: BatchData
, Controls
, and OuterCount
. The referenced model has one signal marked for logging: InnerCount
.
Create an empty Simulink.SimulationData.ModelLoggingInfo
object so that no signals are logged when the logging mode is set to the override settings specified in the Signals
property.
You can use the setLogAsSpecifiedInModel
function to log only signals in the top model using the logging settings specified in that model. Set the outer model to log signals as specified in the model. Then, set the inner model to use override settings. Since the Signals
property vector is empty, no signals are logged when override settings are applied.
The getLogAsSpecifiedInModel
function returns the logging mode.
Apply the model override object settings. Then, simulate the model. The software logs only those signals marked for logging in the top model.
ans =
Simulink.SimulationData.Dataset 'logsout' with 3 elements
Name BlockPath
__________ _________________________
1 [1x1 Signal] BatchData CounterSystem/Concatenate
2 [1x1 Signal] OuterCount CounterSystem/Model
3 [1x1 Signal] Controls CounterSystem/Subsystem
- Use braces { } to access, modify, or add elements using index.
You can also use the setLogAsSpecifiedInModel
function to log only signals in the referenced model using the logging settings specified in that model. Set the outer model to use override settings. Then, set the inner model to log signals as specified in the model.
To verify that the logging mode for the top model and inner model have changed, you can use the getLogAsSpecifiedInModel
function.
Apply the model override object settings. Then, simulate the model. This time, the software logs only the InnerCount
signal.
ans =
Simulink.SimulationData.Dataset 'logsout' with 1 element
Name BlockPath
__________ ________________________________________
1 [1x1 Signal] InnerCount ...l|CounterAlgorithm/For Each Subsystem
- Use braces { } to access, modify, or add elements using index.