Simulink External Mode with ACG SDK
Table of Contents
This document provides instructions on how to use Simulink External Mode with ACG SDK, the software kit for programming imperix targets graphically.
Simulink External Mode establishes a communication channel between a Simulink model and the corresponding code running in a B-Box or B-Board power electronics controller. It allows to:
- Modify or tune block parameters in real-time. When the parameter is changed in the model, Simulink downloads the new values to the executing target application.
- Monitor and save signal data from the executing target application.
Enabling External Mode
To use Simulink External Mode with ACG SDK, enable External Mode on the Simulink model:
- Go in Model Configuration Parameters (Ctrl+E) -> Code Generation -> Interface
- Check External mode (in older MATLAB version: select External mode as the Interface)
- Make sure tcpip is selected as the Transport layer. If the option is not shown then close the configuration window and use the command
sl_refresh_customizations
in MATLAB Command Window. - In the MEX-file arguments field enter the B-Box or B-Board IP in single quotation marks, for instance
ā10.10.10.112ā
- Static memory allocation should be checked and Static memory buffer size kept at its default value
- Click āOKā
data:image/s3,"s3://crabby-images/5c819/5c8199a1bdbe3726a9acc1bf0fd0c8ef0a27370a" alt="Product notes > PN144: Simulink External Mode > image2020-11-9_17-37-0.png Enabling external mide in the model configuration parameters"
Build and Connect
When Simulink External Mode is enabled, building the model (Ctrl+B) integrates External Mode code to the executable. Once the code runs on the B-Box RCP or B-Board PRO power electronics controller, the Simulink model can be connected to the target.
MATLAB R2019b and below
Use the simulation stop time to define the size of the scope graphs.
data:image/s3,"s3://crabby-images/21118/2111870d7ae7b028139346d9186ed0f6ca5ca2e2" alt="Product notes > PN144: Simulink External Mode > image-20200508-120732.png Change the simulation stop time"
In order to use the external mode, the simulation must be configured as External using the drop-down menu, then the Connect To Target button can be used.
data:image/s3,"s3://crabby-images/69f45/69f453b6b1b1ce79fffe1412bf0817aceb27c556" alt="Product notes > PN144: Simulink External Mode > image-20200507-123003.png Change simulation to External"
data:image/s3,"s3://crabby-images/d5830/d5830e54255ff0872858404d187a388ed501bfcc" alt="Product notes > PN144: Simulink External Mode > image-20200507-123018.png Connect to target button"
MATLAB R2020a
In MATLAB R2020a, the connection can be managed from within the Control Panel.
data:image/s3,"s3://crabby-images/4467f/4467f1ee7356fbf208853d781e6ed4700358adb5" alt="Product notes > PN144: Simulink External Mode > 2020_11_09_17_48_16_DTC_PMSM_Simulink_third_party_support_use.png Button to open to the control panel"
data:image/s3,"s3://crabby-images/92c07/92c0767287221441c5a940cdf658711d3b5cfde2" alt="Product notes > PN144: Simulink External Mode > image-20200507-123437.png External mode control panel"
Troubleshooting
Not enough memory on the target
When using a lot of scopes, the memory dedicated to the Simulink External Mode may not be enough and the message “Not enough memory on the target to process the packet: EXT_SELECT_SIGNALS” may appear.
data:image/s3,"s3://crabby-images/6aa04/6aa045131a04f75933375a2de0e69a627d18092f" alt="Product notes > PN144: Simulink External Mode > image2020-11-13_10-17-43.png Error message in the diagnostic viewer"
To fix this issue:
- Open the Control panel
- Click on the Signal & Triggering… button
- Under the Trigger options, reduce the Duration
External Mode and Multi-tasking
External Mode is not compatible with MultiTasking (see Multi-rate control with Simulink (PN145)). As such, when MultiTasking and External Mode are enabled at the same time, there must be no Simulink scope used in a sub-task. Using scopes in the main control task still works.