Turing learning: a metricfree approach to inferring behavior and its application to swarms
 10k Downloads
 4 Citations
Abstract
We propose Turing Learning, a novel system identification method for inferring the behavior of natural or artificial systems. Turing Learning simultaneously optimizes two populations of computer programs, one representing models of the behavior of the system under investigation, and the other representing classifiers. By observing the behavior of the system as well as the behaviors produced by the models, two sets of data samples are obtained. The classifiers are rewarded for discriminating between these two sets, that is, for correctly categorizing data samples as either genuine or counterfeit. Conversely, the models are rewarded for ‘tricking’ the classifiers into categorizing their data samples as genuine. Unlike other methods for system identification, Turing Learning does not require predefined metrics to quantify the difference between the system and its models. We present two case studies with swarms of simulated robots and prove that the underlying behaviors cannot be inferred by a metricbased system identification method. By contrast, Turing Learning infers the behaviors with high accuracy. It also produces a useful byproduct—the classifiers—that can be used to detect abnormal behavior in the swarm. Moreover, we show that Turing Learning also successfully infers the behavior of physical robot swarms. The results show that collective behaviors can be directly inferred from motion trajectories of individuals in the swarm, which may have significant implications for the study of animal collectives. Furthermore, Turing Learning could prove useful whenever a behavior is not easily characterizable using metrics, making it suitable for a wide range of applications.
Keywords
System identification Turing test Collective behavior Swarm robotics Coevolution Machine learning1 Introduction
System identification is the process of modeling natural or artificial systems through observed data. It has drawn a large interest among researchers for decades (Ljung 2010; Billings 2013). A limitation of current system identification methods is that they rely on predefined metrics, such as the sum of square errors, to measure the difference between the output of the models and that of the system under investigation. Model optimization then proceeds by minimizing the measured differences. However, for complex systems, defining a metric can be nontrivial and casedependent. It may require prior information about the systems. Moreover, an unsuitable metric may not distinguish well between good and bad models, or even bias the identification process. This paper overcomes these problems by introducing a system identification method that does not rely on predefined metrics.
A promising application of such a metricfree method is the identification of collective behaviors, which are emergent behaviors that arise from the interactions of numerous simple individuals (Camazine et al. 2003). Inferring collective behaviors is particularly challenging, as the individuals not only interact with the environment but also with each other. Typically, their motion appears stochastic and is hard to predict (Helbing and Johansson 2011). For instance, given a swarm of simulated fish, one would have to evaluate how close its behavior is to that of a real fish swarm, or how close the individual behavior of a simulated fish is to that of a real fish. Characterizing the behavior at the level of the swarm is difficult (Harvey et al. 2015). Such a metric may require domainspecific knowledge; moreover, it may not be able to discriminate among distinct individual behaviors that lead to similar collective dynamics (Weitz et al. 2012). Characterizing the behavior at the level of individuals is also difficult, as even the same individual fish in the swarm is likely to exhibit a different trajectory every time it is being looked at.
In this paper, we propose Turing Learning, a novel system identification method that allows a machine to autonomously infer the behavior of a natural or artificial system. Turing Learning simultaneously optimizes two populations of computer programs, one representing models of the behavior, and the other representing classifiers. The purpose of the models is to imitate the behavior of the system under investigation. The purpose of the classifiers is to discriminate between the behaviors produced by the system and any of the models. In Turing Learning, all behaviors are observed for a period of time. This generates two sets of data samples. The first set consists of genuine data samples, which originate from the system. The second set consists of counterfeit data samples, which originate from the models. The classifiers are rewarded for discriminating between samples of these two sets: Ideally, they should recognize any data sample from the system as genuine, and any data sample from the models as counterfeit. Conversely, the models are rewarded for their ability to ‘trick’ the classifiers into categorizing their data samples as genuine.
Turing Learning does not rely on predefined metrics for measuring how close the models reproduce the behavior of the system under investigation; rather, the metrics (classifiers) are produced as a byproduct of the identification process. The method is inspired by the Turing test (Turing 1950; Saygin et al. 2000; Harnad 2000), which machines can pass if behaving indistinguishably from humans. Similarly, the models could pass the tests by the classifiers if behaving indistinguishably from the system under investigation. We hence call our method Turing Learning.
In the following, we examine the ability of Turing Learning to infer the behavioral rules of a swarm of mobile agents. The agents are either simulated or physical robots. They execute known behavioral rules. This allows us to compare the inferred models to the ground truth. To obtain the data samples, we record the motion trajectories of all the agents. In addition, we record the motion trajectories of an agent replica, which is mixed into the group of agents. The replica executes the rules defined by the models—one at a time. As will be shown, by observing the motion trajectories of agents and of the agent replica, Turing Learning automatically infers the behavioral rules of the agents. The behavioral rules examined here relate to two canonical problems in swarm robotics: selforganized aggregation (Gauci et al. 2014c) and object clustering (Gauci et al. 2014b). They are reactive; in other words, each agent maps its inputs (sensor readings) directly onto the outputs (actions). The problem of inferring the mapping is challenging, as the inputs are not known. Instead, Turing Learning has to infer the mapping indirectly, from the observed motion trajectories of the agents and of the replica.

It presents an algorithmic description of Turing Learning;

It shows that Turing Learning outperforms a metricbased system identification method in terms of model accuracy;

It proves that the metricbased method is fundamentally flawed, as the globally optimal solution differs from the solution that should be inferred;

It demonstrates, to the best of our knowledge for the first time, that system identification can infer the behavior of swarms of physical robots;

It examines in detail the usefulness of the classifiers;

It examines through simulation how Turing Learning can simultaneously infer the agent’s brain (controller) and an aspect of its morphology that determines the agent’s field of view;

It demonstrates through simulation that Turing Learning can infer the behavior even if the agent’s control system structure is unknown.
2 Related work
This section is organized as follows. First, we outline our previous work on Turing Learning and review a similar line of research, which has appeared since its publication. As the Turing Learning implementation uses coevolutionary algorithms, we then overview work using coevolutionary algorithms (but with predefined metrics), as well as work on the evolution of physical systems. Finally, works using replicas in ethological studies are presented.
Turing Learning is a system identification method that simultaneously optimizes a population of models and a population of classifiers. The objective for the models is to be indistinguishable from the system under investigation. The objective for the classifiers is to distinguish between the models and the system. The idea of Turing Learning was first proposed in Li et al. (2013); this work presented a coevolutionary approach for inferring the behavioral rules of a single agent. The agent moved in a simulated, onedimensional environment. Classifiers were rewarded for distinguishing between the models and the agent. In addition, they were able to control the stimulus that influenced the behavior of the agent. This allowed the classifiers to interact with the agent during the learning process. Turing Learning was subsequently investigated with swarms of simulated robots (Li et al. 2014).
Goodfellow et al. (2014) proposed generative adversarial nets (GANs). GANs, while independently invented, are essentially based on the same idea as Turing Learning. The authors used GANs to train models for generating counterfeit images that resemble real images, for example, from the Toronto Face Database [for further examples, see (Radford et al. 2016)]. They simultaneously optimized a generative model (producing counterfeit images) and a discriminative model that estimates the probability of an image to be real. The optimization was done using a stochastic gradient descent method.
In a work reported in HerbertRead et al. (2015), humans were asked to discriminate between the collective motion of real and simulated fish. The authors reported that the humans could do so even though the data from the model were consistent with the real data according to predefined metrics. Their results “highlight a limitation of fitting detailed models to realworld data.” The authors argued that “observational tests [...] could be used to crossvalidate models” [see also Harel (2005)]. This is in line with Turing Learning. Our method, however, automatically generates both the models and the classifiers, and thus does not require human observers.
While Turing Learning can in principle be used with any optimization algorithm, our implementation relies on coevolutionary algorithms. Metricbased coevolutionary algorithms have already proven effective for system identification (Bongard and Lipson 2004a, b, 2005, 2007; Koos et al. 2009; Mirmomeni and Punch 2011; Le Ly and Lipson 2014). A range of work has been performed on simulated agents. Bongard and Lipson (2004a) proposed the estimation–exploration algorithm, a nonlinear system identification method to coevolve inputs and models in a way that minimizes the number of inputs to be tested on the system. In each generation, the input (test) that led, in simulation, to the highest disagreement between the models’ predicted outputs was carried out on the real system. The models’ predictions were then compared with the actual output of the system. The method was applied to evolve morphological parameters of a simulated quadrupedal robot after it had undergone physical damage. In a later work (Bongard and Lipson 2004b), the authors reported that “in many cases the simulated robot would exhibit wildly different behaviors even when it very closely approximated the damaged ‘physical’ robot. This result is not surprising due to the fact that the robot is a highly coupled, nonlinear system: Thus similar initial conditions [...] are expected to rapidly diverge in behavior over time.” The authors addressed this problem by using a more refined comparison metric reported in Bongard and Lipson (2004b). In Koos et al. (2009), an algorithm which also coevolves models and inputs (tests) was presented to model a simulated quadrotor and improve the control quality. The tests were selected based on multiple criteria: to provide disagreement between models as in Bongard and Lipson (2004a), and to evaluate the control quality in a given task. Models were then refined by comparing the predicted trajectories with those of the real system. In these works, predefined metrics were critical for evaluating the performance of models. Moreover, the algorithms are not applicable to the scenarios we consider here, as the system’s inputs are assumed to be unknown (the same would typically also be the case for biological systems).
Some studies also investigated the implementation of evolution directly in physical environments, on either a single robot (Floreano and Mondada 1996; Zykov et al. 2004; Bongard et al. 2006; Koos et al. 2013; Cully et al. 2015) or multiple robots (Watson et al. 2002; O’Dowd et al. 2014; Heinerman et al. 2015). In Bongard et al. (2006), a fourlegged robot was built to study how it can infer its own morphology through a process of continuous selfmodeling. The robot ran a coevolutionary algorithm on its onboard processor. One population evolved models for the robot’s morphology, while the other evolved actions (inputs) to be conducted on the robot for gauging the quality of these models. Note that this approach required knowledge of the robot’s inputs (sensor data). O’Dowd et al. (2014) presented a distributed approach to coevolve onboard simulators and controllers for a swarm of ten robots. Each robot used its simulators to evolve controllers for performing foraging behavior. The best performing controller was then used to control the physical robot. The foraging performances of the robot and of its neighbors were then compared to inform the evolution of simulators. This physical/embodied evolution helped reduce the reality gap between the simulated and physical environments (Jakobi et al. 1995). In all these approaches, the model optimization was based on predefined metrics (explicit or implicit).
The use of replicas can be found in ethological studies in which researchers use robots that interact with animals (Vaughan et al. 2000; Halloy et al. 2007; Faria et al. 2010; Halloy et al. 2013; Schmickl et al. 2013). Robots can be created and systematically controlled in such a way that they are accepted as conspecifics or heterospecifics by the animals in the group (Krause et al. 2011). For example, in Faria et al. (2010), a replica fish, which resembled sticklebacks in appearance, was created to investigate two types of interaction: recruitment and leadership. In Halloy et al. (2007), autonomous robots, which executed a model, were mixed into a group of cockroaches to modulate their decision making of selecting a shelter. The robots behaved in a similar way to the cockroaches. Although the robots’ appearance was different from that of the cockroaches, the robots released a specific odor such that the cockroaches would perceive them as conspecifics. In these works, the models were manually derived and the robots were only used for model validation. We believe that this robot–animal interaction framework could be enhanced through Turing Learning, which autonomously infers the collective behavior.
3 Methodology
In this section, we present the Turing Learning method and show how it can be applied to two case studies in swarm robotics.
3.1 Turing learning
Turing Learning is a system identification method for inferring the behavior of natural or artificial systems. Turing Learning needs data samples of the behavior—we refer to these data samples as genuine. For example, if the behavior of interest were to shoal like fish, genuine data samples could be trajectory data from fish. If the behavior were to produce paintings in a particular style (e.g., Cubism), genuine data samples could be existing paintings in this style.
Turing Learning simultaneously optimizes two populations of computer programs, one representing models of the behavior, and the other representing classifiers. The purpose of the models is to imitate the behavior of the system under investigation. The models are used to produce data samples—we refer to these data samples as counterfeit. There are thus two sets of data samples: one containing genuine data samples, and the other containing counterfeit ones. The purpose of the classifiers is to discriminate between these two sets. Given a data sample, the classifiers need to judge where it comes from. Is it genuine, and thus originating from the system under investigation? Or is it counterfeit, and thus originating from a model? This setup is akin of a Turing test; hence the name Turing Learning.
The models and classifiers are competing. The models are rewarded for ‘tricking’ the classifiers into categorizing their data samples as genuine, whereas the classifiers are rewarded for correctly categorizing data samples as either genuine or counterfeit. Turing Learning thus optimizes models for producing behaviors that are seemingly genuine, in other words, indistinguishable from the behavior of interest. This is in contrast to other system identification methods, which optimize models for producing behavior that is as similar as possible to the behavior of interest. The Turing test inspired setup allows for model generation irrespective of whether suitable similarity metrics are known.
The model can be any computer program that can be used to produce data samples. It must however be expressive enough to produce data samples that—from an observer’s perspective—are indistinguishable from those of the system.
Algorithm 1 provides a description of Turing Learning. We assume a population of \(M > 1\) models and a population of \(N > 1\) classifiers. After an initialization stage, Turing Learning proceeds in an iterative manner until a termination criterion is met.
In each iteration cycle, data samples are obtained from observations of both the system and the models. In the case studies considered here, the classifiers do not influence the sampling process. Therefore, the same set of data samples is provided to all classifiers of an iteration cycle.^{1} For simplicity, we assume that each of the N classifiers is provided with \(K \ge 1\) data samples for the system and with one data sample for every model.
3.2 Case studies
In the following, we examine the ability of Turing Learning to infer the behavioral rules of swarming agents. The swarm is assumed to be homogeneous; it comprises a set of identical agents of known capabilities. The identification task thus reduces to inferring the behavior of a single agent. The agents are robots, either simulated or physical. The agents have inputs (corresponding to sensor reading values) and outputs (corresponding to motor commands). The input and output values are not known. However, the agents are observed and their motion trajectories are recorded. The trajectories are provided to Turing Learning using a reactive control architecture (Brooks 1991). Evidence indicates that reactive behavioral rules are sufficient to produce a range of complex collective behaviors in both groups of natural and artificial agents (Braitenberg 1984; Arkin 1998; Camazine et al. 2003). Note that although reactive architectures are conceptually simple, learning their parameters is not trivial if the agent’s inputs are not available, as is the case in our problem setup. In fact, as shown in Sect. 4.5, a conventional (metricbased) system identification method fails in this respect.
3.2.1 Agents
Each agent is equipped with a lineofsight sensor that detects the type of item in front of it. We assume that there are n types [e.g., background, other agent, object (Gauci et al. 2014c, b)]. The state of the sensor is denoted by \(I\in \{0,1,\ldots ,n1\}\).
Aggregation: In this behavior, the sensor is binary, that is, \(n=2\). It gives a reading of \(I=1\) if there is an agent in the line of sight, and \(I=0\) otherwise. The environment is free of obstacles. The objective of the agents is to aggregate into a single compact cluster as fast as possible. Further details, including a validation with 40 physical epuck robots, are reported in Gauci et al. (2014c).
When \(I=0\), an agent moves backwards along a clockwise circular trajectory (\(v_{\ell 0} = 0.7\) and \(v_{r0} = 1.0\)). When \(I=1\), an agent rotates clockwise on the spot with maximum angular speed (\(v_{\ell 1} = 1.0\) and \(v_{r1} = 1.0\)). Note that, rather counterintuitively, an agent never moves forward, regardless of I. With this controller, an agent provably aggregates with another agent or with a quasistatic cluster of agents (Gauci et al. 2014c). Figure 2 shows snapshots from a simulation trial with 50 agents.
Object Clustering: In this behavior, the sensor is ternary, that is, \(n=3\). It gives a reading of \(I=2\) if there is an agent in the line of sight, \(I=1\) if there is an object in the line of sight, and \(I=0\) otherwise. The objective of the agents is to arrange the objects into a single compact cluster as fast as possible. Details of this behavior, including a validation using 5 physical epuck robots and 20 cylindrical objects, are presented in Gauci et al. (2014b).
When \(I=0\) and \(I=2\), the agent moves forward along a counterclockwise circular trajectory, but with different linear and angular speeds. When \(I=1\), it moves forward along a clockwise circular trajectory. Figure 3 shows snapshots from a simulation trial with 5 agents and 10 objects.
3.2.2 Models and replicas
We assume the availability of replicas, which must have the potential to produce data samples that—to an external observer (classifier)—are indistinguishable from those of the agent. In our case, the replicas have the same morphology as the agent, including identical lineofsight sensors and differential drive mechanisms.^{2}

In a gray box representation, the agent’s control system structure is assumed to be known. In other words, the model and the agent share the same control system structure, as defined in Eq. (5). This representation reduces the complexity of the identification process, in the sense that only the parameters of Eq. (5) need to be inferred. Additionally, this allows for an objective evaluation of how well the identification process performs, because one can compare the inferred parameters directly with the ground truth.

In a black box representation, the agent’s control system structure is assumed to be unknown, and the model has to be represented in a general way. In particular, we use a control system structure with memory, in the form of a neural network with recurrent connections (see Sect. 4.6.2).
3.2.3 Classifiers
The classifiers need to discriminate between data samples originating from the agents and ones originating from the replicas. We use the term individual to refer to either the agent or a replica executing a model.
A data sample comes from the motion trajectory of an individual observed for the duration of a trial. We assume that it is possible to track both the individual’s position and orientation. The sample comprises the linear speed (s) and angular speed \((\omega )\).^{3} Full details (e.g., trial duration) are provided in Sects. 4.2 and 5.3 for the cases of simulation and physical experiments, respectively.
3.2.4 Optimization algorithm
The optimization of models and classifiers is realized using an evolutionary algorithm. We use a \((\mu +\lambda )\) evolution strategy with selfadaptive mutation strengths (Eiben and Smith 2003) to optimize either population. As a consequence, the optimization consists of two processes, one for the model population, and another for the classifier population. The two processes synchronize whenever the solution qualities described in Sect. 3.1 are computed. The implementation of the evolutionary algorithm is detailed in Li et al. (2013).
For the remainder of this paper, we adopt terminology used in evolutionary computing and refer to the quality of solutions as their fitness and to iteration cycles as generations. Note that in coevolutionary algorithms, each population’s fitness depends on the performance of the other populations and is hence referred to as the subjective fitness. By contrast, the fitness measure as used in conventional evolutionary algorithms is referred to as the objective fitness.
3.2.5 Termination criterion
The algorithm stops after running for a fixed number of iterations.
4 Simulation experiments
In this section, we present the simulation experiments for the two case studies. Sections 4.1 and 4.2, respectively, describe the simulation platform and setups. Sections 4.3 and 4.4, respectively, analyze the inferred models and classifiers. Section 4.5 compares Turing Learning with a metricbased identification method and mathematically analyzes this latter method. Section 4.6 presents further results of testing the generality of Turing Learning through exploring different scenarios, which include: (i) simultaneously inferring the control of the agent and an aspect of its morphology; (ii) using artificial neural networks as a model representation, thereby removing the assumption of a known agent control system structure; (iii) separating the replicas and the agents, thereby allowing for a potentially simpler experimental setup; and (iv) inferring arbitrary reactive behaviors.
4.1 Simulation platform
We use the opensource Enki library (Magnenat et al. 2011), which models the kinematics and dynamics of rigid objects, and handles collisions. Enki has a builtin 2D model of the epuck. The robot is represented as a disk of diameter \(7.0\hbox { cm}\) and mass \(150\hbox { g}\). The interwheel distance is \(5.1\hbox { cm}\). The speed of each wheel can be set independently. Enki induces noise on each wheel speed by multiplying the set value by a number in the range (0.95, 1.05) chosen randomly with uniform distribution. The maximum speed of the epuck is \(12.8{\hbox { cm/s}}\), forwards or backwards. The lineofsight sensor is simulated by casting a ray from the epuck’s front and checking the first item with which it intersects (if any). The range of this sensor is unlimited in simulation.
In the object clustering case study, we model objects as disks of diameter \(10\hbox { cm}\) with mass \(35\hbox { g}\) and a coefficient of static friction with the ground of 0.58, which makes it movable by a single epuck.
The robot’s control cycle is updated every \(0.1\hbox { s}\), and the physics is updated every \(0.01\hbox { s}\).
4.2 Simulation setups
In all simulations, we use an unbounded environment. For the aggregation case study, we use groups of 11 individuals—10 agents and 1 replica that executes a model. The initial positions of individuals are generated randomly in a square region of sides \(331.66\hbox { cm}\), following a uniform distribution (average area per individual = \(10000\hbox { cm}^2\)). For the object clustering case study, we use groups of 5 individuals—4 agents and 1 replica that executes a model—and 10 cylindrical objects. The initial positions of individuals and objects are generated randomly in a square region of sides \(100\hbox { cm}\), following a uniform distribution (average area per object = \(1000\hbox { cm}^2\)). In both case studies, individual starting orientations are chosen randomly in \([\pi ,\pi )\) with uniform distribution.
We performed 30 runs of Turing Learning for each case study. Each run lasted 1000 generations. The model and classifier populations each consisted of 100 solutions (\(\mu = 50\), \(\lambda = 50\)). In each trial, classifiers observed individuals for \(10\hbox { s}\) at \(0.1\hbox { s}\) intervals (100 data points). In both setups, the total number of samples for the agents in each generation was equal to \(n_t \times n_a\), where \(n_t\) is the number of trials performed (one per model) and \(n_a\) is the number of agents in each trial.
4.3 Analysis of inferred models
We also investigate the evolutionary dynamics. Figure 5 shows how the model parameters converge over generations. In the aggregation case study (see Fig. 5a), the parameters corresponding to \(I=0\) are learned first. After around 50 generations, both \(v_{\ell 0}\) and \(v_{r0}\) closely approximate their true values (\(0.7\) and \(1.0\)). For \(I=1\), it takes about 200 generations for both \(v_{\ell 1}\) and \(v_{r1}\) to converge. A likely reason for this effect is that an agent spends a larger proportion of its time seeing nothing \((I=0)\) than seeing other agents \((I=1)\)—simulations revealed these percentages to be 91.2 and \(8.8\,\%\) respectively (mean values over 100 trials).
Although the inferred models approximate the agents well in terms of parameters, it is not uncommon in swarm systems that small changes in individual behavior lead to vastly different emergent behaviors, especially when using large numbers of agents (Levi and Kernbach 2010). For this reason, we evaluate the quality of the emergent behaviors that the models give rise to. In the case of aggregation, we measure dispersion of the swarm after some elapsed time as defined in Gauci et al. (2014c).^{5} For each of the 30 models with the highest subjective fitness in the final generation, we performed 30 trials with 50 replicas executing the model. For comparison, we also performed 30 trials using the agent [see Eq. (6)]. The set of initial configurations was the same for the replicas and the agents. Figure 6a shows the dispersion of agents and replicas after \(400\hbox { s}\). All models led to aggregation. We performed a statistical test^{6} on the final dispersion of the individuals between the agents and replicas for each model. There is no statistically significant difference in 30 out of 30 cases (tests with Bonferroni correction).
In the case of object clustering, we use the dispersion of the objects after \(400\hbox { s}\) as a measure of the emergent behavior. We performed 30 trials with 25 individuals and 50 objects for the agent and each model. The results are shown in Fig. 6b. In the final dispersion of objects by the agent or any of the models (replicas), there is no statistically significant difference in 26 out of 30 cases (tests with Bonferroni correction).
4.4 Analysis of generated classifiers
The primary outcome of the Turing Learning method (and of any system identification method) is the model, which has been discussed in the previous section. However, the generated classifiers can also be considered as a useful byproduct. For instance they could be used to detect abnormal agents in a swarm. We now analyze the performance of the classifiers. For the remainder of this paper, we consider only the aggregation case study.
We performed 10 trials using a set of initial configurations common to all classifiers. Figure 7 shows the average decision accuracy of the classifier with the highest subjective fitness during the evolution (best classifier (subjective)) in 30 runs of Turing Learning. The accuracy of the classifier increases in the first 5 generations, then drops, and fluctuates within range 62–\(80\,\%\). For a comparison, we also plot the highest decision accuracy that a single classifier achieved during the postevaluation for each generation. This classifier is referred to best classifier (objective). Interestingly, the accuracy of the best classifier (objective) increases almost monotonically, reaching a level above \(95\,\%\). To select the best classifier (objective), all the classifiers were postevaluated using the aforementioned 14641 models.
At first sight, it seems counterintuitive that the best classifier (subjective) has a low decision accuracy. This phenomenon, however, can be explained when considering the model population. We have shown in the previous section (see Fig. 5a) that the models converge rapidly at the beginning of the coevolutions. As a result, when classifiers are evaluated in later generations, the trials are likely to include models very similar to each other. Classifiers that become overspecialized to this small set of models (the ones dominating the later generations) have a higher chance of being selected during the evolutionary process. These classifiers may however have a low performance when evaluated across the entire model space.
Note that our analysis does not exclude the potential existence of models for which the performance of the classifiers degenerates substantially. As reported by Nguyen et al. (2015), welltrained classifiers, which in their case are represented by deep neural networks, can be easily fooled. For instance, the classifiers may label a randomlooking image as a guitar with high confidence. However, in this degenerate case, the image was obtained through evolutionary learning, while the classifiers remained static. By contrast, in Turing Learning, the classifiers are coevolving with the models, and hence have the opportunity to adapt to such a situation.
4.5 A metricbased system identification method: mathematical analysis and comparison with Turing Learning
4.5.1 Mathematical analysis
We begin our analysis by first analyzing an abstract version of the problem.
Theorem 1
Consider two binary random variables X and Y. Variable X takes value \(x_1\) with probability p, and value \(x_2\), otherwise. Variable Y takes value \(y_1\) with the same probability p, and value \(y_2\), otherwise. Variables X and Y are assumed to be independent of each other. Assuming \(y_1\) and \(y_2\) are given, then the metric \(D={\mathbb {E}}\{(XY)^2\}\) has a global minimum at \(X^*\) with \(x_1^*=x_2^*={\mathbb {E}}\{Y\}\). If \(p\in (0,1)\), the solution is unique.
Proof
Corollary 1
If \(p\in (0,1)\) and \(y_1\ne y_2\), then \(X^*\ne Y\).
Proof
As \(p\in (0,1)\), the only global minimum exists at \(X^*\). As \(x^*_1 = x^*_2\) and \(y_1\ne y_2\), it follows that \(X^*\ne Y\). \(\square \)
Corollary 2
Consider two discrete random variables X and Y with values \(x_1\), \(x_2, \ldots , x_n\), and \(y_1\), \(y_2, \ldots , y_n\), respectively, \(n>1\). Variable X takes value \(x_i\) with probability \(p_i\) and variable Y takes value \(y_i\) with the same probability \(p_i\), \(i=1,2,\dots ,n\), where \(\sum \limits _{i=1}^{n} p_i = 1\) and \(\exists i,j:y_i\ne y_j\). Variables X and Y are assumed to be independent of each other. Metric D has a global minimum at \(X^*\ne Y\) with \(x_1^*= x_2^* = \ldots = x_n^*={\mathbb {E}}\{Y\}\). If all \(p_i\in (0,1)\), then \(X^*\) is unique.
Proof
This proof, which is omitted here, can be obtained by examining the first and second derivatives of a generalized version of Eq. (12). Rather than four \((2^2)\) cases, there are \(n^2\) cases to be considered. \(\square \)
Corollary 3
Consider a sequence of pairs of binary random variables (\(X_t\), \(Y_t\)), \(t=1,\ldots ,T\). Variable \(X_t\) takes value \(x_1\) with probability \(p_t\), and value \(x_2\), otherwise. Variable \(Y_t\) takes value \(y_1\) with the same probability \(p_t\), and value \(y_2\ne y_1\), otherwise. For all t, variables \(X_t\) and \(Y_t\) are assumed to be independent of each other. If all \(p_t\in (0,1)\), then the metric \(D={\mathbb {E}}\left\{ \sum _{t=1}^T(X_tY_t)^2\right\} \) has one global minimum at \(X^*\ne Y\).
Proof
4.5.2 Comparison with Turing Learning
To verify whether the theoretical result (and its assumptions) holds in practice, we used an evolutionary algorithm with a single population of models. The algorithm was identical to the model optimization subalgorithm in Turing Learning except for the fitness calculation, where the metric of Eq. (11) was employed. We performed 30 evolutionary runs for each case study. Each evolutionary run lasted 1000 generations. The simulation setup and number of fitness evaluations for the models were kept the same as in Turing Learning.
Figure 8a shows the parameter distribution of the evolved models with highest fitness in the last generation over 30 runs. The distributions of the evolved parameters corresponding to \(I=0\) and \(I=1\) are similar. This phenomenon can be explained as follows. In the identification problem that we consider, the method has no knowledge of the input, that is, whether the agent perceives another agent \((I=1)\) or not \((I=0)\). This is consistent with Turing Learning as the classifiers that are used to optimize the models also do not have any knowledge of the inputs. The metricbased algorithm seems to construct controllers that do not respond differently to either input, but work as good as it gets on average, that is, for the particular distribution of inputs, 0 and 1. For the left wheel speed, both parameters are approximately \(0.54\). This is almost identical to the weighted mean \((0.7*0.912 + 1.0*0.088=0.5504)\), which takes into account that parameter \(v_{\ell 0}=0.7\) is observed around 91.2 % of the time, whereas parameter \(v_{\ell 1}=1\) is observed around 8.8 % of the time (see also Sect. 4.3). The parameters related to \(I=1\) evolved well as the agent’s parameters are identical regardless of the input \((v_{r0}=v_{r1}=1.0)\). For both \(I=0\) and \(I=1\), the evolved parameters show good agreement with Theorem 1. As the model and the agents are only observed for \(10\hbox { s}\) in the simulation trials, the probabilities of seeing a 0 or a 1 are nearly constant throughout the trial. Hence, this scenario approximates very well the conditions of Theorem 1, and the effects of nonstationary probabilities on the optimal point (Corollary 3) are minimal. Similar results were found when inferring the object clustering behavior (see Fig. 8b).
By comparing Figs. 4 and 8, one can see that Turing Learning outperforms the metricbased evolutionary algorithm in terms of model accuracy in both case studies. As argued before, due to the unpredictable interactions in swarms, the traditional metricbased method is not suited for inferring the behaviors.
4.6 Generality of Turing Learning
In the following, we present four orthogonal studies testing the generality of Turing Learning. The experimental setup in each section is identical to that described previously (see Sect. 4.2), except for the modifications discussed within each section.
4.6.1 Simultaneously inferring control and morphology
Figure 10a shows the parameters of the subjectively best models in the last (1000th) generations of 30 runs. The means (standard deviations) of the AEs in each model parameter are as follows: 0.02 (0.01), 0.02 (0.02), 0.05 (0.07), 0.06 (0.06), and 0.01 (0.01). All parameters including \(\theta \) are still learned with high accuracy.
The case where the true value of \(\theta \) is \(0\hbox { rad}\) is an edge case, because given an arbitrarily small \(\epsilon >0\), the logistic sigmoid function maps an unbounded domain of values onto \((0,\epsilon )\). This makes it simpler for Turing Learning to infer this parameter. For this reason, we also consider another scenario where the agents’ angle of view is \(\pi /3\hbox { rad}\) rather than \(0\hbox { rad}\). The controller parameters for achieving aggregation in this case are different from those in Eq. (6). They were found by rerunning a grid search with the modified sensor. Figure 10b shows the results from 30 runs with this setup. The means (standard deviations) of the AEs in each parameter are as follows: 0.04 (0.04), 0.03 (0.03), 0.05 (0.06), 0.05 (0.05), and 0.20 (0.19). The controller parameters are still learned with good accuracy. The accuracy in the angle of view is noticeably lower, but still reasonable.
4.6.2 Inferring behavior without assuming a known control system structure
We first analyze the steadystate behavior of the inferred network models. To obtain their steadystate outputs, we fed them with a constant input (\(I=0\) or \(I=1\) depending on the parameters) for 20 time steps. Figure 11 shows the outputs in the final time step of the inferred models with the highest subjective fitness in the last generation in 30 runs for the three cases. In all cases, the parameters of the swarming agent can be inferred correctly with reasonable accuracy. More hidden neurons lead to worse results, probably due to the larger search space.
We now analyze the dynamic behavior of the inferred network models. Figure 12 shows the dynamic output of 1 of the 30 neural networks. The chosen neural network is the one exhibiting the median performance according to metric \(\sum \nolimits _{i=1}^{4} \sum \nolimits _{t=1}^{20} (o_{it}  p_{i})^2\), where \(p_i\) denotes the \(i\hbox {th}\) parameter in Eq. (6), and \(o_{it}\) denotes the output of the neural network in the \(t\hbox {th}\) time step corresponding to the \(i\hbox {th}\) parameter in Eq. (6). The inferred networks react to the inputs rapidly and maintain a steadystate output (with little disturbance). The results show that Turing Learning can infer the behavior without assuming the agent’s control system structure to be known.
4.6.3 Separating the replicas and the agents
The distribution of the inferred model parameters is shown in Fig. 13. The results show that Turing Learning can still identify the model parameters well. There is no significant difference between either approach in the case studies considered in this paper. The method of separating replicas and agents is recommended if potential biases are suspected.
4.6.4 Inferring other reactive behaviors
The aggregation controller that agents used in our case study was originally synthesized by searching over the parameter space defined in Eq. (5) with \(n=2\), using a metric to assess the swarm’s global performance (Gauci et al. 2014c). Each of these points produces a global behavior. Some of these behaviors are particularly interesting, such as the circle formation behavior reported in Gauci et al. (2014a).
Figure 14a shows a histogram of the MAE of the inferred models. The distribution has a single mode close to zero and decays rapidly for increasing values. Over \(89\,\%\) of the 1000 cases have an error below 0.05. This suggests that the accuracy of Turing Learning is not highly sensitive to the particular behavior under investigation (i.e., most behaviors are learned equally well). Figure 14b shows the AEs of each model parameter. The means (standard deviations) of the AEs in each parameter are as follows: 0.01 (0.05), 0.02 (0.07), 0.07 (0.6), and 0.05 (0.2). We performed a statistical test on the AEs between the model parameters corresponding to \(I=0\) (\(v_{\ell 0}\) and \(v_{r0}\)) and \(I=1\) (\(v_{\ell 1}\) and \(v_{r1}\)). The AEs of the inferred \(v_{\ell 0}\) and \(v_{r0}\) are significantly lower than those of \(v_{\ell 1}\) and \(v_{r1}\). This is likely due to the reason reported in Sect. 4.3, that is, an agent is likely to spend more time seeing nothing \((I=0)\) than seeing other agents \((I=1)\) in each trial.
5 Physical experiments
In this section, we present a realworld validation of Turing Learning. We explain how it can be used to infer the behavior of a swarm of real agents. The agents and replicas are represented by physical robots. We use the same type of robot (epuck) as in simulation. The agents execute the aggregation behavior described in Sect. 3.2.1. The replicas execute the candidate models. We use two replicas to speed up the identification process, as will be explained in Sect. 5.3.
5.1 Physical platform
5.1.1 Robot arena
The robot arena is rectangular with sides \(200\hbox { cm} \times 225\hbox { cm}\) and bounded by walls of \(50\hbox { cm}\) high. The floor has a light gray color, and the walls are painted white.
5.1.2 Robot platform and sensor implementations
We also use the epuck’s infrared sensors, in two cases. Firstly, before each trial, the robots disperse themselves within the arena. In this case, they use the infrared sensors to avoid both robots and walls, making the dispersion process more efficient. Secondly, we observe that using only the lineofsight sensor can lead to robots becoming stuck against the walls of the arena, hindering the identification process. We therefore use the infrared sensors for wall avoidance, but in such a way as to not affect interrobot interactions.^{8} Details of these two collision avoidance behaviors are provided in the online supplementary materials (Li et al. 2016).
5.1.3 Motion capture
To facilitate motion data extraction, we fit robots with markers on their tops, consisting of a colored isosceles triangle on a circular white background (see Fig. 1). The triangle’s color allows for distinction between robots; we use blue triangles for all agents, and orange and purple triangles for the two replicas. The triangle’s shape eases extraction of robots’ orientations.
The robots’ motion is captured using a camera mounted around \(270\hbox { cm}\) above the arena floor. The camera’s frame rate is set to \(10\hbox { fps}\). The video stream is fed to the PC, which performs video processing to extract motion data about individual robots (position and orientation). The video processing software is written using OpenCV (Bradski and Kaehler 2008).
5.2 Turing Learning with physical robots
Figure 17 shows a flow diagram of the programs run by the PC and the replicas, respectively. Dashed arrows indicate communication between the units.

P1. Wait for “Stop” Signal. The program is paused until “Stop” signals are received from both replicas. These signals indicate that a trial has finished.

P2. Send Model Parameters. The PC sends new model parameters to the buffer of each replica.

P3. Wait for “Start” Signal. The program is paused until “Start” signals are received from both replicas, indicating that a trial is starting.

P4. Track Robots. The PC waits \(1\hbox { s}\) and then tracks the robots using the overhead camera for \(5\hbox { s}\). The tracking data contain the positions and orientations of the agents and replicas.

P5. Update Turing Learning Algorithm. The PC uses the motion data from the trial observed in P4 to update the solution quality (fitness values) of the corresponding two models and all classifiers. Once all models in the current iteration cycle (generation) have been evaluated, the PC also generates new model and classifier populations. The method for calculating the qualities of solutions and the optimization algorithm are described in Sects. 3.1 and 3.2.4, respectively. The PC then goes back to P1.

R1. Send “Stop” Signal. After a trial stops, the replica informs the PC by sending a “Stop” signal. The replica waits \(1\hbox { s}\) before proceeding with R2, so that all robots remain synchronized. Waiting \(1\hbox { s}\) in other states serves the same purpose.

R2. Disperse. The replica disperses in the environment, while avoiding collisions with other robots and the walls. This behavior lasts \(8\hbox { s}\).

R3. Receive Model Parameters. The replica reads new model parameters from its buffer (sent earlier by the PC). It waits \(1\hbox { s}\) before proceeding with R4.

R4. Send “Start” Signal. The replica sends a start signal to the PC to inform it that a trial is about to start. The replica waits \(1\hbox { s}\) before proceeding with R5.

R5. Execute Model. The replica moves within the swarm according to its model. This behavior lasts \(7\hbox { s}\) (the tracking data corresponds to the middle \(5\hbox { s}\), see P4). The replica then goes back to R1.
Each iteration (loop) of the program for the PC, replicas, and agents lasts \(18\hbox { s}\).
5.3 Experimental setup
As in simulation, we use a population size of 100 for classifiers (\(\mu = 50\), \(\lambda = 50\)). However, the model population size is reduced from 100 to 20 (\(\mu = 10\), \(\lambda = 10\)) to shorten the experimentation time. We use 10 robots: 8 representing agents executing the original aggregation controller [Eq. (6)], and 2 representing replicas that execute models. This means that in each trial, 2 models from the population could be simultaneously evaluated; consequently, each generation consists of \(20/2=10 \hbox { trials}\).
The Turing Learning algorithm is implemented without any modification to the code used in simulation (except for model population size and observation time in each trial). We still let the model parameters evolve unboundedly (i.e., in \({\mathbb {R}}^4\)). However, as the speed of the physical robots is naturally bounded, we apply the hyperbolic tangent function \((\tanh {x})\) on each model parameter, before sending a model to a replica. This bounds the parameters to \(\left( 1,1\right) ^4\), with \(1\) and 1 representing the maximum backwards and forwards wheel speeds, respectively.

The robots have been running continuously for 25 generations. All batteries are replaced.

Hardware failure has occurred on a robot, for example because of a lost battery connection or because the robot has become stuck on the floor. Appropriate action is taken for the affected robot to restore its functionality.

A replica has lost its Bluetooth connection with the PC. The connection with both replicas is restarted.

A robot indicates a low battery status through its LED after running for only a short time. That robot’s battery is changed.
We conducted 10 runs of Turing Learning using the physical system. Each run lasted 100 generations, corresponding to 5 hours (excluding human intervention time). Video recordings of all runs can be found in the online supplementary materials (Li et al. 2016).
5.4 Analysis of inferred models
To investigate the effects of realworld conditions on the identification process, we performed 10 simulated runs of Turing Learning with the same setup as in the physical runs. Figure 19 shows the evolutionary dynamics of the parameters of the inferred models (with the highest subjective fitness) in the physical and simulated runs. The dynamics show good correspondence. However, the convergence in the physical runs is somewhat less smooth than that in the simulated ones (e.g., see spikes in \(v_{\ell 0}\) and \(v_{\ell 1}\)). In each generation of every run (physical and simulated), we computed the MAE of each model. We compared the error of the model with the highest subjective fitness with the average and lowest errors. The results are shown in Fig. 20. For both the physical and simulated runs, the subjectively best model (green) has an error in between the lowest error (blue) and the average error (red) in the majority of generations.
For each controllers, we performed 10 trials using 40 physical epucks. Each trial lasted 10 minutes. Figure 21a shows the proportion of robots in the largest cluster^{9} over time with the agent and model controllers. Figure 21b shows the dispersion (as defined in Sect. 4.3) of the robots over time with the two controllers. The aggregation dynamics of the agents and the models show good correspondence. Figure 22 shows a sequence of snapshots from a trial with 40 epucks executing the inferred model controller.
A video accompanying this paper shows the Turing Learning identification process of the models (in a particular run) both in simulation and on the physical system. Additionally, videos of all 20 postevaluation trials with 40 epucks are provided in the online supplementary materials (Li et al. 2016).
5.5 Analysis of generated classifiers
When postevaluating the classifiers generated in the physical runs of Turing Learning, we limited the number of candidate models to 100, in order to reduce the physical experimentation time. Each candidate model was chosen randomly, with uniform distribution, from the parameter space defined in Eq. (5). Figure 23 shows the average decision accuracy of the best classifiers over the 10 runs. Similar to the results in simulation, the best classifier (objective) still has a high decision accuracy. However, in contrast to simulation, the decision accuracy of the best classifier (subjective) does not drop within 100 generations. This could be due to the noise present in the physical runs, which may have prevented the classifiers from getting overspecialized in the comparatively short time provided (100 generations).
6 Conclusions
This paper presented a new system identification method—Turing Learning—that can autonomously infer the behavior of a system from observations. To the best of our knowledge, Turing Learning is the first system identification method that does not rely on any predefined metric to quantitatively gauge the difference between the system and the inferred models. This eliminates the need to choose a suitable metric and the bias that such metric may have on the identification process.
Through competitive and successive generation of models and classifiers, the system successfully learned two behaviors: selforganized aggregation and object clustering in swarms of mobile agents. Both the model parameters, which were automatically inferred, and emergent global behaviors closely matched those of the original swarm system.
We also examined a conventional system identification method, which used a leastsquare error metric rather than classifiers. We proved that the metricbased method was fundamentally flawed for the case studies considered here. In particular, as the inputs to the agents and to the models were not correlated, the model solution that was globally optimal with respect to the metric was not identical to the agent solution. In other words, according to the metric, the parameter set of the agent itself scored worse than a different—and hence incorrect—parameter set. Simulation results were in good agreement with these theoretical findings.
The classifiers generated by Turing Learning can be a useful byproduct. Given a data sample (motion trajectory), they can tell whether it is genuine, in other words, whether it originates from the reference system. Such classifiers could be used for detecting abnormal behavior—for example when faults occur in some members of the swarm—and are obtained without the need to define a priori what constitutes abnormal behavior.
In this paper, we presented the main results using a gray box model representation; in other words, the model structure was assumed to be known. Consequently, the inferred model parameters could be compared against the ground truth, enabling us to objectively gauge the quality of the identification process. Note that even though the search space for the models is small, identifying the parameters is challenging as the input values are unknown (consequently, the metricbased system identification method did not succeed in this respect).
The Turing Learning method was further validated using a physical system. We applied it to automatically infer the aggregation behavior of an observed swarm of epuck robots. The behavior was learned successfully, and the results obtained in the physical experiments showed good correspondence with those obtained in simulation. This shows the robustness of our method with respect to noise and uncertainties typical of realworld experiments. To the best of our knowledge, this is also the first time that a system identification method was used to infer the behavior of physical robots in a swarm.
We conducted further simulation experiments to test the generality of Turing Learning. First, we showed that Turing Learning can simultaneously infer the agent’s brain (controller) as well as an aspect of the agent’s morphology that determines its field of view. Second, we showed that Turing Learning can infer the behavior without assuming the agent’s control system structure to be known. The models were represented as fixedstructure recurrent neural networks, and the behavior could still be successfully inferred. For more complex behaviors, one could adopt other optimization algorithms such as NEAT (Stanley and Miikkulainen 2002), which gradually increases the complexity of the neural networks being evolved. Third, we assessed an alternative setup of Turing Learning, in which the replica—the robot used to test the models—is not in the same environment as the swarm of agents. While this requires a swarm of replicas, it has the advantage of ensuring that the agents are not affected by the replica’s presence. In addition, it opens up the possibility of the replica not being a physical agent, but rather residing in a simulated world, which may lead to a less costly implementation. On the other hand, the advantage of using a physical replica is that it may help to address the reality gap issue. As the replica shares the same physics as the agent, its evolved behavior will rely on the same physics. This is not necessarily true for a simulated replica—for instance, when evolving a simulated fish, it is hard (and computationally expensive) to fully capture the hydrodynamics of the real environment. As a final experiment, we showed that Turing Learning is able to infer a wide range of randomly generated reactive behaviors.
In the future, we intend to use Turing Learning to infer the complex behaviors exhibited in natural swarms, such as in shoals of fish or herds of land mammals. We are interested in both reactive and nonreactive behaviors. As shown in Li et al. (2013, (2016), it can be beneficial if the classifiers are not restricted to observing the system passively. Rather, they could influence the process by which data samples are obtained, effectively choosing the conditions under which the system is to be observed.
Footnotes
 1.
In general, the classifiers may influence the sampling process. In this case, independent data samples should be generated for each classifier. In particular, the classifiers could change the stimuli that influence the behavior of the system under investigation. This would enable a classifier to interact with the system by choosing the conditions under which the behavior is observed (Li et al. 2013). The classifier could then extract hidden information about the system, which may not be revealed through passive observation alone (Li 2016).
 2.
In Sect. 4.6.1, we show that this assumption can be relaxed by also inferring some aspect of the agent’s morphology.
 3.
We define the linear speed to be positive when the angle between the individual’s orientation and its direction of motion is smaller than \(\pi / 2\hbox { rad}\), and negative otherwise.
 4.
The box plots presented here are all as follows. The line inside the box represents the median of the data. The edges of the box represent the lower and the upper quartiles of the data, whereas the whiskers represent the lowest and the highest data points that are within 1.5 times the range from the lower and the upper quartiles, respectively. Circles represent outliers.
 5.
 6.
Throughout this paper, the statistical test used is a twosided Mann–Whitney test with a \(5\%\) significance level.
 7.
 8.
To do so, the epucks determine whether a perceived object is a wall or another robot.
 9.
A cluster of robots is defined as a maximal connected subgraph of the graph defined by the robots’ positions, where two robots are considered to be adjacent if another robot cannot fit between them (Gauci et al. 2014c).
Notes
Acknowledgments
The authors are grateful for the support received by Jianing Chen, especially in relation to the physical implementation of Turing Learning. The authors also thank the anonymous referees for their helpful comments.
Supplementary material
Supplementary material 1 (mp4 11324 KB)
References
 Arkin, R. C. (1998). Behaviorbased robotics. Cambridge: MIT Press.Google Scholar
 Billings, S. A. (2013). Nonlinear system identification: NARMAX methods in the time, frequency, and spatiotemporal domains. Hoboken: Wiley.CrossRefzbMATHGoogle Scholar
 Bjerknes, J., & Winfield, A. F. T. (2013). On fault tolerance and scalability of swarm robotic systems. In A. Martinoli, F. Mondada, N. Correll, G. Mermoud, M. Egerstedt, A. M. Hsieh, et al. (Eds.), Distributed autonomous robotic systems (Vol. 83, pp. 431–444). Berlin, Heidelberg: Springer.CrossRefGoogle Scholar
 Bongard, J., & Lipson, H. (2004). Automated damage diagnosis and recovery for remote robotics. In Proceedings of the 2004 IEEE International Conference on Robotics and Automation (pp. 3545–3550). Piscataway: IEEE.Google Scholar
 Bongard, J., & Lipson, H. (2004). Automated robot function recovery after unanticipated failure or environmental change using a minimum of hardware trials. In Proceedings of the 2004 NASA/DoD Conference on Evolvable Hardware (pp. 169–176). Piscataway: IEEE.Google Scholar
 Bongard, J., & Lipson, H. (2005). Nonlinear system identification using coevolution of models and tests. IEEE Transactions on Evolutionary Computation, 9(4), 361–384.CrossRefzbMATHGoogle Scholar
 Bongard, J., & Lipson, H. (2007). Automated reverse engineering of nonlinear dynamical systems. Proceedings of the National Academy of Sciences, 104(24), 9943–9948.CrossRefzbMATHGoogle Scholar
 Bongard, J., Zykov, V., & Lipson, H. (2006). Resilient machines through continuous selfmodeling. Science, 314(5802), 1118–1121.CrossRefGoogle Scholar
 Bradski, G., & Kaehler, A. (2008). Learning OpenCV: Computer vision with the OpenCV library. Sebastopol: O’Reilly Media.Google Scholar
 Braitenberg, V. (1984). Vehicles: Experiments in synthetic psychology. Cambridge: MIT Press.Google Scholar
 Brooks, R. A. (1991). Intelligence without representation. Artificial Intelligence, 47(1), 139–159.CrossRefGoogle Scholar
 Camazine, S., Deneubourg, J. L., Franks, N. R., Sneyd, J., Theraula, G., & Bonabeau, E. (2003). Selforganization in biological systems. Princeton: Princeton University Press.zbMATHGoogle Scholar
 Cully, A., Clune, J., Tarapore, D., & Mouret, J. (2015). Robots that can adapt like animals. Nature, 521(7553), 503–507.CrossRefGoogle Scholar
 Eiben, A. E., & Smith, J. E. (2003). Introduction to evolutionary computing. Berlin, Heidelberg: Springer.CrossRefzbMATHGoogle Scholar
 Elman, J. L. (1990). Finding structure in time. Cognitive Science, 14(2), 179–211.CrossRefGoogle Scholar
 Faria, J. J., Dyer, J. R. G., Clément, R. O., Couzin, I. D., Holt, N., Ward, A. J. W., et al. (2010). A novel method for investigating the collective behaviour of fish: Introducing ‘Robofish’. Behavioral Ecology and Sociobiology, 64(8), 1211–1218.CrossRefGoogle Scholar
 Floreano, D., & Mondada, F. (1996). Evolution of homing navigation in a real mobile robot. IEEE Transactions on Systems, Man, and Cybernetics, Part B, 26(3), 396–407.CrossRefGoogle Scholar
 Gauci, M., Chen, J., Li, W., Dodd, T. J., & Groß, R. (2014). Clustering objects with robots that do not compute. In Proceedings of the 2014 Internation Conference Autonomous Agents and MultiAgent Systems (pp. 421–428). Richland: IFAAMAS.Google Scholar
 Gauci, M., Chen, J., Dodd, T., & Groß, R. (2014a). Evolving aggregation behaviors in multirobot systems with binary sensors. In M. Ani Hsieh & G. Chirikjian (Eds.), Distributed autonomous robotic systems (Vol. 104, pp. 355–367). Berlin, Heidelberg: Springer.Google Scholar
 Gauci, M., Chen, J., Li, W., Dodd, T. J., & Groß, R. (2014c). Selforganized aggregation without computation. International Journal of Robotics Research, 33(8), 1145–1161.CrossRefGoogle Scholar
 Goodfellow, I., et al. (2014). Generative adversarial nets. In Z. Ghahramani, M. Welling, C. Cortes, N. D. Lawrence, & K. Q. Weinberger (Eds.), Advances in neural information processing systems (Vol. 27). Red Hook: Curran Associates Inc.Google Scholar
 Graham, R. L., & Sloane, N. J. A. (1990). Pennypacking and twodimensional codes. Discrete and Computational Geometry, 5(1), 1–11.CrossRefzbMATHMathSciNetGoogle Scholar
 Halloy, J., Mondada, F., Kernbach, S., & Schmickl, T. (2013). Towards biohybrid systems made of social animals and robots. In N. F. Lepora, A. Mura, H. G. Krapp, P. Verschure, & T. J. Prescott (Eds.), Biomimetic and biohybrid systems (Vol. 8064, pp. 384–386). Berlin, Heidelberg: Springer.CrossRefGoogle Scholar
 Halloy, J., Sempo, G., Caprari, G., Rivault, C., Asadpour, M., Tâche, F., et al. (2007). Social integration of robots into groups of cockroaches to control selforganized choices. Science, 318(5853), 1155–1158.CrossRefGoogle Scholar
 Harel, D. (2005). A Turinglike test for biological modeling. Nature Biotechnology, 23, 495–496.CrossRefGoogle Scholar
 Harnad, S. (2000). Minds, machines and Turing: The indistinguishability of indistinguishables. Journal of Logic, Language and Information, 9(4), 425–445.CrossRefzbMATHMathSciNetGoogle Scholar
 Harvey, J., Merrick, K., & Abbass, H. A. (2015). Application of chaos measures to a simplified boids flocking model. Swarm Intelligence, 9(1), 23–41.CrossRefGoogle Scholar
 Heinerman, J., Rango, M., & Eiben, A. E. (2015). Evolution, individual learning, and social learning in a swarm of real robots. In Proceedings of the 2015 Genetic and Evolutionary Computation Conference (pp. 177–183). New York: ACM.Google Scholar
 Helbing, D., & Johansson, A. (2011). Pedestrian, crowd and evacuation dynamics. In R. A. Meyers (Ed.), Extreme environmental events (pp. 697–716). New York: Springer.CrossRefGoogle Scholar
 HerbertRead, J. E., Romenskyy, M., & Sumpter, D. J. T. (2015). A Turing test for collective motion. Biology Letters, 11(12), 20150674. doi: 10.1098/rsbl.2015.0674.
 Jakobi, N., Husbands, P., & Harvey, I. (1995). Noise and the reality gap: The use of simulation in evolutionary robotics. In F. Morán, A. Moreno, J. Merelo, & P. Chacón (Eds.), Advances in artificial life (Vol. 929, pp. 704–720). Berlin, Heidelberg: Springer.CrossRefGoogle Scholar
 Koos, S., Mouret, J., & Doncieux, S. (2009). Automatic system identification based on coevolution of models and tests. In Proceedings of the 2009 IEEE Congress on Evolutionary Computation (pp. 560–567). Piscataway: IEEE.Google Scholar
 Koos, S., Mouret, J., & Doncieux, S. (2013). The transferability approach: Crossing the reality gap in evolutionary robotics. IEEE Transactions on Evolutionary Computation, 17(1), 122–145.CrossRefGoogle Scholar
 Krause, J., Winfield, A. F., & Deneubourg, J. L. (2011). Interactive robots in experimental biology. Trends in Ecology and Evolution, 26(7), 369–375.CrossRefGoogle Scholar
 Le Ly, D., & Lipson, H. (2014). Optimal experiment design for coevolutionary active learning. IEEE Transactions on Evolutionary Computation, 18(3), 394–404.CrossRefGoogle Scholar
 Levi, P., & Kernbach, S. (2010). Symbiotic multirobot organisms: Reliability, adaptability, evolution. Berlin, Heidelberg: Springer.CrossRefzbMATHGoogle Scholar
 Li, W. (2016). Automated reverse engineering of agent behaviors. The University of Sheffield. Ph.D. thesis, URL http://etheses.whiterose.ac.uk/12375/.
 Li, W., Gauci, M., & Groß, R. (2013). A coevolutionary approach to learn animal behavior through controlled interaction. In Proceedings of the 2013 Genetic and Evolutionary Computation (pp. 223–230). New York: ACM.Google Scholar
 Li, W., Gauci, M., & Groß, R. (2014). Coevolutionary learning of swarm behaviors without metrics. In Proceedings of the 2014 Genetic and Evolutionary Computation Conference (pp. 201–208). New York: ACM.Google Scholar
 Li, W., Gauci, M., & Groß, R. (2016). Online supplementary material. URL http://naturalrobotics.group.shef.ac.uk/supp/2016003.
 Ljung, L. (2010). Perspectives on system identification. Annual Reviews in Control, 34(1), 1–12.CrossRefMathSciNetGoogle Scholar
 Magnenat, S., Waibel, M., & Beyeler, A. (2011). Enki: The fast 2D robot simulator. URL http://home.gna.org/enki.
 Mirmomeni, M., & Punch, W. (2011). Coevolving data driven models and test data sets with the application to forecast chaotic time series. In Proceedings of the 2011 IEEE Congress on Evolutionary Computation (pp. 14–20). Piscataway: IEEE.Google Scholar
 Mondada, F., Bonani, M., Raemy, X., Pugh, J., Cianci, C., & Klaptocz, A., et al. (2009). The epuck, a robot designed for education in engineering. In Proceedings of the 9th Conference on Autonomous Robot Systems and Competitions (pp. 59–65). Bragana, Portugal: IEEE.Google Scholar
 Nguyen, A., Yosinski, J., & Clune, J. (2015). Deep neural networks are easily fooled: High confidence predictions for unrecognizable images. In Proceedings of the 2015 IEEE Conference on Computer Vision and Pattern Recognition (pp. 427–436). Boston: IEEE.Google Scholar
 O’Dowd, P. J., Studley, M., & Winfield, A. F. (2014). The distributed coevolution of an onboard simulator and controller for swarm robot behaviours. Evolutionary Intelligence, 7(2), 95–106.CrossRefGoogle Scholar
 Radford, A., Metz, L., & Chintala, S. (2016). Unsupervised representation learning with deep convolutional generative adversarial networks. In Proceedings of the 2016 International Conference on Learning Representations. In press; available online: arxiv:1511.06434.
 Saygin, A. P., Cicekli, I., & Akman, V. (2000). Turing test: 50 years later. Minds and Machines, 10, 463–518.CrossRefGoogle Scholar
 Schmickl, T., Bogdan, S., Correia, L., Kernbach, S., Mondada, F., Bodi, M., et al. (2013). Assisi: Mixing animals with robots in a hybrid society. In N. F. Lepora, A. Mura, H. G. Krapp, P. Verschure, & T. J. Prescott (Eds.), Biomimetic and biohybrid systems (pp. 441–443). Berlin, Heidelberg: Springer.CrossRefGoogle Scholar
 Stanley, K. O., & Miikkulainen, R. (2002). Evolving neural networks through augmenting topologies. Evolutionary Computation, 10(2), 99–127.CrossRefGoogle Scholar
 Turing, A. M. (1950). Computing machinery and intelligence. Mind, 59(236), 433–460.CrossRefMathSciNetGoogle Scholar
 Vaughan, R., Sumpter, N., Henderson, J., Frost, A., & Stephen, C. (2000). Experiments in automatic flock control. Robotics and Autonomous Systems, 31(1), 109–117.CrossRefGoogle Scholar
 Watson, R. A., Ficici, S. G., & Pollack, J. B. (2002). Embodied evolution: Distributing an evolutionary algorithm in a population of robots. Robotics and Autonomous Systems, 39(1), 1–18.CrossRefGoogle Scholar
 Weitz, S., Blanco, S., Fournier, R., Gautrais, J., Jost, C., & Theraulaz, G. (2012). Modeling collective animal behavior with a cognitive perspective: A methodological framework. PLoS ONE, 7(6), e38588.CrossRefGoogle Scholar
 Zykov, V., Bongard, J., & Lipson, H. (2004). Evolving dynamic gaits on a physical robot. In Proceedings of the 2004 Genetic and Evolutionary Computation Conference (pp. 4722–4728). New York: ACM.Google Scholar
Copyright information
Open AccessThis article is distributed under the terms of the Creative Commons Attribution 4.0 International License (http://creativecommons.org/licenses/by/4.0/), which permits unrestricted use, distribution, and reproduction in any medium, provided you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons license, and indicate if changes were made.