Application of a microprocessor to a spacecraft attitude control by Hermann, F. W. & Brady, D. H.
APPLICATION OF A MICROPROCESSOR TO A
SPACECRAFT ATTITUDE CONTROL
D. H. Brady and F. W. Hermann
TRW Defense and Space Systems Group
Redondo Beach, California
The space-qualif ied TDRSS attitude control system (ACS) microprocessor
development work spanned three main design areas: hardware and instruction set,
ACS firmware, and hardware/firmware verif ication testing.
The Control Processor Electronics (CPE) hardware utilizes two parallel
AM2901 4-bit microprocessors, with a microprogrammed instruction set tailored
to the TDRSS controls application. Fourteen special purpose I/O instructions
interface with the ACS hardware, each transferring data for one sensor while
meeting timing and data-handling requirements. The ACS firmware resides in
5120 bytes of ROM with 1024 bytes of RAM for scratch data storage. The 16-bit
add, subtract, and divide operations are overflow-protected and multiplies are
done in hardware.
The firmware includes data processing for five sensors, four attitude
control laws, and telemetry and commands. The main design limitations were:
16-bit word length, 1024 8-bit byte RAM, and computation speed/task sharing
tradeoffs. It performed ACS computations quickly and without significant data
degradation. The word length limitation motivated the careful selection of
control filter topology and sacrif ice of dynamic range in favor of null per-
formance.
The flight program design was tested with three tools: Varian V-73 mini-
computer, CDC Cyber computer, and the CPE development station. The V-73
simulation tested source (assembly) programs prior to development station
availability. The CDC Cyber simulation was used primarily for accuracy
analysis. The development station included commercial versions of the flight
hardware which were run at full speed. All formal verification tests were
run on the development station to verify timing, accuracy, and interface re-
quirements.
From this development experience, additional hardware and software re-
quirements were identified:
0 Rapid Memory Examine/Change
• Floating point hardware
• High level language
• . 47
https://ntrs.nasa.gov/search.jsp?R=19810003143 2020-03-21T16:10:52+00:00Z
COARSE
SUN SENSOR
SINGLE ACCESS
ANTENNA
SINGLE ACCESS
ANTENNA
SPACE/GROUND
LINK ANTENNA
FINE
SUN SENSOR
COARSE
SUN SENSORS
ROLL
TDRSS SPACECRAFT CONFIGURATION
TRACKING AND DATA RELAY SATELLITE (TDRSS) MISSION:
• COMMERCIAL COMMUNICATION FOR WESTERN UNION
t SATELLITE TRACKING AND DATA RELAY FOR NASA
INTRODUCTION TRW
t TDRSS IS ONE RECENT TRW APPLICATION OF THE USE OF A MICROPROCESSOR
TO PERFORM SPACECRAFT ATTITUDE CONTROL SYSTEM COMPUTATIONS
• DEVELOPMENT WORK SPANNED THE FOLLOWING AREAS:
- HARDWARE DESIGN OF THE CONTROL PROCESSING ELECTRONICS (CPE),
A SPECIAL-PURPOSE MICROCOMPUTER BASED ON THE AMD 2901 BIT-
SLICE MICROPROCESSOR
- DEFINITION OF THE INSTRUCTION SET
- DESIGN AND CODE THE FIRMWARE FLIGHT PROGRAM
- VERIFICATION TESTING OF THE FIRMWARE
48
TDRSS ATTITUDE CONTROL HARDWARE TRW
• CONTROL ELECTRONICS ASSEMBLY
• SENSORS
- EARTH SENSOR
- COARSE SUN SENSORS
- FINE SUN SENSORS
- GYROS
- REACTION WHEEL TACHOMETERS
- SOLAR ARRAY DRIVE RESOLVERS
t ACTUATORS
- THRUSTERS
- REACTION WHEELS
TDRSS CONTROL ELECTRONICS ASSEMBLY TRW
SERIAL
COMMANDS
SERIAL
TELEMETRY
ANALOG
AND
SERIAL -
DIGITAL I
SENSOR -
DATA
SENSOR
INPUT
ELECTRONICS
SERIAL
„ DATA ,
L CLOCK
, STROBES
REDUNDANCY
NOT SHOWN
I f
COMMAND AND .
TELEMETRY
ELECTRONICS
t . 4
•sx <JJ
«_> OQ
0 g
H H-
CO
GO
CQ
CD
CONTROL
PROCESSING
ELECTRONICS
SERIAL
n«T/v
CLOCK
STTO
— V
— »
VALVE DRIVE
ELECTRONICS
WHEEL
DRIVE
ELECTRONICS
" VALVE
FIRING
••COMMANDS
.REACTION
WHEEL
TORQUE
"COMMANDS
49
CPE BLOCK DIAGRAM TRW
ENABLEVDt SABLE
CTE-ON-Y
-On
DATA STROBE
ADDRESS STROBE
STROBE STROBE
CPE INSTRUCTION SET TRW
• SPECIFIED BY CPE CONTROL FIRMWARE DESIGNERS TO BE OPTIMUM FOR
TDRSS APPLICATION
• INSTRUCTION SET MICROPROGRAMMED BY HARDWARE DESIGNERS
• 108 TOTAL INSTRUCTIONS INCLUDING:
- SINGLE- OR MULTIPLE-BIT SET, RESET AND TEST
- 16-BIT FRACTIONAL FIXED-POINT ARITHMETIC
- 16-BIT ADD, SUBTRACT AND DIVIDE CLAMPED AT ±1.0 WHEN
OVERFLOW OCCURS
- MULTI-BIT LOGICAL AND ARITHMETIC SHIFTS (SINGLE AND
DOUBLE-PRECISION)
- FOURTEEN INPUT/OUTPUT INSTRUCTIONS DEDICATED TO PARTICULAR
SENSORS OR ACTUATORS WITH ALL HARDWARE TIMING BEING TAKEN
CARE OF IN THE MICROCODE. FOR EXAMPLE, INSS INSTRUCTION
INPUTS ALL DATA ASSOCIATED WITH THE COARSE AND FINE SUN
SENSORS TO PAGE 0 OF RAM; OUWTQ OUTPUTS TORQUE COMMANDS TO
THE REACTION WHEELS FROM PAGE 0 OF RAM.
50
PROGRAM STRUCTURE TRW
CYCLE PERIOD "
0.06 SEC
0.10 SEC
•
0.08 SEC
0.10 SEC
0.10 SEC
0.20 SEC
0.20 SEC
2.0 SEC
0.20 SEC
2.0 SEC
0.20 SEC
START
1 INITIALIZATION 1 .
|
PROGRAM SYNCHRONIZATION
SENSOR INPUT
TELEMETRY FORMATTING AND PROCESSING
COMMAND PROCESSING
EIA/SSA PROCESSING
QYRO PROCESSING
INERTIAL MODE CONTROL LAW PROCESSING
EARTH MODE CONTROL LAW PROCESSING
NORMAL MODE CONTROL LAW PROCESSING
SUN MODE CONTROL LAW PROCESSING
RWA CONTROL LAW PROCESSING
VOE OUTPUT PROCESSING
TELEMETRY BIT RATES OF 200, 1000, AND 4000 BITS/SECOND AHE SELECTABLE
FOR THE 512 BIT MAIN FRAME. THESE PRODUCE TELEMETRY CYCLE TIMES OF
2.048, 0.512. AND 0.128 SECONDS RESPECTIVELY.
'EXECUTION FREQUENCY (NOT EXECUTION TIME) FOR EACH PHOQRAM MODULE.
FIRMWARE DEVELOPMENT/VERIFICATION PHILOSOPHIES TRW
DESIGN SCOPE -
0 MICROPROCESSOR DEDICATED TO ATTITUDE CONTROL FUNCTION
• INSTRUCTION SET TAILORED TO CONTROL NEEDS (ARITHMETIC
LIMITING, CONTROL HARDWARE I/O)
DESIGN PERSONNEL
• FIRMWARE DESIGNED CODED, AND TESTED BY CONTROL SYSTEMS
ENGINEERS
- IMPROVED COMMUNICATION FOR MECHANIZATION OF CONTROLS
REQUIREMENTS IN FIRMWARE
- INTERACTION IMPROVED FOR ACHIEVING ADEQUATE PERFORMANCE
IN THE FIRMWARE
INDEPENDENT VERIFICATION
• ACHIEVED BY SWAPPING MODULE RESPONSIBILITY AT VERIFICATION
TIME
• VERIFICATION TEST PLAN INDEPENDENT OF MODULE DESIGNERS
t REVIEW OF TEST RESULTS BY CONTROL LOOP ANALYSTS
51
CONSTRAINTS AND THEIR EFFECTS ON FIRMWARE DESIGN TRW
16 BIT WORD LENGTH MAXIMUM, 8-BIT BYTES
t CAREFUL MAGNITUDE SCALING FOR COMPUTATIONS
• QUANTIZATION EFFECTS ON CONTROL FILTER TOPOLOGIES
• LOW LEVEL PERFORMANCE/DYNAMIC RANGE TRADEOFFS .
1024 8-BIT BYTES ADDRESSABLE IN RAM
• ATTITUDE CONTROL FILTER COMPLEXITY
t FILTER STATE ACCURACY/MULTIPLE PRECISION ARITHMETIC
DATA PROCESSING
0 COMPUTATION COMPLEXITY/TIME DELAYS
t COMPUTATION COMPLEXITY/TASK SHARING
FILTER IMPLEMENTATION TOPOLOGIES TRW
WORD LENGTH EFFECTS -
• ACCURACY, QUANTIZATION
FILTER TOPOLOGIES -
.• POLYNOMIAL FORM (REJECTED)
• CASCADED FORM (ACCEPTED)
OTHER ALTERNATIVE FORMS
• PARALLEL FORM
• MATRIX FORM
• DFT, FFT
SCALING CONSIDERATIONS
• TOPOLOGY AND GAIN DISTRIBUTION FOR
INTERMEDIATE STATES
• DYNAMIC RANGE, ETC.
52
TRW
FIRMWARE DEVELOPMENT 8 VERIFICATION TOOLS
• VARIAN V-73 MINICOMPUTER
• 8 AND 16 BIT ARITHMETIC
• FORTRAN FUNCTIONS SIMULATING INDIVIDUAL CPE INSTRUCTIONS
• PROVIDES INTERFACE IN ENGINEERING UNITS FOR MAXIMUM
VISIBILITY
. i INPUT SAME AS ASSEMBLER INPUT
• CYBER 71 TIMESHARE
• SCIENTIFIC SIMULATION OF ARITHMETIC INSTRUCTIONS
• PROVIDES TOOL FOR CONTROL LOOP DESIGNERS
- .".ASSESS LIMITED WORD LENGTH EFFECTS
- FILTER DESIGN .
• RESIDENCE FOR CONTROLLED CPE SOURCE PROGRAM
t RESIDENCE FOR CPE ASSEMBLER PROGRAM
FIRMWARE DEVELOPMENT 8 VERIFICATION TOOLS (CONTINUED) TRW
TI 990/10 MINICOMPUTER
t VERIFICATION TOOL
• USED AS DRIVER FOR VERIFICATION TESTS
• DATA COLLECTION AND PRINTOUT
• PROVIDES DYNAMICS SIMULATION FOR DYNAMIC ENVIRONMENT
CPE DEVELOPMENT STATION
• BREADBOARD CPE
• FRONT PANEL FOR PROGRAM ENTRY, EDIT, AND EXECUTION
INTERFACE BOX
• HARDWARE LINK OF TI 990/10 AND BREADBOARD CPE
• GROUND STATION COMMAND SIMULATOR
53
CO
Q_
O
LU
>
LU
O
cc
LU5
O
cc
0.
O
oc
0.
O
54
REVIEWING THE FIRMWARE DESIGN
TRW
DESIGN IMPROVEMENT, FUTURE DESIGNS ARE ENHANCED BY DESIGN REVIEW AT SIGNIFICANT
MILESTONES -
• INITIAL DESIGN
• COARSE PROGRAM FLOWS
• DETAILED PROGRAM FLOWS
• CODE CHECKOUT, MODULE LEVEL
t TOTAL INTEGRATED PROGRAM VERIFICATION
• SUBSYSTEM TESTING
• SPACECRAFT OPERATIONS DESIGN
• FLIGHT EXPERIENCE
DESIGN REVIEW AREAS -
• HARDWARE DESIGN
• MICROCODE DESIGN
• INSTRUCTION SET DESIGN
• GROUND STATION COMMANDS SET
• TELEMETRY DATA AVAILABLE
• PROGRAM STRUCTURE
• DESIGN PHILOSOPHIES
REVIEWING THE FIRMWARE DESIGN TRW
SOME DESIGN IMPROVEMENTS UNCOVERED -
t RAM MEMORY LOAD AND MOVE DATA INSTRUCTION
t EXECUTIVE PROGRAM AND SUBROUTINES STRUCTURE
t GROUND COMMANDS TAILORED TO SPACECRAFT OPERATIONS
i MICROPROCESSOR DEVELOPMENT STATION SOFTWARE CHECKOUT
FEATURES
- RAM
- SCRATCHPAD VISIBILITY
- RAPID MEMORY EXAMINE/CHANGE
• CONTROL FILTER STATES WORD LENGTH >24 BITS
t FLOATING POINT HARDWARE
0 HIGH LEVEL LANGUAGE
55
