주요 콘텐츠

Instrument

Create real-time instrument object

Description

An slrealtime.Instrument object streams signal data from a real-time simulation running on a Speedgoat® target computer to a MATLAB® development computer. The object provides access to Object Functions, Instrument Object Properties, and Instrument Object Events related to the instrument in the real-time application.

The object provides access to methods and properties that:

  • Find instrumented signals in the real-time application and add these to the instrument object.

  • Add or remove signals in the instrument object.

  • Connect signals in the object to axes or scalar displays.

  • Add, get data from, or remove callbacks for signals in the object.

Creation

instrument_object = slrealtime.Instrument('appName') creates an empty instrument object for an existing real-time application appName.

Example: Create Instrument Object for Real-Time Application

instrument_object = slrealtime.Instrument() creates an empty instrument object without an assigned real-time application.

Example: Create Instrument Object without Real-Time Application

Properties

expand all

The AxesTimeSpan property controls the time axis (x-axis) for all axes in an App Designer UI. When set to Inf, the signal value from the real-time application running on the target computer is displayed in the axes. If you change to a value, for example 10, the time axis for all axes is set to that value, for example 10 seconds.

The AxesTimeSpanOverrun property controls the response for axes in an App Designer UI when the data overruns the AxesTimeSpan property value. When the AxesTimeSpan property value is Inf, the AxesTimeSpanOverrun property has no effect. When the AxesTimeSpan property value is set in seconds, the time axis for all axes is set to a finite width (time range). When a signal value from the real-time application exceeds the largest time value on the x-axis, the axes can either scroll or wrap.

You can set the value of the Application property to an existing real-time application when you create the Instrument object or you can set the value later. After value is written to this property, it become read-only. You can not change the Application property value directly after creating the object. The property value can only be changed after object creation by using the validate function.

Object Functions

addInstrumentedSignalsFind instrumented signals and add these to real-time instrument object
addSignalAdd signal for streaming to be available in callback
clearScalarAndLineDataClear data from children of real-time instrument object
connectCallbackAdd callback that responds to new data from target computer
connectLineConnect signal for streaming to axes
connectScalarAdd signal for streaming to scalar display
connectXYPlotConnect X and Y signal structures to display on axes
deleteDelete real-time instrument object
generateScriptGenerate script that creates scalar and axes controls from signals, scalars, and lines in real-time instrument object
getBufferedDataGets data from the real-time application instrument buffer
getCallbackDataForSignalGet callback data for a signal in real-time instrument object
removeCallbackRemoved callback from real-time instrument object
removeSignalRemove signal from real-time instrument object
validateValidate signals in instrument object

Examples

collapse all

Create instrument object hInst for an existing real-time application appName.

appName = 'slrt_ex_pendulum_100Hz.mldatx';
hInst = slrealtime.Instrument(appName);

Create instrument object hInst without assigning a real-time application. This approach is useful when building a GUI and the real-time application MLDATX file is not available.

hInst = slrealtime.Instrument();

This example shows how to create an Instrument object and apply Instrument object methods. This example uses real-time application slrt_ex_traffic_lights.mldatx and includes the signals that are connected to the instrument object.

Connect Target Computer

Connect to the default target computer.

tg = slrealtime;
connect(tg);

Configure Model for Target Computer

Open the example model and configure the system target file (STF) selection.

model = 'slrt_ex_traffic_lights';
open_system(model);
modelSTF = getSTFName(tg);
set_param(model,"SystemTargetFile",modelSTF);

Build Real-Time Application

Build the real-time app. Use evalc to suppress build messages.

evalc('slbuild(model)');

Open App Generator and MLDATX File

To created an Instrument object and apply Instrument object methods, use the Simulink Real-Time App Generator to bind signals and parameters to controls then generate the app.

Start the App Generator by using the button on the Real-Time tab in the Simulink® Editor.

Open the slrt_ex_traffic_lights.mat file that specifies a set of application controls. You can use this setup to generate the traffic_lighs.mlapp app.

Tip: Open the Parameter panel in the App Generator to inspect parameters for the controls.

Open App Designer and View Callback Code

From the Files in MATLAB®, open the traffic_lighs.mlapp app.

To view the callback code that demonstrates the object methods, switch from Design View to Code View. Scroll to the portion of the callback code that starts with this text:

  Code that executes after component creation
      function startupFcn(app)

To modify this code, open the MAT file, modify the configuration of controls, and click the Update App button.

Close Model and App

When done examining callback code, close the model, the App Generator, and App Designer.

bdclose(model);

Version History

Introduced in R2020b