Design and Implementation of a femto-satellite technology demonstrator by Kravchenko, Victor
Design and implementation
of a femto-satellite
technology demonstrator
Victor Kravchenko
SUPERVISED BY
Joshua Tristancho
Universitat Polite`cnica de Catalunya
Master in Aerospace Science & Technology
June 30, 2011

Design and implementation
of a femto-satellite
technology demonstrator
BY
Victor Kravchenko
DIPLOMA THESIS FOR DEGREE
Master in Aerospace Science and Technology
AT
Universitat Polite`cnica de Catalunya
SUPERVISED BY:
Joshua Tristancho
Applied Physics department

ABSTRACT
The present work is aimed to demonstrate the development and implementation of a scal-
able femto-satellite technology demonstrator, experimentation and development platform
in order to practically prove the possibility of meeting the N-Prize competition require-
ments as well as introducing some possible scientific applications of a femto-satellite as
a satellite-on-a-board spacecraft. In order to achieve these goals the low-cost low-power
self-sufficient platform with communication, data processing position determination and
keeping abilities was designed and implemented. A set of subsystem qualification tests
was designed and performed in order to obtain numerical results and calls for the fu-
ture studies. The ability to meet the general space qualification and particular N-Prize
competition-related requirements was studied and the overall conclusions were stated.
Keywords: Femto-satellite, satellite-on-a-board, PCBSat, COTS, MEMS, OSHW, Open
Source, Mini-Launcher, N-Prize, WikiSat, EETAC, UPC

Acknowledgements
I’m grateful to my parents and my friend Elena for encouraging and supporting me during
this work.
I’m very grateful to my tutor Joshua Tristancho for the opportunity to do this research as
well as his help and inspiration in this work.
I’m very grateful to Roger Jove for introducing me to the WikiSat research group.
I want to thank members of the WikiSat research group who helped me with this work im-
plementing the low-cost tools, providing the supplies and prototyping the boards, specially
Joshua Tristancho, Roberto Rodrı´guez, Esteve Bardolet, Sonia Pe´rez and Jordi Gutie´rrez.
I’m very grateful to people who helped and participated in the long range link test cam-
paign, specially Raquel Gonza´lez, Enric Ferna´ndez, Roberto Rodrı´guez, Joan Martı´nez
and Javier Pe´rez.
I want to thank the EETAC school for the laboratories and equipment they have provided
to support this research.
Special thanks to Luis Izquierdo from the Universidad Nebrija and A´ngel Esteban from the
D47 company for their interest in this research and the opportunity to participate in the
TURISMAP project funded by AVANZA grant, project code F-00300.

CONTENTS
ABSTRACT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . i
Acknowledgements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . iii
List of Figures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix
List of Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1. System definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.1 Requirements synthesis . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.1.1 High Level Requirements . . . . . . . . . . . . . . . . . . . . . . . 4
1.1.2 Additional Requirements . . . . . . . . . . . . . . . . . . . . . . . 4
1.1.3 Technological Constraints . . . . . . . . . . . . . . . . . . . . . . . 5
1.2 Product design specification synthesis . . . . . . . . . . . . . . . . . . . . 6
1.2.1 Central processing unit . . . . . . . . . . . . . . . . . . . . . . . . 7
1.2.2 Position determination subsystem . . . . . . . . . . . . . . . . . . . 9
1.2.3 Thermal control subsystem . . . . . . . . . . . . . . . . . . . . . . 9
1.2.4 Pointing subsystem . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.5 Communication subsystem . . . . . . . . . . . . . . . . . . . . . . 10
1.2.6 Time reference unit . . . . . . . . . . . . . . . . . . . . . . . . . . 10
1.2.7 Power supply subsystem . . . . . . . . . . . . . . . . . . . . . . . 11
1.2.8 Development support subsystem . . . . . . . . . . . . . . . . . . . 11
1.2.9 The AWIP definition . . . . . . . . . . . . . . . . . . . . . . . . . . 12
1.3 Components selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2. Technical Implementation . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.1 Hardware design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.1.1 System busses . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.1.2 Components conditioning and interfacing . . . . . . . . . . . . . . . 17
2.1.3 The bill of materials . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.1.4 Board design process . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.2 PCB prototyping procedure . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.3 Post-factory MCU initialization . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.4 PCB assembling procedure . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.5 Post-production treatment . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
2.6 Environmental Impact . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
3. Testing and Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
3.1 Proof of alive test group . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
3.1.1 USB-UART interface test . . . . . . . . . . . . . . . . . . . . . . . 25
3.1.2 Subsystem discovery test procedure . . . . . . . . . . . . . . . . . 25
3.2 Subsystem performance evaluation and testing . . . . . . . . . . . . . . . 27
3.2.1 UART to USB performance evaluation . . . . . . . . . . . . . . . . 27
3.2.2 IMU data acquisition performance evaluation . . . . . . . . . . . . . 28
3.2.3 IMU data processing demo . . . . . . . . . . . . . . . . . . . . . . 29
3.2.4 RF output power and offset test . . . . . . . . . . . . . . . . . . . . 30
3.2.5 Wireless Link Test . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
4. Application Scenarios . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
4.1 Femto-satellite and ground station development kit . . . . . . . . . . . . . 33
4.2 Secondary application scenarios . . . . . . . . . . . . . . . . . . . . . . . 34
4.2.1 PicoRover autopilot and remote control unit . . . . . . . . . . . . . . 34
4.2.2 PID tuning bench . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
4.2.3 IMU-Assisted GPS (GAP) . . . . . . . . . . . . . . . . . . . . . . . 36
CONCLUSIONS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Bibliography . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
APPENDIX A. AWIP Schematics . . . . . . . . . . . . . . . . . . . . . . . 43
APPENDIX B. AWIP Assembly Form . . . . . . . . . . . . . . . . . . . . 47
APPENDIX C. Source Codes . . . . . . . . . . . . . . . . . . . . . . . . . 49
C.1 AWIP Post-production Discovery Test, Source Code . . . . . . . . . . . . 49
C.2 AWIP UART Performance Test, Source Code . . . . . . . . . . . . . . . . . 50
C.3 AWIP DAQ Performance Test, Source Code . . . . . . . . . . . . . . . . . 50
C.4 AWIP RF Carrier Test, Source Code . . . . . . . . . . . . . . . . . . . . . . 52
C.5 AWIP RF Link Test - GS Role, Source Code . . . . . . . . . . . . . . . . . . 53
C.6 AWIP RF Link Test - Remote Node Role, Source Code . . . . . . . . . . . . 54
C.7 AWIP RF Link Library, Source Code . . . . . . . . . . . . . . . . . . . . . . 56
C.8 AWIP RF Link Test with GPS payload, RX role . . . . . . . . . . . . . . . . 61
C.9 AWIP RF Link Test with GPS payload, TX role . . . . . . . . . . . . . . . . 61

LIST OF FIGURES
1.1 Subsystems definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.2 MCU IO requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.3 Software structure overview . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.1 MCU interfacing schematics . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.2 PCB design process . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.3 Low-cost PCB prototyping tools . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.4 Low-cost programming tools for MLF-32-encapsulated ATMEGA MCUs . . . . 21
2.5 Assembled AWIP prototypes . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.6 Post-production electrical safety test procedures . . . . . . . . . . . . . . . . . 23
3.1 Post-production subsystem discovery test . . . . . . . . . . . . . . . . . . . . 26
3.2 IMU axis alignment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.3 IMU data visualization examples . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.4 AWIP ground station setup example . . . . . . . . . . . . . . . . . . . . . . . 31
3.5 Wireless link test elements . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
4.1 Femto-satellite SDK application scenario . . . . . . . . . . . . . . . . . . . . . 33
4.2 PicoRover application scenario examples . . . . . . . . . . . . . . . . . . . . 35
4.3 PID test bench setup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
4.4 AWIP board used in a GAP device . . . . . . . . . . . . . . . . . . . . . . . . 36

LIST OF TABLES
1.1 Estimated performance and memory costs of some functions . . . . . . . . . 8
1.2 Central processing unit specification . . . . . . . . . . . . . . . . . . . . . . . 8
1.3 Position determination subsystem specification . . . . . . . . . . . . . . . . . 9
1.4 Thermal control subsystem specification . . . . . . . . . . . . . . . . . . . . . 9
1.5 Communication subsystem specification . . . . . . . . . . . . . . . . . . . . . 10
1.6 Power supply subsystem specification . . . . . . . . . . . . . . . . . . . . . . 11
1.7 Communication subsystem specification . . . . . . . . . . . . . . . . . . . . . 12
1.8 Key platform components list . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.1 The complete AWIP bill of materials . . . . . . . . . . . . . . . . . . . . . . . 18
3.1 The UART communication test summary . . . . . . . . . . . . . . . . . . . . 27
3.2 AWIP DAQ evaluation results . . . . . . . . . . . . . . . . . . . . . . . . . . 28

1INTRODUCTION
A significant amount of breakthrough achievements in both science and technology in
areas such as electronics, telecommunications and materials for the last decade have pro-
voked a dramatically change in the modern understanding of a spacecraft as a technical
system. A tendency to decrease mass, volume and power consumption of a spacecraft in
space market areas such as Earth observation, remote sensing and scientific in general
has led to the rapid development of a generation of micro, nano and pico satellites. Up
to the date, there are dozens of CubeSats with the mass varying from 100 to a few kilo-
grams orbiting the Earth and performing various scientific, governmental and commercial
missions. The new generation of university CubeSats in a mass range from 1 to 10kg has
shown ability to successfully perform Earth observation and other scientific missions in a
budget below 100000USD [17, 6] that a few years ago were possible only with million USD
budgets.
It has been theoretically proved as well as practically demonstrated that the modern Com-
mercial Of The Shelf (COTS) electronic products are sufficient to meet the requirements of
the space environment [31, 32, 17] and enable a design and implementation of the next-
generation spacecrafts for scientific purposes, femto-satellites with a mass below 100g
though allowing significant decrease in production cost and design time [6]. A feasibility
study [4] was done to prove a possibility of creating a fully functional satellite-on-a-chip for
the Earth observation purposes with a mass of 1g. A low-cost satellite-on-a-board was
proposed and the prototype was demonstrated [6] with a cost below 300USD though has
not flown to the date. A few distributed sensor array and cloud-missions for pico and femto
satellites were proposed and proved to be feasible [6, 5]. A major interest of both govern-
mental and industrial sectors to the emerging new technologies in the satellite market has
been demonstrated by a growing amount of research groups involved in the studies with
the financial support of aforementioned institutions. All the facts stated above show the
tendency of shift in advance driving force role from governmental and industrial institutions
to university research groups.
It is also very important to note that shifting the payload mass to the range below 100g
opens completely new space of launch opportunities based on the re-utilization of old and
well known low cost (in comparison to the conventional launchers) chemical rocket propul-
sion technologies for low mass payloads (also known as missiles) and stratospheric bal-
loons as the launchpad. The feasibility study of the low-cost launch technology based on
the aforementioned studies was made [8] and demonstrated the high success probability.
Public interest to the ongoing progress was demonstrated by a challenge given by the N-
Prize competition [10]: to put into the orbit a satellite with a mass between 9.99 and 19.99
grams and to prove its completion of at least 9 orbits assuming that no part of any orbit can
be lower than 99.99km. It is also required that total cost of the launcher and satellite must
be within a budget of 999.99GBP. As the response to the call of the N-Prize competition,
a research work has been performed and a feasibility study was done [28] showing the
possibility to achieve the goals of the competition.
The present work is aimed to demonstrate the development and implementation of a scal-
able femto-satellite technology demonstrator, experimentation and development platform
2 Design and implementation of a femto-satellite technology demonstrator
in order to practically prove the possibility of meeting the N-Prize competition require-
ments as well as introducing some possible scientific applications of a femto-satellite as
a satellite-on-a-board spacecraft. In order to achieve these goals the low-cost low-power
self-sufficient platform with communication, data processing position determination and
keeping abilities was designed and implemented using affordable technologies and open
source or free-ware tools along with the community knowledge and technological experi-
ence.
The Chapter 1 will synthesize a set of requirements to the femto-satellite technology
demonstrator capable of achieving the N-Prize goals. The Advanced Wireless Inertial
Platform (AWIP) will be introduced as the affordable low-cost multi-functional development
and experimentation platform capable of meeting the aforementioned requirements.
The technical design and implementation of the AWIP will be described in the Chapter 2.
The concurrency-based component selection and functional analysis will be presented as
the design optimization driving force. A set of free-ware, Open Source and Open Source
Hardware (OSHW) tools used in the platform development will be introduced. The hard-
ware implementation technique will be demonstrated including low-cost and professional
implementation approaches. The prototyping budget will be shown and justified. The de-
sign and technology related difficulties and mistakes observed will be discussed. Flash
programming methods including In-System Programming (ISP) and High Voltage Parallel
Programming (HVPP) will be discussed along with the rapid firmware prototyping methods
and low-cost OSHW tools.
The 3rd Chapter will demonstrate the test and validation methods developed in order to ob-
tain experimental data proving the device operability. The observations of the qualification
tests performed will be discussed in this chapter as well. The hardware-in-the-loop devel-
opment and simulation concept will be demonstrated with the platform and the Moon2.0
space mission simulation software [30].
The Chapter 4 will provide a set of application scenarios for the AWIP as a femto-satellite
technology demonstration and experimentation platform as well as some other possible
spin-off applications. A set of very basic implementation guidelines for each scenario will
be given.
System definition 3
CHAPTER 1. SYSTEM DEFINITION
The scope of this chapter is to define the femto-satellite technology demonstrator following
the requirements analysis guidelines for the system engineering in general [20] as well as
spacecraft-specific [12, 23] resulting in the product design specification (PDS) [27] to be
followed during the design and implementation processes. It is also worth mentioning that
the preliminary definition of the femto-satellite technology demonstrator is a satellite-on-a-
board or a PCBSat system and, thus, we have to assume the engineering design process
as a design of embedded electronic system with all the corresponding requirements and
constraints [14]. Another set of constraints and requirement is presented by the N-Prize
competition rules and the WikiSat team internal agreements and regulations [29, 28] and
will be introduced in the requirements analysis and PDS synthesis as well.
1.1 Requirements synthesis
To achieve the goal of the N-Prize competition the preliminary requirements analysis for
the femto-satellite was made [28]. However, it is necessary to make a revision of the
requirements analysis in order to take into account technology-specific criteria related to
implementation of the satellite-on-a-board in general and technology demonstration, ex-
perimentation and development platform in particular. The target platform is aimed to
represent the station-keeping functionality.
There exist different requirements and product design strategies, and among them there
are at least 3 strategies applicable to the subject of the current study: general product engi-
neering, spacecraft and embedded electronic system design strategies with corresponding
requirements analysis methods. Practically, it is possible to combine some parts of differ-
ent design strategies. For instance, satellite-on-a-board may be viewed as a device in
general as well as spacecraft and printed circuit board providing additional flexibility to the
definition process. It is important to note that the object of development is a technology
demonstrator and developer platform all-in-one, thus some femto-satellite requirements
are to be reasonably suppressed. A requirements synthesis strategy based on reasonable
combination of the aforementioned ones was used.
One important constraint source for the requirements synthesis to mention is introduced by
the WikiSat team rules list, stated in [28, 29]. Among them there are three to be considered
as the most affecting the requirements design:
Geographical Availability: There must be at least one alternative for each component
selected and there must be at least 1 company in the European community able to
provide this component.
Zero Redundancy: Redundant hardware is not allowed in the design, however some re-
dundancy may be presented in the software if necessary and possible.
Simplicity: The design should be Kept Simple and Safe (KISS rule).
4 Design and implementation of a femto-satellite technology demonstrator
Taking into account the requirements stated in [28] for the femto-satellite as well as the
available technical and technological solutions and a set of geographical and political con-
straints, a list of requirements to the satellite-on-a-board technology demonstrator for the
N-Prize mission is summarized and presented below:
1.1.1 High Level Requirements
HL0: The device should be able to provide bi-directional link capability on the 2.4GHz
frequency with at least 1200bps bandwidth in order to transmit the station-keeping
data including at least the determined position and to receive the possible updates
about the target to point the antenna.
HL1: The device should be able to determine its own position with respect to the center
of gravity of the Earth by inertial means only.
HL2: The device should be able to keep tracking the selected target pointing its antenna
by the means of magnetic actuators.
HL3: The processing unit should be able to perform the necessary computations in order
to process the sensor data, generate the control instructions for the pointing system
and keep receiving or transmitting data fast enough to fulfill the N-Prize require-
ments.
1.1.2 Additional Requirements
The fact that the device is not only a PCBSat technology demonstrator, but also a software
development and hardware experimentation kit applies additional set of requirements that
is important to mention.
AR0: It should be possible to re-program the device using the on-board USB interface.
AR1: It should be possible to perform the debugging operations using the on-board USB
interface.
AR2: The device may be powered using the on board USB interface
AR3: The device may be powered by any kind of battery source with the input voltage
varying from 3.4 to 12Vdc
AR4: The device should have at least 2 GPIO pins with analog or PWM output capabilities
to interface with any possible simulator of the magnetic actuation system for the
pointing control.
AR5: The device should have a low-level programming interface to enable firmware re-
covery in case of damage.
AR6: The device should have a power-up LED indicator providing the visual proof of life
to the operator/developer.
System definition 5
1.1.3 Technological Constraints
It is important to mention a list of technological constraints based on some internal agree-
ments of the WikiSat team. One of the noteworthy key statements is one defining the
design rules and affecting the selection of the technological solution, which states that it
should be possible to manufacture the device using amateur tools and low-cost means.
The study of the low cost and amateur PCB manufacturing technologies was done and re-
ported in [3]. The resulting list of technological constraints was defined and stated below:
TC0: It should be possible to mask the PCB for etching using toner-transfer masking tech-
nology.
TC1: It should be possible to etch the PCB using FeCl3 heated water solution.
TC2: The vias should have internal diameter of at least 0.6mm to allow low-precision
drilling technique.
TC3: The PCB track width can’t be small than 0.2mm (forced by TC0).
TC4: The gap between tracks can not be smaller than 0.15mm (forced by TC0, TC1).
TC5: Low temperature soldering paste (with the temperature peak at 230◦C) is allowed
to be used for the in-house prototyping purposes only due to the limitations of con-
sumer electric ovens used for amateur reflow-based SMD PCBA processes.
TC6: Any component package can be used except for array-based like BGA, LGA or PGA
due to the limitations of amateur pick and place tools.
TC7: The smallest standard passive component package can be used is 0201 due to the
technological limitations of the most industrial and amateur pick and place tools.
6 Design and implementation of a femto-satellite technology demonstrator
1.2 Product design specification synthesis
The constraint and requirements definition allows establishing the final product design
specification. The specification model can be defined with respect to subsystems in a
way similar to the Low Level requirements definition shown in [28] or can be performed
component-wise taking into account that the PCB is a target device, thus it is possible
to define the component list with high precision. It is also important to note that some
PCBSat components may play a role of a complete subsystem. Following the component-
based specification definition method will simplify the following component selection task
decreasing though overall design time.
Core Subsystems
Communication Unit
Transciever
External RF interface
Pointing Unit
External
actuator
interface
Position Determination Unit
MEMS Gyroscope
MEMS Accelerometer
Thermal Control Unit
Temperature sensor
Thermal vias
Power Supply Unit
Voltage regulator
External
battery interface
Central Processing Unit
Time reference
Development and Experimentation Assisting Units
USB Programming and Debugging Interface Direct Programing Interface
Figure 1.1: The definition of the subsystem-component relation model
As shown in the Figure 1.1, the component and subsystem relation is very strong as in the
most cases a subsystem is defined by a single component (assuming that the component
is an integrated circuit and its support elements). It is well seen that the component-based
specification design in this case can be more efficient than a classical subsystem-based
approach.
System definition 7
1.2.1 Central processing unit
The design specification for the desired central processing unit is one of the key issues
of this work as it needs both hardware compatibility and computational performance re-
quirements justification. It has been observed that for this kind of short-term missions an
optimal solution for the role of the central processing unit is a micro-controller [17, 6, 4] as
basically the accuracy, computational power, IO and memory are flexible enough to fulfill a
wide range of possible requirements.
Position Determination Subsystem
USB Programming and Debugging
In-System Programming
Communication Subsystem
Pointing Subsystem
MCU UART
SPI
2-Wire Bus
2x PWM Out
SPI
Figure 1.2: The definition of the MCU IO requirements
The hardware specification of the MCU IO ports is well defined by the needs of the subsys-
tems as illustrated in the Figure 1.2. It is necessary to note that the dedicated SPI bus for
the communication subsystem is preferable and may be software-emulated by hardware
design if needed so. The preferable low or direct memory programming interface is a serial
in-system (ISP) for the efficient pin-space utilization.
The definition of the performance specification for the MCU appears to be the most critical
part as its optimal selection strongly affects overall system specification. There are basi-
cally two MCU families in the scope of this study - 8-bit low power RISC MCUs and 16/32
bit high performance MCUs. For the N-Prize satellite-on-a-board it is necessary to choose
an MCU which is sufficient to fulfill the mission requirements. It should have the smallest
form-factor, lowest power consumption and optimal performance. As the only data sources
are 2-wire bus MEMS sensors with the size of a single value equal to 16 bits and transfer
rate about 100 - 300kHz it is possible to assume that management of these sensors and
data acquisition can be performed with a low-power 8-bit MCU.
Kalman Filter PID Controller Actuator output(PWM)
Status Reporting (TT&C)
6 DoF Inertial Data Acquisition
& thermal drift compensation
Pointing Task Update
Monitor (TT&C)
Figure 1.3: Structural overview of the satellite firmware for the N-Prize mission
The internal flash memory size and computational power (architecture, number of opera-
tions per second, mathematical co-processing) may be specified according to the require-
ments of the algorithms that should be implemented in order to achieve the mission tasks.
8 Design and implementation of a femto-satellite technology demonstrator
The software structure overview shown in the Figure 1.3 illustrates the key software func-
tions necessary to accomplish the N-Prize mission. An estimation of their impact on the
system performance, based on the benchmark comparison is summarized in the Table 1.1.
It is necessary to take into account that this data is an initial guess and the performance
characteristics are to be improved.
Table 1.1: Estimated performance and memory costs of some functions
Function Memory, kB
Execution time1, ms
Generic 8-bit RISC
Kalman filter2 5.8 5.2 (192Hz)
PID3 5.6 2.1 (476Hz)
Total 11.4 7.9 (126Hz)
Assuming that the efficient programming will be an additional challenge or even a call for
future work, it is concluded that 8-bit MCU can perform all the required tasks with the
lowest consumption profile and can be found in a smallest package. It is also clear that
using for instance an ARM Cortex M3 or similar MCU the programming and code efficiency
requirements are non significant due to the extensive computational power, though it is
hard to find a representative model of an MCU in this class with a comparable power
profile or suitable form factor: most of MLF, QFN and TQFP packages for such MCUs
starts with the side length of 7mm, when an 8-bit MCU can be found even in 3x3 mm QFN
package.
As stated in the table above, a 16 MIPS 8-bit MCU and 12kB memory space is sufficient
to perform the most expensive functions in terms of required memory capacity and ex-
ecution time. Assuming that 1 program cicle is performed at least at 100 Hz frequency
it is possible to consider an 8-bit low-power MCU a suitable target platform. Applying all
the requirements and constraints, the resulting MCU design specification was summarized
and stated in the Table 1.2.
Table 1.2: Central processing unit specification
Parameter Min Max Unit
In-system programable flash 16 KB
Internal SRAM 1 KB
IO interfaces 1xUART, 1xSPI, 1xI2C(TWI), 6xPWM
Computational power 1 MIPS/MHz, up to 20 MIPS
Clock frequency 0.4 16 MHz
1The benchmark results were selected only for MCUs equipped with an 16-bit MPU that were tested at
16MHz of the clock frequency.
2The Kalman filter implementation for the 8-bit platform used in the performance test was taken from
http://www.starlino.com/imu_guide.html.
3The PID controller source code used for the performance test was provided by Brett Beauregard at
http://www.arduino.cc/playground/Code/PIDLibrary
System definition 9
1.2.2 Position determination subsystem
In case of the inertial measurement unit, the subsystem design specification was done and
the components selection was justified [3]. The aforementioned work was performed as
the part of WikiSat research group activities so it is assumed that the selected components
are meeting all the requirements of this work as well. The resulting design specification of
the position determination subsystem is presented in the Table 1.3.
Table 1.3: Position determination subsystem specification
Parameter
Accelerometer Rate Gyroscope
Min Max Unit Min Max Unit
Measurement range ±6 ±24 g ±2000 deg/sec
Data rate 50 1000 Hz 1000 8000 Hz
Sensitivity ±6 ±3 mg/digit 14.3 deg/sec
Resolution 16 bits
1.2.3 Thermal control subsystem
The thermal control subsystem is considered to be passive and used only for data correc-
tion purposes. A temperature sensor is necessary to monitor the system temperature in
order to predict and compensate for thermal drifts in sensors or adjust the transmission
channel.
Nowadays, temperature sensors are embedded in most MEMS motion sensors for ther-
mal drift compensation purposes. To ensure homogeneous heat distribution between the
key subsystems a strong common ground plane as well as thermal vias are to be used.
The resulting design specification of the thermal control subsystem are presented in the
Table 1.4.
Table 1.4: Thermal control subsystem specification
Parameter MCU Accelerometer Gyro Transciever Resulting/
Operating Max +85 +85 +85 +85 +85
Temperature, °C Min −40 −40 −40 −40 -40
On-board temperature sensor characteristics
Parameter Min Max Units
Measurement range −30 +85 °C
Resolution 16 bit
1.2.4 Pointing subsystem
The study of the magnetic actuators for the N-Prize satellite-on-a-board orientation in the
magnetic field of Earth was performed [21] explaining the design methods and require-
ments to the subsystem. In order to provide additional flexibility in the final actuator se-
lection and related experiments, it was decided to use a raw non-amplified analog output
10 Design and implementation of a femto-satellite technology demonstrator
or PWM interface able to provide at least 40mA in peak. Such a decision will provide ad-
ditional flexibility for the device in its development and experimentation applications. The
optimal solution in this case can be achieved using an MCU with 2 analog output or raw
PWM output lines.
1.2.5 Communication subsystem
The carrier frequency for the communication subsystem is one of the key specification
defining criteria for the transceiver. The 2.4GHz frequency was selected as the current
radio link budget study for the N-Prize femto-satellite [28] has shown that this frequency
is preferable for the platform because it can meet the requirements of a wide range of
possible missions. The high gain antenna for the satellite-on-a-board concept has been
developed [9] to work on this frequency as well. The transceiver should have a sleep mode
and allow power consumption profile.
The RF output of the transceiver should be compatible with a standard 50Ohm antenna
RF interface as it will be used to work with different amplifiers and/or antennas. The digital
interface between the processing unit and the transceiver should be based on one SPI bus
for the programming simplicity and efficiency reasons. The communication protocol may
be proprietary but it should be documented good enough to be decoded by a software radio
if needed. The transceiver should be able to work in a mesh or p2p network mode with
up to at least 100 of instances. The resulting design specification of the communication
subsystem is presented in the Table 1.5.
Table 1.5: Communication subsystem specification
Parameter Min Max Unit
Operating frequency 2400 2525 MHz
Air data rate 250 2000 kbps
Frequency deviation ±160 ±320 kHz
Non-overlapping channel spacing 1 2 MHz
Maximum output power +4 dBm
Bandwidth (depending on data rate) 700 2000 kHz
Sensitivity −94 −82 dBm
external crystal frequency 16 MHz
external crystal tollerance ±60 ppm
modulation type GFSK
1.2.6 Time reference unit
As the mission duration is limited to a maximum one week, it is not necessary to install a
special RTC for time determination and it is possible to use high quality crystal oscillator.
It also was observed that many transceivers for 2.4GHz carrier frequency are requiring a
16MHz clock source as well as most of the MCU in the class of interest. The decision was
made to use a 16MHz crystal oscillator with the smallest possible form-factor and highest
System definition 11
accuracy. To ensure high stability and coexistence with the transceiver, the frequency
tolerance value of the oscillator selected should not be higher than ±60×10−6.
1.2.7 Power supply subsystem
As the N-Prize femto-satellite mission is limited to 9 spins and previous research [28] has
shown that other similar low-cost missions based on the same technology should be limited
to a week, the power source for the satellite should be a battery and there is no need in
its recharging or solar panel interfacing. This assumption allows limitation of the power
supply subsystem to a battery interface and a voltage regulator, which should have low
noise properties and should have good thermal drift characteristics.
The power supply for the pointing actuators should be provided by a separate regulator
with a consumption limit which should be defined during the pointing actuation system
development. This fact allows limiting the power supply subsystem to a single voltage
regulator which should provide a stable source for communication, position determination,
time reference subsystems and to the central processing unit as well.
An overview of the low power low cost MCU market shows that a typical 20 - 25MIPS
MCU with a 8 - 20MHz clock source is powered in a range from 2.7 to 5.5Vdc. For position
determination and communication subsystems it is optimal to use a 3.3Vdc power source.
It is also important to take into account the development and experimentation platform
functionality of the target device which makes it interesting to use a USB programming
and debugging interface as an alternative power source for the core subsystems. The
resulting specification of the power supply subsystem is presented in the Table 1.6.
Table 1.6: Power supply subsystem specification
Parameter MCU Accelerometer Gyro Transciever
Common/
Total
Supply voltage, V
Min 1.8 2.16 2.1 1.9 2.16
Max 5.5 3.6 3.6 3.6 3.6
Current Min 1.2
0.25 6.5
0.4 8.35
consumption, mA Max 5.0 13.5 25.25
1.2.8 Development support subsystem
Most of the modern 8-bit RISC MCU platforms have an in-system self programmable flash
program memory feature that basically allows making MCU re-programmable via any in-
terface by means of the proper boot-loader. For the simplicity of implementation and wide
community support reasons it was decided to follow the approach of using the UART in-
terface for boot-loader-based in-system programming and debugging purposes.
The USB to UART bridge was a necessary solution in order to provide a comfortable
development and experimentation environment allowing the developer to perform software
experiments in a fast and safe way. Support of the bit-banging mode as well as the 500000
12 Design and implementation of a femto-satellite technology demonstrator
baud per second operating mode and existence of the on-board 3.3 Vdc voltage regulator
with at least 100mA output were the selection criteria for the USB to UART bridge.The
resulting design specification for the development support subsystems is presented in the
Table 1.7.
Table 1.7: Communication subsystem specification
Parameter Min Max Unit
Data rate 300 576000 baud/s
Voltage requlator output, 3.0 3.6 V
Max voltage regulator
100 mA
output current
1.2.9 The AWIP definition
So far, taking into account all aforementioned facts regarding the required system struc-
ture, functionality and performance it is clearly seen that the desired satellite-on-a-board
technology demonstrator that is capable of meeting the N-Prize requirements as well as
playing a role of development and experimentation toolkit is nothing more than an Ad-
vanced Wireless Inertial Platform (AWIP).
This definition allows extending the initial aims of the device, making it an interesting techni-
cal solution for a variety of scientific, educational and engineering problems. It can possibly
become a helpful tool speeding up the development of motion processing, feedback control
and other low-cost embedded applications with wireless communication capabilities. The
target applications may vary from a femto-satellite or a UAV autopilot to an ultra-compact
object tracker to even a geo-tagging camera plug-in for 3D-imaging applications.
System definition 13
1.3 Components selection
Following the design specification stated above the component selection was performed.
The primary and backup (or secondary) component instances were selected according to
the Geographical Availability rule of the WikiSat research group taking as well into account
their cost characteristics. The summary of the component selection work is summarized
in the Table 1.8
One of the selection reasons that is worth mentioning in case of the MCU selection was
that the Atmel ATMEGA168 MCU was selected as the primary candidate has a strong
community support in terms of available hardware and firmware solutions. The Arduino1
development IDE as well as boot-loader firmware and corresponding libraries can signifi-
cantly simplify the final firmware development process.
Table 1.8: Key platform components list
Component candidate Mfg Model
Size Package Price2
mm Type e
MCU
Primary Atmel ATMEGA168 5×5 MLF32 3.07
Secondary ST STM8L151G6 4×4 QFN28 2.35
Accelerometer
Primary ST LIS331HH 3×3 QFN14 3.64
Secondary ST LIS3DH 3×3 QFN14 3.64
Rate Gyroscope
Primary InvenSense ITG-3200 4×4 QFN24 25.39
Secondary ST L3G4200D 4×4 LGA16 13.72
Transciever
Primary Nordic nRF24L01+ 4×4 QFN20 3.78
Secondary TI CC2500 4×4 MLF20 3.67
USB to UART
Primary Silabs CP2103 5×5 QFN28 4.05
Secondary FTDI FT232RQ 5×5 QFN32 5.93
Clock
Primary Epson TSX-3225 2.5×3.2 QFN28 2.54
Secondary Kyocera PBRV16.00MR 4.5×1.2 QFN32 1.52
Total components cost, minimum: 28.95
Total components cost, maximum: 44.35
Total components cost, primary: 42.47
1Open source and open hardware development and educational platform based on ATMEGA MCU family,
http://www.arduino.cc
2The prices are given for a reference purposes only; the price information was obtained from local web-
sites of Farnell and RS-Online electronic component distributors and are taken for the quantities below 10
units.
14 Design and implementation of a femto-satellite technology demonstrator
Technical Implementation 15
CHAPTER 2. TECHNICAL IMPLEMENTATION
The technical implementation of the AWIP was split into the following parts: hardware
design, prototyping, hardware debugging and firmware implementation for the life-proof
tests. The aforementioned implementation steps were performed and documented below.
One of the key aims of the technical implementation part was to perform it with minimum
expenses and using low-cost in-house manufacturing tools that could be afforded by a
particular hobbyist, open source and open hardware programming and debugging tools.
2.1 Hardware design
One of the most important tools in the hardware design process is the CAD software
used for schematics and board design, electrical and manufacturing-related rules compli-
ance revision and CAM output synthesis for prototyping or outsourced manufacturing. The
study of available open source and freeware tools was performed and the CadSoft Eagle
CAD was selected1 due to its advantages such as freeware license; wide community sup-
port and amount of component libraries; user-scripting language support making the CAD
highly customizable and others.
This software package is able to produce CAM output in GERBER RS-2742 and EXCEL-
LON3 providing though a high compatibility with industrial PCB manufacturing and assem-
bling services as well as in-house prototyping using even a toner-transfer method. It is
also important to note that the package is equipped with an auto-routing tool which allows
achieving the lowest development time.
2.1.1 System busses
The hardware design of the system was based on the data sheets and application notes
of the components selected. The interconection of the key component and interface se-
lection was performed according to the corresponding specifications as well as following
the interfacing scheme presented in the Figure 1.2. The pin numbers referenced below
correspond to the MLF-32 package of the ATMEGA168 MCU.
2.1.1.1 Serial ISP bus
The hardware SPI4 bus interface of the MCU was used for the low-level in-system pro-
graaming (ISP) mode natively supported by the MCU. This mode is toggled if the proper
1Official website: http://www.cadsoft.de/
2PCB manufacturing CAM format, http://en.wikipedia.org/wiki/Gerber_format
3PCB drilling and routing CAM format, http://en.wikipedia.org/wiki/Excellon_Format
4Stands for Serial Peripheral Interface bus, http://en.wikipedia.org/wiki/Serial_Peripheral_
Interface_Bus
16 Design and implementation of a femto-satellite technology demonstrator
command is received by the MCU on the SPI bus in a few milliseconds after the reset
event. The MISO (master in - slave out, pin 16), MOSI(master out - slave in, pin 15), SCK
(serial clock, pin 17) and RESET (29) pins of the MCU are used for this interface.
By means of this interface it is possible to re-program the boot-loader section. For this pur-
pose, a proper hardware adaptor and corresponding programming software are required.
2.1.1.2 USART bus
The USART5 bus was selected for intrfacing with the USB to UART bridge for boot-loader
based in-system programming and debug terminal purposes. The RX(30), TX(31) and
DTR (connected to the reset pin 29 through the 0.1µF capacitor) data lines were used in
this bus. The boot-loader program will begin the firmware update procedure if in the first
few seconds after the power-on or reset event the correct STK-500 command is received
through the RX pin. The DTR pin is used to provide a remote control of the MCU reset
event to the programming host computer as it allows toggling the programming mode on
demand.
According to the factory default settings the serial ISP programming mode is disabled and
can be enabled only through the low-level high-voltage parallel programming which can be
performed using low-cost hardware tools as well. The listening time may be defined by
programming the MCU configuration registers.
2.1.1.3 Two-wire bus (I2C)
The 2-wire bus (TWI) or I2C was used to interface with the accelerometer and gyroscope.
The bus can simultaneously contain up to 125 devices with the same address space and
can be operated at up to 400 kHz frequency. Native hardware interface was used assigning
the serial clock role (SCL) to the pin 28 and the serial data (SDA) to the pin 27.
2.1.1.4 Soft SPI and transceiver control
To ensure safety of the native SPI interface used for serial ISP and due to the neglectable
losses as well as pin-spacing reasons, the decision was made to use the transceiver inter-
face SPI bus in the software mode connecting the transceiver to general input-output pins
instead of a native SPI. Software mode basically means that the role of the shift registers
will be performed by the code. Practically it means that instead of 10ns for data-shifting
transaction it will take from 160 to 80 depending on the code efficiency.
Transmission enable (CE pin of the transceiver) and interrupt (IRQ pin of the transceiver)
pins are also required to control the transceiver. Additional pins are required to control the
transceiver. The soft SPI role will be performed by pin 9 (MISO), 10 (MOSI), 11 (SCK) and
13 for chip-select (CSN).
5Stands for universal asynchronous receiver/transmitter, http://en.wikipedia.org/wiki/
Universal_asynchronous_receiver/transmitter
Technical Implementation 17
2.1.1.5 PWM actuator outputs
Due to the very limited pin-space, the decision was made to use pins 11 and 12 necessary
for the serial ISP as the PWM outputs for the actuators as the usage overlap is impossible.
Both pins are able to provide a pulse-width modulated output with the 8-bit resolution by
the hardware means of the MCU.
2.1.1.6 GPS input
An external GPS receiver may be connected to the pin 13 used as the serial clock of the
serial ISP interface. In such a case the soft UART bus should be implemented. For the best
performance of the soft UART the usage of a state-machine and interrupt based algorithm
is assumed.
2.1.2 Components conditioning and interfacing
The conditioning of all the components was performed according to the manufacturers
recommendations of the implementation methods stated in the corresponding data sheets
[2, 26, 15, 22, 11, 25] and taking into account the interfacing agreements mentioned above.
The values of the passive components used were preferably selected according to the
corresponding component manufacturers recommendations, though package types were
selected preferring the smallest acceptable form factor if can be provided by any local
distributor.
The MCU conditioning and interface scheme is presented in the Figure 2.1 as an ex-
ample of the schematics design process. The complete schematics design document is
presented in the Appendix A.
ATmega 168/328
10K
0.1
uF
0.1uF
GND GND
0.1uF
ADC6 19
ADC7 22
AGND21
AREF20
AVCC18
GND3
GND5
PB0(ICP) 12
PB1(OC1A) 13
PB2(SS/OC1B) 14
PB3(MOSI/OC2) 15
PB4(MISO) 16
PB5(SCK) 17
PB6(XTAL1/TOSC1)7
PB7(XTAL2/TOSC2)8
PC0(ADC0) 23
PC1(ADC1) 24
PC2(ADC2) 25
PC3(ADC3) 26
PC4(ADC4/SDA) 27
PC5(ADC5/SCL) 28
PC6(/RESET)29
PD0(RXD) 30
PD1(TXD) 31
PD2(INT0) 32
PD3(INT1) 1
PD4(XCK/T0) 2
PD5(T1) 9
PD6(AIN0) 10
PD7(AIN1) 11
VCC4
VCC6
MCU
R1
C5
C13
C4
UART
UART
I2C
ISP
ISP
SOFT_SPI
GNDGNDGND
3.3V
3.3V
3.3V3.3V3.3V
DTR
XT1
XT1
XT2
XT2
SCKMISO
MOSI
RESET
RESET
SDASCL
CLKOCSN
INT
CE
RXTX
AREF
AREF
V_MOSIV_SCK
Decouplings Oscillator
Reset Interfacing
Reset Pull-up resistor R1 value may vary
Figure 2.1: MCU interfacing and conditioning schematics
18 Design and implementation of a femto-satellite technology demonstrator
2.1.3 The bill of materials
Once the schematics design was finished the bill of materials (BOM) was created using
an embedded script “bom.ulp”. The BOM was completed with the data of component
providers as well as pricing and delivery time information. The study of local electronic
components providers was performed in order to obtain lowest price values and fastest de-
livery. As regards accelerometers and transceivers it was possible to obtain development
samples from the manufacturing instance. The complete BOM is shown in the Table 2.1.
The component prices shown in the table were taken assuming production of at least 10
units.
Table 2.1: The complete AWIP bill of materials
No Part Mfg Value Case Qty Supplier Reference Price, e
1 IC1 Atmel Atmega168 MLF-32 1 Farnell 1455105 2.92
2 IC2 ST LIS331HH QFN-12 1 Farnell 1838525 3.95
3 IC3 InvenSense ITG3200 QFN-24 1 Farnell 1858279 18.79
4 IC4 Nordic nRF24L01P QFN-24 1 Farnell 1346268 4.87
5 IC5 SiLabs CP2103 QFN-28 1 Farnell 1291538 3.25
6 CLK Epson TSX-3225 custom 1 Farnell 1712841 1.74
7
C3-5, 13,
AVX 0.1µF 0402 8 Farnell 1833862 0.023
14, 16, 20, 21
8 R1, 3, 6 Vishay 10KΩ 0402 3 Farnell 1738864 0.028
9 C6, 17 MURATA 10nF 0201 2 Farnell 1776000 0.03
10 C1, 2 (polar) KEMET 10µF 1206 2 Farnell 1457414 0.27
11 C11 AVX 1.5 pF 0201 1 Farnell 1327609 0.022
12 C7 KEMET 1nF 0201 1 Farnell 1535558 0.3
13 C12 AVX 1 pF 0201 1 Farnell 1327608 0.031
14 C22 AVX 1µF 0402 1 Farnell 1327658 0.195
15 C9, 15 AVX 2.2nF 0201 2 RS 698-3033 0.055
16 C10 MURATA 4.7 pF 0201 1 Farnell 1776018 0.029
17 C18 AVX 10µF 0603 1 Farnell 1833804 0.27
18 C8 MURATA 33nF 0402 1 RS 723-5244 0.022
19 C19 AVX 100nF 0402 1 RS 698-3162 0.045
20 R4 Multicomp 22KΩ 0201 1 Farnell 1851022 0.04
21 L1 Johanson 8.2nH 0201 1 Farnell 1865740 0.047
22 L2 Johanson 2.7nH 0201 1 Farnell 1865731 0.047
23 L3 Johanson 3.9nH 0201 1 Farnell 1865735 0.047
24 IC VREG MICREL MIC5205 custom 1 Farnell 1663083 0.82
25 USB CON KYOCERA USB mini B custom 1 Farnell 1558179 1.69
26 PCB MICRON-20 AWIP F1v1 custom 1 micron-20 15.33
Total: 55.19
Technical Implementation 19
2.1.4 Board design process
The Eagle CAD tool-set allows converting the device schematics into the board design
template hardware links between all the components in the form of wires, directly connect-
ing the corresponding pins in the nets. The board design process can be represented as
a position optimization task.
The PCB design process can be significantly simplified if the proper design procedure
is followed. The procedure used in the current work was graphically represented in the
Figure 2.2 and described by the following text. First, the design rules were introduced to the
system specifying all the tolerances, minimums and maximums as well as preferred tracing
strategies for each layer. Than the optimal position of each component was manually
defined taking into account the optimal spacing inter-connection simplicity factors. The
backup image of the board design was done right after the component positioning process
in order to provide a safe-restore point for the following routing procedures.
Figure 2.2: A simplified diagram of the PCB design process
If the design rules are correctly defined and the component positions are selected properly
the embedded auto-routing script can be applied. Auto-routing script is based on the
iterative algorithm and can be run a few times in order to improve the solution. When the
best possible result is achieved the design rule check (DRC) script should be run. If the
DRC has detected any errors that are to be revised manually. The DRC script should be
run after each significant design check or correction. Once all the DRC issues are resolved
the board design can be considered finished.
As the PCB assembling process was decided to be done in-house, the assembling proce-
dure was created using the final BOM as a design reference. The assembly form is shown
in Appendix B.
20 Design and implementation of a femto-satellite technology demonstrator
2.2 PCB prototyping procedure
In order to fulfill the N-Prize requirements of being low-cost and easy to manufacture, it
was decided to make a prototype using the amateur technology. The toner-transfer mask-
ing and FeCl3 etching methods were selected. A toner-transfer device and etching tank
were manufactured and used for the prototype. A 2-axis drilling semi-automatic CNC was
built and used as well. The design and implementation processes for each of the afore-
mentioned tools are described in [28, 3]. Some of those tools are shown in the Figure 2.3.
toner-transfer FeCl3 etching SMD pick & place reflow soldering oven
PCB prototyping PCB assembling 
Figure 2.3: The low-cost PCB prototyping and assembling tools used in this work
It is important to mention some of the technology-related observations obtained during the
in-house prototyping of the AWIP board. It was observed that the toner-transfer masking
was not very reliable and played a weak point role, though it was possible to obtain a
stable mask and achieve an acceptable result after etching. It was also observed that
the top-bottom layers inter-connections (vias) were to be done after the assembling of the
board in the reflow oven if the wire-based inter-connection technology was used, though it
was acceptable to do the layer inter-connection before assembling if it was based on the
riveting technology. The chemical and electroplating technologies are out of the scope of
the in-house manufacturability study.
The in-house prototyping of the PCB including only toner transfer and etching took 18
hours due to the toner-transfer masking failures related to inhomogeneous heating, over-
exposure, inhomogeneous toner distribution (printing cartridge blade quality to be checked).
Taking into account all the aforementioned facts it is concluded that low-cost in-house pro-
totyping of the board is possible though it is not efficient in terms of time and quality.
Due to the necessity of the PCB rapid prototyping the market study of European rapid
prototyping services was performed. The offers for the shortest lead time were compared
resulting with selection of a Bulgarian PCB prototyping and assembling company6 Micron-
20. The final manufacturing price proposed for an 8-boards batch was 4.19e/board and
the complete price with shipping and artwork production included was 15.33e/board.
6Company website: http://www.micron20.com/en
Technical Implementation 21
2.3 Post-factory MCU initialization
As mentioned above, the ATMEGA MCU comes with a serial ISP feature disabled and the
only possible way to enable this feature is to re-program the MCU fuse registers using the
high-voltage programming method (HVPP) which cannot be done in system.
The implementation of the HVPP method requires a special device capable to control the
procedure. Using the official datasheet, a few on-line papers explaining the experiences of
HVPP method implementation and taking into account the needs of the AWIP project, the
HVPP Toolkit was designed. This method is used not only to enable serial ISP feature, but
also to set the correct external oscillator and enable CLOCK OUT feature. The aforemen-
tioned features were configured by setting the corresponding bits in the fuse registers of
the MCU to the following values provided by the on-line fuse calculator7: 0x87 for the low
fuse, 0xDD for high and 0x00 for extended.
Arduino-compatible board HVPP socket adaptor
USB to ISP
adaptor
ISP socket
adaptor
MLF32 
socket
High voltage parallel programming kit serial ISP kit
Figure 2.4: Low-cost programming tools for MLF-32-encapsulated ATMEGA MCUs
The low cost programming tools used in the HVPP process are shown in the Figure 2.4.
The key hardware component used in the setup was the MLF-32 spring-loaded burn-in
socket8 which was used to connect the MCU to the programmer in a mechanically safe
and non-destructive way. An Arduino-compatible micro-controller board and an adapting
circuit were used to ensure a safe interaction between the programmer and the target
MCU. The programming firmware was derived from an open-source HVPP project [16].
The serial ISP target board compatible with the MLF-32 socket adapter was designed in
order to allow testing the MCU in the same socket-based non-destructive manner before
the assembling as well as allowing the boot-loader programming. Programming the boot-
loader before the assembling process makes the board ready to be used with the USB right
after the post-assembling check procedure. The open-source avrdude9 tool was used as
the programming software to flash the boot-loader image.
7The calculator can be found at http://www.engbedded.com/fusecalc
8The low-cost MLF-32 spring-loaded socket was obtained from http://www.chinics.com/
9The homepage of the avrdude project can be found at http://www.nongnu.org/avrdude/
22 Design and implementation of a femto-satellite technology demonstrator
2.4 PCB assembling procedure
The PCB assembling process was done in-house using a set of very basic tools. The
process was split into 3 main parts: soldering paste application; components positioning;
reflow soldering. An important part of the process was preparing the components for the
assembly in the previously defined assembling order. The aforementioned BOM-based
printed form was made for keeping the components with the help of double-sided duct
tape. The assembly examples of both manually prototyped PCB and the one provided by
an external company are shown in the Figure 2.5.
Low-cost manual in-house PCB prototyping Low-cost industrial PCB prototyping
Figure 2.5: Example of AWIP assemblies with different PCB prototyping methods used
In order to follow the hard low-cost manufacturing style manual needle-based paste dis-
pensing method was used instead of the common stencil-printing method. The average
time10 spent on the paste application is 25 minutes. It was also considered possible to
use a stencil-printing method with a laser-engraved stencil made by external commercial
provider and corresponding GERBER files were produced though were not used due to
the time constraints.
As the smallest part used in the assembly had a size of 0.2 by 0.5 mm it was necessary to
use a pick and place tool for the assembling process. Due to a high cost of the professional
pick-and-place equipment and low efficiency of hobbies-oriented versions, a decision was
made to build a low-cost manual pick-and-place tool (see Figure 2.3) able to operate 0201
packaged11 components . For this reason a special tool, based on the precision bench and
an amateur vacuum pen was designed and implemented. Due to the significant difference
between 0201 package handling and packages above 0402 a set of vacuum pen adapters
was made.
In order to improve the assembling time characteristics, the manual pick and place tool was
equipped with a gear-motor controlled by a keypad. The visual guidance and assembly
inspection modes are provided by a adjustable web camera mounted close to the vacuum
pen tool.
A low-cost reflow oven shown in Figure 2.3 and based on the consumer toaster device was
made in order to ensure a quality reflow soldering. The oven was equipped with a ther-
moresistive temperature sensor attached to the 8-bit ADC of the oven controller. The re-
flow oven controller was based on the same ATMEGA168 hardware and Arduino firmware.
The embedded software allows programming the heat treatment procedure according to
10The measurement was done through assembling of 5 units
11according to SMD component package specification by JEDEC, commonly used international standard.
Technical Implementation 23
the typical requirements of the reflow soldering process (preheating temperature and time,
soldering temperature and time and final cooling time). The feedback of the reflow process
was provided to the PC terminal in the real time during the soldering process via USB to
UART bridge interface. More information on the low-cost assembling tools used in this
work can be found in [3].
2.5 Post-production treatment
The post-production visual inspection was performed for all the prototypes using the cam-
era of the pick-and-place machine. The defects detected during the visual inspection were
corrected using low-cost soldering station with both hot-air rework tool and high precision
soldering iron depending on the defect type observed. A short-circuit caused by an exces-
sive amount of the soldering paste was one of the most commonly observed defects.
Figure 2.6: Post-production electrical safety test procedures
In order to ensure that the device is safe to operate or interface with other electronic equip-
ment a set of basic electrical safety test routines was developed and implemented. Those
routines were designed to ensure absence of short-circuits in the power supply lines and
correct operation of the on-board voltage regulators.
The supply lines short-circuit test routine is illustrated in the Figure 2.6. Points (b,c), (b,d)
and (b,e) were probed for a short-circuit between using a generic digital multimeter (a)
with short-circuit detection function. The setup, illustrated in Figure 2.6(f) was used to test
the on-board voltage regulator in a safe way, varying the input voltage from 0 to 12V and
checking the output value and stability.
24 Design and implementation of a femto-satellite technology demonstrator
2.6 Environmental Impact
The impact of this type of technology demonstrators can be taken in terms of saving power
during the manufacturing process and the life cycle in general. Hazardous materials were
used during the manufacturing process including ferric acid, fluxes and lead-free soldering
pastes that could be harmful for the environment in certain conditions.
A set of safety measures was taken in order to ensure safety of operators. Air extractor
was used in the assembly line and personal protection equipment was used including the
safety gloves, plastic glasses during the work with acids as well as respirators during the
soldering works.
Low cost and lead-free materials were used in this project in order to minimize environ-
mental impact. In order to minimize the amount of waste produced during the work some
recycled components were used. All the boards with production defects were recycled and
reused in other prototypes as well.
Testing and Evaluation 25
CHAPTER 3. TESTING AND EVALUATION
This chapter will demonstrate the test and evaluation procedures developed in order to
assess operability of the device and the results analysis will be stated. In order to improve
credibility of the results obtained all the tests were done for at least 2 devices (up to 6,
depending on the availability). Basically the aforementioned procedures were split into 2
groups: proof of alive tests and performance evaluation. It is also important to mention
that most test procedures are based on the firmware and requires no additional hardware
instrumentation (except for a few RF tests).
3.1 Proof of alive test group
The group of proof of alive tests was designed as an advanced continuation of the post-
production tests intended to provide a quality-control-like feedback for hardware debugging
procedures. The necessity to track and eliminate hardly traceable hardware defects was
an additional factor forcing the development and implementation of this test routine group.
The tests were grouped by the data bus types instead of subsystems.
3.1.1 USB-UART interface test
As the USB to UART interface was designed for programming and debugging purposes
it was necessary to ensure its proper functioning. Basically, the key idea of the test pro-
cedure was to determine if the bridge is operating properly when plugged in the USB bus
and that it is responding correctly to discovery and status requests. There were 6 boards
subjected to this test and no hardware or performance defects were detected among them.
The USB discovery test was performed in the Linux OS using the “lsusb” tool, though it
could be performed in Microsoft Windows by means of “usbview” application.
3.1.2 Subsystem discovery test procedure
In order to ensure that inertial sensors and transceiver are soldered, configured and condi-
tioned properly it was necessary to develop a test procedure. It was observed that due to
mechanical properties of the sensor packages and limitations of the low-cost positioning
and soldering techniques for such kind of packages there was a common soldering defect
when the pins of both sensors used for slave address selection appeared to be floating or
unsoldered resulting in unpredictable slave address change.
To provide a solution for the problem mentioned above an I2C discovery test routine was
implemented. When loaded to the MCU the program scans each address of the I2C bus
device address space and echoes to the UART the ones that are found to be occupied.
If the device address is floating in certain conditions or none of possible slave addresses
are present the mechanical correction is done using a high precision soldering iron or
26 Design and implementation of a femto-satellite technology demonstrator
reworking the sensor IC with a hot air gun depending on the type of soldering defect
observed.
The firmware code for this test routine was derived from the I2C discovery code project
developed for the Arduino platform[19]. Some changes were made to the original code in
order to fix the address space limitation issue as the gyro slave address appeared to be
out of the initial scan range as well as to output the addresses found in a hex for reading
simplicity.
To ensure that transceiver was correctly conditioned and its interface with the MCU was
working well the register scanning test procedure was implemented. The operational the-
ory of the test routine can be presented as reading the transceiver register values and
comparing them with the defaults. If an incorrect response is observed the hardware in-
spection of the IC pads soldering is considered necessary in order to track the defect
source. For all the six boards produced the unsoldered MISO pin was detected only in one
but tracked and repaired during the post-assembly testing procedure.
AWIP Post-production test protocol
1. I2C discovery test
1.1 ST Accelerometer found at 0x19
1.2 InvenSense Gyro found at 0x69
2. nRF24L01 register value test
2.1 Register 0x0 value is 0x8 as expected; PASSED
2.2 Register 0x1 value is 0x3F as expected; PASSED
2.3 Register 0x2 value is 0x3 as expected; PASSED
2.4 Register 0x3 value is 0x3 as expected; PASSED
2.5 Register 0x4 value is 0x3 as expected; PASSED
2.6 Register 0x5 value is 0x2 as expected; PASSED
2.7 Register 0x7 value is 0xE as expected; PASSED
Post-production test finished, session can be closed.
Figure 3.1: Post-production subsystem discovery test output example
The I2C and transceiver discovery tests were combined together in a single source in order
to simplify the test procedure. For the simplicity reasons and due to the time constraints
the aforementioned test procedure was implemented in the Arduino environment. The
typical output protocol obtained via a serial port terminal is illustrated in the Figure 3.1.
The source code is presented in the Section C.1.
The “GTKTerm” package was used for the Linux-based tests though any terminal soft-
ware can be used to communicate with the board during this test. In order to provide an
improved software compatibility, a decision was taken to use 115200 baud rate. For the Mi-
crosoft Windows based test session the “WikiTerminal”1 package was used as it supports
advanced streaming modes and higher data-rates.
1The program can be found in http://code.google.com/p/moon-20/downloads/detail?name=
wikiterminal_win32.zip.
Testing and Evaluation 27
3.2 Subsystem performance evaluation and testing
The purpose of this section is to describe methods, procedures and results obtained during
the performance evaluation tests of the AWIP subsystems. Those tests were done to
determine minimum operational capabilities of the platform and prove that it is enough to
fulfill the initial design requirements stated in the first chapter of this work.
3.2.1 UART to USB performance evaluation
A set of tests was designed and performed in order to determine the data transfer con-
straints related to USB to UART bridge the CPU time cost of a data package transfer from
a platform to PC. The test was performed for 2 boards only as all the hardware defects
that could possibly affect the test performance were assumed filtered during the post-
production testing making the performance characteristics variation neglectable.
Table 3.1: The UART communication test summary
Baudrate Message rate, Hz MCU time cost, s/msg Datarate, kbps
1200 8 0.13128 0.117
4800 31 0.03322 0.454
9600 61 0.01660 0.893
19200 121 0.00830 1.772
38400 241 0.00415 3.530
57600 368 0.00271 5.390
115200 736 0.00135 10.781
230400 1389 0.00071 20.346
250000 1563 0.00063 22.895
500000 3125 0.00031 45.776
1000000 5750 0.00017 84.228
The transmission evaluation test was performed for a constant length payload of 15 bytes
simulating a data packet containing acceleration and angular rates for 3 axis and tem-
perature of the gyroscope package. The test results are summarized in the Table 3.1. It
is necessary to note that communication test failed for 460800, 576000 and 921600 baud
rates as the error rate in this modes is higher than acceptable2. The optimal rate in terms of
MCU time cost was 1000000 mode which allows transmitting 15 bytes message in 170,µs.
The source code of the firmware used to perform this test is presented in the Section C.2.
It is also important to mention that a special USB to UART bridge configuration tool, which
is described in [24], is necessary to enable the 1Mbit mode.
2More information about baud rate modes and errors as well as error estimation formulas are available in
the “The Baud Rate Generator” subsection of the [2, p. 172]
28 Design and implementation of a femto-satellite technology demonstrator
3.2.2 IMU data acquisition performance evaluation
The purpose of this experiment was to perform a study of the DAQ system of sensors
and MCU determining the maximum data acquisition and streaming rates through the
UART interface varying the methods of reading the FIFO registers of the sensors and
I2C bus parameters. It was also necessary to determine an MCU time cost of a single
DAQ operation at the maximum rate. The payload for this experiment was defined as
the 3 values of acceleration and 3 values of angular velocity measurements resulting in a
message size of 12 bytes.
Due to the possibility of externally-induced UART communication errors causing loose of
the synchronization in the binary communication mode, a 2-byte message header was
added as it was considered to be more efficient in the experiment conditions than the
check-sum method. A performance comparison at maximum DAQ rate was made for text3
and binary modes was summarized in the Table 3.2.
Table 3.2: AWIP DAQ evaluation results
Stream data to: MCU, RAM UART, binary mode UART, text mode
Data packet size, B 12 14 13 – 32, variable
Data packets/s 1,628 1,353 374 – 510, variable
Total transmitted, kB 19.07 18.49 13.62, approx.
Message CPU time cost, µs 610 740 2,740, approx.
The source code of the aforementioned experiment is presented in the Section C.3. The
results obtained allowed to perform a DAQ code optimization resulting in an Arduino li-
brary AWIPIMU designed to handle all the sensor operations in the simplified way though
keeping the performance level as high as it was demonstrated in this experiment.
The experiment results showed that the best performance in terms of MCU time was
achieved when the I2C bus was operated in Fast mode (400kHz) and that the CPU time
cost for reading a 16 bit value was equal for both sensors. The total cost for acquiring 12
bytes of data (only accelerations and angular rates were selected as the thermal changes
are considered to happen at lower frequency) assuming the bus operation in Fast mode
was equal to 610µs. The maximum data rate of streaming complete 6-DoF message from
sensors to the MCU RAM achieved was 1,628Hz while in binary streaming mode through
UART at 1,000,000baud/s the value of 1,353Hz was obtained.
The summary of data streaming tests is presented in the Table 3.2. Taking into account
the aforementioned results decision was taken to operate the I2C bus in the Fast mode.
It was also concluded that the sensors output data rates could be set to the 1kHz mode
to ensure loss-less data streaming for future experiments, though it may be interesting in
some cases to slow down to 0.3kHz mode.
3The comma separated value (CSV) text format was used for encoding the message in the text commu-
nication mode
Testing and Evaluation 29
3.2.3 IMU data processing demo
The purpose of this experiment was to demonstrate the way of interfacing the IMU data
with the common scientific tools stating an example of the IMU noise distribution model
study in the non-disturbed condition. A binary data stream of 6-DoF4 (12 bytes) with a 2
bytes synchronization header was recorded for a period of 1s while keeping the board in
a neutral position with minimum of disturbing factors. The δt was not added to the data
stream as it was observed to be equal for all measurements in the binary streaming mode
if the DAQ and streaming operations are performed at the maximum rate (described in the
previous section).
The data recording was done using the WikiTerminal program while the unpacking of the
binary data was performed with a specially made bin2CSV converter5. The CSV format
was chosen as a final storage format for the data due to the simplicity of the import pro-
cedure and compatibility with most of the data processing programs. The synchronization
header was necessary to be used in order to ensure data integrity due to the UART error
factor [2] of at least 1% for the data-rate of 1Mbps All the further processing of the data
obtained was performed in the matlab environment.
ωi[◦/s] = valuei×
(
1
scale f actor
)
(3.1)
ai[m/s2] = valuei×g0×
(grange
215
)
(3.2)
The conversion of the raw gyroscope data to ◦/s was done for each axis according to the
equation 3.1, where the scale factor was taken from the sensor datasheet [15] for normal
temperature of 25◦C without any additional thermal correction. The accelerometer raw
data was converted according to the equation 3.2 where the grange defines the measure-
ment range of the sensor and in this test was equal to ±6g. The standard gravity g0 is
used as additional multiplier to convert the value from g to m/s2. The data collection part
of the test was performed in the normal conditions of 25◦C so no thermal correction or
compensation method was used.
ax
ωx
ayωy
azωz
Figure 3.2: IMU axis alignment
4DoF in this context stands for “degrees of freedom”.
5The program and its sources are available at http://code.google.com/p/moon-20/source/
browse/#svn/gadgets/FAWIP_F1/bin2CSV.
30 Design and implementation of a femto-satellite technology demonstrator
The alignment of the IMU axis with respect to the board is shown in Figure 3.2 and must be
taken into account while reading processing the IMU data. The code for the data collection
routine is presented in the Section C.3 switched to the binary output mode with the 2 byte
synchronization header and 1Mbit UART data-rate in order to gain the highest resolution.
The corresponding code for data post-processing in the matlab is not attached due to its
simplicity, though it is necessary to mention that the CSV data may be imported to the
workspace using the GUI of the workspace window only. An example of the raw data and
the d f ittool output for the data obtained from one of the accelerometer channels is shown
in the Figure 3.3.
(a) 6DoF normalized data example (b) Probability density view example
Figure 3.3: IMU data processing visualization examples in MATLAB
3.2.4 RF output power and offset test
An experiment was carried out in order to ensure that the output power of the transceiver
is correct and constant in all the bands as declared in the datasheet. It was also necessary
to determine the carrier frequency offset levels in all the bands of the transceiver to ensure
its proper operability.
The corresponding test program was implemented and is presented in the Section C.4.
The RF spectrum analyzer for 2.4GHz and a serial data monitoring tool (laptop) were the
only additional hardware resources involved in the test.
F0 = 2400+CH [MHz] (3.3)
The output carrier frequency start, stop and step parameters as well as the time that spec-
ified frequency is active are defined in the constants setup section of the code. The ex-
pected frequency F0 was calculated for each channel according to the formula 3.3, where
the CH was defined as a 7 bit number[22].
The observation of the experiment results showed that the output power was constant for
all the channels tested in the range from 2400MHz to 2525MHz and was equal to 0dbm
as expected according to the datasheet. The frequency offset observed was also constant
Testing and Evaluation 31
for all the bands tested and was equal to 0.25MHz which was within the specification limit
of 1MHz.
3.2.5 Wireless Link Test
The wireless link validation procedure was designed in order to ensure the correct function-
ing of the transceiver as well as the related HAL and control library made for it in various
communication modes. The parameters varied were the data-rate, payload size, control
check-sum presence and its size, acknowledged and non-acknowledged modes. The vari-
ation of the distance was not scope of this test as the antenna and RF front-end may vary
depending on the desired satellite architecture though it was observed that with a typical
dipole antenna for 2.4GHz band the 20m distance may be achieved at least.
The platform combined with external low-noise amplifier and a typical 24dB parabolic an-
tenna for 2.4GHz band6 has been used in a long-range link test campaign in a role of
ground station (setup shown in the Figure 3.4) achieving the desired result of 7km. A
break-board for an RF front-end7 was used for both ground station and the remote node
in this experiment. The maximum power amplifier gain achieved was 7.8dBm while the
receiver sensitivity was supposed to be equal to −104dB. The antenna of remote node
was custom made and is a part of the work presented in the [9]. The source codes of the
programs for RX and TX modes are presented in the Appendix C.8 and Appendix C.9.
Figure 3.4: AWIP ground station setup for a long-range communication test
A ground station and the remote node programs were implemented in order to perform
the test. The main role of the ground station program was to receive the package from a
specific sender, convert it from binary to text format or add binary synchronization header if
the binary output was desired, and echo the final output to the UART interface. The source
code of the ground station role is presented in the Section C.5. The varied parameters
were the node and local address, payload size and structure, RF configuration and the
message representation method.
The source code of the remote node program is presented in the Section C.6. The payload
6The antenna used in this experiment was found in http://www.cablematic.es/Antena-2_dot_
4-GHz--802_dot_11_hyphen_b_-_g_-_n/Antena-parabolica-de-2_comma_4-GHz-y-24-dBi/
?pag=13.
7The datasheet of the front-end used can be found at http://maxiamp.com/downloads/MCP01_r5.
pdf.
32 Design and implementation of a femto-satellite technology demonstrator
data sent by the remote node was taken from various sources during the test, including the
raw IMU data, GPS NMEA stream and a static binary message (to have a measurement
of the real data rate excluding the processing losses). In case of the IMU data streaming
the DAQ rate was limited to 100Hz in order to simplify the real-time visualization process.
During all the tests accelerometer was setup to the ±6g though it was considered possi-
ble to implement an automatic measurement range adjustment algorithm if needed in the
future experiments. The test-ready remote node setup is shown in the Figure 3.5a
The SerialChart8 program was used in order to visualize graphically the received IMU
stream in the ground station computer. The program is able to read the data stream from
the serial port interface of the PC and interpret CSV-encoded data. The data is visualized
than in an oscilloscope style with an option to configure all the display parameters, includ-
ing the individual color representation for each channel. An example of the UI is shown in
the Figure 3.5b.
The experiment performed has confirmed that the wireless link subsystem is functioning
properly and can be easily re-configured to work with any type of data payload. The
hardware abstraction layer and the link library were significantly improved in the sense of
performance and code density during the test development resulting in the compiled library
size of 2.1KB. The source code of the link library is presented in the Section C.7
(a) AWIP remote node setup (b) IMU stream visualization with
SerialChart3
Figure 3.5: Wireless link test elements
8The program and the Figure 3.5b are taken from
http://code.google.com/p/serialchart/.
Application Scenarios 33
CHAPTER 4. APPLICATION SCENARIOS
The following chapter will introduce a set of application scenarios of the platform devel-
oped. Those scenarios are covering various development applications related to the de-
velopment process of a satellite-on-a-board, its subsystems and corresponding software
as well as test setups for hardware-in-a-loop test and evaluation procedures. Also some
scenario proposals related to aeronautic applications in general.
4.1 Femto-satellite and ground station development kit
The femto-satellite application development and experimentation kit is the primary role and
application scenario of the device. Though the combination of external components may
vary depending on the development scope, the global target application scope is the TT&C,
payload management, power and thermal management and attitude control development.
The key hardware elements and their relations for this application scenario are shown in
the Figure 4.1.
In this scenario the 6-DoF scalable motion measurement system is used to determine the
satellites trajectory and provide the data for the trajectory estimator and the control loop
which than can process the data and send the control command to the attitude control
subsystem able to actuate 2 servos used as a representation of the final actuator. Addi-
tional GPIO pin may be used as an input for an external GPS unit in order to gain higher
precision of the trajectory estimation over a long time period.
It is known that the modern sensor fusion algorithms for 6-DoF systems are quite limited in
the sense of long-time performance and drifts, though it may be assumed enough for the
femto-satellite mission as the motion model is well known and may be fitted to the trajectory
estimation algorithm. It is also important to note that there are various research projects
working on the trajectory estimation issues and successfully minimizing the thermal and
integration drifts using various mathematical models [13, 1, 7].
Figure 4.1: Femto-satellite SDK hardware inter-connections map
The determined and estimated trajectory data and the control history are supposed to be
packaged and sent to the ground station using the embedded radio-link subsystem in order
to provide the ground crew with the proof-of-life message. The pointing of antenna and an
34 Design and implementation of a femto-satellite technology demonstrator
optional payload sensor is supposed to be performed by 2 servos in order to simplify the
control development process.
The code for driving thermal and power management subsystems may be developed in
this scenario as well. The hardware means of the control over the current consumption
and sleep-mode of all the components is provided. The thermal data is supposed to be
used in the development process of the thermal drift compensator for the IMU (the initial
compensator parameters are provided for the gyro, accelerometer and the clock in the
corresponding data-sheets [15, 26, 11]) and the system clock source.
Any device compatible with Nordic NRF24 protocol system can be used as a ground station
receiver (including the software defined radio) though it is recommended to use a different
AWIP board for the ground station development purposes due to the code compatibility
and task similarity.
In order to simplify the end RF components development such as power amplifier, low
noise amplifier and switch or complete RF front-end and antenna the system was equipped
with an RP-SMA RF connector.
4.2 Secondary application scenarios
The purpose of this work was to design and implement a satellite-on-a-board development
and experimentation kit, though it was observed that the resulting product may serve to
perform some additional tasks and may be used as a part of other complex systems or as
a stand-alone product. Some of the key secondary application scenarios are stated in the
following sections.
4.2.1 PicoRover autopilot and remote control unit
The PicoRover is a robotic system designed for lunar exploration and developed by the
WikiSat research group as a form of participation in the Team FredNet group, the official
competitor of the Google Lunar X-Prize. The AWIP platform fits perfectly the role of the
autopilot and remote control for this mission as it has an interface for the rover’s actuators
as well as the IMU to provide the inertial reference for the navigation purposes. The UART
interface of the system may be used to interface with the imaging payload if needed. An
example of the AWIP platform used as a PicoRover autopilot is shown in the Figure 4.2.
It is also necessary to note that the AWIP application for the PicoRover allows development
of the scalable rover networks of multiple architectures. The development process for such
application will not require any additional hardware as the embedded hardware resources
are considered sufficient for this role.
Application Scenarios 35
(a) AWIP board as an autopilot (b) PicoRover field test
Figure 4.2: Examples of AWIP used as an autopilot for a PicoRover
4.2.2 PID tuning bench
The AWIP platform may be used as a development platform for an implementation of a
high efficiency PID control algorithm for a low-cost energy-efficient aeronautic system. A
single-engine stabilization test bench was proposed as a low-cost PID development, tuning
and experimentation platform. An example of a hardware setup proposed is shown in the
Figure 4.3.
The key hardware elements involved in this setup are the brushless motor with a propeller,
interfaced with an electronic speed control unit (ESC), a high Li-Poly battery with a fast
discharge capability and an AWIP platform as a control unit and a remote command inter-
face. The IMU is supposed to be the sensor data provided to the PID control loop while
the ESC unit will play a role of actuator interface. The wireless link interface is supposed
to be used as a state setup and monitoring interface.
Figure 4.3: PID test bench setup1
1The image was taken from http://www.nesinfinity.com/Projects-PID.html.
36 Design and implementation of a femto-satellite technology demonstrator
4.2.3 IMU-Assisted GPS (GAP)
The GAP (high precision geo-locator, Spanish abbreviation) is a device developed by the
WikiSat research group in collaboration with Nebrija university and a D47 R&D company
as a part of the TURISMAP project funded by AVANZA grant. The purpose of the device
is to provide a GPS-like information with a high precision using the IMU and sensor fusion
algorithms. The location data should be available even in the areas without GPS coverage
or in RF jamming environment.
GAP is considered to be a multipurpose high precision tracker that can be used for different
final applicastions. The key applications considered was 3D imaging assistant (recording
the position and the heading of a typical camera in order to use the dato for the 3D scene
reconstruction) and the high precision personal tracker for the crew of various tactical
teams of disaster-management organizations.
In this application scenario the only additional hardware element required is an external
GPS unit as the rest necessary resources are embedded in the AWIP platform. The im-
plementation of the filtering and sensor fusion algorithms is the only work to be done in
order to implement the aforementioned device. An example of the AWIP platform used as
a GAP device is shown in the Figure 4.4
Figure 4.4: AWIP board used in a GAP device
Application Scenarios 37
CONCLUSIONS
The present work has shown the necessity of the satellite-on-a-board development and
experimentation kit as well as the process of its design and technical implementation. A
set of hardware testing and validation procedures were presented and the results were
discussed and published by [18]. A group of primary and secondary application scenarios
were shown the possibility of practical usage of the device as a development platform for
various aerospace applications as well as a stand-alone product. It was also shown that
the proposed hardware system is enough to achieve the N-Prize competition goal.
It is important to note that the platform developed has opened a set of new challenges for
the future research related to the development of the flight software for the femto-satellite.
The implementation of the flight software for the N-Prize mission appears to be another
call for future work based on this platform. Some other members all ready started to study
the aforementioned issues using the presented platform.
It is also important to mention that further experimentation and research work is required
in such fields like trajectory estimation and sensor fusion algorithms, thermal and power
management algorithms in order to fulfill the N-Prize requirements. Another development
challenge will be the real time operating system able to manage the states of the final
satellite subsystem which can also be developed using the presented platform.
38 Design and implementation of a femto-satellite technology demonstrator
BIBLIOGRAPHY 39
BIBLIOGRAPHY
[1] E. Foxlin. Inertial head-tracker sensor fusion by a complementary separetebias
Kalman flter. In Proceedings of the IEEE 1996 Virtual Reality Annual International
Symposium (1996).
[2] ATMEL. Atmega 168 data sheet.
http://www.atmel.com/dyn/resources/prod_documents/doc2545.pdf.
[3] BARDOLET, E. Study of a low cost inertial platfom for a femto-satellite deployed by a
mini-launcher. Master’s thesis, Universitat Polite`cnica de Catalunya, 2010.
[4] BARNHART, D., VLADIMIROVA, T., AND SWEETING, M. Satellite-on-a-chip: a feasibility
study. In Fifth Round Table on Micro/Nano Technologies for Space, Nordwijk (2005).
[5] BARNHART, D., VLADIMIROVA, T., AND SWEETING, M. Design of self-powered wire-
less system-on-a-chip sensor nodes for hostile environments. In Circuits and Systems
ISCAS, IEEE International Symposium (2008).
[6] BARNHART, D. J., VLADIMIROVA, T., BAKER, A. M., AND SWEETING, M. N. A low-
cost femto-satellite to enable distributed space missions. Acta Astronautica 64 (2009),
1123 – 1143.
[7] BARSHAN, B., AND DURRANT-WHYTE, H. F. Inertial navigation systems for mobile
robots. IEEE Transactions on Robotics and Automation 11 (1995), 328–342.
[8] BONET, L. High altitude balloon mission design and implementation for a mini-
launcher. Master’s thesis, Universitat Polite`cnica de Catalunya, 2011.
[9] DE LAS HERAS LO´PEZ, A. Design and implementation of a synthetic aperture an-
tenna for a femto-satellite. Master’s thesis, Universitat Polite`cnica de Catalunya, 2011.
[10] DEAR, P. H. N-prize, rules in full.
http://www.n-prize.com/assets/rules_in_full.pdf, 2008.
[11] EPSON TOYOCOM CORPORATION. Tsx-3225.
http://www.epsontoyocom.co.jp/english/product/Crystal/set02/
tsx3225/index.html.
[12] FORTESCUE, P., STARK, J., AND SWINERD, G. Spacecraft Systems Engineering.
Wiley, 2003.
[13] G.S.W. KLEIN, T. D. Tightly integrated sensor fusion for robust visual tracking. Image
and Vision Computing 22 (2004), 769–776.
[14] GUTIERREZ, K., AND COLEY, G. Pcb design guidelines. Tech. rep., Texas Instru-
ments, 2009.
[15] INVENSENSE. Itg-3200 data sheet.
http://invensense.com/mems/gyro/documents/EB-ITG-3200-00-01.1.pdf.
40 Design and implementation of a femto-satellite technology demonstrator
[16] KEYZER, J. Avr hv rescue shield 1.
http://mightyohm.com/blog/products/avr-hv-rescue-shield/.
[17] KLOFAS, B., ANDERSON, J., AND LEVEQUE, K. A survey of cubesat communication
systems. In California Polytechnic State University (2008).
[18] KRAVCHENKO, V., AND TRISTANCHO, J. Advanced wireless inertial platform: A femto-
satellite toolkit development platform. In 50th AIAA Aerospace Science Meeting
(2012).
[19] KURT, T. E. Arduino as i2c bus scanner (blog post).
http://todbot.com/blog/2009/11/29/i2cscanner-pde-arduino-as-i2c-bus-scanner/,
2009.
[20] LIGHTSEY, B. Systems Engineering Fundamentals. Defense Acquisition University
Press, Fort Belvoir, Virginia, 22060-5565, 2001.
[21] NAVARRO MORCILLO, L. Use of hardware-on-the-loop to test missions for a low cost
mini-launcher. Master’s thesis, Universitat Polite`cnica de Catalunya, 2011.
[22] NORDIC SEMICONDUCTOR. nrf24l01+ data sheet.
http://www.nordicsemi.com/eng/Products/2.4GHz-RF/nRF24L01P.
[23] SHISHKO, R., AND ASTER, R. NASA systems engineering handbook, vol. 6105.
NASA Center for AeroSpace Information, 2007.
[24] SILICON LABORATORIES. An205: Cp210x baud rate support. Tech. rep., Silicon
Laboratories, 2007.
[25] SILICON LABS. Cp2103.
http://www.silabs.com/products/interface/usbtouart/Pages/
usb-to-uart-bridge.aspx.
[26] ST ELECTRONICS. Lis331hh data sheet.
http://www.st.com/stonline/books/pdf/docs/16366.pdf.
[27] SUMPNER, D. Manufacturing.
http://openlearn.open.ac.uk/mod/oucontent/view.php?id=
399740&direct=1, Retrieved April 2011.
[28] TRISTANCHO, J. Implementation of a femto-satellite and a mini-launcher. Master’s
thesis, Universitat Polite`cnica de Catalunya, 2010.
[29] TRISTANCHO, J. Wikisat team engineering management plan.
http://code.google.com/p/moon-20/wiki/WikiSat_Engineering_
Management_Plan, Retrieved April 2011.
[30] TRISTANCHO, J., MARTINEZ, J., ET AL. Moon-20 home page.
http://code.google.com/p/moon-20, Retrieved April 2011.
[31] UNDERWOOD, C., UNWIN, M., SORENSEN, R., FRYDLAND, A., AND JAMESON, P.
Radiation testing campaign for a new miniaturised space gps receiver. Radiation
Effects Data Workshop, 2004 IEEE 22 (2004), 120 – 124.
BIBLIOGRAPHY 41
[32] UNDERWOOD, C. I., RICHARDSON, G., AND SAVIGNOL, J. In-orbit results from the
snap-1 nanosatellite and its future potential. Phil. Trans. R. Soc. Lond. A 361 (2003),
199–203.
42 Design and implementation of a femto-satellite technology demonstrator
AWIP Schematics 43
APPENDIX A. AWIP SCHEMATICS
AT
m
eg
a 
16
8/
32
8
10
K
0.1uF
0.
1u
F
G
ND
G
ND
0.
1u
F
AD
C6
19
AD
C7
22
AG
ND
21
AR
EF
20
AV
CC
18
G
ND
3
G
ND
5
PB
0(
IC
P)
12
PB
1(
O
C1
A)
13
PB
2(
SS
/O
C1
B)
14
PB
3(
M
O
SI
/O
C2
)
15
PB
4(
M
IS
O
)
16
PB
5(
SC
K)
17
PB
6(
XT
AL
1/
TO
SC
1)
7
PB
7(
XT
AL
2/
TO
SC
2)
8
PC
0(
AD
C0
)
23
PC
1(
AD
C1
)
24
PC
2(
AD
C2
)
25
PC
3(
AD
C3
)
26
PC
4(
AD
C4
/S
DA
)
27
PC
5(
AD
C5
/S
CL
)
28
PC
6(
/R
ES
ET
)
29
PD
0(
RX
D)
30
PD
1(
TX
D)
31
PD
2(
IN
T0
)
32
PD
3(
IN
T1
)
1
PD
4(
XC
K/
T0
)
2
PD
5(
T1
)
9
PD
6(
AI
N0
)
10
PD
7(
AI
N1
)
11
VC
C
4
VC
C
6
M
CU
R1
C5
C1
3
C4
UA
RT
:R
X,
TX
,D
TR
UART:RX,TX,DTR
UA
RT
:R
X,
TX
,D
TR
I2
C:
SD
A,
SC
L
I2C:SDA,SCL
IS
P:
M
O
SI
,M
IS
O
,S
CK
,R
ES
ET
IS
P:
M
O
SI
,M
IS
O
,S
CK
,R
ES
ET
ISP:MOSI,MISO,SCK,RESET
ISP:MOSI,MISO,SCK,RESET
NR
F:
V_
M
O
SI
,V
_M
IS
O
,V
_S
CK
,C
E,
CS
N,
IN
T
NRF:V_MOSI,V_MISO,V_SCK,CE,CSN,INT
G
ND
G
ND
G
ND
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
DT
R
DT
R
XT
1
XT
1
XT
2
XT
2
SC
K
SC
K
M
IS
O
M
IS
O
M
O
SI
M
O
SI
RE
SE
T
RE
SE
T R
ES
ET
SD
A
SD
A
SC
L
SC
L
CL
KO
CS
N
CS
N
IN
T
IN
T
CE
CERX
RX
TX
TX
AR
EF
AR
EF
V_
M
O
SI
V_
M
O
SI
V_
M
IS
O
V_
SC
K
V_
SC
K
De
co
up
lin
gs
Re
so
na
to
r
Re
se
t I
nt
er
fa
cin
g
Re
se
t P
ul
l-u
p 
re
sis
to
r R
1 
va
lu
e 
m
ay
 v
ar
y
M
icr
oc
on
tro
lle
r U
ni
t
AW
IP
 S
ys
te
m
 D
ef
in
itio
n
UA
RT
 B
us
Th
e 
UA
RT
 b
us
 is
 im
pl
em
en
te
d 
in
 o
rd
er
 to
 p
ro
vid
e 
a 
lin
k
be
tw
ee
n 
M
CU
 a
nd
 U
SB
 in
te
rfa
ce
 o
f t
he
 h
os
t c
om
pu
te
r
fo
r e
nh
an
ce
d 
pr
og
ra
m
in
g 
an
d 
de
bu
gi
ng
.
A 
pu
lse
 o
n 
th
e 
DT
R 
pi
n 
re
se
ts
 th
e 
de
vic
e 
al
ow
in
g 
to
re
st
ar
t t
he
 p
ro
gr
am
 o
r e
nt
er
 th
e 
pr
og
ra
m
m
in
g 
m
od
e
(b
as
ed
 o
n 
th
e 
bo
ot
lo
ad
er
)
Tw
o 
W
ire
 o
r I
2C
 B
us
Th
is 
is 
a 
st
an
da
rd
 im
pl
em
en
ta
tio
n 
of
 th
e 
i2
c 
bu
s,
 u
se
d
fo
r I
M
U 
se
ns
or
s 
in
 th
is 
ap
pl
ica
tio
ns
. M
ay
 b
e 
us
ed
 fo
r
ex
te
rn
al
 p
ay
lo
ad
 a
s 
we
ll.
In
te
rn
al
 p
ul
l-u
p 
re
sis
to
rs
 o
f t
he
 M
CU
 a
re
 u
se
d
In
-S
ys
te
m
 P
ro
gr
am
m
in
g 
In
te
rfa
ce
 (H
ar
dw
ar
e 
SP
I B
us
)
Th
is 
is 
th
e 
di
re
ct
 in
te
rfa
ce
 to
 th
e 
AT
m
eg
a'
s 
SP
I t
ha
t m
ay
be
 u
se
d 
fo
r p
ro
gr
am
 d
ow
nl
oa
di
ng
 (s
up
po
rte
d 
by
 th
e
ha
rd
wa
re
, n
o 
bo
ot
lo
ad
er
 re
qu
ire
d,
 w
or
ks
 o
nl
y 
if 
pr
op
er
 b
it
in
 th
e 
sy
st
em
 fu
se
s 
is 
se
t (
do
ne
 a
t t
he
 a
ss
em
bl
in
g 
st
ag
e)
.
Ne
ts
 M
O
SI
, M
IS
O
 a
nd
 S
CK
 a
re
 th
e 
3,
4 
an
d 
5 
bi
ts
 o
f t
he
 
PW
M
-e
na
bl
ed
 p
or
t B
 a
nd
 m
ay
 b
e 
us
ed
 fo
r e
xt
er
na
l d
ig
ita
l
IO
 o
r P
W
M
 o
ut
pu
t (
m
ot
io
n 
co
nt
ro
l)
Tr
an
sc
ei
ve
r I
nt
er
fa
ce
 (S
of
t S
PI
 B
us
 +
 C
on
tro
l P
in
s)
Th
e 
So
ft 
SP
I b
us
 is
 im
pl
em
en
te
d 
fo
r t
he
 tr
an
sc
ei
ve
r d
ue
 to
th
e 
la
ck
 o
f P
W
M
 e
na
bl
ed
 p
in
s 
so
 b
us
 im
pl
em
en
ta
tio
n 
is
re
qu
ire
d 
in
 th
e 
co
de
 to
 e
na
bl
e 
th
e 
co
m
un
ica
tio
n.
 C
on
tro
l
pi
ns
 o
f t
he
 tr
an
sc
ei
ve
r a
re
 d
es
cr
ib
ed
 in
 th
e 
co
rre
sp
on
di
ng
da
ta
sh
ee
t. 
Th
e 
in
te
rru
pt
 is
 a
tta
ch
ed
 to
 th
e 
PC
IN
T2
1 
lin
e.
Bu
s 
De
sc
rip
tio
ns
Th
e 
de
sig
n 
sh
ow
n 
he
re
 is
 b
as
ed
 o
n 
th
e 
AT
m
eg
a'
s 
da
ta
sh
ee
t r
ec
om
en
da
tio
ns
 a
nd
 is
 im
pl
em
en
te
d 
ac
co
rd
in
g 
to
 th
e 
sy
st
em
 d
es
ig
n 
ta
sk
 a
nd
 re
qu
ire
m
en
ts
 s
et
.
Th
e 
Re
se
t a
nd
 D
ec
ou
pl
in
g 
bl
oc
ks
 a
re
 d
on
e 
ac
co
rd
in
g 
to
 th
e 
da
ta
sh
ee
t r
ec
om
en
da
tio
ns
Th
e 
16
M
Hz
 re
so
na
to
r w
ith
 +
/-0
.5
%
 fr
eq
ue
nc
y 
to
le
ra
nc
e 
is 
us
ed
 in
st
ea
d 
of
 re
co
m
m
en
de
d 
os
cil
at
or
.
De
si
gn
ed
 b
y:
Ap
pr
ov
ed
 b
y:
44 Design and implementation of a femto-satellite technology demonstrator
0.
1u
F
G
ND
2.
2n
F
0.
1u
F
G
ND
10
nF
10
uF
10
0n
F
G
ND
NR
F2
4L
01
G
ND
33
nF
22K
G
ND
8.
2n
H
2.7nH
3.9nH
2.
2n
F
4.
7p
F
1.5pF 1p
F
G
ND
G
ND
10
nF
1n
F
G
ND
10K
G
ND
AD
0
9
CL
KI
N
1
CP
O
UT
20
G
ND
18
IN
T
12
RE
G
O
10
RE
S-
G
11
RE
SV
6
RE
SV
1
7
RE
SV
2
19
RE
SV
3
21
RE
SV
4
22
SC
L
23
SD
A
24
VD
D
13
VL
O
G
8
C1
4
C1
5
C1
6
C1
7
CS
P8
G
ND
P5
G
ND
1
P1
2
G
ND
2
P1
3
G
ND
3
P1
6
IN
T1
P1
1
IN
T2
P9
NC
P2
NC
1
P3
RE
S1
P1
0
RE
S2
P1
5
SC
L
P4
SD
A
P6
SD
O
P7
VD
D
P1
4
VD
DI
O
P1
C1
8
C1
9
AN
T1
12
AN
T2
13
CE
1
CS
N
2
DVDD
19
IREF
16
IR
Q
6
M
IS
O
5
M
O
SI
4
SC
K
3
VDD
7
VDD
15
VDD
18
VD
D_
PA
11
VSS
0
VSS
8
VSS
14
VSS
17
VSS
20
XC1
10
XC2
9
RA
DI
O
C8
R4
L1
L2
L3
C9
C1
0
C11
C1
2
C6
C7
R3
I2C:SDA,SCL
I2C:SDA,SCL
NRF:V_MOSI,V_MISO,V_SCK,CE,CSN,INT
G
ND
G
ND
G
ND
G
ND
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
SD
A
SD
A
SC
L
SC
L
CL
KO
CS
N
CS
N
IN
T
CE
RF
_O
UT
RF
_O
UT
V_
M
O
SI
V_
M
IS
O
V_
SC
K
De
co
up
lin
gs
CS
N 
Pu
ll-
up
 
RF
 P
lu
g
W
ire
le
ss
 M
od
ul
e
Th
is 
de
sig
n 
is 
co
m
pl
et
el
y 
ba
se
d 
on
 th
e 
re
fe
re
nc
e 
de
sig
n 
pr
ov
id
ed
 b
y 
No
rd
ic 
Si
m
ico
nd
uc
to
r
Th
e 
ch
an
ge
s 
ar
e 
m
ai
nl
y 
th
e 
pa
ck
ag
e 
ty
pe
 a
nd
 s
ize
 o
f t
he
 s
m
d 
co
m
po
ne
nt
s
Li
br
ar
y 
el
em
en
t o
f t
he
 n
rf2
4L
01
 is
 ta
ke
n 
fro
m
 th
e 
Sp
ar
kf
un
's 
lib
ra
ry
Ac
ce
le
ro
m
et
er
De
co
up
lin
g
Th
e 
im
pl
em
en
ta
tio
n 
is 
co
m
pl
et
el
y 
ba
se
d 
on
 th
e 
re
fe
re
nc
e 
de
sig
n
pr
ov
id
ed
 in
 th
e 
pr
od
uc
t's
 d
at
as
he
et
 b
y 
ST
 M
icr
oe
le
ct
ro
ni
cs
Im
pl
em
en
ta
tio
n 
an
d 
se
ns
or
 lib
ra
ry
 im
ag
e 
do
ne
 b
y 
Es
te
ve
 B
ar
do
le
t
G
yr
os
co
pe
Th
e 
im
pl
em
en
ta
tio
n 
is 
co
m
pl
et
el
y 
ba
se
d 
on
 th
e 
re
fe
re
nc
e 
de
sig
n
pr
ov
id
ed
 in
 th
e 
pr
od
uc
t's
 d
at
as
he
et
 b
y 
In
ve
nS
en
se
Im
pl
em
en
ta
tio
n 
an
d 
se
ns
or
 lib
ra
ry
 im
ag
e 
do
ne
 b
y 
Es
te
ve
 B
ar
do
le
t
Se
ns
or
 lib
ra
ry
 im
ag
e 
an
d 
th
e 
de
sig
n 
la
yo
ut
s 
we
re
 re
vis
ed
 a
nd
va
ry
 fr
om
 th
e 
on
ce
 p
ro
vid
ed
 b
y 
in
itia
l a
ut
ho
r
De
co
up
lin
g
In
er
tia
l M
ea
su
re
m
en
t U
ni
t
AW
IP
 C
or
e 
M
od
ul
es
De
si
gn
ed
 b
y:
Ap
pr
ov
ed
 b
y:
G
YR
O
IN
SE
_G
YR
O
_I
TG
-3
20
0
AC
C
LI
S3
31
HH
AWIP Schematics 45
SI
LA
BS
 C
P2
10
3
1u
F
0.
1u
F
G
ND
G
ND
1u
F
G
ND
10K
Red
330
Red
G
ND
330
Red
LD
O
_S
O
T2
3
10
uF
10
uF
0.
1
G
ND
G
ND
G
ND
G
ND
D+ D
-
G
1
G
1
G
2
G
2
G
3
G
3
G
4
G
4
G
ND
VB
US
RE
G
IN
7
VD
D
6
G
ND
2
VB
US
8
D+
3
D-
4
RS
T
9
SU
SP
EN
D
12
SU
SP
EN
D
11
RI
1
DC
D
28
DT
R
27
DS
R
26
TX
D
25
RX
D
24
RT
S
23
CT
S
22
US
B_
TO
_U
AR
T_
CO
NV
ER
TE
R
G
ND
EX
P
G
ND
M
G
PI
O
_0
19
G
PI
O
_1
18
G
PI
O
_2
17
G
PI
O
_3
16
VI
O
5
C2
0
C2
1
C2
2
R6
D3
R2
D1
R5
D2
G
D0
3
G
D1
6
PW
0
1
PW
1
4
VS
0
2
VS
1
5
BP
ENG
ND
IN
O
UT
VR
EG
_3
.3
C1
C2
C3
VC
C
1
G
ND
2
G
ND
4
M
IS
O
2
M
O
SI
3
RS
T
6
SC
K
5
VC
C
1
UART:RX,TX,DTR
ISP:MOSI,MISO,SCK,RESET
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
G
ND
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
3.
3V
DT
R
SC
K
SC
K
M
IS
O
M
IS
O
M
O
SI
RE
SE
T
D-
D-
5V
_U
SB
5V
_U
SB
5V
_U
SB
5V
_U
SB
D+
D+
G
PI
O
0
G
PI
O
0
G
PI
O
1
G
PI
O
1
VI
N_
EX
TVI
N_
EX
T
VI
N_
EX
T
VI
N_
EX
T
RX TX
Co
nn
ec
to
rs
2,
54
m
m
 p
in
 s
pa
cin
g 
is 
us
ed
 fo
r C
O
N1
, C
O
N2
 a
nd
 C
O
N3
Vo
lta
ge
 R
eg
ul
at
or
 / 
Ex
t P
SU
 In
te
rfa
ce
De
co
up
lin
gs
C2
0 
an
d 
C2
2 
m
ay
 b
e 
re
pl
ac
ed
 b
y 
0.
1u
F
D1
, D
2,
 R
2,
 R
5 
m
ay
 b
e 
re
m
ov
ed
 a
s 
we
re
 im
pl
em
en
te
d 
fo
r C
P2
10
3'
s 
G
PI
O
te
st
s 
an
d 
ca
n'
t b
e 
us
ed
 b
y 
th
e 
M
CU
R6
, R
2,
 R
5 
m
ay
 b
e 
se
le
ct
ed
 in
 th
e 
0.
3-
10
K 
ra
ng
eLe
d 
In
te
rfa
ce
s
US
B 
to
 U
AR
T 
In
te
rfa
ce
Ex
te
rn
al
 In
te
rfa
ce
s
Th
e 
SI
LA
BS
 C
P2
10
x 
De
vic
e 
Dr
ive
rs
 fo
r W
in
do
ws
, M
ac
 a
nd
 L
in
ux
 a
s 
we
ll a
s 
dr
ive
r s
ou
rc
e 
co
de
 fo
r L
in
ux
 a
re
 a
va
ila
bl
e 
at
:
ht
tp
://
ww
w.
sil
ab
s.
co
m
/p
ro
du
ct
s/
m
cu
/p
ag
es
/u
sb
to
ua
rtb
rid
ge
vc
pd
riv
er
s.
as
px
Th
e 
im
pl
em
en
ta
tio
n 
of
 th
e 
SI
LA
BS
 C
P2
10
3 
is 
co
m
pl
et
el
y 
ba
se
d 
on
 th
e
re
fe
re
nc
e 
de
sig
n 
pr
ov
id
ed
 b
y 
th
e 
SI
LA
BS
 in
 th
e 
de
vic
e 
da
ta
sh
ee
t
A 
fe
w 
no
n-
sig
ni
fic
an
t a
dj
us
tm
en
ts
 w
er
e 
do
ne
 to
 m
at
ch
 th
e 
ap
pl
ica
tio
n
re
qu
ire
m
en
ts
De
si
gn
ed
 b
y:
Ap
pr
ov
ed
 b
y:
US
B
CO
N4
M
IN
I T
YP
E 
AB
CO
N2
SE
RV
O
 P
LU
G
 x
2
CO
N3
EX
T 
PS
U 
PL
UG
CO
N1
IS
P 
PL
UG
46 Design and implementation of a femto-satellite technology demonstrator
43
26
AWIP Assembly Form 47
APPENDIX B. AWIP ASSEMBLY FORM
AWIP F1 Developer’s Board v1.0 BOM/Assembly Part List 
Type Qty Case Value Part 
Passive components – top mount – needle 0201 
CAP 1 0201 1.5pF C11 
CAP 1 0201 1nF C7 
CAP 1 0201 1pF C12 
CAP 2 0201 2.2nF C9, C15 
CAP 1 0201 4.7pF C10 
CAP 2 0201 10nF C6, C17 
RES 1 0201 22K R4 
IND 1 0201 2.7nH L2 
IND 1 0201 3.9nH L3 
IND 1 0201 8.2nH L1 
Passive components – top mount – needle 0402+ 
CAP 7 0402 0.1uF C3, C4, C5, C13, C14, C16, C21 
RES 2 0402 10K R1, R3 
RES 1(+2) 0402 1K R2, R5, R6 
CAP 1 0603 33nF C8 
CAP 1 0603 100nF C19 
LED 1(+2) 0603 RED D1,D2,D3 
POLC 1 1206 10uF or 4.7uF C1, C2 
Passive components – bottom mount – needle 0402+ 
CAP 2 0402 0.1uF C20, C22 
CAP 1 1206 10uF C18 
Active components – top mount – needle 0402+ 
IC 1 QFN20 nRF24L01P  
IC 1 MLF32 ATmega168  
IC 1 Resonator 16MHz  
IC 1 QFN28 CP2103  
IC 1 LGA16 LIS3DH(331HH)  
IC 1 QFN36 ITG3200  
IC 1 Voltage Regulator 3.3V  
CON 1 USB-MINI-B (AB)  
CAP = ceramic capacitor, RES = resistor, IND = inductive coil, POLC = tantalum capacitor, polarized, IC = integrated circuit, CON = connector 
48 Design and implementation of a femto-satellite technology demonstrator
Source Codes 49
APPENDIX C. SOURCE CODES
This appendix contains source codes used to perform proof-of-alive and performance eval-
uation tests of the AWIP platform. Codes are written in C++ language using AVRC and
Arduino libraries. It is recommended to compile the codes listed below with a avr-gcc
compiler. For the using simplicity using of Arduino IDE for project management and pro-
gramming is advised.
C.1 AWIP Post-production Discovery Test, Source Code
The AWIPRF Arduino library is necessary to compile this code. The test procedure is fully
automatic and requires only a terminal connection to display the test results.
# inc lude <AWIPRF. h>
# inc lude <nRF24L01p . h>
# inc lude ” Wire . h ”
ex tern ”C” {
# inc lude ” u t i l i t y / t w i . h ”
}
byte i2cScan (byte start_addr , byte stop_addr )
{
byte result = 0;
byte data = 0;
byte found = 0;
f o r ( byte addr = start_addr ; addr <= stop_addr ; addr++ ) {
result = twi_writeTo (addr , &data , 0 , 1) ;
i f (result == 0){ Serial . print ( ” 1 . ” ) ; Serial . print (found+1 , DEC ) ;
i f ( ( addr == 0x19 ) | | ( addr == 0x18 ) ){Serial . print ( ” ST Accelerometer ” ) ;}
else i f ( ( addr == 0x68 ) | | ( addr == 0x69 ) ){Serial . print ( ” InvenSense Gyro ” ) ;}
else {Serial . print ( ” Unknown device ” ) ;}
Serial . print ( ” found at 0x ” ) ; Serial . println (addr , HEX ) ;
found++; }} r e t u r n found ;
}
vo id setup ( ) {
Serial . begin (115200) ;
Serial . println ( ”AWIP Post−produc t ion t e s t p ro toco l\n\n1 . I2C discovery t e s t ” ) ;
Wire . begin ( ) ;
i f (i2cScan (1 , 120) != 2) Serial . println ( ” 1 . Hardware r e v i s i o n i s advised ” ) ;
Serial . println ( ”\n2 . nRF24L01 r e g i s t e r value t e s t ” ) ;
nrf . init ( ) ;
byte nrf_regs [ 7 ] = {0x00 , 0x01 , 0x02 , 0x03 , 0x04 , 0x05 , 0x07} ;
byte nrf_reg_vals [ 7 ] = {0x08 , 0x3F , 0x03 , 0x03 , 0x03 , 0x02 , 0x0E} ;
boolean passed = t rue ;
f o r (byte i = 0; i < 7; i++){
Serial . print ( ” 2 . ” ) ; Serial . print (i+1 , DEC ) ;
Serial . print ( ” Reg is te r 0x ” ) ; Serial . print (nrf_regs [ i ] , HEX ) ;
byte value = nrf . getReg (nrf_regs [ i ] ) ;
Serial . print ( ” value i s 0x ” ) ; Serial . print (value , HEX ) ;
i f (value != nrf_reg_vals [ i ] ) { passed = f a l s e ; Serial . print ( ” when expected 0x ” ) ;
Serial . print (nrf_reg_vals [ i ] , HEX ) ; Serial . println ( ” ; FAILED ” ) ;} else{
Serial . println ( ” as expected ; PASSED” ) ; }
}
i f ( ! passed ) Serial . println ( ” 2 . Hardware r e v i s i o n i s advised ” ) ;
Serial . println ( ”\nPost−produc t ion t e s t f i n i shed , session can be closed . ” ) ;
}
vo id loop ( ) {}
50 Design and implementation of a femto-satellite technology demonstrator
C.2 AWIP UART Performance Test, Source Code
The desired baudrate to test should be specified as a constant before compiling and down-
loading this code to the target board. The test procedure is fully automatic and requires
only a terminal connection to display the test results.
/ / Constants
# de f ine BAUDRATE 500000
# def ine TESTMSG ”XXYYZZXXYYZZTT”
/ / Global v a r i a b l e s
unsigned long time = 0;
unsigned long cost = 0;
double count = 0;
boolean stat = f a l s e ;
vo id setup ( ) {
Serial . begin (BAUDRATE ) ;
}
vo id loop ( ) {
time = micros ( ) ;
unsigned long local_cost = time ;
i f (time < 1000001){
count++; Serial . println (TESTMSG ) ;
cost += micros ( ) − local_cost ;
}else i f ( ! stat ){ stat = ! stat ;
Serial . println ( ”\n\ r\n\ r ================================== ” ) ;
Serial . print ( ” Baudrate : ” ) ; Serial . println (BAUDRATE ) ;
Serial . print ( ” Message count , t o t a l : ” ) ; Serial . println (count , 0) ;
Serial . print ( ” Message cost , s : ” ) ;
double avg_cost = cost / ( ( count ) *1000000) ; Serial . println (avg_cost , 5) ;
Serial . print ( ” Message size , bytes : ” ) ; Serial . println ( s i z e o f (TESTMSG ) ) ;
Serial . print ( ” Transmited t o t a l , bytes : ” ) ;
Serial . println ( s i z e o f (TESTMSG ) *count , 0) ;
}
}
C.3 AWIP DAQ Performance Test, Source Code
The desired baudrate may be selected in the de f ine section. The output mode may be
selected by uncomenting or commenting the corresponding lines in the text. The output
mode may be switched between none (stream to RAM), stream to UART in binary and
stream to UART in text. It is also possible to switch the I2C bus frequency mode between
Normal and Fast.
/ / I2C bus frequency should be conf igured below
# def ine AWIP TWI FREQ 400000L
/ / UART baud ra te should be conf igured below
# def ine BAUDRATE 1000000
# inc lude <AWIPIMU. h>
# inc lude <Wire . h>
# inc lude ” imu . h ”
vo id setup ( ) {
Wire . begin ( ) ;
Source Codes 51
Serial . begin (BAUDRATE ) ;
/ / Reconf igures the I2C bus f req . to AWIP TWI FREQ
imu . init ( ) ;
/ / Conf igure the sensors to d e f a u l t DAQ modes
/ / More about sensor setup should be found i n
/ / the corresponding data−sheets
imu . setReg (ACC_START ) ;
imu . setReg (ACC_SET_WIN_06G ) ;
imu . setReg (GYRO_SET_R22 ) ;
imu . setReg (GYRO_SET_R62 ) ;
}
/ / Global v a r i a b l es
i n t count = 0;
boolean stat = f a l s e ;
boolean start = f a l s e ;
unsigned long time = 0;
i n t data [ ] = {0 ,0 ,0 ,0 ,0 ,0} ;
/ / Reads the data from sensor $device FIFO to the $out b u f f e r
/ / The $addr s p e c i f i e s the s t a r t r e g i s t e r and $ len set the
/ / r e g i s t e r autoincrement l i m i t , should be equal to the $out s ize
vo id read_stream ( i n t device , byte addr , byte *out , byte len )
{
Wire . beginTransmission (device ) ; Wire . send (addr ) ;
twi_readFrom (device , out , 6) ; Wire . endTransmission ( ) ;
}
/ / Stream the $data to the UART i n a b inary format ,
/ / l eng th l i m i t e d by the $ len
vo id write_data (byte* data , byte len ){
f o r (byte i = 0; i < len ; i++) Serial . write ( * ( data+i ) ) ;
}
vo id loop ( )
{
i f ( ! start ){time = micros ( ) ; start = t rue ; }
i f (micros ( ) − time < 1000001) / / − s t a r t
{
/ / Stream data from sensors to the MCU RAM
read_stream (ACC_ID , B10101000 , (byte * ) &data , 6) ;
read_stream (GYRO_ID , B10011110 , (byte * ) &data+6 , 6) ;
/ / Stream data from MCU RAM to the UART i n b inary mode
/ / S e r i a l . p r i n t ( ”SP” ) ;
/ / w r i t e d a t a ( ( byte * ) &data , s i z e o f ( data ) ) ;
/ / Stream data from MCU RAM to the UART i n b inary mode
f o r (byte i = 0; i < 5; i++){ Serial . print (data [ i ] ) ; Serial . print ( ” , ” ) ; }
Serial . println (data [ 5 ] ) ;
/ / Increment packet counter
count++;
}else i f ( ! stat ){ stat = ! stat ;
Serial . println ( ”\n\ r ================================== ” ) ;
Serial . print ( ” Count : ” ) ; Serial . println (count ) ;
Serial . print ( ” Avg cost , us : ” ) ; Serial . println ( ( double ) 1 /count , 5) ;
}
}
52 Design and implementation of a femto-satellite technology demonstrator
C.4 AWIP RF Carrier Test, Source Code
The desired baudrate may be selected in the de f ine section. Additional hardware is
needed to perform this test: RF spectrum analyzer able to work with 2.4 - 2.5GHz bands
and with a peak search feature. An RP-SMA adapter may be needed to interface the board
with a spectrum analyzer.
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
AWIP RF CARRIER OUTPUT TEST
Device w i l l t r ansm i t a c a r r i e r wave at each channel s t a r t i n g
from RF CHANNEL START and f i n i s h i n g a t RF CHANNEL STOP
wi th a step = RF STEP, MHz ho ld ing the channel a c t i v e
f o r HOLD TIME, ms. Once the RF CHANNEL STOP i s reached , the
t e s t w i l l be r e s t a r t e d from the begin ing .
SPECTRUM ANALYZER SETUP:
center frequency = 2.42GHz, span = 100 MHz,
capture mode = peak hold (TRACE or AVERAGE menu)
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
/ / TEST CONFIGURATION SECTION
# def ine RF CHANNEL START 0 / / F = 2400 + X MHz
# def ine RF CHANNEL STOP 125 / / F = 2400 + X MHz
# def ine HOLD TIME 5000 / / ms
# de f ine RF STEP 1 / / MHz
# def ine BAUDRATE 115200 / / bps
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
# inc lude <AWIPRF. h>
# inc lude ” nRF24L01p . h ”
vo id setup ( )
{
Serial . begin (BAUDRATE ) ;
nrf . init ( ) ;
nrf . setReg (CONFIG , 0x02 ) ;
nrf . setReg (RF_CH , RF_CHANNEL_START ) ;
nrf . setReg (RF_SETUP , 0x9F ) ;
nrf . printSTATUS ( ) ;
nrf . printCONFIG ( ) ;
nrf . printRFSETUP ( ) ;
delayMicroseconds (1500) ;
ceHi ( ) ;
}
byte freq = RF_CHANNEL_START ;
vo id loop ( ) {
Serial . print ( ” Channel ( r e g i s t e r va l ) a c t i v e : ” ) ;
Serial . println (nrf . getReg (RF_CH ) , DEC ) ;
delay (HOLD_TIME ) ;
ceLow ( ) ;
freq +=RF_STEP ;
i f (freq > RF_CHANNEL_STOP ) freq = RF_CHANNEL_START ;
nrf . setReg (RF_CH , freq ) ;
ceHi ( ) ;
}
Source Codes 53
C.5 AWIP RF Link Test - GS Role, Source Code
The desired baudrate may be selected in the de f ine section. The channel number, local
and remote addresses, desired CRC and ACK modes as well as data-rate and payload
type are setup and may be redefined if needed in the de f ine section of the code.
# inc lude <AWIPRF. h>
# inc lude <nRF24L01p . h>
# def ine LOCAL ADDR ” AWsrv ” / / must be 5 bytes
# de f ine REMOTE ADDR ”AWIP0” / / t a r g e t addr , must be 5 bytes
# de f ine RF CHANNEL 75 / / Freq = 2400 + RF CHANNEL and always < 2525 , MHz
# def ine PL SIZE 14 / / Payload packet s ize , must be same f o r both boards
vo id setup ( )
{
Serial . begin (115200) ;
nrf . init ( ) ; / / i n i t i a l i z e the p in modes and p u l l−ups
nrf . configure ( ( byte * ) LOCAL_ADDR , (byte * ) REMOTE_ADDR , RF_CHANNEL , PL_SIZE ) ;
nrf . stateStandbyI ( ) ;
nrf . setReg (CONFIG , 0x0F ) ;
delayMicroseconds (130) ;
ceHi ( ) ;
Serial . println ( ” Last known s ta tus i s : ” ) ;
nrf . printSTATUS ( ) ; nrf . printCONFIG ( ) ;
Serial . println ( ” L i s t e n i n g s t a r t e d . . . ” ) ;
}
byte stat = B00001110 ;
vo id loop ( ) {
ceHi ( ) ;
/ / n r f . printSTATUS ( n r f . getReg (STATUS) ) ;
/ / n r f . printCONFIG ( ) ;
i n t acc [ 8 ] = {0 ,0 ,0 ,0 ,0 ,0 ,0 ,0} ;
byte tmp = nrf . getReg (STATUS ) ;
/ * i f ( s t a t != tmp ){
s t a t = tmp ; * /
i f (nrf . dataReady ( ) ){
/ / ceLow ( ) ;
nrf . getData ( ( byte * ) &acc , 16) ;
/ / f o r ( i n t i = 0 ; i < PL SIZE ; i ++) S e r i a l . p r i n t ( b u f f [ i ] ) ;
Serial . print (acc [ 0 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 1 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 2 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 3 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 4 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 5 ] ) ;
Serial . print ( ” , ” ) ;
Serial . print (acc [ 6 ] ) ;
Serial . println ( ) ;
/ / n r f . setCmd (FLUSH RX) ;
/ / n r f . printRFSETUP ( ) ;
/ / n r f . printCONFIG ( ) ;
/ / delayMicroseconds (1500) ;
/ / ceHi ( ) ;
}
/ / delay ( 1 ) ;
}
54 Design and implementation of a femto-satellite technology demonstrator
C.6 AWIP RF Link Test - Remote Node Role, Source Code
The desired baudrate may be selected in the de f ine section. The channel number, local
and remote addresses, desired CRC and ACK modes as well as data-rate and payload
source are setup and may be redefined if needed in the de f ine section of the code.
# inc lude <Wire . h>
extern ”C” {
# inc lude ” u t i l i t y / t w i . h ” / / from Wire l i b r a r y , so we can do bus scanning
}
# inc lude <AWIPRF. h>
# inc lude <nRF24L01p . h>
# def ine AccID 0x19
# de f ine ACC START 0x20 , B00111111
# def ine ACC WINDOW 0x23 , B00000000
# def ine AccX 0x29 , 0x28
# de f ine AccY 0x2B , 0x2A
# def ine AccZ 0x2D , 0x2C
# def ine GyroID B1101001
# def ine R22 0x16 , B00011011
# def ine R62 0x3e , B00000001
# def ine Temp 0x1b , 0x1c
# de f ine GyroX 0x1d , 0x1e
# de f ine GyroY 0x1f , 0x20
# de f ine GyroZ 0x21 , 0x22
# de f ine URX ADDR ( byte * ) ”AWIP0”
# de f ine UTX ADDR ( byte * ) ” AWsrv ”
# de f ine RF CHANNEL 75
# def ine PL SIZE 14
void i2cSetRegister ( i n t device , i n t address , i n t value )
{
Wire . beginTransmission (device ) ;
Wire . send (address ) ;
Wire . send (value ) ;
Wire . endTransmission ( ) ;
}
byte i2cGetRegister ( i n t device , i n t address )
{
Wire . beginTransmission (device ) ;
Wire . send (address ) ;
Wire . endTransmission ( ) ;
Wire . requestFrom (device , 1) ;
i f (Wire . available ( ) )
r e t u r n Wire . receive ( ) ;
r e t u r n B00000000 ;
}
i n t i2cGetValue ( i n t device , i n t addressH , i n t addressL )
{
i n t i= ( ( unsigned i n t ) (i2cGetRegister (device , addressH ) )<<8) +
i2cGetRegister (device , addressL ) ;
r e t u r n i ;
}
boolean sendd (byte* data , byte psize ){
/ / byte s t a t = n r f . getReg (STATUS) ;
/ / i f ( ( s t a t & ( ( 1 << TX DS) | (1 << MAX RT) ) ) ) r e t u r n f a l s e ;
ceLow ( ) ;
nrf . setReg (CONFIG , 0x0e ) ; / / ?
nrf . setCmd (FLUSH_TX ) ;
nrf . setData (data , psize ) ;
Source Codes 55
ceHi ( ) ;
delayMicroseconds (10) ;
ceLow ( ) ;
}
vo id setup ( )
{
Serial . begin (1000000) ;
nrf . init ( ) ;
nrf . configure (URX_ADDR , UTX_ADDR , RF_CHANNEL , PL_SIZE ) ;
nrf . stateStandbyI ( ) ;
Wire . begin ( ) ;
i2cSetRegister (AccID , 0x20 , B00111111 ) ; / / I n i t i a l i z e a t 1000 Hz
i2cSetRegister (AccID , 0x23 , B00000000 ) ; / / From −6g to +6g . g=5461.3 f ;
i2cSetRegister (GyroID , R62 ) ;
i2cSetRegister (GyroID , R22 ) ;
}
byte stat = B00001110 ;
i n t i = 0;
vo id loop ( ) {
unsigned long time = millis ( ) ;
/ / i n t acc [ 3 ] = { i , i *10 , i *100} ;
i n t x , y , z , i , j , k , t ;
/ / i ++;
/ / x = i ;
/ / i f ( i > 100) i = 0 ;
x=i2cGetValue (AccID , AccX ) ;
y=i2cGetValue (AccID , AccY ) ;
z=i2cGetValue (AccID , AccZ ) ;
i=i2cGetValue (GyroID , GyroX ) ;
j=i2cGetValue (GyroID , GyroY ) ;
k=i2cGetValue (GyroID , GyroZ ) ;
t=i2cGetValue (GyroID , Temp ) ;
/ / delay (10) ;
/ /
i n t acc [ 7 ] = {x , y , z , i , j , k , t} ;
/ * S e r i a l . p r i n t ( acc [ 0 ] ) ;
S e r i a l . p r i n t ( ” , ” ) ;
S e r i a l . p r i n t ( acc [ 1 ] ) ;
S e r i a l . p r i n t ( ” , ” ) ;
S e r i a l . p r i n t ( acc [ 2 ] ) ;
S e r i a l . p r i n t l n ( ) ;
* /
sendd ( ( byte * )&acc , 14) ;
wh i le ( ! ( ( nrf . getReg (STATUS ) & ( ( 1 << TX_DS ) | (1 << MAX_RT ) ) ) ) )
{}
/ / n r f . printSTATUS ( ) ;
/ / ceLow ( ) ;
nrf . setReg (STATUS , ( 1 << TX_DS ) | (1 << MAX_RT ) ) ;
/ / n r f . printSTATUS ( ) ;
/ / n r f . setReg (CONFIG, 0x0F ) ;
/ / delay ( 2 ) ;
/ / ceHi ( ) ; * /
Serial . println (millis ( )−time ) ;
}
56 Design and implementation of a femto-satellite technology demonstrator
C.7 AWIP RF Link Library, Source Code
In order to use files mentioned below correctly with the Arduino environment it is neces-
sary to create a folder with them called AWIPRF and then locate it in the libraries folder
of the Arduino. The library consists of the following files:
AWIPRF.h, the header file
# i f n d e f AWIPRF H
# def ine AWIPRF H
# inc lude <WProgram . h>
# inc lude ” nRF24L01p . h ”
# de f ine pCE 10
# def ine pCSN 9
# def ine SOFT MOSI 6
# de f ine SOFT MISO 5
# def ine SOFT SCK 7
# def ine ceHi ( ) { d i g i t a l W r i t e (pCE, HIGH) ; }
# def ine ceLow ( ) { d i g i t a l W r i t e (pCE, LOW) ; }
# def ine csnLow ( ) { d i g i t a l W r i t e (pCSN, LOW) ; }
# def ine csnHi ( ) { d i g i t a l W r i t e (pCSN, HIGH) ; }
# def ine AWIP CONFIG ((1<<EN CRC) | (0<<CRCO) )
c lass AWIP_nRF24L01 {
p u b l i c :
AWIP_nRF24L01 ( ) {} ;
vo id init ( ) ;
/ / BASIC FUNCTIONS
uint8_t setCmd (uint8_t reg ) ;
uint8_t setReg (uint8_t reg , uint8_t value ) ;
uint8_t setReg (uint8_t reg , uint8_t * value , uint8_t len ) ;
uint8_t getReg (uint8_t reg ) ;
uint8_t getReg (uint8_t reg , uint8_t * value , uint8_t len ) ;
/ /ADVANCED, TESTING
uint8_t tx_payload (uint8_t * data , uint8_t len , boolean transmit ) ;
uint8_t setData (uint8_t * data , uint8_t len ) ;
uint8_t getData (uint8_t * data , uint8_t len ) ;
bool dataReady ( ) ;
vo id configure (uint8_t * myaddr , uint8_t * addr , uint8_t channel , uint8_t pl_size ) ;
vo id stateStandbyI ( ) ;
p r i v a t e :
/ /LOW LEVEL
uint8_t softSpiSend (uint8_t data ) ;
vo id transferSync (uint8_t *dataout , uint8_t *datain , uint8_t len ) ;
vo id transmitSync (uint8_t *dataout , uint8_t len ) ;
} ;
ex tern AWIP_nRF24L01 nrf ;
# end i f / * AWIPRF H * /
Source Codes 57
AWIPRF.cpp,the source file
/ *
BLA BLA BLA
* /
# inc lude ”AWIPRF. h ”
AWIP_nRF24L01 nrf = AWIP_nRF24L01 ( ) ;
vo id AWIP_nRF24L01 : : init ( )
{
pinMode (SOFT_MOSI , OUTPUT ) ;
pinMode (SOFT_MISO , INPUT ) ;
pinMode (SOFT_SCK , OUTPUT ) ;
digitalWrite (SOFT_MOSI , LOW ) ;
digitalWrite (SOFT_SCK , LOW ) ;
pinMode (pCE , OUTPUT ) ;
pinMode (pCSN , OUTPUT ) ;
ceLow ( ) ;
csnHi ( ) ;
}
/ *←↩
===============================================================================================←↩
LOW LEVEL
===============================================================================================←↩
* /
uint8_t AWIP_nRF24L01 : : softSpiSend (uint8_t data )
{
uint8_t buff = 0;
f o r ( i n t i = 7; i>=0; i−−)
{
digitalWrite (SOFT_MOSI , (data>>i&1) ) ;
digitalWrite (SOFT_SCK , HIGH ) ;
buff =buff | ( ( digitalRead (SOFT_MISO ) &1)<<i ) ;
digitalWrite (SOFT_SCK , LOW ) ;
}
r e t u r n buff ;
}
vo id AWIP_nRF24L01 : : transferSync (uint8_t *dataout , uint8_t *datain , uint8_t len ){
uint8_t i ;
f o r (i = 0;i < len ; i++){
datain [ i ] = softSpiSend (dataout [ i ] ) ;
}
}
vo id AWIP_nRF24L01 : : transmitSync (uint8_t *dataout , uint8_t len ){
uint8_t i ;
f o r (i = 0;i < len ; i++){
softSpiSend (dataout [ i ] ) ;
}
}
/ *←↩
===============================================================================================←↩
BASIC FUNCTIONS
===============================================================================================←↩
* /
uint8_t AWIP_nRF24L01 : : setCmd (uint8_t reg )
{
csnLow ( ) ;
status = softSpiSend (reg ) ;
csnHi ( ) ;
r e t u r n status ;
}
uint8_t AWIP_nRF24L01 : : setReg (uint8_t reg , uint8_t value )
{
58 Design and implementation of a femto-satellite technology demonstrator
csnLow ( ) ;
status = softSpiSend (W_REGISTER | (REGISTER_MASK & reg ) ) ;
softSpiSend (value ) ;
csnHi ( ) ;
r e t u r n status ;
}
uint8_t AWIP_nRF24L01 : : setReg (uint8_t reg , uint8_t * value , uint8_t len )
{
uint8_t stat = 0;
csnLow ( ) ;
status = softSpiSend (W_REGISTER | (REGISTER_MASK & reg ) ) ;
transmitSync (value , len ) ;
csnHi ( ) ;
r e t u r n status ;
}
uint8_t AWIP_nRF24L01 : : getReg (uint8_t reg )
{
uint8_t stat = 0;
csnLow ( ) ;
status = softSpiSend (R_REGISTER | (REGISTER_MASK & reg ) ) ;
stat = softSpiSend (reg ) ;
csnHi ( ) ;
r e t u r n stat ;
}
uint8_t AWIP_nRF24L01 : : getReg (uint8_t reg , uint8_t * value , uint8_t len )
{
uint8_t stat = 0;
csnLow ( ) ;
status = softSpiSend (R_REGISTER | (REGISTER_MASK & reg ) ) ;
transferSync (value , value , len ) ;
csnHi ( ) ;
r e t u r n status ;
}
/ *←↩
===============================================================================================←↩
ADVANCED, TESTING
===============================================================================================←↩
* /
uint8_t AWIP_nRF24L01 : : setData (uint8_t * data , uint8_t len )
{
csnLow ( ) ;
status = softSpiSend (W_TX_PAYLOAD ) ;
transmitSync (data , len ) ;
csnHi ( ) ;
}
uint8_t AWIP_nRF24L01 : : getData (uint8_t * data , uint8_t len )
{
csnLow ( ) ;
status = softSpiSend (R_RX_PAYLOAD ) ;
transferSync (data , data , len ) ;
csnHi ( ) ;
setReg (STATUS , (1<<RX_DR ) ) ;
}
bool AWIP_nRF24L01 : : dataReady ( )
{
byte tmp = getReg (STATUS ) ;
i f ( status & (1 << RX_DR ) ) r e t u r n 1 ;
byte fifoStatus = getReg (FIFO_STATUS ) ;
r e t u r n ! ( fifoStatus & (1 << RX_EMPTY ) ) ;
}
vo id AWIP_nRF24L01 : : configure (uint8_t * myaddr , uint8_t * addr , uint8_t channel , uint8_t pl_size←↩
)
{
ceLow ( ) ;
Source Codes 59
setReg (RX_ADDR_P0 , addr , 5) ;
setReg (RX_ADDR_P1 , myaddr , 5) ;
setReg (TX_ADDR , addr , 5) ;
setReg (EN_AA , 0x03 ) ; / / auto ack enabled f o r both rx pipes 0 and 1
setReg (EN_RXADDR , 0x03 ) ; / / both pipes P0 and P1 are enabled to rec ieve
setReg (RX_PW_P0 , pl_size ) ;
setReg (RX_PW_P1 , pl_size ) ;
setReg (SETUP_RETR , 0x1A ) ;
setReg (RF_CH , channel ) ;
setReg (RF_SETUP , 0x07 ) ;
}
vo id AWIP_nRF24L01 : : stateStandbyI ( )
{
ceLow ( ) ;
setReg (CONFIG , 0x0E ) ;
delayMicroseconds (130) ;
}
uint8_t AWIP_nRF24L01 : : tx_payload (uint8_t * data , uint8_t len , boolean transmit )
{
csnLow ( ) ;
status = softSpiSend (W_TX_PAYLOAD ) ;
transmitSync (data , len ) ;
csnHi ( ) ;
i f (transmit == t rue ){
ceHi ( ) ;
delayMicroseconds (100) ;
ceLow ( ) ;
}
r e t u r n status ;
}
nRF24L01p.h, the file that contains device-specific constants
/ * Memory Map * /
# de f ine CONFIG 0x00
# def ine EN AA 0x01
# def ine EN RXADDR 0x02
# def ine SETUP AW 0x03
# def ine SETUP RETR 0x04
# def ine RF CH 0x05
# def ine RF SETUP 0x06
# def ine STATUS 0x07
# def ine OBSERVE TX 0x08
# def ine CD 0x09
# def ine RX ADDR P0 0x0A
# def ine RX ADDR P1 0x0B
# def ine RX ADDR P2 0x0C
# def ine RX ADDR P3 0x0D
# def ine RX ADDR P4 0x0E
# def ine RX ADDR P5 0x0F
# def ine TX ADDR 0x10
# def ine RX PW P0 0x11
# def ine RX PW P1 0x12
# def ine RX PW P2 0x13
# def ine RX PW P3 0x14
# def ine RX PW P4 0x15
# def ine RX PW P5 0x16
# def ine FIFO STATUS 0x17
/ * B i t Mnemonics * /
# de f ine MASK RX DR 6
# def ine MASK TX DS 5
# def ine MASK MAX RT 4
# def ine EN CRC 3
# def ine CRCO 2
# def ine PWR UP 1
# def ine PRIM RX 0
60 Design and implementation of a femto-satellite technology demonstrator
# def ine ENAA P5 5
# def ine ENAA P4 4
# def ine ENAA P3 3
# def ine ENAA P2 2
# def ine ENAA P1 1
# def ine ENAA P0 0
# def ine ERX P5 5
# def ine ERX P4 4
# def ine ERX P3 3
# def ine ERX P2 2
# def ine ERX P1 1
# def ine ERX P0 0
# def ine AW 0
# def ine ARD 4
# def ine ARC 0
# def ine PLL LOCK 4
# def ine RF DR 3
# def ine RF PWR 1
# def ine LNA HCURR 0
# def ine RX DR 6
# def ine TX DS 5
# def ine MAX RT 4
# def ine RX P NO 1
# def ine TX FULL 0
# def ine PLOS CNT 4
# def ine ARC CNT 0
# def ine TX REUSE 6
# def ine FIFO FULL 5
# def ine TX EMPTY 4
# def ine RX FULL 1
# def ine RX EMPTY 0
/ * I n s t r u c t i o n Mnemonics * /
# de f ine R REGISTER 0x00
# def ine W REGISTER 0x20
# def ine REGISTER MASK 0x1F
# def ine R RX PAYLOAD 0x61
# def ine W TX PAYLOAD 0xA0
# def ine FLUSH TX 0xE1
# def ine FLUSH RX 0xE2
# def ine REUSE TX PL 0xE3
# def ine NOP 0xFF
Source Codes 61
C.8 AWIP RF Link Test with GPS payload, RX role
The desired baudrate may be selected in the de f ine section. The channel number, local
and remote addresses, desired CRC and ACK modes as well as data-rate and payload
type are setup and may be redefined if needed in the de f ine section of the code.
# inc lude <AWIPRF. h>
# inc lude <nRF24L01p . h>
# def ine LOCAL ADDR ” AWsrv ” / / must be 5 bytes
# de f ine REMOTE ADDR ”AWIP0” / / t a r g e t addr , must be 5 bytes
# de f ine RF CHANNEL 73 / / Freq = 2400 + RF CHANNEL and always < 2525 , MHz
# def ine PL SIZE 32 / / Payload packet s ize , must be same f o r both boards
vo id setup ( )
{
Serial . begin (115200) ;
nrf . init ( ) ; / / i n i t i a l i z e the p in modes and p u l l−ups
nrf . configure ( ( byte * ) LOCAL_ADDR , (byte * ) REMOTE_ADDR , RF_CHANNEL , PL_SIZE ) ;
nrf . setReg (EN_AA , 0x00 ) ;
nrf . setReg (SETUP_RETR , 0x00 ) ;
nrf . setReg (RF_SETUP , B00100111 ) ;
nrf . stateStandbyI ( ) ;
nrf . setReg (CONFIG , 0x0F ) ;
delayMicroseconds (130) ;
ceHi ( ) ;
Serial . println ( ” Last known s ta tus i s : ” ) ;
nrf . printSTATUS ( ) ; nrf . printCONFIG ( ) ;
Serial . println ( ” L i s t e n i n g s t a r t e d . . . ” ) ;
}
byte stat = B00001110 ;
vo id loop ( ) {
/ / ceHi ( ) ;
char buff [ PL_SIZE ] ;
i f (nrf . dataReady ( ) )
{
/ / ceLow ( ) ;
nrf . getData ( ( byte * ) &buff , PL_SIZE ) ;
/ / f o r ( i n t i = 0 ; i < PL SIZE ; i ++) S e r i a l . p r i n t ( b u f f [ i ] ) ;
f o r (byte i = 0; i < PL_SIZE ; i++) Serial . print (buff [ i ] , BYTE ) ;
}
}
C.9 AWIP RF Link Test with GPS payload, TX role
The desired baudrate may be selected in the de f ine section. The channel number, local
and remote addresses, desired CRC and ACK modes as well as data-rate and payload
source are setup and may be redefined if needed in the de f ine section of the code.
# inc lude <AWIPRF. h>
# inc lude <nRF24L01p . h>
# def ine URX ADDR ( byte * ) ”AWIP0”
62 Design and implementation of a femto-satellite technology demonstrator
# def ine UTX ADDR ( byte * ) ” AWsrv ”
# de f ine RF CHANNEL 73
# def ine PL SIZE 32
boolean sendd (byte* data , byte psize ){
/ / byte s t a t = n r f . getReg (STATUS) ;
/ / i f ( ( s t a t & ( ( 1 << TX DS) | (1 << MAX RT) ) ) ) r e t u r n f a l s e ;
ceLow ( ) ;
nrf . setReg (CONFIG , 0x0e ) ; / / ?
nrf . setCmd (FLUSH_TX ) ;
nrf . setData (data , psize ) ;
ceHi ( ) ;
delayMicroseconds (10) ;
ceLow ( ) ;
}
byte buff [ PL_SIZE ] ;
vo id setup ( )
{
Serial . begin (4800) ;
nrf . init ( ) ;
nrf . configure (URX_ADDR , UTX_ADDR , RF_CHANNEL , PL_SIZE ) ;
nrf . setReg (EN_AA , 0x00 ) ;
nrf . setReg (SETUP_RETR , 0x00 ) ;
nrf . setReg (RF_SETUP , B00100111 ) ;
nrf . stateStandbyI ( ) ;
/ * f o r ( i n t i =0; i<PL SIZE ; i ++){ / / I n i t i a l i z e a b u f f e r f o r rece ived data
b u f f [ i ] = ' ' ;
} * /
}
byte stat = B00001110 ;
vo id loop ( ) {
i n t count = 0;
wh i le (count < PL_SIZE )
{
i f (Serial . available ( ) > 0)
{
buff [ count ] = byte (Serial . read ( ) ) ;
mcount++;
}
}
sendd ( ( byte * )&buff , PL_SIZE ) ;
wh i le ( ! ( ( nrf . getReg (STATUS ) & ( ( 1 << TX_DS ) | (1 << MAX_RT ) ) ) ) )
{}
nrf . setReg (STATUS , ( 1 << TX_DS ) | (1 << MAX_RT ) ) ;
}
