1 Synchronization and quorum sensing in a swarm of humanoid robots Patrick Bechon, Jean-Jacques Slotine Abstract —With the advent of inexpensive simple humanoid robots, new classes of robotic questions can be considered experimentally. One of these is collective behavior of groups of humanoid robots, and in particular robot synchronization and swarming. The goal of this work is to robustly synchronize a group of humanoid robots, and to demonstrate the approach experimentally on a choreography of 8 robots. We aim to be robust to network latencies, and to allow robots to join or leave the group at any time (for example a fallen robot should be able to stand up to rejoin the choreography). Contraction theory is used to allow each robot in the group to synchronize to a common virtual oscillator, and quorum sensing strategies are exploited to fit within the available bandwidth. The humanoids used are Nao’s, developed by Aldebaran Robotics. Index Terms —Nao, synchronization, contraction, quorum sensing. I. I NTRODUCTION With the advent of inexpensive simple humanoid robots, new classes of robotic questions can be considered experimentally. One of these is collective behavior of groups of humanoid robots, and in particular robot synchronization and swarming. Among the great number of humanoid robot projects, one can think of the first robot to walk Asimo by Honda [1], of the Humanoid Robotics Projet supported by AIST [2] or Darwin created at Virginia Tech [3]. Toyota has also been working on his partner robots [4]. The Robocup (a competition of robot soccer) has also created a league for humanoid robots, and has adopted Nao, a french humanoid robot by Aldebaran Robotics [5], as it standard platform for the Standard Platform League. This work is the result of a collaboration between MIT’s Nonlinear System Laboratory and Aldebaran Robotics, the French company who designed Nao. Nao is used worldwide in universities or in schools, mostly for research or education purposes. The aim of this work is to develop a program to synchronize the movements of a large group of robots, for example to realize a synchronized choreography. This project is different from most of the existing work on robot groups because it deals with strong synchronization rather than cooperation, like in Robocup. This kind of experiment has already been conducted by Aldebaran for the Universal Exposition in Shanghai in 2010 with 20 robots. Their approach was to synchronize every robot’s clock by using the NTP protocol [6], which is currently use by every computer to synchronize its clock on Internet. Then all robots start the choreography at the same time, assuming every that every robot will have the same loading time. The drawback of this system is that it is not possible to compensate for an small error on one robot (if it starts with a delay for example), or to add a new robot during the choreography. So we tried to develop a more robust way to synchronize this behavior. Since our goal is really to ensure that every robot is acting precisely with the others (to do synchronization rather than collaboration), the issues that have to be solved are almost entirely network-related. If the robots had access to a perfect network (with immediate transmission of data between all the robots), a master-robot would have been able to sent immediate commands for every other robot, and they would have been synchronized. But with real networks, information takes time to propagate and this time can be highly variable. It can be as small as several milliseconds, but it can also take several seconds Patrick Bechon is a student from Ecole Polyetchnique, France. He is currently studying at MIT in the Nonlinear Systems Laboratory. Jean-Jacques Slotine heads the Nonlinear Systems Laboratory at MIT, USA in worst case, if the network has too much load for instance, and especially if using Wi-Fi. To synchronize clocks betweens two robots, we also use the NTP protocol. It allows every robot to share the same time, with an offset of a few milliseconds in worst case. But the robot will constantly adjust his speed to catch up with every other robot. To achieve this goal our work is based on two theoretical ideas : contraction theory (already used in another case of synchronization between humanoid robots [7]) and quorum sensing [8] . A video illustrating the result of this work is available on the Web, on the Aldebaran Robotics Youtube Channel. 1 II. C ONTRACTION Contraction theory provides a framework to guarantee convergence of complex nonlinear systems, without using information concerning the limit trajectory [9]. A. Contraction definition Let consider a system of the form : ̇ x = f ( x, t ) where x is a size n vector. Let call δx the virtual displacement. This virtual displacement is an infinitesimal displacement at fixed time. Its norm is then a measure of the difference between two trajectories. So the evolution of δx ( x 0 , t ) is the evolution of the difference between the two trajectories with initial conditions at t = 0 , x = x 0 and x = x 0 + δx ( x 0 , t = 0) . The evolution of δx is given by : δ ̇ x = ∂f ∂x ( x, t ) δx It is then possible to calculate the evolution of the difference between two trajectories initially close : d dt ( δx T δx ) = 2 δx T δ ̇ x = 2 δx T ∂f ∂x ( x, t ) δx Let λ max be the higher eigenvalue of the hermitian part of ∂f ∂x . d dt ( δx T δx ) ≤ 2 λ max δx T δx By integration, we can upper bound δx T δx as ‖ δx ‖ ≤ ‖ δx 0 ‖ e ∫ t 0 λ max ( x,t ) dt If λ max is negative on the whole trajectory, δx will tend toward 0, and this for every initial condition. If λ max is negative in a stable region, every system starting in this region will tend toward a limit trajectory, independently of its initial condition. In this case we say that the system is contracting in this region. It will forget its initial condition exponentially fast. B. Generalization It’s possible to generalize the previous proof by noticing that it does not depend on the definition of length. So we can use a more general definition of the length to prove the contraction definition, the exponential convergence will remain true in any other metric. The details of this generalization can be found in [9]. We can define this metric change by a matrix Θ , such as new coordinates are of the form δz = Θ δx . Since this equation is not integrable in general, it’s not always possible to define explicitly z 1 direct link : http://www.youtube.com/watch?v=emFM8xaQkK4 arXiv:1205.2952v3 [nlin.AO] 27 May 2013 2 in term of x . In the new coordinate system, the system is contracting if the largest eigenvalue of the symmetric part of F = ( ̇ Θ + Θ ∂f ∂x ( x, t ) ) Θ − 1 is negative C. Andronov-Hopf oscillator Consider the classical Andronov-Hopf oscillator, [10]. { ̇ x + ( x 2 + y 2 − 1) x + y = 0 ̇ y + ( x 2 + y 2 − 1) y − x = 0 (1) Its trajectories converge to the limit cycle x ( t ) = sin ( t + θ ) , y ( t ) = cos ( t + θ ) , as can be shown applying the invariant set theorem to the Lyapunov-LaSalle function E = x 2 + y 2 − 1 [11] . This is an oscillator so obviously it is not contracting. The goal is to find a coupling between each oscillator to have all of them converge toward the same trajectory. Let consider a coupling between every oscillator, proportional to the difference of position in x and y . { ̇ x i + ( x 2 i + y 2 i − 1) x i + y i = κ ∑ N j =0 ( x j − x i ) ̇ y i + ( x 2 i + y 2 i − 1) y i − x i = κ ∑ N j =0 ( y j − y i ) The contraction of this system is shown in [10]. By adding N κx i in the first equation and N κy i in the second, we can have the same right hand side term for every oscillator : { ̇ x + ( x 2 + y 2 + β ) x + y = u ( t ) ̇ y + ( x 2 + y 2 + β ) y − x = u ( t ) where β = κN − 1 and u ( t ) = κ ∑ N j =0 x j . ∂f ∂x ( x, t ) = − [ 3 x 2 + y 2 + β 2 yx + 1 2 xy − 1 x 2 + 3 y 2 + β ] The eigenvalues of the symmetric part of this matrix are β + x 2 + y 2 and β + 3 x 2 + 3 y 2 . So if β > 0 the system is contracting, and the contraction rate is at least β . So the distance between two trajectories will decrease at least like e − βt [12], [10]. So it is at least β = N κ − 1 , and close to the limit cycle (where x 2 + y 2 = 1 ), it’s at least β = N κ . Here is a simulation of three oscillators, with κ = 1 and initial conditions x i (0) = − 1 + i 10 and y i (0) = 2 + i 10 . So the three oscillators starts in neighboring trajectories. And we have plotted on each of the following figure the evolution of a distance between oscillator 1 and 3, and the curves e − ( N κ − 1) t and e − ( N κ ) t . Fig. 1 shows the difference in x, Fig. 2 shows the distance on the phase diagram, and Fig. 3 shows the difference in φ . 0.5 1.0 1.5 2.0 2.5 3.0 0.02 0.04 0.06 0.08 0.10 exp ^ H - 3t L exp ^ H - 2t L X difference Fig. 1. Evolution of | x 1 − x 3 | and of the contraction rate 0.5 1.0 1.5 2.0 2.5 3.0 0.02 0.04 0.06 0.08 0.10 0.12 0.14 exp ^ H - 3t L exp ^ H - 2t L Distance Fig. 2. Evolution of √ ( x 1 − x 3 ) 2 + ( y 1 − y 3 ) 2 and of the contraction rate. 0.5 1.0 1.5 2.0 2.5 3.0 0.02 0.04 0.06 0.08 0.10 exp - 3 exp - 2 Phi difference Fig. 3. Evolution of | φ 1 − φ 3 | and of the contraction rate. The brown curve is overlaying the blue one. So every oscillator, independently of its initial conditions, will rejoin the other oscillators and oscillate with them. The difference between two oscillators will decrease with a exponentially speed proportional to β . The limit cycle of the oscillators will be of the form x ( t ) = sin ( t + θ ) , y ( t ) = cos ( t + θ ) . III. Q UORUM SENSING To have the best synchronization possible, it is necessary to have a fully-connected network - that is to say, every robot must have access to every other robot position, because if the distance between two robots increases, the time taken to detect and correct this difference will also increase. But on the other hand, the more links we have in the same network the more stress the network will have. So adding links will decrease the overall quality of every link and will also decrease the number of robots that will be able to synchronize in the same time on a given network. To simulate a fully-connected network while limiting the number of links, we can find inspiration in natural mechanisms, such as quorum sensing. The idea is to communicate through a global variable that everyone can access and modify, rather than with every other robot [8] [13]. This strategy also reduces considerably the number of necessary connections. In biology [14], agents (bacteria) can emit a fixed quantity of chemical (so-called auto-inducer), and also measure the concentration of the chemical in its environment so as to have an estimate of the number of agents present locally. As the bacteria multiply, an infection is launched only once the concentration reaches a certain threshold, i.e., once there are enough other agents present and thus a ”quorum” is reached. This phenomenon is reproduced here to calculate the mean of every oscillator position. It is then possible to couple oscillators directly with the mean, and the result will be the same in theory. 3 ̇ x i + ( x 2 i + y 2 i − 1) x i + y i = κ ∑ N j =0 ( x j − x i ) = N κ [ 1 N ( ∑ N j =0 x j ) − x i ] ̇ y i + ( x 2 i + y 2 i − 1) y i − x i = κ ∑ N j =0 ( y j − y i ) = N κ [ 1 N ( ∑ N j =0 y j ) − y i ] To implement this system, it is compulsory to add at least one new node in the network to collect information of position for every node and to send back the mean. So in this case, we will have a star-shaped network (with a number of link proportional to N ) to have the same synchronization speed of a fully-connected network (with a number of link proportional to N 2 ). See Fig 4 Fig. 4. Comparaison of the network topology without (left) or with (right) quorum sensing Even if in this simple case there is only one central server to which every robot is connected, this is not a master/slave system. If the server (or the network) has trouble, the only thing the robots will miss will be their synchronization information. The oscillations will continue at the nominal speed, and the synchronization will not occur until the issue is solved. But if they are already synchronized, they will stay synchronized. It is also possible to easily distribute this system, so as to reduce the load of the server. If several servers are running in the same time, it is only needed that one robot sends its data to several servers to have all the robots on those servers synchronize. In this way, it is possible to have a distributed system if the workload is too large for a single server. To go further, it is also possible to put this server on every robot, and to use only the first one who join the choreography. If the first robot leaves, the robots have to elect one of their own to run the new server [15]. If the first robot detects a workload too high, it can ask another robot to start its server, which will handle any incoming robot. Nevertheless, this system has a drawback : it takes two messages sent on the network to transmit an update from one robot to another. So the effect of any delay on the network will be amplified. To compensate for this, every data sent is sent with its time of emission and its derivative, to be able to predict its new value when needed. This is also used to drop a data that is too old. Alternatively, the same information may be conveyed by a single composite variable combining each data and its derivative [11]. IV. I MPLEMENTATION In this paper we will focus on moving according to a predefined trajectory, like a choreography. A. Trajectory description We have seen in the two previous sections how to synchronize efficiently oscillators over a network, but we want to synchronize more complex trajectories. Since it is not possible to describe a complex trajectory as the limit cycle of a differential equation, we have to link directly the position of the oscillator to a robot position. We also want the movements to be close enough to nominal movement : the robots can go faster or slower to rejoin the others, but the movement has to be only slightly modified. Once synchronized, the robot has to move according to the nominal movement. To describe the movement of a robot inside a predefined choreog- raphy, one needs only to know its time position inside that choreog- raphy. So we only need to convert the position of our oscillator into a parameter going from 0 to 1 uniformly and continuously to cover precisely the initial movement. - 1.0 - 0.5 0.5 1.0 - 1.0 - 0.5 0.5 1.0 Fig. 5. Phase diagram of an Andronov-Hopf oscillator (1) with initial condition x(0) = y(0) = 1. By looking at the phase diagram (Fig. 5) for an Andronov-Hopf oscillator, we can see that the limit cycle is a perfect circle (and we have proved in section II-C). By phase diagram we mean here a plot of x in respect of y . Indeed when E goes to zero, we have { ̇ x + y = 0 ̇ y − x = 0 that is equivalent to ̈ y + y = 0 . The phase diagram in this case would have been ̇ y in respect of y . We just replace ̇ y by x even if E is not null for the analogy. So by considering the angle in this phase portrait, we have a parameter that evolve between 0 and 2 π periodically, and a small variation in the phase diagram (so in the oscillator state) will modify only slightly this angle. The evolution of this angle (called φ ) is plotted Fig 6. B. Oscillator speed ajustment To correctly reproduce a trajectory, it is necessary to adapt to its length, so to adapt the speed of the oscillator. Let { x ( t ) , y ( t ) } be a solution of (1), and then we will look for a differential equation satisfied by { x ( ωt ) , y ( ωt ) } . We have d dt ( y ( ωt )) = ω ̇ y ( ωt ) and d dt ( x ( ωt )) = ω ̇ x ( ωt ) . { ω ̇ x ( ωt ) + ( x ( ωt ) 2 + y ( ωt ) 2 − 1) x ( ωt ) + y ( ωt ) = 0 ω ̇ y ( ωt ) + ( x ( ωt ) 2 + y ( ωt ) 2 − 1) y ( ωt ) − x ( ωt ) = 0 So { x ( ωt ) , y ( ωt ) } satisfy the differential equation : { ̇ x + ω [( x 2 + y 2 − 1) x + y ] = 0 ̇ y + ω [( x 2 + y 2 − 1) y − x ] = 0 4 2 4 6 8 10 - 1.5 - 1.0 - 0.5 0.5 1.0 1.5 Fig. 6. φ evolution of the Andronov-Hopf oscillator shown in Fig 5, in radians. By modifying ω in this equation, we will modify the speed of the oscillator without modifying the trajectory. The phase diagram will stay the same, it will just be covered in a different time. To be precise, the limit cycle will be covered with a period of 2 π ω . To keep the same influence of synchronization, it is also compul- sory to replace κ by ωκ in previous equation. So the final equation for the oscillator number i is :    ̇ x i + ω [( x 2 i + y 2 i − 1) x i + y i ] = N ωκ [ 1 N ( ∑ N j =0 x j ) − x i ] ̇ y i + ω [( x 2 i + y 2 i − 1) y i − x i ] = N ωκ [ 1 N ( ∑ N j =0 y j ) − y i ] C. Music Another issue that has to be considered is the music. We aim at having something to do choreographies, so we need to be able to play music during the performance, and to synchronize the robots with the music. But it is not a good idea to change the speed of the music in real time : in human shows, the music stays at the same pace and only the dancers have to change their pace to synchronize. So we want the music to act as a leader : to share its oscillator position to allow the others to synchronize to itself but not to take into account the other robot positions. To prove that this behavior will act as we want, we have to use partial contraction [16]. The idea is to build a virtual system from the real system, and to prove the contraction of this virtual system to get information on the real system. By proving the contraction of the whole system, we prove that every trajectory will converge to the other. Since the leader trajectory is a particular solution, every trajectory will tend toward this trajectory. Formally, if ̇ x = g ( x, x, t ) is a system, one can build the virtual system ̇ y = g ( y, x, t ) and proving the contraction of this new system will demonstrate that every solution will tend toward x (because x is a particular solution). This theory is developed more in depth in [16]. Let X be [ x, y ] T . The system with a leader is : { ̇ X leader = f ( X leader ) ̇ X i = f ( X i ) + κ ( N X i − ∑ N j =1 X j ) + κ ( X i − X leader ) , i = 1 ...N          ̇ X leader = f ( X leader ) ̇ X i = f ( X i ) + κ ( N + 1) X i ︸ ︷︷ ︸ =g(X i ) , contractant − κ N ∑ j =1 X j − κX leader ︸ ︷︷ ︸ = u ( t ) , for i = 1 ...N Here we can recognize in g ( X i ) the same system than before : the system which we have already proved the contraction. And u ( t ) is the same for any robot, so will not have any effects on the synchronization. Thus we have proved the partial contraction of the new system with the leader. We have then proved that with one robot who share its position without taking into account others’ position, the synchronization remains. So this robot can be the musician, and if he start the music with its oscillator, the two will not change their respective speed so they will stay synchronized. This idea can also be used if we want to predict with a good accuracy the time when every robot will finish : they will all finish with the leader, which has a fixed speed. D. Robot implementation To achieve our initial goal, our implementation has to separate the calculation of the oscillator and the network communication because we don’t want any perturbation from the network (latencies, lost message, etc ...) causing a shacking movement on the robot. So we separate the implementation in two different threads : one for the oscillator simulation and joint command and the other one for network communication. A schematic view is shown Fig. 7. Fig. 7. Schematic robot implementation of this behavior To describe more in detail each task : • Oscillator initialization : For this initialization the robot has to determine its initial condition. For this he retrieve data from the server concerning the mean position of the group and estimate the position of group in 1 second. He then has 1 second to join this position, so when he will start to synchronize he will be close enough to the others. At the end of this step, the network thread can start since there is a virtual oscillator position to be shared with the others. • Numerical data update : To keep the oscillator calculation real- time, we use a calculation step (used in the numerical resolution of the oscillator differential equation) variable, and equal to 5 the time difference between the beginning of the last loop and the beginning of the current loop. During this tack, the robot calculate this step and use the current time to estimate the current mean of every other robot position (or to discard this information if it’s too old, see next section for more information). • New state calculation : Here the robot can use a Euler method with the current state and the synchronization information es- timated on the previous task to calculate the next state of its virtual oscillator. These data are stored in a global variable to be accessed by the network thread. • Commands sending : With the new state available, a new φ can be computed and a new robot position too. This new command is then sent to the robot to be reached in 150 ms (in addition to every remaining command). The movement will then be smooth (without interruption) if the calculation step remains under 150ms. • Network thread initialization : The robot connects itself to the server and request an update of the synchronization information. • Data sent to server : Sending syntonization data to the server, according to the new section • Data received from server : Receiving syntonization data to the server, according to the new section E. Server implementation The precise goal of this program is to receive the virtual oscillator position from every robot, and to send back to each of them the mean. The server can also receive configuration messages (like changing the coupling strength that is send back to every robot, stopping the server, ...). Synchronization data are transmitted with the form : Message for the server time 1 : x : ̇ x : y : ̇ y ; Answer from the serveur time 2 : m x : ̇ m x : m y : ̇ m y : N : κ ; where time 1 is not the sending time, but the time of the calculation that leads to x and y . The values of ̇ x and ̇ y are send only to do prediction on x and y and are not directly used in the synchronization process. Every value is separated by a ’ : ’, and every message finishes with a ’ ; ’. This way, it is easy to parse the incoming messages and separate them. Every robot expects a message of the form presented above, where m x is the mean of x and m y is the mean of y . Their derivatives are there for prediction, N is the total number of robot and κ is the coupling strength. The server will send a copy of this message to every robot that are connected. Here again, time 2 is the time used to evaluate the mean, not the time of the sending. To be more precise m x is the mean of x i + ( time 2 − time 1 ( i )) ∗ ̇ x i and ̇ m x is the mean of ̇ x i ( i is there the robot index). The fact that the server sends κ allows the user to change the coupling in real time, so as to activate, increase or decrease its strength. V. P ERSPECTIVE OF IMPROVEMENTS In this implementation, the movements of the robots are not really related to the virtual oscillator movements. But for movement like walking, it is possible to do a stronger link and to deal for example with every initial condition [7]. To go further, it could be useful to use the same quorum server to synchronize different types of oscillators. For example if several robots are running different choreography (with different length) or are walking with different pace (because of size differences between robots for example), each robot will have to decompose the quorum signal to find the part of the mean concerning the robot identical to itself. For example if 3 robots walking with 1 step/second and 3 robots with 0.5 step/second, each robot can filter the quorum signal for its corresponding frequency. With a fixed calculation step, it is possible to design filter with an arbitrary precision [17]. With a non-constant step, one has to incorporate the step into the filter coefficients. But without knowing the total number of robots (but with the knowledge of the number of similar robot), a robot can synchronize with all the robots sharing the same speed. Another improvement could be to track the tempo of the music [18], and see it as an oscillator. At the beginning the robot has to determine the frequency to configure its own oscillator, but will then be able to use the music instead of the quorum signal to synchronize. So every robot will synchronize its virtual oscillator to the music, so the movements performed will be synchronized with the music. It can also be a good way for the robot to improvise a dance on a music. A CKNOWLEDGMENT The authors would like to thank Aldebaran Robotics, and in particular Rodolphe Gelin, for their help in using Nao and their lending of robots for the final video. R EFERENCES [1] Y. Sakagami, R. Watanabe, C. Aoyama, S. Matsunaga, N. Higaki, and K. Fujimura, “The intelligent asimo: System overview and integration,” in Intelligent Robots and Systems, 2002. IEEE/RSJ International Con- ference on , vol. 3. Ieee, 2002, pp. 2478–2483. [2] K. Akachi, K. Kaneko, N. Kanehira, S. Ota, G. Miyamori, M. Hirata, S. Kajita, and F. Kanehiro, “Development of humanoid robot hrp-3p,” in Humanoid Robots, 2005 5th IEEE-RAS International Conference on . IEEE, 2005, pp. 50–55. [3] K. Muecke and D. Hong, “Darwin’s evolution: development of a humanoid robot,” in Intelligent Robots and Systems, 2007. IROS 2007. IEEE/RSJ International Conference on . IEEE, 2007, pp. 2574–2575. [4] Y. Ota, “Partner robots—from development to implementation,” in Human System Interactions (HSI), 2010 3rd Conference on . IEEE, 2010, pp. 14–16. [5] D. Gouaillier, V. Hugel, P. Blazevic, C. Kilner, J. Monceaux, P. Lafour- cade, B. Marnier, J. Serre, and B. Maisonnier, “The nao hu- manoid: a combination of performance and affordability,” CoRR, vol. abs/0807.3223 , 2008. [6] D. Mills, “Internet time synchronization: The network time protocol,” Communications, IEEE Transactions on , vol. 39, no. 10, pp. 1482–1493, 1991. [7] A. Mukovskiy, J. Slotine, and M. Giese, “Design of the dynamic stability properties of the collective behavior of articulated bipeds,” IEEE-RAS International Conference on Humanoid Robots , 2010. [8] G. Russo and J. Slotine, “Global convergence of quorum-sensing net- works,” Physical Review E , vol. 82, no. 4, p. 041919, 2010. [9] W. Lohmiller and J. Slotine, “On contraction analysis for non-linear systems,” Automatica , vol. 34, no. 6, pp. 683–696, 1998. [10] Q. Pham and J. Slotine, “Stable concurrent synchronization in dynamic system networks,” Neural Networks , vol. 20, no. 1, pp. 62–77, 2007. [11] J. Slotine and W. Li, Applied Nonlinear Control . Prentice-Hall, 1991. [12] M. Belabbas and J. Slotine, “Factorizations and partial contraction of nonlinear systems,” in American Control Conference (ACC), 2010 . IEEE, 2010, pp. 3440–3445. [13] N. Tabareau, J. Slotine, and Q. Pham, “How synchronization protects from noise,” PLoS Computational Biology , vol. 6, no. 1, 2010. [14] W. Ng and B. Bassler, “Bacterial quorum-sensing network architectures,” Annual review of genetics , vol. 43, pp. 197–222, 2009. [15] H. Garcia-Molina, “Elections in a distributed computing system,” Com- puters, IEEE Transactions on , vol. 100, no. 1, pp. 48–59, 1982. [16] W. Wang and J. Slotine, “On partial contraction analysis for coupled nonlinear oscillators,” Biological Cybernetics , vol. 92, no. 1, pp. 38–53, 2005. [17] A. v. Oppenheim, R. Schafer, and J. Buck, Discrete-time signal process- ing . Prentice Hall, 1989. [18] M. Goto and Y. Muraoka, “A real-time beat tracking system for audio signals,” in Proceedings of the International Computer Music Confer- ence . San Francisco: International Computer Music Association, 1995, pp. 171–174.