Handbook of Neuroevolution Through Erlang Gene I. Sher Handbook of Neuroevolution Through Erlang Gene I. Sher Department of Electrical Engineering and Computer Science University of Central Florida Orlando, FL, USA ISBN978-1-4614-4462-6 ISBN9 78-1-4614-4463-3 (eBook) DOI10.1007/978-1-4614-4463-3 Springer New York Heidelberg Dordrecht London Library of Congress Control Number: 2012941276 © Springer Science+Business Media New York 2013 This work is subject to copyright. All rights are reserved by the Publisher, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, reuse of illustrations, recitation, broadcasting, reproduction on microfilms or in any other physical way, and transmission or information storage and retrieval, electronic adaptation, computer software, or by similar or dissimilar methodology now known or hereafter developed. Exempted from this legal reservation are brief excerpts in connection with reviews or scholarly analysis or material supplied specifically for the purpose of being entered and executed on a computer system, for exclusive use by the purchaser of the work. Duplication of this publication or parts thereof is permitted only under the provisions of the Copyright Law of the Publisher’s location, in its current version, and permission for use must always be obtained from Springer. Permissions for use may be obtained through RightsLink at the Copyright Clearance Center. Violations are liable to prosecution under the respective Copyright Law. The use of general descriptive names, registered names, trademarks, service marks, etc. in this publication does not imply, even in the absence of a specific statement, that such names are exempt from the relevant protective laws and regulations and therefore free for general use. While the advice and information in this book are believed to be true and accurate at the date of publication, neither the authors nor the editors nor the publisher can accept any legal responsibility for any errors or omissions that may be made. The publisher makes no warranty, express or implied, with respect to the material contained herein. Printed on acid-free paper Springer is part of Springer Science+Business Media (www.springer.com) Foreword by Joe Armstrong I was delighted to be asked to write a foreword to Gene Sher’s book on Neuroevolution. To be honest I didn’t have a clue what Neuroevolution was before I started reading his manuscript, but the more I read the more I became engaged in the con- tent. Gene addresses what is a fascinating problem: How can we simulate a biologi- cal system in a computer. Can we make a system that learns from its mistakes? Gene chose to program his system in Erlang, which is where I come in. Erlang was designed over twenty five years ago to solve a completely different problem. What we were trying to do at the time and we are still trying, is to make a lan- guage for programming extremely large systems that never stop. Our application was telephony. We wanted to write the control software for a set of large telephone exchanges. This software should in principle run forever. The telephone networks span the planet, and the control systems for these net- works were running before the invention of the computer. Any system like this must be able to tolerate both software and hardware fail- ures, and thus we built a programming language where failures were not a prob- lem. Our approach was to say, “well if something crashes, some other part of the system will detect the error, fix the problem and the system as a whole will not fail.” We also thought that such a system should evolve and change with time. It would never be the case that the software in the system would be correct, right from the start, instead we would have to change the software many times during the life of the product. And we would also have to make these changes without stopping the system. The view of the world that Erlang presents the programmer is intrinsically dis- tributed, intrinsically changing and capable of self-repair. Neuroevolution was far from our thoughts. Twenty years later Gene comes along and discovers Erlang - to him, Erlang processes are neurons. Well of course Erlang processes are not neurons, but they can easily be programmed to behave like neurons. v vi Foreword Erlang was designed to scale. So today we can run a few million processes per node, and a few dozen nodes per chip. Computer architectures have changed from the single core Von-Neumann machine, to the multicore processor, and the archi- tectures will change again. Nobody actually knows how they are going to change, but my bet is that the change will be towards network-on-chip architectures. We’re already talking about putting a few hundred to a thousand cores on a single chip, but for this to happen we have to move to network on chip architec- tures. We can imagine large regular matrices of CPUs connected into a regular switching infrastructure. So we’ll soon end up with thousands of cores, each capa- ble of running millions of Erlang processes. What will we do with such a monster computer and how are we going to pro- gram it? Well I suspect Gene has an answer to this question; he’ll want to build a brain. This book will tell you how. Will it work in the near future or will this take hundreds of years? Nobody knows, but the journey will be interesting and we might build some other useful things on the way. Joe Armstrong Stockholm Dedication To my father Ilya Aleksandrovich Sher To my mother Zinaida Lvovna Sher Preface We biological organisms are fragile things. We are machines whose only armor is skin, a thin layer composed of lipids and proteins, easily damageable. The cells that make us up require constant nourishment, this nourishment is supplied by our blood, which itself easily and rapidly begins to leak when our thin shield is pene- trated. We can only exist in a very limited range of temperatures. 36.7 degrees Celsius is our standard, a few degrees above that and we are uncomfortable, a bit higher and our cells begin to die and our flesh suffers permanent damage. When our temperature drops below 36.7 by a few degrees Celsius, we too can begin to suffer permanent damage unless the temperature is raised again. We burn easily. Our sensory organs are limited, we see electromagnetic radiation in only a very narrow spectrum, between 400 and 800 THz. The same for pressure waves, sound, which we only perceive between 12 and 20000 Hz. Our actuators, how and where we can move are, once again, extremely limited. The maximum speed we can achieve on land, without mechanical assistance, is 44.72km/h (record by Usain Bolt), and only for a limited amount of time, in water 2.29 m/s (record by Tom Jager). We require a constant supply of energy, food and fluid, if we do not con- sume fluids for just a few days we die, we survive only a bit longer when left without food. We are mortal, decaying, with only a few decades of being func- tional, and that only if everything else goes perfectly right. We can study as much as we want, but at the end of the day we will still be lim- ited by our biological nature. Within our brains the signals propagate from neuron to neuron at a maximum speed of 120m/s, this cannot be improved much further. The best of our kind, Feynman, Newton, Gauss, Einstein... They are at the limit of what our specie can achieve, and yet even they are limited by time and what they can do with it. Because there is no longer an evolutionary push towards greater level of intelligence, evolution will not save us, we will not give birth to another biological specie with greater minds, and natural evolution is too slow in either case. Plus, let us be perfectly honest, the evolutionary pressure in our modern so- ciety is actually against intelligence, the Feynmans, Newtons and Einsteins of our world have less children on average than anyone else. But we have Science on our side, and through the application of the Scientific method we are hill climbing towards deeper knowledge and understanding of what we are, how we work, and most importantly, how to improve upon our condition. Make no mistake, there is absolutely nothing mystical about the human brain. It is but a vast graph of interconnected simple biological signal integrators. But though our brain is limited, the non biological based intelligence does not have to be so. Unlike a biological computer, the non biological one, its speed, the vastness ix x Preface and the complexity it can achieve, can all be improved and increased at the speed of technological evolution, which would be under its own control. The brain is complex, and we are actively trying to reverse engineer it [1]... so we are on our way. But even if we somehow won’t be able to reverse engineer our own brains, there is another approach to the creation of intelligence, by creating a new one using the basic elements that we know work, neurons, and through a process that we know works, evolution. We know that this method works, we are the proof of it. We are the proof that evolution works, that simple spatio-temporal signal processors evolved to be connected in vast topologies can produce intelligent systems. If we can supply the elements flexible enough, the environment complex enough, the evolutionary process dynamic enough, and enough computational power to simulate trillions of organisms... it will only be a matter of time... once again, we are the proof of that. [1] The Blue Brain Project EPFL, http://bluebrain.epfl.ch -Gene I. Sher