•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

SSC98-XI-2
Using MathWorks' Simulink® and Real-Time Workshop® Code Generator to Produce Attitude
Control Test and Flight Code
Mark Andrew Salada, Associate Staff
Johns Hopkins Applied Physics Laboratory
(443) 778-7267 (Baltimore)
(240) 228-7267 (Washington, D.C.)
Mark.Salada@jhuapl.edu
Wayne Dellinger, Ph.D., Senior Staff
Johns Hopkins Applied Physics Laboratory
(443) 778-7565 (Baltimore)
(240) 228-7565 (Washington, D.C.)
Wayne.Dellinger@jhuapl.edu
Abstract
This paper describes the use of a
commercial product, MathWorks' RealTime Workshop® (RTW), to generate ac.tual .
flight code for NASA's Thermosphere,
Ionosphere, Mesosphere Energetics and Dynamics (TIMED) mission. The Johns Hopkins University Applied Physics Laboratory
is handling the design and construction of
this satellite for NASA. As TIMED is
scheduled to launch in May of the year 2000,
software development for both ground and
flight systems are well on their way. However, based on experience from previous
APL missions such as Midcourse Space Experiment (MSX) and the Near Earth Asteroid Rendezvous (NEAR), the designers of
the attitude estimation and control system
desire a more streamlined approach for analysts to incorporate their algorithms into
flight code. Specifically, the attitude control
designers want an easier and quicker iteration capability during integration and test
that somehow includes their principle development environment, Simulink®. One of the
problems is that complete attitude simulations in the Simulink models include both
flight and non-flight elements. With a significant initial effort, RTW now separates

M. A. Salada, W. F. Dellinger

flight code from the non-flight code, incorporating changes directly from Simulink instead of editing the code after the fact. RTW
first converts the Simulink inner workings
into a single, "all-knowing" file. The Target
Language CompilerTM. (TLC) then uses this
file to convert the information into actual
code. Simulink's RTW product comes complete with "canned" TLC configuration files
that control the generated C code. By editing
these configuration files, analysts are able to
perform complete estimation and control
simulations in Simulink, and then with the
click of .a button produce code that can be
directly compiled and linked onto flight
systems. This ease has one caveat, however.
By empowering the analysts to generate their
own code, they also inherit the class of
problems associated with real-time embedded systems, such as concerns with time and
space efficiency.
Introduction

The Applied Physics Laboratory is
progressing on work for the Thermosphere,
Ionosphere, Mesosphere Energetics and Dynamics (TIMED) mission scheduled for
launch in the year 2000. The mission distributes the science team among university

12th AIAAJUSU Conference on Small Satellites

partners, with most instruments developed
and operated remotely. APL's principal responsibility is for the spacecraft itself. The
satellite mainly consists of a high fidelity
pointing platform with minimal maneuvering to accommodate multiple, concurrent
science activities, mostly Earth observing.
An on-board GPS system maintains ephemeral information which the attitude control
system uses closed-loop. This way, TIMED
mission operations have the potential to run
autonomously, with minimal interference
from the ground, truly spreading the satellite
operations to the distributed base of science
users. With this simple set of attitude control
requirements, the APL's TIMED attitude
and control team are using the opportunity to
explore a new software engineering trend in
industry: auto-code generators. The motivation for auto-code comes from the need to
reduce the number of people between algorithm development and flight code (i.e., to
streamline the process). On previous missions, such as APL's Midcourse Space Experiment (MSX) and Near Earth Asteroid
Rendezvous (NEAR), analysts produced the
attitude control flight code that flight programmers eventually ingested in the final
code. Although both missions proved the
process successful, neither mission produced
flight code that could be easily re-used on
subsequent missions. Eager to establish a
more controllable process, and to reduce the
cost of starting from scratch each mission,
APL is attempting to streamline the attitude
control flight code process with new commercial auto-code tools. The new approach
attempts to eliminate repeated efforts in
testing and is geared towards establishing a
unified attitude flight code front from one
program to the next.
The opportunity to take advantage of
an auto-code generator has existed in industry for many years. Use of code generators,
however, remains small. This is probably

due to basic inadequacies in existing products, such as the ability to generate code
piecemeal, and then re-ingest into the simulation. All existing code generator tools require a heavy initial effort, especially when
considering the product for flight code. The
TIMED attitude team decided to invest in
MATLAB and RTW for two reasons. First
of all, it is the same environment used for
algorithm development. The second and
empowering feature in MATLAB and Simulink is the open architecture which allows
full end-user control of Simulink's code
generating engine, RTW. With a one-time
effort, MATLAB users can modify the code
generated from Simulink to fit any flight
code platform, and any non-flight platform
for that matter. There are about a half dozen
important issues with APL's RTW modifications. This paper describes the two most
important changes: the re-organization of the
Simulink blocks, and the removal of a key,
but cumbersome data structure. The TIMED
attitude team is also careful to establish the
performance and test of the auto-code. The
final auto-code product will reside on three
platforms, two of which are actual flight
platforms.
Development Environment

It has long been the preference of attitude control analysts to use a graphical tool
for development. lSI's MATRIXx® and
MathWorks' Simulink are two such tools.
APL has used both in the past, and has until
recently favored lSI's due to its ability to
generate Ada code. The TIMED mission attitude developers, however,. use Simulink
due to its ability to generate ANSI C code.
Development for the TIMED mission started
before the release of MATLAB 5.2, and
therefore APL continues to use version 5.1
for all attitude control development. This is
not a version freeze in any sense, and ana2

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
••
•
•

•

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

about every aXIS
(0.03° of knowlGuidance and Control System................................ .
..............................................
edge, 0.5° for conG&C
trol). The attitude
1553
control suite mC&DH
Bus
IAFC
1553
cludes a magneAttitude Flight
Bus
Computer
tometer,
three
(x2)
torque rods, reacI
tion wheels, two
AIU
star trackers, a reAttitude Interface
CTP
h
IRU
Unit
dundant inertial refCommand and
(x2)
Inertial Reference
Telemetry
Unit
erence unit, sun
Processor
(x2)
I
sensors, and finally
(x2)
I
l
a set of two processors, each with a
AST
redundant twin (See
Magnetometer
Autonomous Star
Wheel Control
Figure 1). The AtTracker
Torque Rod Control
(x2)
titude Interface Unit
Sun Sensors
(AIU) is a 16-bit
Etc.
I
RTX 20lO procesThe G&C system uses redu~d~~t·~~~p~~~~i;~ii~~h~d·i~·~·i553·b·~;.·"ih~·;Y;i~~'dijj~~~' sor primarily reonly slightly from previous APL missions. The AIU is responsible for all bus mana~e sponsible for sensor
ment, and sensor/actuator interface. The AFC provides all guidance and control dunng interface, bus manoperational modes.
agement, and remelysts intend to upgrade as soon as the ramIfidial attitude control (safing). The Attitude
cations for the auto-code generator, an addFlight Computer (AFC) is responsible for all
on to MATLAB, are apparent. Additionally,
attitude control, except safing, and utilizes
analysts use a set of SGI and HP machines
the Mongoose V 32-bit processor. APL has
running UNIX as a shared development enconsiderable experience with the AIUIAFC
vironment. There is a particular snag with
attitude control combination, borrowing lessuch a diverse development environment
sons learned from both the MSX and NEAR
because analysts need to maintain separate
programs. A standard double redundant
versions of '.mex' files for S-functions.
1553 bus connects the two processors to
(There is more detail on S-Functions below.)
each other, along with the star trackers and
The new SGI 64-bit machines require aninertial reference units (IRU). A separate
other set of '.mex' functions, bringing the
1553 bus serves as the interface to the comtotal configuration management mess multimand and data handling system through the
plier to three. With a finite and relatively
AIU.
small set of '.mex' functions to date, the
By far, the constraining element of
multi-platform attitude control development
the system is the AIU processor, the RTX
schedule remains manageable.
20lO. With 128k of memory, and 128k of
PROM, the decision to use auto-generated
Target Environment
code came with considerable wariness. In
fact, system developers at APL did not fiTIMED is a three-axis stabilized, nanalize usage of the auto-generated code until
dir pointing platform with tight constraints
Figure 1:

~

3
M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

analysts produced a primitive set of AID attitude code, and performed a baseline performance test on the engineering model.
More detail concerning the performance and
constraints imposed by the processor is below. Confidence in the auto-code approach
continues to grow.
The third platform for the auto-code
is a non-flight platform called T ASTIE.
T AS TIE stands for the TIMED Attitude

Simulation and Test Integration Environment. It is the primary testbed for the satellite guidance and control system. All of the
environmental models and command and
data handling stimulus reside on a separate
component rack, acting as the rest of the satellite and ground system to the guidance
system. The main processor runs OS/9 on a
Motorola 32-bit 68060 VME backplane. The
memory and storage for this environment

Figure 2:
TASTlf.:_bulc~bulld.mdI
V~Ut

DaIIt".OIi.2il
IlttWoI000Nol",,:

1.Chlo.... toTASTlIE .... «k"...d .. odotL
".06.28 wid
2. Chtl.toTASTtE.so&.-_P_....Torq .....
M.06.28 wid

....fo'_~:.,~IE>I---......-

~:-::
-----l..

3.ehMv*toTA9TEGnorItJo.~~TOJqI.w..

... 08..26 ... 6

"--::,

.........

<.-,,<----~

t.u..ttoP""'llllloutputtco~'fIIfI
RTW-'N"C~
atMMt'lll'ftlNIC~buIW.mdI
__

--

.. '"

~

__

IT--""_~·Eol...-----

~-----"'''''<--''.-.',..
:....-.....-

loFCpriftoIIIW~

:a. ...... sunlMilllil, ......... . . . - .

"'ft~---"--"-

b1ldrar~sun--......,

___ "IMIII •
.......... _ _.IoFC .. W

olC~"""lo

s.s«u..~=~
werIII~""RTW

. . .tu.a
_ _ "....a.n

... ~---~-

... ""'.

.~buId,"'TAIl'tIl.W,

1.......... mDdIt".,.,. ....... .,.,...
tMN...."AAI . . Af(; ......

-.

....... _ _ III!D!tJk,i'MNdM .......
IMIIlIIrt.,tIfIKts TDTI£.DI, It':d M'C

... u...lW£D~

..
.. ' .. ..
'

'

'

AID_Code

A2D_Sampling

This is the root-level page for the TIMED Simulink simulation. (Apologies for the micro-font) Each userdefined subsystem corresponds to actual spacecraft hardware. This allows for tidy grouping of generated code,
and consequent separation offlight and non-flight software from the same simulation.

4
M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

dwarf the flight platforms, and therefore
TASTIE provides the most immediate validation of the auto-code approach.

TLC Script Block Re-Organization

As mentioned before, the empowering element of MathWorks' Simulink is the
open architecture. An open architecture describes a commercial product that allows its
users to modify the way certain elements
function without additional support from the
source. The entire code generator in Simulink, also called the Real-Time Workshop
(RTW) , controls its final code product
through a separate scripting language native
to the Target Language Compiler (TLC). As
delivered from MathWorks, the RTW comes
complete with default, or "canned," TLC
scripts that produce code. These scripts
complete the two step process that turns
Simulink block diagrams into a small set of
source files.
The first step in the auto-code process creates a 'core' file containing all the
block diagram connectivity and organization
information. The file has the suffix '.rtw.'
MathWorks organizes Simulink information
in two basic ways. The first and most basic
information element is the block. A block
contains anything from a straightforward
vector sum or multiply, to a complete DSP
function such as a fast Fourier transform
(FFT). The second form of information
groups these blocks into systems and subsystems. Therefore, the '.rtw' file contains
all connection information between blocks,
and then between systems and subsystems.
(The only difference between systems and
subsystems is that user grouped blocks become subsystems, while blocks grouped
necessarily, internal to Simulink, become
systems. A more detailed explanation of
Simulink systems is beyond the scope of this
paper.) (See Figure 3.) It is not possible to
change the way Simulink generates the
ASCII' .rtw' information file. However, it is
possible to completely control the way RTW

A Virtual Satellite
The first auto-code misnomer to dissipate is the myth that auto-code generators
actually auto-generate code. (There is no
magic involved, black or otherwise.) Autocode generators are simply text manipulators
that connect the signals and logical constructs usually specified through an alternate
means (e.g., a graphical interface like Simulink instead of an editor). Auto-code generators do no more than what they are instructed to do, and they have the added
benefit of doing it quickly and reliably.
There are no up-front savings using autocode generators. In fact, there is a greater
than normal initial investment. The savings
come by means of down-the-road repeatability, speed, and code integrity.
The attitude control team chose to
carefully construct the Simulink simulation
to be as "life-like" as possible. In effect,
APL created a virtual satellite in Simulink
with actual subsystems for satellite hardware
items such at the processors and the bus.
Figure 2 shows the top-level page in Simulink for the TIMED model. The left-hand
side of the diagram holds the command
emulator, and all environmental effects for
the simulation. The right-hand side represents the spacecraft elements. Note that there
are separate blocks for each flight processor.
Furthermore, the system models actual
spacecraft elements such as the 1553 communication bus, and digital and analog samplers. The reason APL stresses this representation so heavily is that it becomes the
primary influence on the way the generated
code separates into manageable pieces and
compiles.

5
M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

generates source files Figure 3:
warned by the
MathWorks disfrom this point onCompiledModel {
"timed"
Name
tributors and supward via TLC scripts.
Version
"2.09 (May, 61997)"
port staff, was not
The
second
GeneratedOn
"Thu Jul 9 19:12:33 1998"
Solver
ode4
and final step in the
trivial.
SolverType
FixedStep
The
first
code generation procStartTime
a
StopTime
10000
ess is the invocation
step
in
designing
FixedStepOpts {
FixedStep
0.005
the re-organization
of a series of TLC
TID01EQ
1
was deciding to
scripts. TLC scripts
DataLoggingOpts
{
separate the blocks
are a language on
LogT
their own with full
based
on subsysLogX
"yout"
LogY
access to all informatems resident only
LogYNCols
[106]
tion in the '.rtw' file.
on the root page
LogXFinal
Max Rows
a
Unfortunately,
the
(pictured above in
Decimation
100
Figure 2). There
default organization
NumModellnputs
83
are any number of
of blocks, systems,
NumModelOutputs
106
NumNonVirtBlockslnModel
1636
subsystems hidden
and subsystems does
DirectFeedthrough
yes
beneath
other subnot accommodate the
NumContStates
7
NumDiscStates
65
way the TIMED attisystems,
and
NumModes
10
throughout
the
tude team intends to
ZCFindingDisabled
yes
NumNonsampledZCs
a
model. Thankfully,
utilize the code genNumZCEvents
2
NumRWork
19
erator. The default
the root page has a
NumIWork
12
organization groups
special status in
NumPWork
a
NumDataStoreElements
4
all blocks based on
the .'rtw' file, and
mB
internal
systems,
therefore it was
mostly dependent on
relatively easy to
sample rate, comidentify each subpletely independent Figure 3 is an excerpt from the TIMED '. rtw , file as gener- system. The new
of the user-defined ated by the RTW. This ASCII file acts as a global data set for implementation
subsystems (See Fig- the Target Language Compiler. The TLC scripts use the field that searches the
names in this file to generate code, never basing execution
ure 4). Since APL on hard-coded numbers. Therefore, only a one-time modifi- root page has a
intends to allow the cation of the TLC scripts is necessary. The file organizes all caveat: Now only
user to specify which information by the Simulink-internal systems.
subsystems
may
blocks, or groups of
reside on the root
blocks, reside on an actual system as empage. This means that there can be no standbedded code, the default organization is
alone blocks floating around on the top
clearly insufficient. Therefore, grouping the
page, or otherwise the new organization gets
generated code from blocks grouped by subconfused.
system is the major change made to the deThe next step to the. re-organization
fault TLC files. Since the' .rtw' information
is to scan beneath all of the root-level subfile organizes blocks by the internallysystems and identify all the blocks underdefined systems, there is a natural elegance
neath each. Since the default organization of
to the default TLC scripts that do the same.
the '.rtw' file does not explicitly recognize
Changing the organization, as we were
subsystems, this scan process is very cumbersome. In fact, it is merely an iterative
6
M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

stroyed the integrity
of the model. Imagine
Subsystem
a set of blocks, num~
bering one to ten in a
Subsystem
Subsystem
root-level subsystem.
Recall that the blocks
are originally organROOT
ized by system, and
this particular subsystem has only one
system within it.
Then each of the
blocks should execute, in order, from
one to ten. Now
System
System
imagine an analyst
that intends to group
All blocks in Simulink group into internally defined Systems. The systems, pictured the blocks within the
here as horizontal levels of blocks, are primarily defined by sample rate. The 'root' subsystem differently,
level of blocks, for example, all execute at the fundamental sample rate. The user- say into two further
defined Subsystems sometimes group blocks within systems, and often across systems.
subsystems. He or she
The major change to the TLC scripts is to parse the generated code by subsystem, not
groups one through
by system.
five
in subsystem A,
loop (unfortunately not recursive) that hanand six through ten in subsystem B. The
dles an arbitrarily chosen 'depth' of ten submodel
will execute perfectly if, in every
systems. This means that when an analyst
case, subsystem A generates code before
cascades the subsystems beneath the root
subsystem B. However, in some common
page, he or she may only have nine addicircumstances, the new TLC scripts generate
tional levels of subsystems. This constraint
code
for subsystem B prior to subsystem A,
does not limit the current TIMED model
laying the source lines of code into the files
(with only five levels to date), and can easily
of order. In most cases, the resulting
out
expand to another arbitrary limit if necescode contains erroneous signal propagation.
sary.
Validation becomes impossible because the
The third and final step in organizing
generated source code outputs will most
the blocks by subsystem turned out to be the
likely not match the original's models outmost complicated. With a set of blocks for
puts.
The example of subsystem A and B is
each subsystem concisely stored as an array
very simplistic, and the code generation
of block numbers, the first thought was to
block
order problem becomes enormous
allow the code generator to process each
with such complicated models as the
block as it does normally, one at a time, for
TIMED
simulation.
each subsystem. Unfortunately, the resulting
How then to guarantee the proper
code did not produce simulation results that
block
order
for each root level subsystem?
were identical to the default TLC scripts. It
The answer is in the block numbering itself.
turns out that by separating the blocks into
As long as the TLC scripts sort the blocks,
subsystems, some block sequences lost their
separated
by root-level subsystem, by numproper execution order, and therefore deFigure 4:

7

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

ber in ascending order, the Figure 5:
code signal integrity maintains itself within a sub1* Sample hit for TID=2 *1
system. Finally, after sepaif(ssIsSampleHit(rtS. 2. tid» I
1* DiscreteIntegrator Block: <SI07>/Discrete-Time Integrator *1
rating the blocks by rootrtX.d.s 107 _Discrete_ Time_Integrator[O] = rtX.d.sI 07 _Discrete_TimcIntegrator[O] +
0.04 • rtB.sI03_Switch[0];
level subsystem, the new
rtX.d.sI07 _Discrete_ Time_Integrator[l] = rtX.d.s107_Discrete_ Time_Integrator[l] +
TLC scripts sort the block
0.04 * rtB.sI03_SwilCh[1];
rtX.d.sI07 _Discrete_ TimcIntegrator[2] = rtX.d.s107 _Discrete_Time_Integrator[2] +
lists using a standard heap0.04 * rtB.sI03_Switch[2];
sort algorithmi. Then the
I
scripts feed the block lists
#endif
to the code generator to
produce the code.
#ifdef D2A_Sampling
#endif
Once at the code
generator, all changes im#ifdef GnC_1553
plement a simple goal: Do
#endif
not modify the way the de#ifdef T ASTlE_Code
fault scripts generate the
1* Sample hit for TID=4 *1
final product (the source
if(ssIsSampleHit(rtS. 4. tid» I
1* UnilDelay Block: <S 121:>/dcorbit *1
code) as much as possible.
(
inCT i1;
In other words, the attitude
reaCT 'uO &rtB.sI21_S_Function[0];
team
preferred
nonreal_T *xd &rtX.d.sI2Cdt_orbiC[0]:
destructive additions to the
forOI =0; il <6;il++) {
xd[il] = uO[il];
files as opposed to a slash
I
and bum technique. To this
I
end, the team decided to
1* UnitDelay Block: <S 121>/dCorbit *1
rtX.d.s12 LdCorbit rIB.sI21_Constant7;
separate code for the rootI
level subsystems in the final code using pre-compiler
'#ifdef statements, rather This is an excerpt from the generated source file timed.c. The 'raised'sections
than moving and re- highlight the new separation by subsystem. Each set of code is surrounded by
organizing the source lines pre-compiler statements. Therefore all platform engineers use the same source

I
I

file, timed.c, but with different compilation flags. In some cases, there are no

of code. (The final source source lines of code associated with a subsystem, like the D2A_Sampling subcode is in ANSI C, where system. This approach allows for later inclusion of code for those subsystems
surrounding lines of code once the real hardware dynamics are better understood.
with pre-compiler statements, such as #ifdef
the order of the blocks passed to the genstatements, instructs the compiler to condierator.
APL was very successful with this
tionally include or exclude lines of highapproach. The basic architecture still resemlevel code.) This way, all TLC script addibles the default TLC script architecture, with
tions comprise mainly of inserting prethe final product conditionally dependent on
compiler statements before and after each
block list passes through the generator (See
the user-defined root-level subsystems. The
first target platform, T ASTIE, validated our
Figure 5). At no point do the new TLC
efforts with a relatively smooth integration
scripts change the way the code generator
handles a given block. The only change is
into operation.

8
M. A. Salada, W. F. DeHinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

The Removal of SimstrucU

'.mex' files created within MATLAB, and
allows for inclusion of source code exterior
to Simulink. For example, APL is re-using
actual MSX and NEAR flight code for certain functions by hooking their calls and underlying code modules through S-Functions.
This approach ha<; the added benefit of reducing the number of input and output signals, and also associated parameters for a
given set of blocks. This solved the symbol
table overflow problem because the number
of signals associated with a block is directly
related to the number of fields declared in
the RTW data structures. S-Functions provide a means to gracefully scale back the
amount of new code actually generated by
RTW.
The other compiler problem, with the
forward-referencing structure hang, did not
have such a graceful solution. In fact, since
the RTX compiler tool set was already frozen for development, APL had to either
eliminate the problem or abandon auto-code
on the AID. (This compiler problem may
have been eliminated in a more recent version of the toolset.) The TIMED attitude
team chose to eliminate the problem by
eliminating the code dependence on simstruc {}, the only forward-referencing structure in RTW. To retain as much homogeneity as possible, the attitude team removed
simstruc{} for all TIMED platforms, not just
for the AID.
To say the least, this is a profound
change to the RTW generated code, even
though the change only affects the source
library files included with the RTW toolbox.
The change does not affect the TLC scripts,
or the '.rtw' information file. Without exploring the details of the change, there are
four things to mention about the elimination
of simstruc{}. The elimination of simstruc{}
requires a custom modification to any integrator utilities in Simulink. (The modifications arise because simstruc {} contained all

As mentioned before, there are about
a half-dozen important issues with APL's
modification of RTW. The block reorganization is the most important change to
the TLC scripts. The other most important
change to RTW, this time outside of the
TLC scripts, enabled the usage of the autogenerated code on the most constraining
platform, the RTX 2010 processor. The internal data structure organization of the
RTW generated code is very sophisticated.
The RTW developers at MathWorks have
done an amazing job of implementing a generic code architecture to handle any Simulink block diagram. This generic approach
utilizes a single, global structure for each
model that coordinates everything from
pointers to local data, to references to external functions for the integrators. RTW calls
this structure simstruc{}. This structure is
very elegant, minimizing recompilation of
external source files, and allowing for expansion both in space and function.
With a successful demonstration of
the auto-code approach on the TASTIE environment, the next platform seemed a mere
exercise. We were remiss to ever believe
that. As it turned out, any attempt to simply
compile the generated code with the RTX
201 0 toolset had the unnerving result of
hanging the compiler. There were two significant problems. The first problem was in
size. The fields within the data structures
declared by RTW were simply too numerous
for the compiler symbol table. The second
problem was the inability for the compiler
toolset to handle forward-referencing structures. We handled the first problem readily
by reducing the number of fields declared by
RTW with the convenient S-Function hook
in Simulink. S-Functions are simply blocks
in Simulink where the user can specify a
function call. An S-Function compiles from
9

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

storage structure references for continuous
states.) When the user (analyst) selects an
integrator in Simulink, he or she has the
choice of fixed or variable-step, Oth through
5th-order, and a myriad of techniques, all
selectable by pull-down menu. To date, the
attitude team has adapted only one integrator
for the removal of simstruc { }: the RungeKutta 4 th -order fixed step integrator. Therefore, without further custom work on other
integrators, the TIMED attitude control developers have to use just one type of integrator.
The second thing to mention about
the removal of simstruc{} is the loss of
nearly all RTW "implied integrity" and support. Basically, the level at which APL
modified the delivered source libraries, and
TLC scripts, removes any possibility of support from MathWorks, and raises the question of reliability. Can APL depend on the
RTW commercial quality now that the final
product looks so different from MathWorks'
original delivery? The answer is no. Therefore, the TIMED attitude team established a
rigorous test, verification and validation plan
for the modified product, relying only partly
on the commercial integrity. The testing
section below describes APL's approach to
testing and validating the auto-code.
The third thing to mention about the
removal of simstruc {} is to explain what the
attitude team gained by doing so. Frankly,
the newly generated code is more concise
(smaller), faster, and easier to understand
than the original MathWorks code. Most
importantly, the constraining platform compiler's RTX 2010 toolset now compiles the
source code. The auto-code developers integrated a preliminary set of the auto-code
onto the engineering model of the AIU, and
have encouraging results to show. The code
performed within timing specifications,
taking 22 of the allotted 25 milliseconds to
execute, worst case. Since then, the real-time

epoch changed from 25 Hz to 10Hz, relieving concerns over timing performance.
There are still space concerns, and the code
generator has proven to be not so efficient in
that regard. The attitude team believes that
the S-Function capability provides an avenue for managing space.
A Single Task with Multiple Rates

As stated above, it is the success of
the attitude team's integration of the RTW
product on T ASTIE that validates our approach. There is an aspect to this success
that relates to the removal of simstruc{}.
While modifying the code to become simpler and easier to understand, the removal of
simstruc{} also disables the generated code
from utilizing RTW's multitasking capability. Although a sometimes significant advantage when developing embedded systems, the TIMED attitude team chose not to
use multitasking, implementing all autogenerated code as a single task. To be very
clear, this does not mean that the autogenerated code handles only one rate. Both
the default source code and TIMED team's
modifications handle any number of concurrent rates, as specified in Simulink by the
analyst.
Removing simstruc{} does negate
the use of multitasking, but it simplifies the
coordination of the multi-rates within a
model. The simplified approach allowed the
attitude team to solve a real-time bandwidth
problem when first attempting to integrate
the auto-code on T ASTIE. Figure 6 illustrates an execution profile of the auto-code
on T ASTIE. The presence of multiple rates
is clear with the regularly spaced peaks. The
daunting feature in the plot shows the highest peaks, every 200 samples, exceeding the
5 millisecond fundamental task rate. With
the default MathWorks files and scripts, the
conclusion would be that the RTW auto10

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
••
•
•
•
•
•
•
•
•
•
•
•
•
•
•
••
•
••
•
••

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

Figure 6:
MODL Exection Profile. 7 July 98
OOOO.-----r----.,----.-----.-----.----~----_.----_.----_.----_"

8000

7000

6000

3000

2000

1000

OL-____L -_ _ _ _L -_ _ _ _L -_ _ _ _L -_ _ _ _L -_ _

o

100

200

300

400

500
Samples

~

_ _ _ _~_ _ _ _~_ _ _ _~_ _ _ _~

600

700

800

This is a run-time profile of TASTIE code. The processor load for each rate is visually apparent. The maximum
allowable time for any sample is 5 milliseconds, clearly violated by the I Hz code. (Recall that the fundamental
sample rate is 200 Hz.) This required the separation of the I Hz 'task' from the other 'tasks,' easily facilitated with
the multi-rate implementation established by RTW, and emulated by the new TIMED implementation sans Simstruc{}.

code cannot fit on the T ASTlE platform.
However, with the new simplified code, the
attitude team was able to separate out the 1
Hz auto-code, intact, and place it in another
task managed by the OS/9 operating system.
This separation of rates, above and beyond
the separation of subsystems, is an exception
to the general rule that all RTW code is a
single task with multiple rates. The AIU
code performs within margin as a single
task, and the attitude team anticipates no difficulty with performance on the AFC platform.

Testing of Auto-Code Product

At the bottom-most level, all testing
on auto-generated code is black box testing.
The plan treats each user-defined root-level
subsystem as a unit, and conducts separate
tests on each. The plan has two phases. The
first phase is entirely in Simulink itself, and
comprises of stimulating all subsystems, or
'units' completely to follow every branch in
the model. This phase produces the data
outputs to which all subsequent tests check
11

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

their results. Phase two
follows a basic phi10sophy: Equality establishes that if A
equals B, and B equals
C, then A must also
equal C. In this case, A
is the Simulink model,
whose range is the data
outputs of phase one
testing. 'B' is the autogenerated code, as
produced by the default TLC scripts, and
library source files.
Testers establish the
relationship between
the internal Simulink
model and the generated code, already assumed to be tested by
MathWorks'
quality
assurance. Any differ-

Figure 7:
3~O-15
Y~~-,____, -____~E~r~~b~e~~n~si~~'=ink~.n~d;~='-t=ime~e=o~~__- , , -__- ,__~

2 '

-1

-2

-30

20

40

60

~ime (-~f

120

140

180

This is a plot of the error between the internal Simulink simulation re~ults and the
new TIMED generated code results. The plot shows the four quaternlOn elements
over the first 180 seconds of the simulation. At 200 Hz, the plot compares. a t~tal of
36,000 samples. Errors mainly come from printf() rounding and resolutIOn En the
files that are compared by environment.
.

ences between the outputs of phase one and
this first half of phase
.. .
two attribute to compiler and machme hffiltations (assumed benign). Finally, to complete phase two, testers perform, on each
respective platform, the same tests on the
TIMED TLC script-generated files and
source ('C') as performed in Simulink CA'),
and verified on the default auto-code ('B').
Then as A equals C, the internal Simulink
model matches the TIMED TLC scriptgenerated code. Together with the phase one
testing, this rigorously tests every branch of
the flight code.
Believed to be the most crucial aspect of using auto-generated code, testers
match the values of input and output signals
on each subsystem (unit) at every fundamental step in Simulink. This means that
over the span of the simulation time
(currently around 10,000 seconds) each 200

Hz tick-output compares to the last possIble
decimal place for a given platform. To date,
we have seen only machine epsilon variations in output differences. (See Figure 7.)
Program Impact

Using Simulink's RTW solves many
problems for APL attitude control analysts.
It creates a readily accessible attitude control
environment in the same 'language' that
analysts use to develop the algorithms.
Namely, the graphical interface in Simulink
provides a computer language-independent
arena for analysts from different backgrounds to converse. An analyst who developed control code for an Ada-based. flight
code set is now able to converse dIrectly
with a C-based developer by removing the
analysts from the tedium of flight code pro12

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

gramming. On the other side, Simulink's
RTW unifies the product delivered to flight
processor programmers. Using an auto-code
generator creates a new position: the autocode specialist. This person, and it can indeed be just a single person, knows the connectivity between the graphical representation and the auto-code source files. The specialist knows exactly how a "bug" in the
generated files traces back to the block diagram. This single person replaces the role of
attitude flight code programmer across the
entire project. From scratch to working
flight code, a single auto-code specialist fills
the gap between the analyst and the embedded processor engineers. All of the work
presented in this paper summarizes the last
half-year of development.
The specialist position has a unique
role in the TIMED program. For this demonstration program, the initial investment in
the specialist is heavy. From that point forward, however, the specialist only needs to
maintain a maintenance role, remaining "on
call" if problems arise. This maintenance
role continues past the first program into
subsequent programs. Future APL missions
will utilize the code generator without starting from scratch.
There are however, some serious difficulties with using MathWorks' code generator. First of all, there is no facility in
Simulink to 'find' blocks, or to configure
them within in the graphical interface. Simulink lacks a vested mechanism for organizing, tracking, and maintaining blocks in a
model. All management of Simulink block
diagrams is manuaL (Of course, after RTW
produces the source, traditional configuration management with tools such as RCS
and MKSTM resume.) The TIMED attitude
control development and subsequent code
generation is subject to 'upgrade,' and all
RTW enhancements. There is no guarantee
that the TIMED TLC scripts are compatible

with the next release of RTW. Of course,
every program faces such difficulties in the
new NASA paradigm of COTS products.
Finally, the most profound impact on
the TIMED program has been the effect of
using Simulink on the analysts themselves.
Using an auto-code generator directly from
the analysts' simulations requires a great
deal more discipline on the analysts part,
perhaps more than they bargained for. Concerns for execution time, code space, signal
conditioning, and configuration management
essentially all rest on the shoulders of the
analysts, who previously relegated those
concerns to the flight processor engineer.
While helping consolidate their efforts, the
auto-code generator introduced a new class
of concerns. However, these concerns can
only increase the quality and realism of the
simulations. Forcing analysts to model
spacecraft components such at the 1553 bus
and the analog-to-digital converters increases the burden, but may potentially
avoid downstream mismatches so common
in spacecraft development.
Summary

Analyst discipline in Simulink enables realism in simulation, and a high quality flight code product. The auto-code generator's open architecture empowers the new
auto-code specialists to make radical, resource saving changes to attitude flight code
while streamlining the process. The TIMED
attitude team now develops algorithms in the
same environment that produces the flight
code. We have essentially eliminated the
middle-man. At the current time, auto-code
runs on two of the three intended platforms.
There are things we expect to see
from the Simulink RTW tools in the future.
Namely, the ability to easily re-ingest generated code back into Simulink remains at the
top of the list. Furthermore, we anticipate
13

M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

enhancements to block and subsystem management within Simulink itself. Although
specific to APL's attitude team, these desires
reflect the growing community of systems
designers, not just attitude and control designers, eager to use auto-code generators
for test and flight software. The TIMED
demonstration of auto-code utility is not a
technological step forward as much as it
may influence the general acceptance of
such tools in the satellite industry.
i

Press, W. H., Numerical Recipes in C : The Art of
Scientific Computing Second Edition; Cambridge University Press, New York, 1992;
pp.336 338

14
M. A. Salada, W. F. Dellinger

12th AIAAlUSU Conference on Small Satellites

•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•

