Standalone User Interface using the MATLAB® Compiler™

This example shows how to create a standalone user interface running on a Windows computer that interacts with a real-time application using the MATLAB API.

Open and build the model

Click here to open the model: open_system('dApplicationDeploymentExample').

The model consists of a sine wave signal source, the output of which is filtered by a Discrete Filter. The model monitors the performance of the digital filter and compares it with theoretical results from the Bode plot of the filter transfer function. The frequency of the signal and the filter coefficients are defined by workspace variables that are created during model load.

model = 'dApplicationDeploymentExample';

The model is configured to build a real-time application for the default Simulink Real-Time target computer but not to automatically download the application to the target computer after building. Instead, we load it using the user interface.

### Starting Simulink Real-Time build procedure for model: dApplicationDeploymentExample
Warning: This model contains blocks that do not handle sample time
changes at runtime. To avoid incorrect results, only change
the sample time in the original model, then rebuild the model. 
### Successful completion of build procedure for model: dApplicationDeploymentExample
### Created MLDATX ..\dApplicationDeploymentExample.mldatx
### Download process is disabled. 

Set up the target computer

When we deploy a Simulink Real-Time function, we assume that the target computer has been correctly set up and is running the Simulink Real-Time kernel. We also expect that the Windows computer is able to communicate with the target computer over a reliable TCP/IP network.

Open the application in MATLAB

We create the user interface using GUIDE. The specific tasks that it implements are:

  1. Connect to target machine

  2. Download application

  3. Start and stop application

  4. Tune a parameter

  5. Monitor signals via a host scope

  6. Integrate MATLAB data analysis with the Simulink Real-Time functions


The example consists of the following:

  1. In the top section, you enter the target IP address and port that will be used when you click 'Connect'. These should match the settings used when you set up the target computer. Once connected, you can download the real-time application to the target computer and start or stop it using the corresponding buttons.

  2. The MATLAB figure on the left displays the Bode magnitude plot of the system calculated in MATLAB from the numerator and denominator coefficients of the discrete filter.

  3. The 'System Response Plot' displays the filtered output signal acquired from the target computer using a host scope. The signal is plotted in blue and the expected maximum and minimum value of the signal is plotted in red. The expected value is calculated from the theoretically obtained Bode magnitude plot.

  4. The 'Frequency' slider allows you to vary the input signal frequency for the real-time application. Every time the slider is changed, a blue '*' indicates the magnitude gain of the discrete filter calculated from the signal values obtained from the target computer.

Compile the User Interface

You use the following MATLAB Compiler command to create a standalone executable from the MATLAB file ApplicationDeploymentExampleGUI.m and the related figure ApplicationDeploymentExampleGUI.fig.

Note: To avoid issues with the generated EXE, copy ApplicationDeploymentExampleGUI.m and ApplicationDeploymentExampleGUI.fig to a temporary directory outside the MATLAB installation location, change directory to that location and then execute the following command.

mcc -m ApplicationDeploymentExampleGUI.m ApplicationDeploymentExampleGUI.fig

Run the executable

You can run the executable on a Windows computer different from the development computer. You must first install the MATLAB Compiler Runtime (MCR). Make sure that the MCR exists on the Windows PATH so that the generated application can find it. More information about distributing the application is present in the README file that is created by the MCC command. The standalone application can be invoked at the Windows command prompt by executing:


If you run the application on the same Windows computer as MATLAB, exit MATLAB before running the executable.