Development of a Cost-e ffi cient Autonomous MAV for an Unstructured Indoor Environment 1 Serge Kernbach, 2 Kristof Jebens 1 , 2 Institute Parallel and Distributed Systems, University of Stuttgart, Universit ̈ atstr. 38, 70569 Stuttgart, Germany 1 serge.kernbach@ipvs.uni-stuttgart.de , 2 former member of the institute Abstract — Performing rescuing and surveillance opera- tions with autonomous ground and aerial vehicles become more and more apparent task. Involving unmanned robot systems allows making these operations more e ffi cient, safe and reliable especially in hazardous areas. This work is devoted to the development of a cost-e ffi cient micro aerial vehicle in a quadrocopter shape for developmental pur- poses within indoor scenarios. It has been constructed with o ff -the-shelf components available for mini helicopters. Additional sensors and electronics are incorporated into this aerial vehicle to stabilize its flight behavior and to provide a capability of an autonomous navigation in a partially unstructured indoor environment. I. I ntroduction Collective robotics is a young research field, which is devoted to di ff erent ground, aerial and underwater systems [1]. Advantages of collective robotic are a high reliability, extended spatial properties, collective e ffi - ciency, which define application fields such as search and rescue operations, environmental monitoring or surveillance scenarios [2]. Especial attention is paid to micro aerial vehicles (MAV) due to their small size, low cost and a potential of creating a large-scale system [3]. The goal of this work is to develop an autonomous cost-e ffi cient MAV, which is capable of indoor flight in a partially unstructured environment. MAVs have several advantages over ground vehicles due to their capability of passing objects in the third dimension rather than finding a suitable 2D route around an obstacle. This feature considerably improves the use of autonomous vehicles and also decreases computational complexity and di ffi culty for maneuvering to a point of interest. Since a quadrocopter is like a Sikorsky helicopter 1 a very instable aerial vehicle, it needs several stabi- lization mechanisms, which always keep the vehicle in the upright position [4]. Without a kind of stabilization the MAV flights quickly towards one direction and can flip in the air. A very simple stabilization can be accomplished using two gyroscope sensors one for the nick and one for the roll axis with two independent PID 2 controllers to minimize the angular velocity [5]. 1 Named after Igor Sikorsky; developer of helicopter with single main and tail rotor 2 Proportional-integral-derivative controller (PID controller) Although this kind of regulation provides relatively stable flight there are many complex enhancements possible. Since this work originates from the swarm devel- opment [6] (see more in [7]), many technologies and ideas from Jasmine platform is used here [8]. For the MAV development we utilized two additional sensors such as gyroscope and ultrasonic sensors for the flight stabilization [9] and analyzing the surrounding en- vironment. Therefore sensor reliability is imperative, because false readings could result in unavoidable crashes, leading to damages. In further developments the concept of collective embodiment will be used [10] as well as more complex sensors such as cameras [11], however they require powerful on-board hardware to react quickly. Depending on the task, the computational require- ments are important for an autonomous flight since reaction times are essentially shorter than for ground vehicles. Additionally, the micro controller has to per- form various time-critical tasks in on-board and on- line manner [12], such as e.g. decision making [13] and a flight stabilization. Here, an application of a low-complex numerical approaches [14] for decision making and planning [15], [16] is required. This work is organized in the following way. Firstly, in Sec. II we shortly describe the developed hardware and software system. Sec. III is devoted to encountered problems, which required a special attention in further development. Finally, several performed experiments are demonstrated in Sec. IV and we conclude this work in Sec. V. II. H ardware and S oftware The hardware design of the MAV [17] corresponds to the state of the art approaches for the quadrocopter- type of the aerial vehicles. There are four bars with four motors attached to the respective end of the bars. The other ends are held together in the middle, so that two bars are perpendicular to the others. All electronic components should be located in the center since a cen- ter imbalance will have only minimal side e ff ects, see Fig. 1. Components in the outer regions will block parts of the propeller surface lowering energy e ffi ciency. The arXiv:1111.0500v1 [cs.RO] 2 Nov 2011 Fig. 1. Prototype of the MAV. bars attaching the motors also have an underestimated e ff ect on the flight properties: depending on the ma- terial it might suppress or increase vibrations induced by the motors. The weight of the bars will also have a much greater e ff ect on the torque inertia than masses located in the center. This quadrocopter has been designed using the fol- lowing components: • four 17cm aluminum pipes • four AXI 2254 brushless motors • two clock- / counterclock- wise propellers • four conrad brushless regulators • three ACT Micro Digital gyroscopes • one ADXL203 dual axis accelerometer • six SRF10 ultrasonic modules • two Jasmine mainboards with AT Mega168 micro controllers • one Graupner RC receiver • 3 Cell LiPo battery 1250 mAh Overall dimensions are 48 cm in diameter, maximum height in the center is about 10 cm. For the gyroscopes, the accelerometers and connections to the brushless regulators, ultrasonic modules, the RC receiver and two Jasmine mainboards holding the two micro controllers, a PCB was designed. The structure of the electronics is shown in Fig. 2. It was decided to use mainboards from the micro robots Jasmine [18] since they have proven to be a very stable platform in various experiments. Since we intend to study collective behavior of such MAVs [19], the already existing software for these mainboards can be re-used. As a result only the inputs and outputs had to be connected to these boards. The constructed mainboard provides a reliable platform for the core components and makes it possible to connect di ff erent sensor mod- Control micro-controller TWI Bus Gyroscope (3x separetly) Accelerometer RC receiver Sensing micro-controller TWI Bus Ultrasonic (6x seperately) Energy sensor PPM 4x PPM Brushless controller Micro-controller Brushless controller Micro-controller Brushless controller Micro-controller Brushless controller Micro-controller Micro-controller Micro-controller Micro-controller ADC ADC ADC Fig. 2. Structure of the electronics of the MAV. ules using TWI bus or switching to di ff erent receivers etc. The mainboard also has functionality to measure voltage level and current supplied by the battery. Especially the voltage measurement is highly advis- able since a deep discharge will permanently damage lithium polymer cells. Since it is rather di ffi cult to find clock and counter clockwise propellers, propellers from the model toy X-Ufo have been used. These propellers are relatively e ffi cient and due to their soft material not as dangerous as most other model propellers. The quadrocopter has been equipped with a Zig- Bee module for a wireless communication between a host computer. It allows observing flight parameters and their modification while being in the air. Since the ultrasonic modules are connected to the TWI any processor can directly control these modules. However, the second processor takes care of this task to reduce load on the control processor. The second processor performs calculations based on this information and just sends a suitable course correction command to the processor for flight control. So far calculations are limited to throttle commands dependent on the current height or roll commands if obstacles are in the way. For both calculations PID controllers are used. A. Providing stable flight On a macroscopic layer the first step can be seen as reading sensor signals, remote control commands and producing the suitable output for the brushless controllers. The output is calculated using three inde- pendent PID regulators for stabilizing the nick, roll and yaw axis. Assuming the model is symmetric. the nick and roll axis are stabilized using the same parameters. The Fig. 3 shows the roll gyroscope data during flight (red) and the corresponding course corrections (blue). Although this task is simple from a macroscopic point of view, the implementation on a micro controller Fig. 3. The roll gyroscope data during flight (red) and the corre- sponding course corrections (blue). is critical. Standard modeling components use pulse pause modulation (PPM) to provide signal informa- tion. In this case the RC receiver and gyroscopes will produce those signals and the brushless regulators are required to be controlled by PPM. To lower the com- plexity the gyroscope sensors were directly connected to the ADC ports of the micro controller. So there are four output PPM signals to be generated and four input PPM signals have to be read simultaneously. The input PPM signals from the RC receiver are the requested throttle, yaw, roll and nick commands. The input PPM signals are received 50 times per seconds resulting in 400 signal changes on the input ports per second. The output signals should be produced as quickly as possi- ble since they are directly responsible for the regulation frequency of the entire system. The maximum fre- quency for the brushless regulators however is reached when the low period is reduced to zero. In practical this refers to a regulation frequency with model brushless regulators of about 500 Hz . The di ffi culty is that 400 signal changes per second have to be measured with a precision of about 40 μ s and simultaneously about 3000 output signals with the same precision have to be produced. Additionally, the calculations for the PID regulation have to be performed simultaneously. The main di ffi culty is keeping the precision during all thinkable events. Worst case events are for example a signal change on an input port triggering an interrupt and four timer events, which determine a signal change for the output signals. It is imperative, that any critical calculation during such an event is performed quickly, while non critical calculations are delayed. Otherwise there would be unacceptable false measurements or incorrect output signals. B. Improving flight stability To improve the hovering capability a dual axis ac- celerometer ADXL203 from analog devices has been used. While hovering at one specific spot the data from the accelerometer can be used to stabilize the quadro- copter in an upright position. However, since transla- tional cannot be distinguished from gravitational accel- erations, a sensor fusion of gyroscopes and accelerom- eters is imperative. Additionally accelerometers tend to be very sensitive to vibrations - much more than gyroscopes. It has therefore been decided to implement a kalman filter, which estimates the current orientation based on the gyroscopes and accelerometers. Using this information the translational accelerations can be computed as well. Additional PID regulators can be implemented to further stabilize the position. III. P roblems A. Timing In contrast to ground vehicles timings are very crit- ical on board a quadrocopter, as several calculations have to be done in realtime. A delay would result in a crash. So for all actions the restrictions have to be care- fully considered. Timings are especially critical since several time relevant actions happen simultaneously. Among those are sensor signal changes which have to be evaluated between 100 and 1000 times per second. Steering commands using standard hardware require a signal analysis about 200 times per second. This is followed by the calculations, which produce the output signals for the four brushless regulators simultane- ously. Since those signal changes often have to be read and produced with considerable precision, other calcula- tions have to be carefully moved to free time slots. The simultaneous actions not only require a powerful hardware, but also careful prioritization of tasks. The opacity of simultaneous actions and reactions makes the programming a serious challenge and requires ex- act planing. B. Sensor data Sensor signals on board a quadrocopter can be di- vided into important time critical and additional sensor signals. Time critical sensor signals can further be pri- oritized. The most critical data comes from gyroscope sensors since a loss of signal will immediately result in a crash of the quadrocopter. Less important are accelerometers which can be used to compensate quite disturbing drift e ff ects of gyroscope sensors. A loss of accelerometers will result in a considerable, unno- ticeable drift in position. At slow speeds ultrasonic sensors can be considered as a low priority sensor system which only has to be updated several times per second. Naturally the time frame decreases with in- creased velocities of the quadrocopter. However, sensor losses or considerable false readings have to be handled with extreme care independent of the sensor priority, otherwise resulting in false actions. TABLE I E nergy consumption Component Energy consumption Weight in % motors 45W 26% gyroscopes 150mW 4% accelerometers 5mW 0.1% ultrasonic sensors 500mW 5% Jasmine mainboards 60mW 5% C. Energy The energy requirements on board a flying platform are considerably higher compared to ground vehicles. With currently available high power lithium polymer batteries flight times of about 45 minutes can be reached. However, strict optimizations are required. For further increased flight times the design of the en- tire flight platform would have to be changed, however helicopter platforms are all of similar e ffi ciency. In fact a quadrocopter is a rather energy e ffi cient helicopter platform due to the low weight. Ordinary Sikorsky helicopters need a far more complex hardware design, which results in an exceptionally energy expensive increased weight. In general apart from the propulsion e ffi ciency, all optimizations for overall energy con- sumption should almost solely be in the form of weight optimizations. An increased energy consumption of electronic components will normally be negligible in comparison to the increased propulsion energy needed to carry an additional gram. The high energy demand can be explained by the following formula: F = 3 √ 2 ∗ ρ ∗ A ∗ P 2 (1) where F refers to the thrust produced by an ideal propeller covering an area A driven at a shaft power P in a gas with density ρ [20]. In reality there are ad- ditional energy losses due to less than ideal propellers and energy e ffi ciency will especially for small motors often be below 80%. Probably the easiest factor for optimization, is the size of the propellers, if the overall size of the quadrocopter does not matter. The formula also describes that the thrust increases sublinear to the power input. Therefore any additional weight will be- come more expensive. Due to those weight restrictions all sensors not only have to be carefully chosen for their quality, but as an important factor also for their weight. If suitable miniaturized sensor and actuator modules are available, power demands decrease for small platforms, since F ∼ A 1 3 , F required = g ∗ m , where the mass m ∼ A 3 2 , however since energy reserves also decrease cubical, miniaturization is a very serious problem. D. Hardware interaction As in most complex systems there are various side e ff ects taking place. Those e ff ects can be divided into EMC (Electro Magnetic Compatibility) problems and interactions due to mechanical coupling. 1) EMC: Various problems di ffi cult to locate are re- lated to EMC problems. Since the problem is increased with high currents the on-board hardware has to be carefully designed to protect sensor signals and micro controller hardware. Without a proper EMC planing it will be impossible to have a well functioning MAV. It is problematic, because the motors are driven by a considerable current, which is not constant in nature. As a result the induced currents can be quite high in all kind of wires on the PCB. Electromagnetic waves can also disturb micro controllers and sensor modules. Additionally any on board wireless communication might be interfered. Due to the high load on the battery pack there will also be a drop in voltage depending on the flight maneuver. 2) Mechanical coupling: The second di ffi culty arises due to mechanical e ff ects. Since there are relatively strong forces and masses rotating at very high speeds the entire construction is vulnerable to strong vibra- tions. Those vibrations are responsible for serious false readings especially of accelerometers. It is therefore important to either lower the vibratory e ff ects or to filter the sensor data accordingly. A well function IMU (Inertia Measuring Unit) requires a rather powerful and optimized filtering to gain reliable information. IV. E xperiments Experiments have shown, that the software imple- mentation is critical on a microcontroller and that software errors can produce harmful e ff ects. The first reason is, that false measurements can for example result in a full throttle command although it has not been issued. Secondly, lost or delayed timer events will send a full throttle command to the brushless regulators. If such failures occur during flight time it will result in a serious crash or depending on the propellers can seriously harm human tissue. Therefore an eye protection has to be worn at all time. One has to consider that the maximum constant power of each motor is about 100W and that the peak power can be multiple times higher for a short period of time. Flight experiments have shown, that it is not trivial to adjust the PID parameters even to lift o ff the ground. If the parameters are too much from the actual values it is impossible to hold the quadrocopter even approx- imately at the same position, i.e. it will wildly perform unacceptable course corrections. It has however been found out, that it is possible to find flyable parameters using solely a PD regulator. However, adjusting the integral part considerably improves flight performance. Unfortunately those parameters cannot be optimized one by one since they influence each other. Natu- rally the regulation frequency is also an important factor. Experiments have shown, that increasing the fre- quency improved flight characteristics considerably up to 300 Hz . At such regulation frequencies the quadro- copter hovers extremely calm. Nevertheless, even a perfect trimming to the hover- ing position results in a relatively quick translational movement. Therefore the pilot has to perform constant course corrections. The situation makes it di ffi cult to implement an autonomous navigation. Further exper- iments have shown, that a PID regulation based on the estimated orientation using the data calculated from the kalman filter greatly improves flight stabil- ity. Holding a certain position becomes much easier, since the drift is reduced significantly. Although such a sensor combination is not able to absolutely hold a set position drift rates become so slow that a low speed sensor system can regularly move the MAV to its original position. This makes it much easier to navigate autonomously with for example ultrasonic sensors. Fig. 4. Quadrocopter during a flight. During the experiments the ZigBee module proved to provide an extremely robust communication be- tween a ground computer and the quadrocopter over an indoor distance of about 30 m . The data has been transmitted at a speed of 19200 baud . Changing reg- ulation parameters during flight proved to be very helpful. Finding stable parameters has been very time consuming and can now be accomplished in a matter of minutes. However, in several situations it is prudent to test a change in the regulation system, e.g. a limitation factor or a sudden regulation jump. Another advantage is, that that sensor data can be directly transmitted to a ground station for analysis. Otherwise, the data would have to be saved on board and later transmitted. Since the RAM is limited in size it does not serve as a solution. All in all, experiments have shown, that it is strongly advisable to use a wireless on-board solution. A. Flight at a Constant Height The experiment of a flight at a constant height, see Fig. 4, intends to demonstrate capabilities of sensor- data processing from the gyroscopes, accelerometers, ultrasonic sensors and the reactions sent to the brush- less controllers. Figs. 5(a)-5(f) show a flight in a rela- tively constant height referring to the ground over a chair. Fig. 5(g) shows the sensor data of the ultrasonic (a) (b) (c) (d) (e) (f) (g) Fig. 5. (a)-(f) Experiment with a flight at a constant height; (g) The measured height level. All images are from [17]. sensor captured during this flight. The flight over the chair can clearly be seen as a height drop of about 60 cm . The overall data is relatively smooth, the dis- tance fluctuations can also be seen in the experimental data. B. Collision avoidance Several additional ultrasonic sensor modules enable the quadrocopter to not only hold the height, but also to implement a 3D collision avoidance. For the first experiment only the roll axis was regulated by a sensor signal from one side. The PD regulation was able to keep the quadrocopter within a certain distance to the wall and by adding a sort of emergency factor it is very unlikely for a pilot to hit objects. However, it was not possible to find parameters holding a quadrocopter in any premature situation constant at a certain distance. When the aircraft approaches the wall too quickly, the used parameters were not good enough to keep it away from the wall unless there is a strong emergency factor involved. However, such an abrupt manoeuver intro- duces a rather chaotic flight behavior the next couple of seconds, which can only be secured by a human pilot. Fig. 6 demonstrates a human pilot roughly holds the distance to a nearby wall. The green line indicates the distance to the wall, the yellow the steering commands of the pilot. 0 50 100 150 200 250 −150 −100 −50 0 50 100 150 200 time axis distance/input commmands distance steering commands Fig. 6. Distance to a obstacle (nearby wall). The green line indicates the distance to the wall, the yellow the steering commands of the pilot Using six ultrasonic sensor modules pointing in all directions it should be possible to implement a 3D collision avoidance capable of navigating safely in an unstructured indoor environment. This kind of sensor system can be supported by a camera system, to further increase flight safety and to perform higher tasks. However, it has to be mentioned, that implementing a stable 3D collision avoidance requires careful param- eter tuning, otherwise the quadrocopter will perform flight maneuvers, which cannot be re-stabilized in time by ultrasonic sensors due to the relatively low update speed. C. Autonomous Flight Since flight performance has been tuned to a very sta- ble level, the next task was implementing an automatic flight control with the use of an ultrasonic module. The goal was a height control, permanently adjusting the throttle to stay at a given height level, and collision avoidance. Even in this experiment it turned out that finding suitable parameters is not trivial. Dramatic problems can occur due to faulty measurements. For example, the regulation needs to be turned o ff as soon as there is no signal received from the sensor module or the throttle will attain to a faulty value. Fig. 7 visualizes a height profile of start and landing. It can be seen that the values are quite often interrupted by zeros, which refer to invisibility errors. It is important to treat those values with care. Due to the tilt of the MAV during flight time, there occurs another problem of measuring the height by ultrasonic sensors. This produces a height measurement, which is diverted from the real value and is therefore dependent on the tilting value and also on the opening angle of the ultrasonic scanning beam. Fig. 7. Height profile of start and landing. It was possible to implement a reliable height control with a simple PD regulator. This is deactivated upon zero measurements and has a limited throttle adjust- ment, therefore requiring the pilot to roughly adjust the throttle. Without the D factor the quadrocopter will swing around the requested height. V. C onclusion This work has been done within several exploratory pilot projects for extension of ground swarms into underwater [21], reconfigurable [22] and aerial [17] dimensions with the goal to explore adaptive, self- organizing and evolutionary approaches in di ff erent embodiments. Several of these pilot projects results later in the research projects [23], [24], [25]. We successfully implemented the hard- and software of a cost-e ff ective MAV capable of a 3D obstacle de- tection and automatic course corrections. This work proved that the used sensors are enough to provide a random flight within a partially unstructured envi- ronment. For further miniaturization the energy is the most prohibiting factor. Current sensor modules based on MEMS technology enable a quadrocopter size of less than 10 cm in diameter. However, without dramatically reducing the weight it will be impossible to keep such helicopters in the air for long time periods. Future prototypes need to have an improved hardware design to counteract various software issues. Brushless con- trollers need to be controlled via a common bus system or ideally they all should be integrated on one board. Furthermore, a sensor system with an integrated bus system could lower noise e ff ects and rise overall flight performance. This could be achieved by using more enhanced micro controllers on board, which would also allow the use of additional software filters. Such a micro processor will also decrease software complexity for example by introducing the capability of threading. Especially with growing overall complexity, i.e. vision controlled flight, such a system is essential. Experiments have shown, that computational re- quirements are quite enormous on board a flying robot. Although most calculations are mathematically not too complex, they have to be performed hundreds of times per second. Especially when more complex regulation models are used, much more powerful micro con- trollers are imperative. Future prototypes are planned to be equipped with a micro controller at a speed beyond 100 MHz and capable of handling several interrupts in parallel. Such a processor will enable the quadrocopter for example to track other object based on visual information. R eferences [1] Serge Kernbach, editor. Handbook of Collective Robotics: Fun- damentals and Challenges . Pan Stanford Publishing, Singapore, 2011. [2] David Howden. Continuous swarm surveillance via distributed priority maps. In Proceedings of the 4th Australian Conference on Artificial Life: Borrowing from Biology , ACAL ’09, pages 221–231, Berlin, Heidelberg, 2009. Springer-Verlag. [3] Jean-Christophe Zu ff erey, Antoine Beyeler, and Dario Floreano. Autonomous flight at low altitude using light sensors and little computational power. International Journal of Micro Air Vehicles , 2(2):107–117, 2010. [4] P. McKerrow. Modelling the draganflyer four-rotor helicopter. In Robotics and Automation, 2004. Proceedings. ICRA ’04. 2004 IEEE International Conference on , volume 4, pages 3596 – 3601 Vol.4, 26-may 1, 2004. [5] A. Tayebi and S. McGilvray. Attitude stabilization of a vtol quadrotor aircraft. Control Systems Technology, IEEE Transactions on , 14(3):562 – 571, may 2006. [6] S. Kornienko, O. Kornienko, C. Constantinescu, M. Pradier, and P. Levi. Cognitive micro-agents: individual and collective per- ception in microrobotic swarm. In Proc. of the IJCAI-05 Workshop on Agents in real-time and dynamic environments, Edinburgh, UK , pages 33–42, 2005. [7] S. Kernbach. Structural Self-organization in Multi-Agents and Multi-Robotic Systems . Logos Verlag, Berlin, 2008. [8] S. Kornienko, O. Kornienko, and P. Levi. About nature of emergent behavior in micro-systems. In Proc. of the Int. Conf. on Informatics in Control, Automation and Robotics (ICINCO 2004), Setubal, Portugal , pages 33–40, 2004. [9] Young Soo Suh. Attitude estimation using low cost accelerom- eter and gyroscope. In Science and Technology, 2003. Proceedings KORUS 2003. The 7th Korea-Russia International Symposium on , volume 2, pages 423 –427 vol.2, july 2003. [10] S. Kornienko, O. Kornienko, and P. Levi. Swarm embodiment - a new way for deriving emergent behaviour in artificial swarms. In P.Levi and et al., editors, Autonome Mobile Systeme (AMS’05) , pages 25–32, 2005. [11] Tarek Hamel Robert Mahony, Sung-Han Cha. A coupled estima- tion and control analysis for attitude stabilisation of mini aerial vehicles. In Australasian Conference on Robotics and Automation ACRA, Auckland , volume 2, 2006. [12] L. K ̈ onig, K. Jebens, Serge Kernbach, and Paul Levi. Stability of on-line and on-board evolving of adaptive collective behavior. In Herman Bruyninckx, Libor Preucil, and Miroslav Kulich, editors, European Robotics Symposium 2008 , pages 293–302. 2008. [13] O. Kornienko, S. Kornienko, and P. Levi. Collective decision making using natural self-organization in distributed systems. In Proc. of Int. Conf. on Computational Intelligence for Modelling, Control and Automation (CIMCA’2001), Las Vegas, USA , pages 460–471, 2001. [14] P. Levi, M. Schanz, S. Kornienko, and O. Kornienko. Application of order parameter equation for the analysis and the control of nonlinear time discrete dynamical systems. Int. J. Bifurcation and Chaos , 9(8):1619–1634, 1999. [15] S. Kornienko, O. Kornienko, and P. Levi. Flexible manufacturing process planning based on the multi-agent technology. In Proc. of the 21st IASTED Int. Conf. on AI and Applications (AIA ’2003), Innsbruck, Austria , pages 156–161, 2003. [16] S. Kornienko, O. Kornienko, and P. Levi. Multi-agent repairer of damaged process plans in manufacturing environment. In Proc. of the 8th Conf. on Intelligent Autonomous Systems (IAS-8), Amsterdam, NL , pages 485–494, 2004. [17] K. Jebens. Development of a quadrocopter with autonomous 3D navigation capability . Diploma, University of Stuttgart, Germany, 2007. [18] S. Kornienko and O. Kornienko. IR-based communication and perception in microrobotic swarms. In IROS 2005, Edmonton, Canada , 2005. [19] S. Kornienko, O. Kornienko, and P. Levi. Generation of desired emergent behavior in swarm of micro-robots. In R. Lopez de Mantaras and L. Saitta, editors, Proc. of the 16th European conference on artificial intelligence (ECAI 2004), Valencia, Spain , pages 239–243. Amsterdam: IOS Press, 2004. [20] Helmut Schenk. Standschub von Propellern und Rotoren . http: // www.rc-network.de / magazin / artikel 02 / art 02- 0037 / Standschub.pdf, 2007. [21] AquaJelly. AquaJelly: An autonomously controlled artificial jellyfish . Festo AG & Co. KG, 2008. [22] S. Kernbach, L. Ricotti, J. Liedke, P. Corradi, and M. Rother- mel. Study of macroscopic morphological features of symbi- otic robotic organisms. In Proceedings of the workshop on self- reconfigurable robots, IROS08, Nice , pages 18–25, 2008. [23] Serge Kernbach, Eugen Meister, Florian Schlachter, Kristof Jebens, Marc Szymanski, Jens Liedke, Davide Laneri, Lutz Winkler, Thomas Schmickl, Ronald Thenius, Paolo Corradi, and Leonardo Ricotti. Symbiotic robot organisms: REPLICATOR and SYMBRION projects. In Proceedings of the 8th Workshop on Performance Metrics for Intelligent Systems , PerMIS ’08, pages 62– 69, New York, NY, USA, 2008. ACM. [24] Paul Levi and Serge Kernbach, editors. Symbiotic Multi-Robot Organisms: Reliability, Adaptability, Evolution . Springer Verlag, 2010. [25] CoCoRo. Collective Cognitive Robots, FP7 . European Communi- ties, 2011-2013.