Win RealTime TRGT
Win RealTime TRGT
R2012a
Product enhancement suggestions Bug reports Documentation error reports Order status, license renewals, passcodes Sales, pricing, and general information
508-647-7000 (Phone) 508-647-7001 (Fax) The MathWorks, Inc. 3 Apple Hill Drive Natick, MA 01760-2098
For contact information about worldwide offices, see the MathWorks Web site. Real-Time Windows Target Users Guide COPYRIGHT 19992012 by The MathWorks, Inc.
The software described in this document is furnished under a license agreement. The software may be used or copied only under the terms of the license agreement. No part of this manual may be photocopied or reproduced in any form without prior written consent from The MathWorks, Inc. FEDERAL ACQUISITION: This provision applies to all acquisitions of the Program and Documentation by, for, or through the federal government of the United States. By accepting delivery of the Program or Documentation, the government hereby agrees that this software or documentation qualifies as commercial computer software or commercial computer software documentation as such terms are used or defined in FAR 12.212, DFARS Part 227.72, and DFARS 252.227-7014. Accordingly, the terms and conditions of this Agreement and only those rights specified in this Agreement, shall pertain to and govern the use, modification, reproduction, release, performance, display, and disclosure of the Program and Documentation by the federal government (or other entity acquiring for or through the federal government) and shall supersede any conflicting contractual terms or conditions. If this License fails to meet the governments needs or is inconsistent in any respect with federal procurement law, the government agrees to return the Program and Documentation, unused, to The MathWorks, Inc.
Trademarks
MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand names may be trademarks or registered trademarks of their respective holders.
Patents
MathWorks products are protected by one or more U.S. patents. Please see www.mathworks.com/patents for more information.
Revision History
January 1999 January 2000 September 2000 June 2001 July 2002 June 2004 October 2004 March 2005 September 2005 March 2006 September 2006 March 2007 September 2007 March 2008 October 2008 March 2009 September 2009 March 2010 September 2010 April 2011 September 2011 March 2012
First printing Second printing Third printing Online only Online only Fourth printing Fifth printing Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only Online only
New for Version 1.0 (Release 11.0) Revised for Version 1.5 (Release 11.1+) Revised for Version 2.0 (Release R12) Revised for Version 2.1 (Release R12.1) Revised for Version 2.2 (Release 13) Revised for Version 2.5 (Release 14) Revised for Version 2.5.1 (Release 14SP1) Revised for Version 2.5.2 (Release 14SP2) Revised for Version 2.6 (Release 14SP3) Revised for Version 2.6.1 (Release 2006a) Revised for Version 2.6.2 (Release 2006b) Revised for Version 2.7 (Release 2007a) Revised for Version 3.0 (Release 2007b) Revised for Version 3.1 (Release 2008a) Revised for Version 3.2 (Release 2008b) Revised for Version 3.3 (Release 2009a) Revised for Version 3.4 (Release 2009b) Revised for Version 3.5 (Release 2010a) Revised for Version 3.6 (Release 2010b) Revised for Version 3.7 (Release 2011a) Revised for Version 3.8 (Release 2011b) Revised for Version 4.0 (Release 2012a)
Contents
Getting Started
1
Product Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Key Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Using the Product . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Using This Guide . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Real-Time Kernel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Real-Time Application . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Signal Acquisition and Analysis . . . . . . . . . . . . . . . . . . . . . . Parameter Tuning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Hardware Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . PC-Compatible Computer . . . . . . . . . . . . . . . . . . . . . . . . . . . Input/Output Driver Support . . . . . . . . . . . . . . . . . . . . . . . . Software Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Non-Real-Time Simulation . . . . . . . . . . . . . . . . . . . . . . . . . . Normal Mode Real-Time Simulation . . . . . . . . . . . . . . . . . . External Mode Real-Time Execution . . . . . . . . . . . . . . . . . . Development Process . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . System Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Simulink Normal Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Simulink External Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . Data Buffers and Transferring Data . . . . . . . . . . . . . . . . . . 1-2 1-2 1-3 1-4 1-5 1-5 1-6 1-7 1-8 1-10 1-10 1-10 1-12 1-12 1-12 1-13 1-13 1-15 1-15 1-16 1-18
2
Hardware Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . Software Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . The MATLAB Environment . . . . . . . . . . . . . . . . . . . . . . . . . Simulink Software . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Simulink Coder Software . . . . . . . . . . . . . . . . . . . . . . . . MATLAB Coder Software . . . . . . . . . . . . . . . . . . . . . . . . Installed Files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Initial Working Directory . . . . . . . . . . . . . . . . . . . . . . . . . . Working Directory Location Requirement . . . . . . . . . . . . . . Setting the Working Directory from the Desktop Icon . . . . Setting the Working Directory from the MATLAB Environment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Real-Time Kernel Installation . . . . . . . . . . . . . . . . . . . . . . Installing the Kernel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Uninstalling the Kernel . . . . . . . . . . . . . . . . . . . . . . . . . . . . Testing the Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . Running the Model rtvdp.mdl . . . . . . . . . . . . . . . . . . . . . . . Displaying Status Information . . . . . . . . . . . . . . . . . . . . . . . Detecting Excessive Sample Rates . . . . . . . . . . . . . . . . . . . . Examples Library . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-2 2-3 2-3 2-3 2-5 2-5 2-6 2-8 2-8 2-8 2-8 2-10 2-10 2-11 2-14 2-14 2-16 2-17 2-18
Basic Procedures
3
Using Simulink Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . About Simulink Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . Creating a Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Configuring a Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Running a Simulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-2 3-2 3-2 3-6 3-11
vi
Contents
Using Real-Time Applications . . . . . . . . . . . . . . . . . . . . . . Real-Time Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Entering External Mode Code Generation Parameters . . . Entering Scope Parameters for Signal Tracing . . . . . . . . . . Creating a Real-Time Application . . . . . . . . . . . . . . . . . . . . Entering External Mode Scope Parameters for Signal Tracing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Running a Real-Time Application from Simulink . . . . . . . . Running an Application from the MATLAB Command Line . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Logging Signals to the MATLAB Workspace . . . . . . . . . . Signal Logging to the Workspace . . . . . . . . . . . . . . . . . . . . . Scope Parameters for Logging to the Workspace . . . . . . . . External Mode Signal and Triggering Properties for Logging to the Workspace . . . . . . . . . . . . . . . . . . . . . . . . Plotting Signal Data Logged to the Workspace . . . . . . . . . . Logging Signals to a File . . . . . . . . . . . . . . . . . . . . . . . . . . . Signal Logging to a File . . . . . . . . . . . . . . . . . . . . . . . . . . . . Scope Parameters for Logging to a File . . . . . . . . . . . . . . . . External Mode Signal and Triggering Properties for Logging to a File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . External Mode Data Archiving Parameters for Logging to a File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Plotting Signal Data Logged to a File . . . . . . . . . . . . . . . . . Tuning Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Tuning Block Parameters and MATLAB Variables . . . . . . Changing Model Parameters . . . . . . . . . . . . . . . . . . . . . . . .
3-13 3-13 3-20 3-22 3-24 3-25 3-28 3-31 3-33 3-33 3-33 3-35 3-38 3-40 3-40 3-40 3-43 3-45 3-47 3-50 3-50 3-51
4
Using I/O Boards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . About I/O Boards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Installing and Configuring I/O Boards and Drivers . . . . . . ISA Bus Board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PCI Bus Board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-2 4-2 4-2 4-6 4-6
vii
PC/104 Board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Compact PCI Board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PCMCIA Board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Using I/O Driver Blocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . About I/O Driver Blocks . . . . . . . . . . . . . . . . . . . . . . . . . . . . The Real-Time Windows Target Library . . . . . . . . . . . . . . . Output Signals from an I/O Block . . . . . . . . . . . . . . . . . . . . Variations with Channel Selection . . . . . . . . . . . . . . . . . . . Using Analog I/O Drivers . . . . . . . . . . . . . . . . . . . . . . . . . . . About Analog Drivers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . I/O Driver Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . Normalized Scaling for Analog Inputs . . . . . . . . . . . . . . . . . Using Vector CAN Drivers . . . . . . . . . . . . . . . . . . . . . . . . . .
4-7 4-7 4-8 4-9 4-9 4-10 4-10 4-11 4-15 4-15 4-15 4-16 4-20
Troubleshooting
5
Building Older Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Plots Not Visible in Simulink Scope Block . . . . . . . . . . . Failure to Connect to Target . . . . . . . . . . . . . . . . . . . . . . . . Scope Output Delayed or Missing . . . . . . . . . . . . . . . . . . . S-Functions Using Math Functions . . . . . . . . . . . . . . . . . . 5-2 5-3 5-4 5-5 5-6
A
Supported C Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-2
viii
Contents
...............
Examples
B
Simulink Model Examples . . . . . . . . . . . . . . . . . . . . . . . . . . Real-Time Application Examples . . . . . . . . . . . . . . . . . . . . Signal Logging to MATLAB Workspace Examples . . . . . Signal Logging to Disk Drive Examples . . . . . . . . . . . . . . Parameter Tuning Examples B-2 B-3 B-4 B-5 B-6 B-7
.......................
Index
ix
Contents
1
Getting Started
Product Description on page 1-2 Using the Product on page 1-3 Using This Guide on page 1-4 Features on page 1-5 Hardware Environment on page 1-10 Software Environment on page 1-12 System Concepts on page 1-15
Getting Started
Product Description
Run Simulink models in real time on Microsoft Windows PCs Real-Time Windows Target provides a real-time engine for executing Simulink models on a Microsoft Windows PC and blocks that connect to a range of I/O boards. It enables you to create and control a real-time system for rapid prototyping or hardware-in-the-loop simulation. Real-Time Windows Target supports two Simulink simulation modes: normal mode, for simple real-time operation with access to I/O devices, and external mode, for higher real-time performance (with Simulink Coder).
Key Features
Real-time closed-loop execution of Simulink models on Microsoft Windows Signal visualization and parameter tuning while model is running Execution control directly from Simulink, creating a PC-in-the-loop prototyping environment Real-time performance exceeding 500 Hz in normal execution mode Real-time performance exceeding 5 kHz in external execution mode (with Simulink Coder) Blocks supporting more than 250 I/O modules (including analog I/O, digital I/O, counters, encoders, and frequency output) and communication protocols (including UDP, serial, and CAN)
1-2
1-3
Getting Started
1-4
Features
Features
In this section... Real-Time Kernel on page 1-5 Real-Time Application on page 1-6 Signal Acquisition and Analysis on page 1-7 Parameter Tuning on page 1-8
Real-Time Kernel
The Real-Time Windows Target software uses a small real-time kernel that runs in Windows kernel mode using the built-in PC clock as its primary time source. In external mode, both the application and the I/O drivers run in the kernel. In Simulink normal mode, only the I/O drivers run in the kernel. Timer interrupt The kernel intercepts the interrupt from the PC clock before the Windows operating system receives it. The kernel then uses the interrupt to trigger the execution of the compiled model. As a result, the kernel is able to give the real-time application the highest priority available. Note This behavior intercepts any calls to the Windows operating system. Consequently, you cannot use Win32 calls in your C-code S-function. For more information, see Incompatibility with Win32 API Calls on page A-4. The kernel is provided as a Windows kernel-mode driver. To achieve more accurate sampling, the kernel reprograms the PC clock to a higher frequency. Because the PC clock is also the primary time source for the Windows operating system, the kernel sends a timer interrupt to the operating system at the original interrupt rate. Scheduler The timer interrupt clocks a simple scheduler that runs the executable. The number of tasks is equal to the number of sampling periods in the model with multitasking mode. With single-tasking mode, there is only one task. The maximum number of tasks is 32, and faster
1-5
Getting Started
tasks have higher priorities than slower tasks. For example, a faster task can interrupt a slower task. During execution, the executable stores data in buffers. Later, the data in these buffers is retrieved by the Scope block. The scheduling, data storing, data transferring, and running the executable all run in Windows kernel mode. Communication with hardware The kernel interfaces and communicates with I/O hardware using I/O driver blocks, and it checks that the I/O board has been installed. If the board has been installed, the drivers allow your real-time application to run. You can choose to have a driver block use values equal to voltage, normalize values from 0 to +1, normalize values from -1 to +1, or use the raw integer values from the A/D or D/A conversion press. Drivers also run in Windows kernel mode. Simulink normal mode Communication between the Simulink software algorithm and the real-time kernel is carried out by interprocess communication. Simulink external mode Communication between the Simulink software and the real-time application is through the Simulink external mode interface module. This module talks directly to the real-time kernel, and is used to start the real-time application, change parameters, and retrieve scope data. Note External mode is not supported for 64-bit installations of Real-Time Windows Target.
Real-Time Application
The real-time application runs in real time on your host computer and has the following characteristics: Compiled code Created from the generated C-code using a bundled C compiler shipped with the Real-Time Windows Target software. No other third-party compiler is required or can be used.
1-6
Features
Note The Real-Time Windows Target software always uses the bundled compiler, even if you have specified some other compiler using the mex -setup command. Relation to your Simulink model The executable contains a binary form of all Simulink model components, connections between blocks, time dependencies, and variables in the Simulink blocks. Relation to the kernel The executable must be loaded and executed directly by the Real-Time Windows Target kernel. It cannot be executed without the kernel. The kernel runs as a kernel-mode driver, intercepts timer interrupts from the PC clock, maintains clock signals for the Windows operating system, and runs the application in real-time. As a result, both the kernel and the real-time application run in Windows kernel mode. Checksum The Simulink model and the executable contain a checksum value. The kernel uses this checksum value to determine if the Simulink model structure, at the time of code generation, is consistent with the real-time application structure during execution. This verifies that when you change parameters during an execution, the Simulink model parameters map to the memory locations in the real-time application. If you make structural changes to your Simulink model, the Simulink checksum value will not match the executable checksum value. You will have to rebuild your executable before you can connect it to your Simulink model.
1-7
Getting Started
Signal Tracing Process of acquiring and visualizing signals during a real-time run. It allows you to acquire signal data and visualize it on your computer while the executable is running. Signal Logging Process for acquiring signal data during a real-time run. After the run reaches its final time or you manually stop the run, you can plot and analyze the data. You can save (log) data to variables in the MATLAB workspace or save data to a MAT-file. Signal logging differs from signal tracing. With signal logging you can only look at a signal after a run is finished. For more information, see Logging Signals to the MATLAB Workspace on page 3-33 and Logging Signals to a File on page 3-40.
Parameter Tuning
Change the parameters in your Simulink model and observe the effect of those changes during a simulation or while running an application in real time. Simulink normal mode You use your Simulink block diagram to access block parameters just as you would in any Simulink model. Parameter changes are propagated to the I/O drivers and from there to the hardware. Simulink external mode You use Simulink external mode to connect your Simulink block diagram to your real-time application. The block diagram becomes a graphical user interface (GUI) to that executable. Simulink external mode allows you to change parameters by editing the block diagram while running a simulation in external mode. New parameter values are automatically transferred to the real-time application while it is running. There are different types of model parameters that you can change while running your real-time application. For example, parameters include the amplitude of a gain and the frequency of a sine wave. After you connect your real-time application to your Simulink model, you can change parameters. You can change these parameters before or while your real-time application is running by using one of the following methods:
1-8
Features
Block parameters Change values in the dialog boxes associated with the Simulink blocks. Block parameters for masked subsystems Change values in user-created dialog boxes associated with a subsystem. MATLAB variables Create MATLAB variables that represent Simulink block parameters, and then change parameter values by entering the changes through the MATLAB command line. For more information about parameter tuning, see Tuning Parameters on page 3-50.
1-9
Getting Started
Hardware Environment
In this section... PC-Compatible Computer on page 1-10 Input/Output Driver Support on page 1-10
PC-Compatible Computer
You can use any PC-compatible computer that runs 32bit versions of Microsoft Windows XP, Microsoft Windows Vista , or Microsoft Windows 7. Your computer can be a desktop, laptop, or notebook PC.
I/O Boards
I/O boards Real-Time Windows Target software supports a wide range of I/O boards. Some of the capabilities on a board may not be supported by Real-Time Windows Target software. Check Supported I/O Boards on the MathWorks Web site for an updated list of supported boards and capabilities.
1-10
Hardware Environment
an I/O driver block to your model just as you would connect any standard Simulink block. You create a real-time application in the same way as you create any other Simulink model, by using standard blocks and C-code S-functions. You can add input and output devices to your Simulink model by using the I/O driver blocks from the rtwinlib library provided with the Real-Time Windows Target software. This library contains the following blocks: Analog Input Analog Output Counter Input Digital Input Digital Output Encoder Input Frequency Output Other Input Other Output Packet Input Packet Output Real-Time Sync Stream Input Stream Output The Real-Time Windows Target software provides driver blocks for more than 200 I/O boards. These driver blocks connect the physical world to your real-time application: Sensors and actuators are connected to I/O boards. I/O boards convert voltages to numerical values and numerical values to voltages. Numerical values are read from or written to I/O boards by the I/O drivers.
1-11
Getting Started
Software Environment
In this section... Non-Real-Time Simulation on page 1-12 Normal Mode Real-Time Simulation on page 1-12 External Mode Real-Time Execution on page 1-13 Development Process on page 1-13
Non-Real-Time Simulation
You create a Simulink model and use Simulink software in normal mode for non-real-time simulation on your host computer. Simulink model Create block diagrams with Simulink software by using simple drag-and-drop operations, and then enter values for the block parameters and select a sample rate. Non-real-time simulation Simulink software uses a computed time vector to step your Simulink model. After the outputs are computed for a given time value, the Simulink software immediately repeats the computations for the next time value. This process is repeated until it reaches the stop time. Because this computed time vector is not connected to a hardware clock, the outputs are calculated in nonreal time as fast as your computer can run. The time to run a simulation can differ significantly from real time.
1-12
Software Environment
communicates signal values to and from the I/O hardware, it synchronizes the simulation with the real-time clock. Because only the I/O drivers are synchronized with the real-time clock, the simulation might miss clock ticks. You can set I/O block parameters to handle a specified number of missed ticks.
Development Process
With Real-Time Windows Target rapid prototyping software, you can use your desktop PC with the MATLAB environment, Simulink software, Simulink Coder code generation software, and Real-Time Windows Target software to:
1 Design a control system Use the MATLAB environment and Control
System Toolbox software to design and select the system coefficients for your controller.
1-13
Getting Started
before you create a real-time application. For example, you can check the stability of your model.
4 Run a normal mode simulation in real-timeCheck the behavior of your
model in real time with reduced performance before doing code generation. For example, you can check your model at low sample rates before moving to high sample rates. Tip To run a non-real-time normal mode model in real-time normal mode, you must: Add one or more configured Real-Time Windows Target blocks to the model. Install the real-time kernel (see Installing the Kernel on page 2-10).
5 Create a real-time application Simulink Coder code generation software
creates C code from your Simulink model. The bundled C compiler compiles the C code to an executable that runs with the Real-Time Windows Target kernel.
6 Run an application in real time Your desktop PC is the target computer
saved to the MATLAB workspace or a disk. Note Although Real-Time Windows Target applications run on the same hardware as Windows, the Real-Time Windows Target kernel and the Win32 kernel are incompatible. When a Real-Time Windows Target application includes externally created code, such as a custom I/O driver block or a user-supplied S-function, the code cannot access any Win32 function. For more information, see Incompatibility with Win32 API Calls on page A-4.
1-14
System Concepts
System Concepts
In this section... Simulink Normal Mode on page 1-15 Simulink External Mode on page 1-16 Data Buffers and Transferring Data on page 1-18
1-15
Getting Started
I/O Driver
Normal Mode
Simulink Process
1-16
System Concepts
In some Simulink Coder targets, such as Tornado/VME targets, the communications interface uses TCP/IP protocol. For a Real-Time Windows Target application, the host computer serves as the target computer, running the target application in a separate Windows kernel mode process. Therefore, only a virtual I/O driver is required to exchange parameters between the MATLAB environment, Simulink memory space, and memory accessible to the real-time application. Signal acquisition You can capture and display signals from your real-time application while it is running. Signal data is retrieved from the real-time application and displayed in the same Simulink Scope blocks you used for simulating your model. Parameter tuning You can change parameters in your Simulink block diagram and have the new parameters passed automatically to the real-time application. Simulink external mode changes parameters in your real-time application while it is running in real time.
1-17
Getting Started
I/O Driver
Simulink Process
1-18
System Concepts
Once the data buffer is filled, Simulink software suspends data capture while the data is transferred back to the MATLAB environment through Simulink external mode. Your real-time application, however, continues to run. Transfer of data is less critical than maintaining deterministic real-time updates at the selected sample interval. Therefore, data transfer runs at a lower priority in the remaining CPU time after model computations are performed while waiting for another interrupt to trigger the next model update. Data captured within one buffer is contiguous. When a buffer of data has been transferred, it is immediately plotted in a Simulink Scope block, or it can be saved directly to a MAT-file using the data archiving feature of the Simulink external mode. With data archiving, each buffer of data can be saved to its own MAT-file. The MAT-file names can be automatically incremented, allowing you to capture and automatically store many data buffers. Although points within a buffer are contiguous, the time required to transfer data back to the Simulink software forces an intermission for data collection until the entire buffer has been transferred and may result in lost sample points between data buffers.
1-19
Getting Started
1-20
2
Installation and Configuration
Hardware Configuration on page 2-2 Software Configuration on page 2-3 Installed Files on page 2-6 Initial Working Directory on page 2-8 Real-Time Kernel Installation on page 2-10 Testing the Installation on page 2-14
Hardware Configuration
The Real-Time Windows Target rapid prototyping software is a self-targeting system where the host and the target computer are the same computer.
Note For basic Real-Time Windows Target system requirements, see http://www.mathworks.com/products/rtwt/requirements.html on the Real-Time Windows Target product page (http://www.mathworks.com/products/rtwt). For material on related products, see http://www.mathworks.com/products/rtwt/related.html.
At a minimum, Real-Time Windows Target requires the following computer hardware: Hardware CPU Peripherals Description Intel Pentium or higher in a desktop, laptop, or compact PCI or PC104 industrial computer Hard disk drive with 16 megabytes of free space Data acquisition board (for a list of supported boards, see Supported I/O Boards) DVD drive RAM 128 megabytes minimum, 256 megabytes suggested
When you are using a laptop computer, Real-Time Windows Target software provides a portable environment where your computer uses PCMCIA cards to interface to real world devices.
2-2
Software Configuration
Software Configuration
At a minimum, Real-Time Windows Target requires the following software configuration: 32-bit or 64-bit Microsoft Windows 7 or Windows XP. MATLAB 7.14 Simulink 7.9 Simulink Coder 8.2 MATLAB Coder 2.2 Real-Time Windows Target 4.0
Note Simulink Coder is required for External Mode only. External mode is not supported for 64-bit installations of Real-Time Windows Target. The Real-Time Windows Target software does not support the Simscape or SimDriveline products.
Simulink Software
Simulink software provides an environment where you model your physical system and controller as a block diagram. You create the block diagram by
2-3
using a mouse to connect blocks and a keyboard to edit block parameters. C code S-functions are supported by Simulink Coder code generation software. With Real-Time Windows Target software, you can remove the physical system model and replace it with Real-Time Windows Target I/O driver blocks connected to your sensors and actuators. The Real-Time Windows Target I/O library supports more than 200 boards. Note Some of the functions on a board may not be supported by Real-Time Windows Target software. Check the MathWorks Web site for an updated list of supported boards and functions at Supported I/O Boards. For information on Simulink software, see Simulink Users Guide, which explains how to connect blocks to build models and change block parameters. It also provides a reference that describes each block in the standard Simulink library. Known limitations include: External mode is not supported in 64-bit installations of Real-Time Windows Target. Unsupported Simulink blocks in external mode You can use Real-Time Windows Target software with most Simulink blocks, including discrete-time and continuous-time systems. In external mode, Real-Time Windows Target software does not support blocks that do not run in real time, nor does it support To File blocks. Limitations with Simulink Coder code generation software:
When you use a continuous-time system and generate code for external mode execution with Simulink Coder code generation software, you must use a fixed-step integration algorithm. The Simulink Coder product provides an API for the MATLAB Distributed Computing Server or Parallel Computing Toolbox products to perform parallel builds that reduce build time for referenced models. However, this API does not support parallel builds for models whose system target file parameter is set to rtwin.tlc or rtwinert.tlc. In
2-4
Software Configuration
other words, you cannot perform parallel builds for Real-Time Windows Target.
Note Simulink Coder is required for External Mode only. Code generation is not supported for 64-bit installations. For 32-bit installations of Real-Time Windows Target, the real-time executable is built with a subset of Open Watcom bundled with the product. No additional or external compiler is required.
Real-Time Windows Target software is designed for maximum flexibility during rapid prototyping. This flexibility allows parameter tuning and signal tracing during a real-time run, but increases the size of the generated code. However, Simulink Coder code generation software provides other code formats that generate more compact code for embedded applications. For information on code generation with Simulink Coder, see the Simulink Coder Users Guide.
2-5
Installed Files
You can install Real-Time Windows Target software as part of the regular installation process documented in MathWorks installation guides. This section describes installed files that are unique to Real-Time Windows Target software. When using the product, you may find it helpful to know where these files are located. MATLAB working directory Simulink models (model.mdl) and the Real-Time Windows Target executable (model.rwd). Note Select a working directory outside the MATLAB root. See Initial Working Directory on page 2-8. Simulink Coder project directory The Simulink Coder C-code files (model.c, model.h) are in a subdirectory called model_rtwin. Real-Time Windows Target Files The files included with Real-Time Windows Target software are located in the directory
matlabroot\toolbox\rtw\targets\rtwin
Open Watcom C/C++ compiler directory The Open Watcom C/C++ compiler files are located in a subdirectory called openwat. Note The Open Watcom source code is available under the terms of the Open Watcom License. For more information, visit http://www.openwatcom.org. Real-Time Windows Target software provides files to help Simulink Coder code generation software create C code from your Simulink model and compile that code to a real-time executable: System Target File (rtwin.tlc) Defines the process of generating C code by Real-Time Windows Target software.
2-6
Installed Files
Template Makefile and Makefile (rtwin.tmf, model_name.mk) The template makefile serves as a template for generating the real makefile, which the make utility uses during model compilation. During the automatic build procedure, the make command extracts information from the template makefile rtwintmf.m and generates the makefile model_name.mk. Make Command (make_rtw.m) The standard make command supplied with Simulink Coder code generation software. Other files provided with Real-Time Windows Target software include I/O drivers (*.rwd) Binaries for I/O device drivers. Real-Time Windows Target software does not link the driver object files with your real-time executable. The drivers are loaded into memory and run by the kernel separately. Simulink external mode interface (rtwinext.mex*) MEX-file for communicating between Simulink external mode and the Real-Time Windows Target kernel. Simulink external mode uses the MEX-file interface module to download new parameter values to the real-time model and to retrieve signals from the real-time model. You can display these signals in Simulink Scope blocks. Kernel install and uninstall commands (rtwintgt.m, rtwho.m) .m scripts to install and uninstall the Real-Time Windows Target kernel and check installation.
2-7
want the MATLAB environment to use initially outside the MATLAB root directory.
3 Click OK, and then start the MATLAB environment. To check your
2-8
cd c:\mwd
2 Check the current working directory, type
cd
2-9
rtwintgt -install
or:
a Click the MATLAB Start button. b
Select Simulink > Real-Time Windows Target > Install real-time kernel
2-10
You are going to install the Real-Time Windows Target kernel. Do you want to proceed? [y] :
or:
There is a different version of the Real-Time Windows Target kernel installed. Do you want to update to the current version? [y] :
making any changes. If you type y, the MATLAB environment installs the kernel and displays the message:
The Real-Time Windows Target kernel has been successfully installed.
attempting to use the kernel, or your Real-Time Windows Target model will not run.
4 After installing the kernel, verify that it was installed by typing:
rtwho
The MATLAB Command Window should display a message that shows the kernel version number, followed by performance, time slice, and other information. Once the kernel is installed, you can leave it installed. The kernel remains idle after you have installed it, which allows the Windows operating system to control the execution of any standard Windows based application, including Internet browsers, word processors, the MATLAB environment, and so on. The kernel becomes active when you begin execution of your model, and becomes idle again after model execution completes.
2-11
rtwintgt -uninstall
or:
a Click the MATLAB Start button. b
Select Simulink > Real-Time Windows Target > Uninstall real-time kernel
without making any changes. If you type y, the MATLAB environment uninstalls the kernel by removing it from memory, then displays the message:
The Real-Time Windows Target kernel has been successfully uninstalled.
rtwho
2-12
rtwintgt -uninstall
The rtwintgt program uninstalls the kernel by removing it from memory, then displays the message:
The Real-Time Windows Target kernel uninstalled successfully.
2-13
2-14
Real-Time Windows Target software includes the model rtvdp.mdl, which already has Simulink Coder options selected for you:
1 In the MATLAB Command Window, type
rtvdp
Tip The model is initially in normal mode. At this point, you might start real-time normal mode simulation by clicking Simulation > Start.
3 From the Tools menu, choose Code Generation > Build Model.
2-15
4 From the Simulation menu, click External, and then click Connect to
The Scope window displays the output signals. If your Scope window looks like the next figure, you have installed the Real-Time Windows Target software and have run a real-time application.
The real-time application stops running, and the Scope window stops displaying the output signals.
2-16
and other information. To see this information, in the MATLAB Command Window type
rtwho
The command displays several lines of information in the MATLAB Command Window. Some possible lines and their interpretations are:
MATLAB performance = 100.0%
This message indicates that the MATLAB environment and other non-real-time applications (for example, a word processor) are able to run at 100% performance because no real-time applications are currently executing. When a real-time application is executing, the MATLAB performance is at a value below 100%. For example, if the MATLAB performance is 90.0%, then the real-time application is using 10% of the CPU time. Select a sample rate such that rtwho returns a MATLAB performance of at least 80%.
Kernel timeslice period = 1 ms
The kernel time slice period is the current frequency of the hardware timer interrupt. One millisecond is the maximum value for models with large sample times (slow sampling rate) or when an application has not been built. This value changes when you select sampling times less than 1 millisecond.
TIMERS: Number 1 Period 0.01 Running Yes
The indicated timer(s) exist on your system with the period and run status shown for each timer.
DRIVERS: Name Humusoft AD512 ecg Address 0x300 0 Parameters [] []
The indicated device driver(s) are installed on your system at the address and with the parameter(s) shown for each driver.
2-17
exceeding 10 kHz can be achieved on Pentium computers. Once the model is running, you can issue the rtwho command in the MATLAB Command Window to observe the system performance. For example, the following lines show that MATLAB performance has decreased because the system is overloaded:
MATLAB performance = 77.1% Kernel timeslice period = 0.001 ms
Examples Library
The examples library includes models with preset values and dialog boxes. These models include simple signal processing and simple control examples that use no I/O blocks, use A/D blocks only, and use both A/D and D/A blocks.
Tip To run an example that uses I/O blocks, you must configure the Adapter block to match the I/O board installed in your computer. You can run examples in both Simulink Normal Mode (initial setting) and in Simulink External Mode. To see these models from the MATLAB environment:
1 Type rtwtdemo in the MATLAB Command Window.
2-18
3
Basic Procedures
Using Simulink Models on page 3-2 Using Real-Time Applications on page 3-13 Logging Signals to the MATLAB Workspace on page 3-33 Logging Signals to a File on page 3-40 Tuning Parameters on page 3-50
Basic Procedures
Creating a Model
You need to create a Simulink model before you can run a simulation or create a real-time application. This procedure explains how to create a simple Simulink model. You can use this model as an example to learn other procedures that are useful with Real-Time Windows Target software.
1 In the MATLAB Command Window, type
simulink
The Simulink Library Browser opens. The left pane shows a hierarchy of libraries and block categories, with the Simulink library at the top. The right pane shows the blocks available in the category selected on the left. See Library Browser for more information.
2 Choose File > New > Model, or click the New model button on the toolbar.
> Sources. Click and drag a Signal Generator block from the browser to the Simulink window.
3-2
Select Continuous. Click and drag a Transfer Fcn block to the Simulink window. Select Sinks. Click and drag a Scope block to the Simulink window.
4 Connect the Signal Generator output to the Transfer Fcn input by
clicking-and-dragging a line between the blocks. Likewise, connect the Transfer Fcn output to the Scope input.
5 Double-click the Transfer Fcn block. The Block Parameters dialog box
Your Block Parameters dialog box looks similar to the next figure.
3-3
Basic Procedures
6 Click OK. 7 Double-click the Signal Generator block. The Block Parameters dialog box
opens. From the Wave form list, select square. In the Amplitude text box, enter
1
From the Units list, select rad/sec. Your Block Parameters dialog box looks similar to the next figure.
8 Click OK.
The next figure shows the completed Simulink block diagram, with toolbar and status bar not shown:
3-4
9 From the File menu, click Save As. The Save As dialog box opens. In the
File name text box, enter a file name for your Simulink model and click Save. For example, type
rtwin_model
The Simulink software saves your model in the file rtwin_model.mdl. To specify a default Real-Time Windows Target configuration set for your model, see Specifying the Default Configuration Set on page 3-7. If you activate this configuration set for your model, you can build your real-time application later without setting additional configuration parameters. To manually configure your model, continue to Entering Configuration Parameters Manually on page 3-8, following. That section teaches you how to enter configuration parameters for your Simulink model, then leads you into procedures for entering scope parameters and running a non-real-time simulation of the model.
Model Referencing
The Real-Time Windows Target software supports model referencing. See Referencing a Model in the Simulink Users Guide guide for more information.
3-5
Basic Procedures
If a Real-Time Windows Target model contains any block that tries to perform file system I/O, an error could occur when you try to compile the model, generate code for it, or use External Mode with it. Even if no error occurs, the block has no effect on either simulation or code execution. Tip You can use file I/O blocks in Simulink normal mode simulation in real time. In this case, the file I/O is not carried out by the real-time kernel, but by Simulink itself. To log signal data without needing a file system, use the techniques described in Logging Signals to a File on page 3-40. See Running a Real-Time Application from Simulink on page 3-28 for information about using External Mode to execute a Real-Time Windows Target application.
Configuring a Model
After you create a Simulink model, you can enter configuration parameters for the model. These parameters control many properties of the model for simulation and code generation. This section contains the essential information you need when setting configuration parameters for a Real-Time Windows Target application. For complete information about Simulink configuration parameters, see Manage a Configuration Set and Configuration Parameters Dialog Box. A configuration set is a named set of values for model parameters, such as solver type and simulation start or stop time. Every new model is created with a default configuration set, called Configuration, that initially specifies default values for the models model parameters. You can subsequently create additional configuration sets and associate them with the model, as described in Manage a Configuration Reference. The easiest way to specify configuration parameters for a Real-Time Windows Target model is to programmatically assign the default Real-Time Windows Target configuration set, as described in Specifying the Default Configuration Set on page 3-7. You can also set parameters manually, as described in Entering Configuration Parameters Manually on page 3-8. Other sections describe setting configuration patterns for specific purposes.
3-6
As. The Save As dialog box opens. In the File name text box, enter a file name for your Simulink model and click Save. For example, type
rtwin_model
rtwinconfigset('rtwin_model')
The default Real-Time Windows Target configuration set, RTWin, is now active for the rtwin_model model. (Alternatively, you can set the default Real-Time Windows Target configuration set by setting the Configuration Parameters System target file option to rtwin.tlc.) You do not need to perform any other configuration for a Real-Time Windows Target application.
3 Save the model.
See Creating a Real-Time Application on page 3-24 for a description of how to build your Real-Time Windows Target application. To revert to the default configuration set, Configuration, or any other configuration set you have for the model, use Model Explorer. This is an alternative tool that you can use to enter simulation parameters for a model. See the Simulink documentation for a description of how to use Model Explorer.
3-7
Basic Procedures
Note Your model uses a Real-Time Windows Target configuration set when you change the System target file value to a Real-Time Windows Target one, such as rtwin.tlc or rtwinert.tlc. The software creates the Real-Time Windows Target configuration set, RTWin or RTWinERT, only if one does not already exist.
Configuration Parameters. In the Configuration Parameters dialog box, click the Solver tab. The Solver pane opens.
2 In the Start time field, enter 0.0. In the Stop time field, enter the amount
of time you want your model to run. For example, enter 10.0 seconds.
3 From the Type list, choose Fixed-step. Simulink Coder code generation
blocks that have different sample times, choose MultiTasking.) Your Solver pane looks similar to the next figure.
3-8
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
3-9
Basic Procedures
3 Click the General tab. In the Number of axes field, enter the number of
graphs you want in one Scope window. For example, enter 1 for a single graph. Do not select the floating scope check box. In the Time range field, enter the upper value for the time range. For example, enter 1 second. From the Tick labels list, choose all. From the Sampling list, choose Sample time and enter 0 in the text box. Entering 0 indicates that the Simulink software evaluates this block as a continuous time block. If you have discrete blocks in your model, enter the Fixed step size you entered in the Configuration Parameters dialog box. Your Scope parameters dialog box looks similar to the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
5 In the Scope window, point to the y-axis shown in the next figure, and
right-click.
3-10
6 From the pop-up menu, click Axes Properties. 7 The Scope properties: axis 1 dialog box opens. In the Y-min and Y-max
text boxes, enter the range for the y-axis in the Scope window. For example, enter -2 and 2 as shown in the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
Running a Simulation
You use Simulink normal mode to run a non-real-time simulation. Running a simulation lets you observe the behavior of your model in nonreal time.
3-11
Basic Procedures
After you load your Simulink model into the MATLAB workspace, you can run a simulation. This procedure uses the Simulink model rtwin_model.mdl as an example and assumes you have loaded that model:
1 In the Simulink window, double-click the Scope block.
Select Normal mode simulation. Choose Start to begin simulation. The Simulink software runs the simulation and plots the signal data in the Scope window. During the simulation, the Scope window displays the samples for one time range, increases the time offset, and then displays the samples for the next time range.
Let the simulation run to the stop time. From the Simulation menu, click Stop. The simulation stops. The MATLAB environment does not display any messages.
3-12
Real-Time Applications
The simulation algorithm for a non-real-time model runs entirely within Simulink. While the model can use either a fixed-step or variable-step solver, there is no real-time clock, so the simulation is not synchronized with real time. The model runs as fast as it can, given the presence of competing Windows processes.
Simulink Process
3-13
Basic Procedures
If you want your model to operate with a real-time system outside Simulink, you must create a Real-Time Windows Target application synchronized to a real-time clock. Real-Time Windows Target simulations run in two modes, normal and external, distinguished mainly by performance.
3-14
Normal Mode
The lower-performance mode is normal mode. In Real-Time Windows Target normal mode, you run the algorithm in Simulink and the I/O drivers run in a separate Windows kernel mode process that maintains the real-time clock.
I/O Driver
Normal Mode
Simulink Process
3-15
Basic Procedures
simulation, the step size is determined automatically by Simulink or by the Min Step Size attribute. A consequence of this kind of limited synchronization is that your simulation can miss real-time clock ticks and their associated data points. Ticks can be missed under the following circumstances: Complexity of Model The model might be so complex that Simulink cannot keep up with the real-time kernel. In this case, the number of missed ticks increases steadily with time. Once the number of missed ticks exceeds Maximum Missed Ticks, an error occurs, even if Maximum Missed Ticks is set to a large value. This situation is marked by a rising straight line on a Scope connected to the optional Missed Ticks port. Process Contention The model generally executes faster than required to keep up with the kernel, but process contention or some random operating system condition prevents Simulink from executing the model over some time period. In this case, the number of missed ticks jumps to some number, then decreases to zero as Simulink catches up with the kernel. This situation is marked by a sawtooth-like shape on a Scope connected to the Missed Ticks port. Variable-Step Solver If you are using a variable-step solver, the number of ticks per algorithm step may vary during simulation. If Simulink execution does not reach the Real-Time Sync or I/O blocks in time to synchronize with the tick, the number of missed ticks jumps to some number, then decreases to zero as Simulink catches up with the kernel. As with process contention, this situation is marked by a sawtooth-like shape on a Scope connected to the Missed Ticks port.
External Mode
The higher-performance mode (the default) is external mode. In external mode, you use Simulink Coder to dynamically link generated algorithm code with generated hardware driver code. The resulting executable runs in Windows kernel mode and communicates with Simulink via an internal communications path.
3-16
Note You must use a fixed-step solver in external mode. External mode is not supported for 64-bit installations of Real-Time Windows Target.
The external mode executable is fully synchronized with the real-time clock. The main role of Simulink is to read and display simulation results returned from the executable.
3-17
Basic Procedures
I/O Driver
Simulink Process
3-18
Basic Procedures
3-19
Basic Procedures
Configuration Parameters.
2 Click the Code Generation node.
The dialog automatically enters the system target file rtwin.tlc, the template makefile rtwin.tmf, and the make command make_rtw into the Code Generation pane. If you have the Embedded Coder product, you can build an ERT target application. To build an ERT target application, in the Target selection section, click the Browse button at the System target file list. Click rtwinert.tlc, and then click OK. Although not visible in the Code Generation pane, when you click OK you also configure the external target interface MEX file rtwinext. This allows external mode to pass new parameters to the real-time application
3-20
and to return signal data from the real-time application. The data is displayed in Scope blocks or saved with signal logging. Your Code Generation pane looks similar to the next figure.
Do not select Inline parameters on the Signals and Parameters node under Optimization. Inlining parameters is used for custom targets when you want to reduce the amount of RAM or ROM with embedded systems. Also, if you select inlining parameters, you disable the parameter tuning feature. Since PCs have more memory than embedded systems, you should not inline parameters.
5 Click the Hardware Implementation node. The following values are
set by default: Device vendor Generic Device type 32-bit x86 compatible Emulation hardware None
3-21
Basic Procedures
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
3-22
graphs you want in one Scope window. For example, enter 1 for a single graph. Do not select the floating scope check box. In the Time range field, enter the upper value for the time range. For example, enter 1 second. From the Tick labels list, choose all. From the Sampling list, choose Sample time and enter 0 in the text box. Entering 0 indicates that the Simulink software evaluates this block as a continuous time block. If you have discrete blocks in your model, enter the Fixed step size you entered in the Configuration Parameters dialog box. Your Scope parameters dialog box looks similar to the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
3-23
Basic Procedures
5 In the Scope window, point to the y-axis and right-click. From the menu,
click Axes Properties. The Scope properties: axis 1 dialog box opens.
6 In the Y-min and Y-max text boxes enter the range for the y-axis in the
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
Normal Mode
The basic setup for normal mode is minimal. In the simulation model dialog box:
1 Select Simulation > Normal. 2 In your Real-Time Windows Target model, set values for the Sample Time
External Mode
In external mode, you must first create an executable target application. The Simulink Coder code generation software creates C code from your Simulink
3-24
model, then the bundled C compiler compiles and links that C code into a real-time application. This procedure uses the Simulink model rtwin_model.mdl as an example, and assumes you have loaded that model:
1 Enter parameters into the Configuration Parameters dialog box for use by the
Simulink Coder code generation software. See Entering External Mode Code Generation Parameters on page 3-20.
2 In the Simulink window, from the Tools menu, point to Code Generation,
and then click Build Model. The build process does the following: The Simulink Coder code generation software creates the C code source files rtwin_model.c and rtwin_model.h. The build process creates the makefile rtwin_model.mk from the template makefile rtwin.tmf. The build process creates the real-time application rtwin_model.rwd using the makefile rtwin_model.mk created above. The file rtwin_model.rwd is a binary file that we refer to as your real-time application. You can run the real-time application with the Real-Time Windows Target kernel.
3 Connect your Simulink model to your real-time application. See Entering
External Mode Scope Parameters for Signal Tracing on page 3-25. After you create a real-time application, you can exit the MATLAB environment, start the MATLAB environment again, and then connect and run the executable without having to rebuild.
3-25
Basic Procedures
Simulink external mode connects your Simulink model to your real-time application. This connection allows you to use the Simulink block diagram as a graphical user interface as in normal mode. After you have created a real-time application, you can enter scope parameters for signal tracing with Simulink external mode:
1 In the Simulation window, and from the Simulation menu, click
Configuration Parameters.
2 Select the Code Generation > Real-Time Windows Target node.
real-time application. The MEX-file name label should have an entry of rtwinext. The MEX-file rtwinext.mex* is supplied with the Real-Time Windows Target software to work with Simulink external mode and support uploading signal data and downloading parameter values. The Real-Time Windows Target pane should appear as follows.
3-26
4 Click OK. 5 In the Simulation window, and from the Tools menu, click External
Mode Control Panel. The External Mode Control Panel dialog box opens.
From the Mode list, choose normal. The X under Signal selection indicates that a signal is tagged for data collection, and T indicates that the signal is tagged as a trigger signal.
8 In the Duration field, enter the number of sample points in a data buffer.
For example, to specify a sample rate of 1000 samples/second and a stop time of 10 seconds, enter
10001
9 Select the Arm when connecting to target check box.
3-27
Basic Procedures
If you do not select this check box, data is not displayed in the Scope window. The External Signal & Triggering dialog box looks like this:
Click Apply to apply the changes to your model and leave the dialog box open. Click Close to apply the changes to your model and close the dialog box. You must click the Apply or Close button on the External Signal & Triggering dialog box for the changes you made to take effect.
Normal Mode
In normal mode, the procedure is as follows:
3-28
1 From the Simulation menu, select Normal mode simulation. 2 Select Start.
Tip You can also start the code from the toolbar by clicking
3 Do one of the following:
Let the simulation run until it reaches the stop time. Select Stop. The real-time simulation stops.
External Mode
In external mode, you run your real-time application to observe the behavior of your model in real time with the generated code. The process of connecting consists of Establishing a connection between your Simulink model and the kernel to allow exchange of commands, parameters, and logged data. Running the application in real time. The procedure is as follows:
1 From the Simulation menu, select External mode simulation. 2 Choose Connect To Target.
Tip You can connect to the target from the toolbar by clicking The MATLAB Command Window displays the message
Model rtwin_model loaded
3-29
Basic Procedures
Tip You can also start the code from the toolbar by clicking The Simulink software runs the execution and plots the signal data in the Scope window. In this example, the Scope window displays 1000 samples in 1 second, increases the time offset, and then displays the samples for the next 1 second. Note Transfer of data is less critical than calculating the signal outputs at the selected sample interval. Therefore, data transfer runs at a lower priority in the remaining CPU time after real-time application computations are performed while waiting for another interrupt to trigger the next real-time application update. The result may be a loss of data points displayed in the Scope window.
Let the execution run until it reaches the stop time. From the Simulation menu, click Stop Real-time Code.
3-30
From Target.
6 From the Simulation menu, click External.
Normal Mode
1 In the MATLAB Command Window, type
set_param(gcs,'SimulationMode','normal')
set_param(gcs,'SimulationCommand','start')
set_param(gcs,'SimulationCommand','stop')
3-31
Basic Procedures
External Mode
1 In the MATLAB Command Window, type
set_param(gcs,'SimulationMode','external')
set_param(gcs,'SimulationCommand','connect')
The MATLAB environment loads the real-time application, connects it to the Simulink block diagram, and displays the message
Model rtwin_model loaded
3 Type
set_param(gcs,'SimulationCommand','start')
set_param(gcs,'SimulationCommand','stop')
3-32
3-33
Basic Procedures
Note If you entered the scope parameters for running a simulation, you may want to look over this procedure, because the Scope parameters dialog box is related to the External Signal and Triggering dialog box.
1 In the Simulink window, double-click the Scope block.
If you are running a simulation, select the Limit data points to last check box, and enter the number of sample points to save. If you are running an execution, do not select the Limit data points to last check box. The Limit data points to last check box is related to the Duration value in the External Signal and Triggering dialog box. The smaller of either value limits the number of sample points saved to the MATLAB workspace. When you are using Real-Time Windows Target software, use the Duration value to set the number of sample points you save. To set the Duration value, see the next section.
5 Select the Save data to workspace check box. In the Variable name
text box, enter the name of a MATLAB variable. The default name is ScopeData.
6 From the Format list, choose Structure with time, Structure, or Array
(compatible with V2.0-2.2). For example, to save the sample times and signal values at those times, choose Structure with time.
3-34
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box. When you modify anything in the Scope parameters dialog box, you must click the Apply or OK button for the changes to take effect, and you must rebuild your real-time application before connecting and starting it. If you do not rebuild, an error dialog box will open. If you do not click Apply, your executable will run, but it will use the old settings. The reason why you need to rebuild is because the model checksum includes settings from the Scope block used for signal logging. If the model checksum does not match the checksum in the generated code, the real-time application cannot run. Always rebuild your real-time application after changing Scope parameters.
External Mode Signal and Triggering Properties for Logging to the Workspace
Data is saved to the MATLAB workspace through a Simulink Scope block. Signal and triggering properties need to be set only when you are running
3-35
Basic Procedures
a real-time application. If you are running a normal mode simulation, you can skip this procedure. After you create a Simulink model and add a Scope block, you can enter the signal and triggering properties for logging to the MATLAB workspace. This procedure uses the Simulink model rtwin_model.mdl as an example and assumes you have already loaded that model:
1 In the Simulink window, and from the Tools menu, click External Mode
Control Panel. The External Mode Control Panel dialog box opens.
2 Click the Signal & Triggering button.
the Mode list, choose normal. The X under Signal selection designates that a signal has been tagged for data collection, and T designates that the signal has been tagged as a trigger signal.
4 In the Duration field, enter the number of sample points in a data buffer.
For example, if you have a sample rate of 1000 samples/second and a stop time of 10 seconds, you could enter
10000
The Duration value is related to the Limit data points to last value in the Scope parameters dialog box. The smaller of either value limits the number of sample points saved to the MATLAB workspace. You should not select the Limit data points to last check box; instead, use the Duration value to set the number of sample points saved. To clear the Limit data points to last check box, see Scope Parameters for Logging to the Workspace on page 3-33. The Duration value specifies the number of contiguous points of data to be collected in each buffer of data. You should enter a Duration value equal
3-36
to the total number of sample points that you need to collect rather than relying on a series of buffers to be continuous. If you enter a value less than the total number of sample points, you may lose sample points during the time spent transferring values from the data buffer to the MATLAB workspace. The Real-Time Windows Target software maintains point continuity only within one buffer. Between buffers, because of transfer time, some samples will be omitted. Also, you should set the time axis for Simulink Scope blocks equal to the sample interval (in seconds) times the number of points in each data buffer. This setting will display one buffer of data across the entire Simulink Scope plot. The External Signal & Triggering dialog box looks similar to the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click Close to apply the changes to your model and close the dialog box.
3-37
Basic Procedures
You must click the Apply or Close button on the External Signal & Triggering dialog box for the changes you made to take effect.
ScopeData
The MATLAB Command Window shows the structure of the variable ScopeData. The variable ScopeData is a MATLAB structure containing fields for the time vector, signal structure, and a string containing the block name.
ScopeData = time: [10000x1 double] signals: [1x1 struct] blockName: 'rtwin_model/Scope'
The MATLAB Command Window shows the structure of the variable ScopeData.signals. This structure contains one or more vectors of signal data depending on the number of signal inputs to the Scope block.
ans = values: dimensions: label: title: plotStyle: [10000x1 double] 1 '' [] 1
3-38
plot(ScopeData.time(1:1000),ScopeData.signals.values(1:1000))
The MATLAB environment plots the first 1000 samples from 0.0000 to 0.9990 second.
The MATLAB environment saves the scope data to the file ScopeData.mat.
3-39
Basic Procedures
3-40
Note If you entered the scope parameters for running a simulation, you may want to look over this procedure, because the Scope parameters dialog box is related to the External Signal & Triggering dialog box and the Data Archiving dialog box.
1 In the Simulink window, double-click the Scope block.
If you are running a simulation, you can select the Limit data points to last check box, and enter the number of sample points to save. If you are running an execution, do not select the Limit data points to last check box. The Limit data points to last check box is related to the Duration value in the External Signal & Triggering dialog box. The smaller of either value limits the number of sample points saved to the MATLAB workspace. When using Real-Time Windows Target software, you should use the Duration value to set the number of sample points you save. To set the Duration value, see External Mode Signal and Triggering Properties for Logging to a File on page 3-43.
5 Select the Save data to workspace check box. In the Variable name
text box, enter the name of a MATLAB variable. The default name is ScopeData.
3-41
Basic Procedures
The Scope parameters dialog box is related to the Data Archiving dialog box. In the Scope parameters dialog box, you must select the Save data to workspace check box to be able to save data to a file, for two reasons: The data is first transferred from the data buffer to the MATLAB workspace before being written to a MAT-file. The Variable name entered in the Scope parameters dialog box is the same as the one in the MATLAB workspace and the MAT-file. If you do not select the Save data to workspace check box, the MAT-files for data logging will be created, but they will be empty.
6 From the Format list, choose either Structure with time, Structure, or
Array (compatible with Version 2.0 through Version 2.2). For example, to save the sample times and signal values at those times, choose Structure with time. Your History pane looks similar to the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click OK to apply the changes to your model and close the dialog box.
3-42
You must rebuild your real-time application before connecting and starting the application with changed settings. If you do not rebuild after making changes, an error will occur.
Control Panel. The External Mode Control Panel dialog box opens.
2 Click the Signal & Triggering button.
the Mode list, choose normal. The X under Signal selection designates that a signal has been tagged for data collection, and T designates that the signal has been tagged as a trigger signal.
4 In the Duration field, enter the number of sample points in a data buffer.
For example, if you have a sample rate of 1000 samples/second and a stop time of 10 seconds, then enter
10000
The Duration value is related to the Limit data points to last value in the Scope parameters dialog box. The smaller of either value limits the number of sample points saved to the MATLAB workspace. You should not
3-43
Basic Procedures
select the Limit data points to last check box, and use the Duration value to set the number of sample points saved. The Duration value specifies the number of contiguous points of data to be collected in each buffer of data. You should enter a Duration value equal to the total number of sample points you need to collect for a run. If you enter a value less than the total number of sample points, you may lose sample points due to the time spent transferring values from the data buffer to the MATLAB workspace. You should also set the time axis for Simulink Scope blocks equal to the sample interval (in seconds) times the number of points in each data buffer. This setting will display one buffer of data across the entire Simulink Scope plot. The External Signal & Triggering dialog box looks similar to the next figure.
Click Apply to apply the changes to your model and leave the dialog box open. Click Close to apply the changes to your model and close the dialog box.
3-44
You must click the Apply or Close button on the External Signal & Triggering dialog box for the changes you made to take effect, but you do not have to rebuild your real-time application.
Mode Control Panel. The External Mode Control Panel dialog box opens:
3-45
Basic Procedures
The External Data Archiving dialog box opens. This dialog box allows you to specify data archiving options.
3 Select the Enable archiving check box. 4 In the Directory text box, enter the path to a directory on your disk. For
The MATLAB environment names the files data_0.mat, data_1.mat, etc. The number of files equals the total sample points. For example, if you set Duration to Total sample points, then only one file is created.
6 Select the Append file suffix to variable names check box.
3-46
Within each MAT-file, a variable is saved with the same name you entered in the Variable name text box (History pane on the Scope parameters dialog box). By selecting the Append file suffix to variable names check box, the same suffix that is added to the MAT-file is added to the variable name. For example, if you entered the variable name ScopeData, then within the file data_0.mat will be a variable ScopeData_0. Your External Data Archiving dialog box looks similar to the next figure.
The parameters you entered are applied to your model. There is no Apply button with this dialog box. You must click the Close button for the changes you make to take effect.
ScopeData
3-47
Basic Procedures
The MATLAB Command Window shows the structure of the variable ScopeData. The variable ScopeData is a MATLAB structure containing the fields time vector, signal structure, and a string containing the block name.
ScopeData = time: [10000x1 double] signals: [1x1 struct] blockName: 'rtwin_model/Scope'
2 To list the MAT-files saved to your disk, type
dir *.mat
The MATLAB Command Window shows the MAT-files in your current working directory.
ScopeData.mat
3 To clear the MATLAB workspace and load the scope data, type
The MATLAB environment plots the first 1000 samples from 0.0000 to 0.9990 second.
3-48
3-49
Basic Procedures
Tuning Parameters
In this section... Tuning Block Parameters and MATLAB Variables on page 3-50 Changing Model Parameters on page 3-51
3-50
Tuning Parameters
detected automatically using model checksum and reported to the MATLAB Command Window to avoid conflicts.
The real-time execution starts running and signal data is displayed in the Scope window.
2 From the Simulink block diagram, double-click the Transfer Function block.
3-51
Basic Procedures
3-52
4
Boards, Blocks, and Drivers
Real-Time Windows Target software includes driver blocks for more than 200 I/O boards. These driver blocks connect the physical world to your real-time application. Using I/O Boards on page 4-2 Using I/O Driver Blocks on page 4-9 Using Analog I/O Drivers on page 4-15 Using Vector CAN Drivers on page 4-20
4-2
Hardware selectable and software readable Specify the desired settings by configuring jumpers or switches on the board. The driver reads the settings you selected and displays them in the I/O Block Parameters dialog box. Hardware selectable, but not software readable Set jumpers or switches on the physical board, and then enter the same settings in the I/O Block Parameters dialog box. These entries must match the hardware jumpers or switches you set on the board. Use this type of setting when the board manufacturer does not provide a means for the I/O driver to write or read all board settings. Examples include base address, D/A gain, and differential or single-ended A/D inputs. You can configure a Real-Time Windows Target model to use an I/O board whether or not the board exists in the computer, but you will not be able to run the model until the board is installed with all jumpers and switches set. Details of installation and configuration depend on the data transfer direction and the specific board, but are essentially similar in all cases. Details for various types of boards and drivers appear later in this chapter. The following instructions use the Humusoft AD512 I/O board as an example, configure the board for analog input, and assume that you have physically configured and installed the board in your computer before you add its driver to your model. Customize the steps to achieve the results you need. To install and configure an I/O board and its driver,
1 Install the board in the computer, setting jumpers or switches according to
The I/O Block Parameters dialog box opens. For an Analog Input block, the dialog box initially looks like this:
4-3
5 Click Install new board. From the list that appears, point to a
manufacturer, then select a board type. For example, point to Humusoft, then click AD512:
The I/O board dialog box opens. The name of this dialog box depends on which I/O board you selected. The box for the Humusoft AD512 board looks like this:
4-4
For an ISA bus board, enter a hexadecimal base address. This value must match the base address jumpers or switches set on the physical board. For example, to enter a base address of 0x300, in the Address box type
300
You can also select the base address by checking boxes A9 through A3. For a PCI bus board, enter the logical device number in the Device order box or check Auto-detect.
7 Set the other required block parameters using the I/O Block Parameters
dialog box.
8 Click Test.
The Real-Time Windows Target kernel tries to connect to the selected board, and if it does so without an error, displays the following message.
9 Click OK on the message box, and again on the I/O Block Parameters
dialog box. The I/O Block Parameters dialog box closes, and the parameter values are included in your Simulink model.
4-5
Autodetecting Multiple Boards. The Autodetect feature cannot be used to locate multiple boards of the same type. You must specify their logical device numbers manually.
4-6
software does not use these manufacturer-supplied drivers. However, they sometimes initiate the plug-and-play recognition of the board. Without these drivers installed, the board might be invisible to your computer and to the Real-Time Windows Target software.
PC/104 Board
Most PC/104 bus I/O boards are preset with a base address of 0x300. If you are using multiple I/O boards or other boards (for example, network cards) that already use the address 0x300, you must set your board with another base address. In the I/O board dialog box, enter the same base address that you set on the physical board. You open the I/O board dialog box from any I/O driver Block Parameters dialog box.
4-7
PCMCIA Board
The plug-and-play feature of the Windows operating system assigns a base address automatically. You can enter this address in the I/O board dialog box, or you can let the driver determine the address for you. You open the I/O board dialog box from any I/O driver Block Parameters dialog box. Before you use a PCI or PCMCIA board, install the drivers supplied by the board manufacturer. Real-Time Windows Target software does not use these manufacturer-supplied drivers. However, they sometimes initiate the plug-and-play recognition of the board. Without these drivers installed, the board might be invisible to your computer and to the Real-Time Windows Target software.
4-8
4-9
The Simulink Library Browser opens. The left pane shows a hierarchy of libraries and categories, with the Simulink library at the top. The right pane shows the blocks available in the category selected on the left. See Library Browser for more information.
2 In the left column, double-click Real-Time Windows Target.
The Real-Time Windows Target library opens. You can add any I/O block in the library to your Simulink model by dragging it from the library to the model. After you add the block, connect it to your model as you would any other block, and provide block configuration parameter values as described for the block in Blocks Alphabetical List.
4-10
3 Double-click the Demux block. The Block Parameters: Demux dialog box
opens. Enter the number of lines leaving the Demux block. For example, if you entered three channels in the Analog Input driver block, enter 3 in the Number of outputs box.
Connect the Analog Input block to the Demux block input. Connect each of the Demux block output lines to the input of other blocks. In the Simulink window, and from the Format menu, click Port/Signal Displays > Wide Nonscalar Lines, and click Signal Dimensions. In this simple example, inputs 1 and 2 are not connected, but they could be connected to other Simulink blocks.
4-11
Analog input (A/D) 16 single-ended or 8 differential analog inputs (12-bit), polarity is switch configured as either unipolar (0 to 10 volts) or bipolar ( 10 volts). Gain is software configured to 1, 10, 100, and 500. Digital input Four unidirectional digital inputs Analog output (D/A) Two analog outputs (12-bit). Gain is switch configured as 0 to 5 volts, 0 to 10 volts, 5 volts, or 10 volts Digital output Four unidirectional digital outputs Base address Switch configured base address This section explores different configurations for input signals. Once an Analog Input block has been placed in the model and the I/O board selected and configured, you can set up the Analog Input block to handle input signals. Single analog input The most basic case is for a single analog input signal that will be physically connected to the first analog input channel on the board. In the Block Parameter: Analog Input dialog box, and the Input channels box, enter
1 or [1]
The use of brackets is optional for a single input. Input vector with differential analog Analog channels are numbered starting with channel 1 and continue until you reach a number corresponding to the maximum number of analog signals supported by the I/O board. In the case of the DAS-1601, when configured as differential inputs, eight analog channels are supported. The analog input lines are numbered 1 through 8. The complete input vector is
[1 2 3 4 5 6 7 8] or [1:8]
If you want to use the first four differential analog channels, enter
[1 2 3 4]
4-12
Input vector with single-ended analog Now, assume your DAS-1601 board is configured to be single-ended analog input. In this case, 16 analog input channels are supported. The complete input vector is
[1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16] or [1:16]
Do not specify more channels than you actually use in your block diagram. This results in additional overhead for the processor with A/D or D/A conversions. In this case, for example, even though some channels are not actually used in the block diagram, these channels are still converted. You could attach terminator blocks to channels 4 and 5 inside your block diagram after passing the Analog Input block vector in to a Demux block. Adding terminator blocks provides you with graphical information in your block diagram to clearly indicate which channels you connected and which are available. The penalty is that even the terminated channels are converted, adding some computational overhead. The next figure shows the block implementation.
4-13
Depending on the board and the number of channels used, I/O conversion time can affect the maximum sample rate that can be achieved on your system. Rather than converting unused channels, specify only the set of channels that are actually required by your model.
4-14
4-15
4-16
4-17
4-18
This may require that you adjust your signal amplitudes using a Gain block, Constant block, and Summer block depending on the selected voltage range.
4-19
documentation for installation instructions for hardware devices such as CANcaseXL, CANboardXL, and CANcardXL, drivers, support libraries, and so on.
2 Install the Vector XL driver library for the Windows XP, Windows Vista,
or Windows 7 operating systems. If you do not have this library, download it from the Vector Informatik GmbH web site:
https://www.vector.com/vi_downloadcenter_en.html
3 Install the driver file. 4 Copy the vxlapi.dll file into the Windows system root\system32
directory.
5 Use the Vector software to assign physical CAN channels to an application.
When specifying the name for the Real-Time Windows Targets application, use the string MATLAB.
4-20
5
Troubleshooting
Solutions have been worked out for some common errors and problems that can occur when you are using Real-Time Windows Target software. Building Older Models on page 5-2 Plots Not Visible in Simulink Scope Block on page 5-3 Failure to Connect to Target on page 5-4 Scope Output Delayed or Missing on page 5-5 S-Functions Using Math Functions on page 5-6
Troubleshooting
This is simply a warning, and you can ignore the message. To eliminate this message, you can use the rtwinconfigset command, as follows:
rtwinconfigset('<model_name>')
5-2
5-3
Troubleshooting
Solution This indicates that the model structure has changed since the last time code was generated. You must rebuild the real-time application. If your model fails to build, delete .mk and .obj files from the Simulink Coder project directory, and then select Build from the Tools menu. Possible Problem When trying to connect to the target, the Simulink Diagnostic dialog box displays
External mode MEX-file "win_tgt" does not exist or is not on the MATLAB path.
Solution Versions 1.0 and 1.5 of the Real-Time Windows Target software used the MEX-file win_tgt. For Version 2.2 and later, the MEX-file name was changed to rtwinext. If you create a new Simulink model, the new filename is entered. If you have a Simulink model where you used Version 1.0 or 1.5, you need to change the filename using the following procedure:
1 In the Simulink window, from the Tools menu, click External Mode
Control Panel.
2 On the External Mode Control Panel dialog box, click the Target interface
button.
3 In the MEX-file for external mode text box, enter
rtwinext
4 Click OK.
5-4
5-5
Troubleshooting
5-6
A
Custom I/O Driver Blocks
You can write custom I/O device drivers to work with Real-Time Windows Target applications. Note Do not use Analog Input, Analog Output, Digital Input, or Digital Output drivers as a starting point for creating custom device drivers. Supported C Functions on page A-2 Unsupported C Functions on page A-3 Incompatibility with Win32 API Calls on page A-4 I/O Register Access from S-Functions Limitation on page A-5
Supported C Functions
You can use ANSI C functions that do not use the Windows operating system in your custom blocks or I/O drivers. The following includes a partial list of supported functions: Data conversion abs, atof, atoi, atol, itoa, labs, ltoa, strtod, strtol, strtoul, ultoa Memory allocation calloc, free, malloc Note Memory allocation is not an operation that can be done in real time. To work with a Real-Time Windows Target application, memory management must occur before real-time simulation begins. Simulation switches into real-time after mdlStart, so you can allocate memory in mdlInitializeSizes or mdlStart. You cannot allocate memory in any function after mdlStart, such as mdlOutputs or mdlUpdate. Memory manipulation _memccpy, memcpy, memchr, memcmp, _memicmp, memmove, memset String manipulation strcat, strchr, strcmp, strcpy, strcspn, _strdup, _stricmp, strlen, _strlwr, strncat, strncmp, strncpy, _strnset, strpbrk, strrchr, _strrev, _strset, strspn, strstr, strtok,
strupr
Mathematical acos, asin, atan, atan2, ceil, cos, cosh, div, exp, fabs, floor, fmod, frexp, ldexp, ldiv, log, log10, max, min, modf, pow, rand, sin, sinh, sqrt, srand, tan, tanh, uldiv Character class tests and conversion isalnum, isalpha, _isascii, iscntrl, isdigit, isgraph, islower, isprint, ispunct, isspace, isupper, isxdigit, isxupper, isxlower, _toascii, tolower, toupper Searching and sorting bsearch, qsort Dummy functions exit, fprintf, prinf
A-2
Unsupported C Functions
Unsupported C Functions
If you create your own custom I/O driver blocks, you should use only C functions supported by Real-Time Windows Target software. Functions that use the Windows operating system are not supported by Real-Time Windows Target. This includes functions from vendor-supplied driver libraries for Windows, which are also not supported. The following list includes many, but not all, of the unsupported functions: File I/O fopen, freopen, fclose, fread, fwrite, fputs, fputc, fgets, fgetc, gets, getc, getchar, puts, putc, putchar, fflush, setbuf, setvbuf Console I/O printf, fprintf, sprintf, vfprintf, vprintf, vsprintf, fscanf, scanf, sscanf Process management spawn, exit, abort, atexit Signals and exceptions signal, longimp, raise Time functions clock, time, difftime, asctime, ctime, difftime, gmtime, localtime, mktime, strftime Win32 API functions No Windows API functions are supported.
A-3
A-4
A-5
A-6
B
Examples
Use this list to find examples in the documentation.
Examples
B-2
B-3
Examples
B-4
B-5
Examples
B-6
B-7
Examples
B-8
Index
A
Index
D
D/A. See digital-to-analog data archiving parameters entering 3-45 logging data to file 3-45 data buffers 1-18 default configuration set 3-7 Demux block separating I/O signals 4-10 description Simulink external mode 1-16 Simulink normal mode 1-15 device drivers channel selection 4-11 custom I/O A-1 writing custom A-1 digital-to-analog channel selection 4-11 directories installed 2-6 MATLAB working 2-6 project 2-6 Simulink Coder working 2-6 working 2-6
A/D. See analog-to-digital adding I/O driver blocks 4-9 analog input normalized scaling 4-16 analog-to-digital channel selection 4-11 application Real-Time Windows Target 1-6
C
capturing and displaying signals 1-3 changing parameters parameter tuning 1-8 channel selection entering configurations 4-11 compact PCI installing 4-7 compatibility with MathWorks software 1-5 compiler bundled 1-7 Watcom C/C++ only 1-7 computer PC-compatible 1-10 configuring I/O boards and drivers 4-2 connecting real-time application 3-25 Simulink model 3-25 creating real-time application 3-24 Simulink model 1-13 custom I/O drivers incompatible with Win32 A-4
E
entering data archiving parameters 3-45 scope properties 3-40 signal and triggering properties 3-43 simulation parameters for Simulink 3-8 simulation parameters for Simulink Coder 3-20 examples library opening 2-18 Real-Time Windows Target 2-18 execution real-time external mode 1-13 running in real time 1-13
Index-1
Index
external interface MEX-file rtwinext 5-4 win_tgt 5-4 external mode description 1-16 parameter tuning 1-8
F
failure to connect troubleshooting 5-4 features signal logging 1-7 signal tracing 1-7 file plotting logged data 3-47 signal logging 3-40 files application 2-6 external mode interface 2-6 I/O drivers 2-6 installed 2-6 kernel install command 2-6 make command 2-6 makefile 2-6 project directory 2-6 Real-Time Windows Target directory 2-6 system target 2-6 system target file 2-6 template makefile 2-6 working directory 2-6
configuring 4-2 installing 4-2 ISA bus 4-6 overview 4-2 PC/104 bus 4-7 PCI bus 4-6 PCMCIA 4-8 I/O drivers characteristics 4-15 configuring 4-2 installing 4-2 using 4-15 input blocks overview 4-9 input/output support 1-10 installing compact PCI 4-7 I/O boards 4-2 I/O boards and drivers 4-2 kernel overview 2-10 Real-Time Windows Target 2-6 testing installation 2-14 ISA bus installing 4-6
K
kernel communication with hardware 1-5 installing 2-10 scheduler 1-5 timer interrupt 1-5 uninstalling 2-11
I
I/O blocks input and output 4-9 library 4-10 separating signals 4-10 I/O boards compact PCI boards 4-7
L
logging data to file 3-40 data archiving parameters 3-45
Index-2
Index
P
parameter tuning changing model parameters 3-51 changing parameters 1-8 external mode 1-8 feature 1-8 overview 3-50 PCI bus installing 4-6 PCMCIA bus installing 4-8 plots not visible troubleshooting 5-3 plotting logged data from disk 3-47 logged data from workspace 3-38
M
makefile 2-6 MathWorks compatible software 1-5 Simulink blocks 1-5 MATLAB workspace signal logging 3-33 memory management limitation on A-2 model parameters changing 3-51 parameter tuning 3-51
N
nonreal time simulation 3-11 normal mode description 1-15 normalized scaling analog input 4-16
R
real-time control 1-3 hardware-in-the-loop 1-3 signal processing 1-3 real-time application and the development process 1-13 connecting to Simulink model 3-25 creating 3-24 overview 3-13 Real-Time Windows Target 1-6 scope properties for signal tracing 3-22 simulation parameters for Simulink Coder 3-20 Simulink Coder parameters 3-20 software environment 1-6 starting 3-28 stopping 3-28 real-time external mode execution 1-13 real-time kernel Real-Time Windows Target 1-5
O
opening examples library 2-18 output blocks overview 4-9 overview I/O boards 4-2 input blocks 4-9 installing kernel 2-10 output blocks 4-9 parameter tuning 3-50 real-time application 3-13 system concepts 1-15 testing installation 2-14
Index-3
Index
scheduler 1-5 software environment 1-5 timer interrupt 1-5 real-time normal mode execution 1-12 Real-Time Windows Target application 1-6 custom I/O device drivers A-1 development process 1-13 examples library 2-18 files 2-6 installing kernel 2-10 overview 1-3 real-time application 1-6 real-time kernel 1-5 software environment 1-12 uninstalling kernel 2-11 Real-Time Windows Target Library I/O blocks 4-10 requirements hardware 2-2 software 2-3
rtvdp.mdl
external interface MEX-file 5-4 running execution in real time 1-13 real-time application 3-28 simulation in nonreal time 3-11
S
S-functions C-code supported in 2-3 limitation on I/O register access A-5 limitation on memory management A-2 MATLAB code not supported in 2-3 using math functions in 5-6
Win32 calls not usable in 1-5 sample rates excessive 2-17 scope output delayed or missing 5-5 scope properties entering 3-40 entering for signal tracing 3-22 for signal logging to file 3-40 for signal logging to workspace 3-33 separating I/O signals 4-10 setting initial working directory 2-8 working directory from MATLAB 2-8 from the Desktop icon 2-8 signal and triggering entering properties 3-35 properties 3-43 signal archiving. See signal logging signal data plotting from file 3-47 plotting from workspace 3-38 signal logging entering scope properties 3-33 feature 1-7 plotting data 3-38 signal and triggering properties 3-43 to file 3-40 to MATLAB workspace 3-33 signal logging to file data archiving parameters 3-45 signal and triggering properties 3-43 signal logging to workspace scope properties 3-33 signal and triggering properties 3-35 signal tracing feature 1-7 scope properties 3-22
Index-4
Index
signals capturing and displaying 1-3 simulation nonreal time 3-11 real-time normal mode 1-12 running in nonreal time 1-13 simulation parameters entering 3-8 for Simulink Coder 3-20 Simulink compatibility 2-3 compatible software 1-5 required product 2-3 running a simulation 3-11 Simulink Coder entering simulation parameters 3-20 Simulink external mode description 1-16 parameter tuning 1-8 Simulink model and the development process 1-13 connect to real-time application 3-25 creating 1-13 rtvdp.mdl 2-14 Simulink normal mode description 1-15 software system requirements 2-3 software environment overview 1-12 real-time application 1-6 real-time kernel 1-5 requirements 2-3 starting real-time application 3-28 stopping real-time application 3-28 support input/output 1-10 system concepts
data buffers 1-18 overview 1-15 transferring data 1-18 system requirements hardware 2-2 software 2-3 software environment 2-3 system target file 2-6
T
template makefile 2-6 testing installation overview 2-14 transferring data 1-18 troubleshooting failure to connect 5-4 incorrect MEX-file 5-4 plots not visible 5-3 scope output delayed or missing 5-5
U
uninstalling kernel 2-11 using I/O device drivers 4-15
W
Win32 calls not usable in S-functions 1-5 incompatible with I/O drivers A-4 working directory initial 2-8 setting from MATLAB 2-8 from the Desktop icon 2-8 setting initial 2-8 writing customized device drivers A-1
Index-5