# Simulation-Based Testing of Embedded Attitude Control Algorithms of an FPGA based Micro Satellite



### Overview

- □ Introduction
- □OBC Hardware Configuration
- □ Implementation of ACS Algorithms
- □Simulation Environment
- **□**Results
- **□**Conclusions





# Mission Facts







Polar, sun-synchronous orbit, 500-900 km Nodal time passage 9:30-11:00h LTAN

3-axis stabilized Mass ~120 kg

Design lifetime: 2 years

TM&TC: VHF, UHF, S-band

Ka-band (Experimental)

Down-link: 2.2 GHz / 20 GHz Up-link: 2.0 GHz / 30 GHz

Solar panels: GaAs cells, 0.9 m<sup>2</sup>, 200 W

Peak power consumption: 300 W

Quad self-controlling FPGA architecture based on Xilinx Vertex II with 4 million system gates, up to 200 MHz clock, 256 MB RAM, 1 GB Ext. Flash (Re-)loadable FPGA/OBC

Launch: compatible with PSLV, 2012



# FLP Primary Mission Objectives



#### <u>Technology demonstration:</u>

- FPGA On-Board Computing System
- High speed Ka-band communication
- Accurate and agile attitude control system (7.5 arcseconds, Abs.)
- GENIUS GPS Experiment
- NEA detection using the Star Tracker
- 'Rent-A-Sat' mode
- Fiber Optical Gyros
- Solar Cells

- 1 S-band Antennas (LG)
- 2 Communication Unit
- 3 Ka-band Electronic
- 4 On-board Computer
- 5 Star Tracker
- 6 Magnetometers
- 7 Reaction Wheels
- 8 Power Control Unit

- 9 Sun Sensor
- 10 MICS
- 11 Gyros
- 12 VHF Antenna
- 13 Deployment Device
- 14 Magnetic Torquer
- 15 Ultra Stable Oscillator
- 16 TICS

- 17 Travelling Wave Tube
- 18 Ka-band Feed Horn (LG)
- 19 PamCam
- 20 Feed Horns
- 21 Cassegrain Mirror
- 22 Li-Ion Batteries
- 23 S-band Antenna (HG)
- 24 UHF-Antenna











# ACS Hardware





# Attitude Control System

| ACS Components            | Number |  |  |
|---------------------------|--------|--|--|
| Reaction Wheels           | 4      |  |  |
| Magnetic Torquer          | 3      |  |  |
| 3-axis Magnetometer       | 2      |  |  |
| Coarse Sun Sensor         | 16     |  |  |
| GPS                       | 3      |  |  |
| Star Tracker Camera Heads | 2      |  |  |
| Single axis rate gyro     | 4      |  |  |



| Pointing knowledge, absolute | ±7 arcsec (±1 pixel)     |
|------------------------------|--------------------------|
| Pointing knowledge, relative | ±2.5 arcsec (±1/3 pixel) |
| Pointing accuracy            | ±150 arcsec (± 20 pixel) |





# Attitude Control Mode



| Mode        | RW | MGT      | MGM       | GPS | STR | FOG | SuS      |
|-------------|----|----------|-----------|-----|-----|-----|----------|
| Detumblimg  |    |          | $\sqrt{}$ |     |     |     |          |
| Safe        |    | √        | √         |     |     |     | <b>√</b> |
| Idle        | √  | <b>√</b> | V         |     | V   | V   | V        |
| Target P.   | V  | V        | V         | V   | V   | V   |          |
| Nadir P.    | V  | V        | V         | V   | V   | V   |          |
| Inertial P. | V  | V        | V         |     | V   | V   |          |





### Hardware Connections



SSC-2009

# FPGA On-Board Computer

- ☐ FPGA: Field Programmable Gate Array
  - Programmable Logic
  - Reconfigurable
  - No software
  - Parallel executable processes
- Advantages against traditional Microprocessor-based Computing System
  - Reconfigurable
  - Start-up und reset within ms order
  - No interference between parallel processes
  - Precise timing
  - Reduction of hardware interface





#### On-board Computing System (OBC) Hardware Configuration



BPL: Back Plane

CIB: Connector Interface Board





# OBC Configuration (Quad FPGA Architecture)

#### **CPN Block Diagram**



#### **OBC Architecture**



#### **Clock Distribution**



- 4 million system gates
- 200MHz clock
- 256 MB RAM
- 4 Banks of 1Mx36 SSRAMs (indep. access)
- Triple redundant config.
  Flash





### Algorithms Development and Testing





# Layered Structure of Algorithms Implementation







### Matlab Simulation Environment

#### Simulation Environment





### **MDVE**





# Results

#### Matlab Simulator











#### Safe mode



(a) Rotational Rates (MDVE)



(b) Rotational Rates (Matlab Simulator)



(a) Angle between solar panel normal and sun vector (MDVE)



(b) Angle between solar panel normal and sun vector (Matlab Simulator)







#### Inertial Pointing Mode











#### Conclusions

- ☐ In this paper the entire ACS algorithms are implemented in a FPGA-based OBC. The implementation of the interface between the simulator and OBC is described. The conducted work shows that building an ACS entirely in hardware is possible. The performance of embedded ACS algorithms is verified through the simulation in the loop tests. The use of two different kinds of simulation environments further increase the credibility of these tests. The results of MDVE are compared with the results of the Matlab Simulator. Both results are consistent and they also verify the developed simulation environment.
- ☐ The established simulation environment could further be utilized for the development and verification of the on-board algorithms of the FPGA-based OBC as well as this could be further used in the Hardware-in-the-loop tests by using the satellite hardware components.







