# Small Universal Spiking Neural P Systems 

Andrei Păun ${ }^{1}$, Gheorghe Păun ${ }^{2}$<br>${ }^{1}$ Department of Computer Science Louisiana Tech University, Ruston PO Box 10348, Louisiana, LA-71272 USA<br>apaun@latech.edu<br>${ }^{2}$ Institute of Mathematics of the Romanian Academy PO Box 1-764, 014700 Bucharest, Romania<br>and<br>Research Group on Natural Computing<br>Department of Computer Science and Artificial Intelligence<br>University of Sevilla<br>Avda Reina Mercedes s/n, 41012 Sevilla, Spain<br>george.paun@imar.ro, gpaun@us.es

Summary. In search for small universal computing devices of various types, we consider here the case of spiking neural P systems (SN P systems), in two versions: as devices computing functions and as devices generating sets of numbers. We start with the first case and we produce a universal spiking neural P system with 84 neurons. If a slight generalization of the used rules is adopted, namely, we allow rules for producing simultaneously several spikes, then a considerable improvement, to 49 neurons, is obtained. For SN P systems used as generators of sets of numbers, we find a universal system with restricted rules having 76 neurons, and one with extended rules having 50 neurons.

## 1 Introduction

Looking for small universal computing devices is a natural and well investigated topic in computer science, see, e.g., [4], [11], and the references therein. Recently, this issue started to be considered also in membrane computing; first contributions of this kind can be found in [13] (for tissue P systems with string objects processed by splicing operations) and [1] (for symport/antiport P systems).

In the present paper, we address the case of the recently introduced (see [3], [9], [10]) spiking neural P systems (in short, SN P systems), computing models which bring into membrane computing (see [8] for an introduction and [15] for updated information) ingredients from neural computing by spiking (see, e.g., [5], [6]).

In short, an SN P system consists of a set of neurons placed in the nodes of a directed graph (representing synapses) and sending to each other spikes, identical electrical impulses; the distance between consecutive spikes is the main way to
encode information; the neurons contain rules for emitting spikes and for forgetting spikes; one neuron is distinguished as the output neuron and its spikes also exit into the environment, thus producing a spike train.

Such systems can be used as computing devices in various ways; generating sets of numbers (encoded in the number of steps between consecutive spikes sent into the environment by the output neuron), generating strings (the spike train itself is such a string over the binary alphabet), or computing functions (an input neuron "reads" the arguments of the function from the environment and the output neuron "writes" the function value, in all cases with the numbers being encoded in the distance between consecutive spikes). More precise definitions will be given in Subsection 2.2.

Here we deal with the first and the third cases, of SN P systems generating numbers and computing functions.

Already in [3], the SN P systems used for computing sets of numbers were proved to be computationally complete (able to compute all Turing computable sets of numbers), but no bound on the number of used neurons was found. The proof from [3] is based on simulating register machines with SN P systems, hence the same strategy as that followed in [1] in search of small universal P systems is useful also here: starting from a small universal register machine as those constructed in [4], we can get a small universal SN P system, with the important mentioning that in [4] one works with register machines computing functions. That is why we also start here with this case.

We work with the so-called strong universality (without encodings of the input and output) and we use the standard type of register machines (using ADD and SUB instructions). For this case, a universal register machine with 8 registers and 23 instructions (the halting one included) was constructed in [4]. (The "code" of the particular partial recursive function and the argument of the function are introduced in registers 1 and 2 of the universal machine and the value of the function for that argument, if defined, is found in register 0 when/if the machine halts.) Following then the construction of an SN P system simulating a register machine from [3], with some improvements inspired from [2] and some additional "code optimization", as well as a suitable input module, we get an SN P system with 84 neurons simulating the register machine from [4].

We may formulate this result as follows: there is a universal "brain" (in the form of an SN P system) with only 84 neurons.

Of course, this number needs to be checked for optimality, but it is our expectation that in the framework used here (with the type of SN P systems considered, i.e., with standard rules) it is not possible to significantly decrease the number of neurons.

However, if we allow rules which produce two or more spikes, then a considerable improvement of the previous result is obtained: 49 neurons are sufficient for universality.

We pass then to the case when SN P systems are used for generating sets of numbers, starting from the observation that a set $Q \subseteq \mathbf{N}$ is recursively enumer-
able if and only if the characteristic function of $Q$ (equal to 1 for elements of $Q$ and undefined otherwise) is a partial recursive function. Similar results as for the previous case are obtained: 76 neurons are sufficient for universality when using restricted rules and 50 when using extended rules.

In the next section we introduce all necessary prerequisites related to register machines, universality, and standard SN P systems. Section 3 gives the first universal SN P system, and in Section 4 we introduce the extended spiking rules and we produce the universal computing SN P system with 49 rules. In Section 5 we consider the case of universal SN P systems working as generators of sets of numbers.

## 2 Prerequisites

The reader is assumed to have some elementary knowledge in theoretical computer science as available from the many monographs in the field (e.g., from [12], [14]), so that we specify here only some notations and basic definitions.

For an alphabet $V, V^{*}$ denotes the set of all strings over $V$, with the empty string denoted by $\lambda$.

A regular expression over an alphabet $V$ is defined as follows: (i) $\lambda$ and each $a \in V$ is a regular expression, (ii) if $E_{1}, E_{2}$ are regular expressions over $V$, then $\left(E_{1}\right)\left(E_{2}\right),\left(E_{1}\right) \cup\left(E_{2}\right)$, and $\left(E_{1}\right)^{+}$are regular expressions over $V$, and (iii) nothing else is a regular expression over $V$. Clearly, we assume that the parentheses are not in $V$; as a matter of fact, we will often omit "unnecessary parentheses". Also, $E_{1}^{+} \cup \lambda$ can be written as $E_{1}^{*}$. With each expression $E$ we associate its language $L(E)$ as follows: (i) $L(\lambda)=\{\lambda\}, L(a)=\{a\}$, for $a \in V$, (ii) $L\left(\left(E_{1}\right)\left(E_{2}\right)\right)=$ $L\left(E_{1}\right) L\left(E_{2}\right), L\left(\left(E_{1}\right) \cup\left(E_{2}\right)\right)=L\left(E_{1}\right) \cup L\left(E_{2}\right)$, and $L\left(\left(E_{1}\right)^{+}\right)=L\left(E_{1}\right)^{+}$, for all regular expressions $E_{1}, E_{2}$.

The operations used here are the standard union, concatenation, and Kleene + . We also need below the operation of right derivative of a language $L \subseteq V^{*}$ with respect to a string $x \in V^{*}$, which is defined by $L / x=\left\{y \in V^{*} \mid y x \in L\right\}$.

We pass now to introducing the necessary notions related register machines and universality, then the spiking neural P systems.

### 2.1 Universal Register Machines

We use here register machines given in the form $M=\left(m, H, l_{0}, l_{h}, I\right)$, where $m$ is the number of registers, $H$ is the set of instruction labels, $l_{0}$ is the start label, $l_{h}$ is the halt label (assigned to instruction HALT), and $I$ is the set of instructions; each label from $H$ is associated with only one instruction from $I$, thus precisely identifying it (therefore, there are as many labels as instructions). The instructions are of the following forms:

- $l_{i}:\left(\operatorname{ADD}(r), l_{j}, l_{k}\right)$ (add 1 to register $r$ and then go to one the instructions with labels $l_{j}$ and $l_{k}$, non-deterministically chosen),
- $l_{i}:\left(\operatorname{SUB}(r), l_{j}, l_{k}\right)$ (if register $r$ is non-empty, then subtract 1 from it and go to the instruction with label $l_{j}$, otherwise go to the instruction with label $l_{k}$ ),
- $l_{h}$ : HALT (the halt instruction).

A register machine $M$ generates a set of numbers in the following way: we start with all registers empty (i.e., storing the number zero), we apply the instruction with label $l_{0}$ and we proceed to apply instructions as indicated by the labels (and made possible by the contents of registers); if we reach the halt instruction, then the number $n$ stored at that moment in a specified register $r_{0}$ is said to be computed by $M$; if the computation does not halt, then no number is generated. The set of all numbers generated by $M$ is denoted by $N(M)$. It is known (see, e.g., [7]) that register machines generate all sets of numbers which are Turing computable.

A register machine can also compute any Turing computable function: we introduce the arguments in specified registers $r_{1}, \ldots, r_{k}$ (without loss of the generality, we may assume that we use the first $k$ registers), we start with the instruction with label $l_{0}$, and if we stop (with the instruction with label $l_{h}$ ), then the value of the function is placed in another specified register, $r_{t}$, with all registers different from $r_{t}$ being empty. The partial function computed in this way is denoted by $M\left(n_{1}, n_{2}, \ldots, n_{k}\right)$. In the computing form, the register machines can be considered deterministic, without losing the Turing completeness; then, the ADD instructions $l_{i}:\left(\operatorname{ADD}(r), l_{j}, l_{k}\right)$ have $l_{j}=l_{k}$ (and the instruction is written in the form $\left.l_{i}:\left(\operatorname{ADD}(r), l_{j}\right)\right)$.

In [4], the register machines are used for computing functions, with the universality defined as follows. Let $\left(\varphi_{0}, \varphi_{1}, \ldots\right)$ be a fixed admissible enumeration of the unary partial recursive functions. A register machine $M_{u}$ is said to be universal if there is a recursive function $g$ such that for all natural numbers $x, y$ we have $\varphi_{x}(y)=M_{u}(g(x), y)$. In [4], several universal register machines are constructed, with the input (the couple of numbers $g(x)$ and $y$ ) introduced in registers 1 and 2 , and the result obtained in register 0 , so that, from now on we also assume that the registers are always numbered from 0 to $m-1$.

In general, we directly continue here the results from [4], using one of the universal register machines constructed there, implicitly also the recursive function $g$ which encodes the partial recursive function $\varphi_{x}$ in the form of the number $g(x)$ as used in the universal register machine.

We give now in the notation introduced above the specific universal register machine from [4] which will be used in Section 3 below: we have $M_{u}=\left(8, H, l_{0}, l_{h}, I\right)$, with the instructions (their labels constitute the set $H$ ) presented in Figure 1. (The machine from [4] contains a separate check for zero of register 6 , of the form " $l_{8}$ : if $\operatorname{register}(6)=0$, then go to $l_{0}$, else go to $l_{10}$ "; this instruction was replaced in our setup by $\left.l_{8}:\left(\operatorname{SUB}(6), l_{9}, l_{0}\right), l_{9}:\left(\operatorname{ADD}(6), l_{10}\right).\right)$ Therefore, there are 8 registers (numbered from 0 to 7 ) and 23 instructions (hence 23 labels), the last instruction being the halting one. The input numbers (the "code" of the partial
recursive function to simulate and the argument for this function) are introduced in registers 1 and 2, and the result is obtained in register 0 .

| $l_{0}:\left(\operatorname{SUB}(1), l_{1}, l_{2}\right)$, | $l_{1}:\left(\operatorname{ADD}(7), l_{0}\right)$, |
| :--- | :--- |
| $l_{2}:\left(\operatorname{ADD}(6), l_{3}\right)$, | $l_{3}:\left(\operatorname{SUB}(5), l_{2}, l_{4}\right)$, |
| $l_{4}:\left(\operatorname{SUB}(6), l_{5}, l_{3}\right)$, | $l_{5}:\left(\operatorname{ADD}(5), l_{6}\right)$, |
| $l_{6}:\left(\operatorname{SUB}(7), l_{7}, l_{8}\right)$, | $l_{7}:\left(\operatorname{ADD}(1), l_{4}\right)$, |
| $l_{8}:\left(\operatorname{SUB}(6), l_{9}, l_{0}\right)$, | $l_{9}:\left(\operatorname{ADD}(6), l_{10}\right)$, |
| $l_{10}:\left(\operatorname{SUB}(4), l_{0}, l_{11}\right)$, | $l_{11}:\left(\operatorname{SUB}(5), l_{12}, l_{13}\right)$, |
| $l_{12}:\left(\operatorname{SUB}(5), l_{14}, l_{15}\right)$, | $l_{13}:\left(\operatorname{SUB}(2), l_{18}, l_{19}\right)$, |
| $l_{14}:\left(\operatorname{SUB}(5), l_{16}, l_{17}\right)$, | $l_{15}:\left(\operatorname{SUB}(3), l_{18}, l_{20}\right)$, |
| $l_{16}:\left(\operatorname{ADD}(4), l_{11}\right)$, | $l_{17}:\left(\operatorname{ADD}(2), l_{21}\right)$, |
| $l_{18}:\left(\operatorname{SUB}(4), l_{0}, l_{h}\right)$, | $l_{19}:\left(\operatorname{SUB}(0), l_{0}, l_{18}\right)$, |
| $l_{20}:\left(\operatorname{ADD}(0), l_{0}\right)$, | $l_{21}:\left(\operatorname{ADD}(3), l_{18}\right)$, |
| $l_{h}: \operatorname{HALT}$. |  |

Fig. 1. The universal register machine from [4]

### 2.2 Spiking Neural P Systems

We introduce now the SN P systems in the form necessary for universality considerations, hence computing functions.

A computing spiking neural P system (abbreviated SN P system), of degree $m \geq 1$, is a construct of the form

$$
\Pi=\left(O, \sigma_{1}, \ldots, \sigma_{m}, \text { syn, in }, \text { out }\right),
$$

where:

1. $O=\{a\}$ is the singleton alphabet ( $a$ is called spike);
2. $\sigma_{1}, \ldots, \sigma_{m}$ are neurons, of the form

$$
\sigma_{i}=\left(n_{i}, R_{i}\right), 1 \leq i \leq m
$$

where:
a) $n_{i} \geq 0$ is the initial number of spikes contained in $\sigma_{i}$;
b) $R_{i}$ is a finite set of rules of the following two forms:
(1) $E / a^{c} \rightarrow a ; d$, where $E$ is a regular expression over $a$ and $c \geq 1, d \geq 0$;
(2) $a^{s} \rightarrow \lambda$, for $s \geq 1$, with the restriction that for each rule $E / a^{c} \rightarrow a ; d$ of type (1) from $R_{i}$, we have $a^{s} \notin L(E)$;
3. syn $\subseteq\{1,2, \ldots, m\} \times\{1,2, \ldots, m\}$ with $i \neq j$ for all $(i, j) \in \operatorname{syn}, 1 \leq i, j \leq m$ (synapses between neurons);
4. in, out $\in\{1,2, \ldots, m\}$ indicate the input and the output neurons, respectively.

An SN P system with rules as above is said to be of the standard type.
The rules of type (1) are firing (we also say spiking) rules, and they are applied as follows. If the neuron $\sigma_{i}$ contains $k$ spikes, and $a^{k} \in L(E), k \geq c$, then the rule $E / a^{c} \rightarrow a ; d \in R_{i}$ can be applied. This means consuming (removing) $c$ spikes (thus only $k-c$ remain in $\sigma_{i}$; this corresponds to the right derivative operation $L(E) / a^{c}$ ), the neuron is fired, and it produces a spike after $d$ time units (as usual in membrane computing, a global clock is assumed, marking the time for the whole system, hence the functioning of the system is synchronized). If $d=0$, then the spike is emitted immediately, if $d=1$, then the spike is emitted in the next step, etc. If the rule is used in step $t$ and $d \geq 1$, then in steps $t, t+1, t+2, \ldots, t+d-1$ the neuron is closed (this corresponds to the refractory period from neurobiology), so that it cannot receive new spikes (if a neuron has a synapse to a closed neuron and tries to send a spike along it, then that particular spike is lost). In the step $t+d$, the neuron spikes and becomes again open, so that it can receive spikes (which can be used starting with the step $t+d+1$, when the neuron can again apply rules).

The rules of type (2) are forgetting rules; they are applied as follows: if the neuron $\sigma_{i}$ contains exactly $s$ spikes, then the rule $a^{s} \rightarrow \lambda$ from $R_{i}$ can be used, meaning that all $s$ spikes are removed from $\sigma_{i}$.

If a rule $E / a^{c} \rightarrow a ; d$ of type (1) has $E=a^{c}$, then we write it in the simplified form $a^{c} \rightarrow a ; d$.

In each time unit, if a neuron $\sigma_{i}$ can use one of its rules, then a rule from $R_{i}$ must be used. Since two firing rules, $E_{1} / a^{c_{1}} \rightarrow a ; d_{1}$ and $E_{2} / a^{c_{2}} \rightarrow a ; d_{2}$, can have $L\left(E_{1}\right) \cap L\left(E_{2}\right) \neq \emptyset$, it is possible that two or more rules can be applied in a neuron, and in that case, only one of them is chosen non-deterministically. Note however that, by definition, if a firing rule is applicable, then no forgetting rule is applicable, and vice versa.

Thus, the rules are used in the sequential manner in each neuron, at most one in each step, but neurons function in parallel with each other. It is important to notice that the applicability of a rule is established based on the total number of spikes contained in the neuron.

The initial configuration of the system is described by the numbers $n_{1}, n_{2}, \ldots, n_{m}$, of spikes present in each neuron, with all neurons being open. During the computation, a configuration is described by both the number of spikes present in each neuron and by the state of the neuron, more precisely, by the number of steps to count down until it becomes open (this number is zero if the neuron is already open). Thus, $\left\langle r_{1} / t_{1}, \ldots, r_{m} / t_{m}\right\rangle$ is the configuration where neuron $\sigma_{i}$ contains $r_{i} \geq 0$ spikes and it will be open after $t_{i} \geq 0$ steps, $i=1,2, \ldots, m$; with this notation, the initial configuration is $C_{0}=\left\langle n_{1} / 0, \ldots, n_{m} / 0\right\rangle$.

A computation in a system as above starts in the initial configuration. In order to compute a function $f: \mathbf{N}^{k} \longrightarrow \mathbf{N}$, we introduce $k$ natural numbers $n_{1}, \ldots, n_{k}$ in the system by "reading" from the environment a binary sequence $z=10^{n_{1}-1} 10^{n_{2}-1} 1 \ldots 10^{n_{k}-1} 1$. This means that the input neuron of $\Pi$ receives a spike in each step corresponding to a digit 1 from the string $z$ and no spike
otherwise. Note that we input exactly $k+1$ spikes, i.e., after the last spike we assume that no further spike is coming to the input neuron. The result of the computation is also encoded in the distance between two spikes: we impose the restriction that the system outputs exactly two spikes and halt (immediately after the second spike), hence producing a train spike of the form $0^{b} 10^{r-1} 1$, for some $b \geq 0$ and with $r=f\left(n_{1}, \ldots, n_{k}\right)$ ( the system outputs no spike a non-specified number of steps from the beginning of the computation until the first spike).

In Section 5 the SN P systems are used as number generators - in a way which will be specified there.

An SN P system can be represented graphically in a very natural way: the neurons are placed in the nodes of a graph representing the synapses, with the rules and the initial spikes mentioned in each neuron; the input neuron has an incoming arrow and the output neuron has an outgoing arrow, suggesting their communication with the environment. In the next sections we will always present the systems we construct in this way, which is much more transparent (easy to understand) than the symbolic one.

## 3 A Small Universal SN P System

We pass now to constructing the first of the four announced universal SN P systems, namely the one for computing functions and using rules of the standard type. To this aim, we follow the way used in [3] to simulate a deterministic register machine by an SN P system. This is done as follows: neurons are associated with each register and with each label of an instruction of the machine; if a register contains a number $n$, then the associated neuron will contain $2 n$ spikes; modules as in Figures 2 and 3 are associated with the ADD and the SUB instructions (each of these modules contains two neurons which do not correspond to registers or to labels of instructions, namely the neurons with labels $\left.l_{i}^{\prime}, l_{i}^{\prime \prime}\right)$.

The work of the system is triggered by introducing two spikes in the neuron $\sigma_{l_{0}}$ (associated with the starting instruction of the register machine). In general, the simulation of an ADD or SUB instruction starts by introducing two spikes in the neuron with the instruction label (we say that this neuron is activated). We do not describe here in detail the (pretty transparent) way the modules from Figures 2 and 3 work (if necessary, the reader can consult [3] in this respect), but we only remark that after incrementing, respectively decrementing (if possible) the value of register $r$ (the number of spikes in neuron $\sigma_{r}$ ), we activate exactly one neuron, $\sigma_{l_{j}}$ or $\sigma_{l_{k}}$, as requested by the instruction.

Starting with neurons $\sigma_{1}$ and $\sigma_{2}$ already loaded with $g(x)$ and $y$ spikes, respectively, and introducing two spikes in neuron $\sigma_{l_{0}}$, we can compute in our system in the same way as the universal register machine $M_{u}$ from Figure 1; if the computation halts, then neuron $\sigma_{0}$ will contain the double of $\varphi_{x}(y)$ spikes.

There are two additional tasks to solve: to introduce the mentioned spikes in the neurons $\sigma_{l_{0}}, \sigma_{1}, \sigma_{2}$, and to output the computed number. The first task is


Fig. 2. Module ADD (simulating $\left.l_{i}:\left(\operatorname{ADD}(r), l_{j}\right)\right)$


Fig. 3. Module SUB (simulating $\left.l_{i}:\left(\operatorname{SUB}(r), l_{j}, l_{k}\right)\right)$
covered by module INPUT presented in Figure 4. The neurons $\sigma_{c_{1}}, \sigma_{c_{2}}$ fire only after receiving the third spike, and then they send two spikes to neuron $\sigma_{l_{0}}$, thus starting the simulation of $M_{u}$. At that moment, neurons $\sigma_{1}$ and $\sigma_{2}$ are already loaded: neurons $\sigma_{c_{3}}$ and $\sigma_{c_{4}}$ send to neuron $\sigma_{1}$ as many pairs of spikes as the number of steps between the first two input spikes, and after that they get "over flooded" by the second input spike and are blocked; in turn, neurons $\sigma_{c_{5}}, \sigma_{c_{6}}$ start working only after collecting two spikes and stop working after receiving the third spike.


Fig. 4. Module INPUT

The second task needs a modification in the universal register machine: the construction from [3] does not allow subtraction operations on the neuron where we place the result, but register 0 of $M_{u}$ is subject of such operations. That is why we have to add a further register - we label it with 8 - and we replace the halt instruction of $M_{u}$ with the following instructions:

$$
l_{h}:\left(\operatorname{SUB}(0), l_{22}, l_{h}^{\prime}\right), \quad l_{22}:\left(\operatorname{ADD}(8), l_{h}\right), \quad l_{h}^{\prime}: \operatorname{HALT} .
$$

In this way, we have 9 registers, 24 ADD and SUB instructions, and 25 labels.
We denote by $M_{u}^{\prime}$ the obtained register machine.
Having the result of the computation in register 8 , which is never decremented during the computation, we can output the result by means of the module OUTPUT from Figure 5. When neuron $\sigma_{l_{h}^{\prime}}$ receives two spikes, it fires and sends a spike to neuron $\sigma_{8}$; in this way, the number of spikes of this neuron becomes odd, hence its rule can be applied. A spike arrives in the output neuron, which spikes. From the next step on until exhausting the spikes from neuron $\sigma_{8}$, the output neuron receives two spikes (one from $\sigma_{8}$ and one from $\sigma_{d_{1}}$ ), hence neuron $\sigma_{\text {out }}$ collects an even number of spikes and cannot fire. When neuron $\sigma_{8}$ has only one spike, it cannot fire anymore, but one further spike comes in neuron $\sigma_{\text {out }}$ from neuron $\sigma_{d_{1}}$, and thus the output neuron spikes for the second (and last) time.

The overall design of the system is given in Figure 6.
Thus, we have


Fig. 5. Module OUTPUT

| 9 neurons | for the 9 registers, |
| ---: | :--- |
| 25 neurons | for the 25 labels, |
| 48 neurons | for the 24 ADD and SUB instructions, |
| 7 neurons | in the INPUT module, |
| 2 neurons | in the OUTPUT module, |

which comes to a total of 91 neurons.
This number can be slightly decreased, by some "code optimization", exploiting some particularities of the register machine $M_{u}^{\prime}$.

First, let us observe that the sequence of two consecutive ADD instructions

$$
l_{17}:\left(\operatorname{ADD}(2), l_{21}\right), \quad l_{21}:\left(\operatorname{ADD}(3), l_{18}\right),
$$

without any other instruction addressing the label $l_{21}$, can be simulated by the module from Figure 7, and in this way we save the neuron associated with $l_{21}$ and instead of four auxiliary neurons used in the two separate ADD instructions we use two neurons.

A similar operation is possible for the following two sequences of ADD - SUB instructions, where again we can save the intermediate labels ( $l_{6}$ and $l_{10}$ ), as well as one auxiliary neuron for each pair:

$$
\begin{aligned}
& l_{5}:\left(\operatorname{ADD}(5), l_{6}\right), \quad l_{6}:\left(\operatorname{SUB}(7), l_{7}, l_{8}\right), \\
& l_{9}:\left(\operatorname{ADD}(6), l_{10}\right), \quad l_{10}:\left(\operatorname{SUB}(4), l_{0}, l_{11}\right) .
\end{aligned}
$$

Instead of the modules ADD and SUB as in Figures 2 and 3, for each couple of instructions as above we can use a module as that from Figure 8, where the labeling of neurons corresponds to the first couple of instructions mentioned above.


Fig. 6. The general design of the universal SN P system

A similar module is used for the second pair of instructions. In each case, we save two neurons; together with the three neurons saved by the module in Figure 7 , we get the improvement from 91 to 84 neurons.

We state this result in the form of a theorem in order to stress its importance:
Theorem 1. There is a universal computing $S N P$ system with standard rules having 84 neurons.

In the register machine $M_{u}^{\prime}$ there are also couples of SUB - ADD instructions with the label of the second instruction used only in the first instruction, but we were not able to find a coupled module for this case with a smaller number of neurons than in the two SUB and ADD modules given in Figures 2 and 3.

## 4 Using More General Rules

In several of the modules constructed in the previous section we need pairs of intermediate neurons for duplicating the spike which is transmitted further (such


Fig. 7. A module simulating two consecutive ADD instructions


Fig. 8. A module simulating consecutive ADD - SUB instructions
as $\sigma_{l_{i}^{\prime}}$ and $\sigma_{l_{i}^{\prime \prime}}$ in Figure 2), and this suggests to consider an extension of the rules of SN P systems: to allow spiking rules of the form $E / a^{c} \rightarrow a^{p} ; d$, where all components are as usual, and $p \geq 1$. To be "realistic" (conservative), we impose the restriction $c \geq p$ (the number of produced spikes is not larger than the number of consumed spikes).

The rules of this type are said to be extended.

For reasons which will become apparent below, in this section we return to the initial universal register machine $M_{u}$, hence having 8 registers (with the result placed in register 0) and 23 instructions.

Using extended rules, the modules for the simulation of ADD and SUB instructions become smaller in the number of neurons, but more complex in the functioning - see Figures 9, 10. Moreover, the delay from firing to spiking is always zero, that is why from now on we do not mention the delay when writing the rules.

This time, the encoding of the value $n$ of a register $r$ is done by means of placing $6 n$ spikes in the neuron $\sigma_{r}$ associated with the register. That is why, the neuron $\sigma_{l_{i}}$ corresponding to an ADD instruction $l_{i}:\left(\operatorname{ADD}(r), l_{j}\right)$ has to produce 6 spikes, which are sent both to neuron $\sigma_{r}$ and to the neuron with the label $l_{j}$. If $l_{j}$ is a label which also appears in a SUB instruction, then, as one can see in Figure 10, neuron $\sigma_{l_{j}}$ also fires when receiving 10 or 11 spikes, that is why we also have the rules $a^{10} \rightarrow a^{6}$ and $a^{11} \rightarrow a^{6}$ present in neuron $\sigma_{l_{i}}$. Similarly, because the neurons $\sigma_{l_{i}}, \sigma_{l_{j}}$ can be involved in SUB instructions, we have considered the forgetting rules $a^{7} \rightarrow \lambda, a^{8} \rightarrow \lambda, a^{9} \rightarrow \lambda$, and $a^{13} \rightarrow \lambda$ in both these neurons in Figure 9 . The significance/value of $\delta\left(l_{j}\right)$ will be specified immediately.


Fig. 9. Module ADD (simulating $\left.l_{i}:\left(\operatorname{ADD}(r), l_{j}\right)\right)$ for extended rules

The simulation of a $\operatorname{SUB}$ instruction $l_{i}:\left(\operatorname{SUB}(r), l_{j}, l_{k}\right)$ proceeds as follows. Assume that at some moment, neuron $\sigma_{l_{i}}$ receives either 6 spikes (if $l_{i}$ is the "output" label of an ADD instruction), or 10 or 11 spikes (if $l_{i}$ is an "output" label of a SUB instruction), and fires, producing 4 spikes. These spikes are sent at the same time to all neurons $\sigma_{r}, \sigma_{l_{i}^{\prime}}, \sigma_{l_{j}}$, and $\sigma_{l_{k}}$ from Figure 10. There is no rule for handling 4 spikes in the last two neurons, hence these spikes wait here one step.


Fig. 10. Module $\operatorname{SUB}$ (simulating $\left.l_{i}:\left(\operatorname{SUB}(r), l_{j}, l_{k}\right)\right)$ for extended rules

In the next step, neuron $\sigma_{l_{i}^{\prime}}$ fires and sends three spikes to all neurons $\sigma_{l_{s}}$ of the system such that $\operatorname{SUB}$ instructions $l_{t}:\left(\operatorname{SUB}(r) ; l_{s}, l_{s^{\prime}}\right)$ or $l_{t}:\left(\operatorname{SUB}(r) ; l_{s^{\prime}}, l_{s}\right)$ exist in the register machine $M$, with the exception of $\sigma_{l_{j}}$ (hence to all neurons associated with output labels of SUB instructions which decrement register $r$, but not to $\sigma_{l_{j}}$ ). Simultaneously, $\sigma_{r}$ spikes, because its rules are now applicable, the number of spikes it holds is no longer a multiple of 6 , but it is of the form $6 m+4$ for some
$m \geq 0$. If $m \geq 1$, this means that the register $r$ was non-empty; the subtraction is done by the rule $a^{4}\left(a^{6}\right)^{+} / a^{10} \rightarrow a^{6}$. Note that in this way the number of spikes remaining in neuron $\sigma_{r}$ returns to a multiple of 6 . The six spikes arrive at the same time in all neurons associated with output labels of SUB instructions which decrement register $r$. In neuron $\sigma_{l_{j}}$ we have in this way 10 spikes (four were waiting here from the previous step), and this neuron can fire. In neuron $\sigma_{l_{k}}$ we have 13 spikes ( 6 coming from $\sigma_{r}, 4$ waiting here, and 3 just arrived from $\sigma_{l_{i}^{\prime}}$ ), and they are removed by the forgetting rule $a^{13} \rightarrow \lambda$. In all other neurons associated with output labels of SUB instructions which decrement register $r$ we have 9 spikes, and also they are immediately forgotten by the rule $a^{9} \rightarrow \lambda$ placed in all neurons associated with labels of $M_{u}$.


Fig. 11. The INPUT module in the case of extended rules

If register $r$ was empty, this means that after $\sigma_{l_{i}}$ fires, we have only four spikes in neuron $\sigma_{r}$, hence the rule $a^{4} \rightarrow a^{4}$ is used. This time, neuron $\sigma_{l_{j}}$ gets only 8 spikes, and they are removed, but neuron $\sigma_{l_{k}}$ gets 11 spikes, and fires. All other neurons associated with output labels of SUB instructions which decrement register $r$ have 7 spikes ( 4 from $\sigma_{r}$ and 3 from $\sigma_{l_{i}^{\prime}}$ ) and these spikes are removed by the rule $a^{7} \rightarrow \lambda$ present in all these neurons.

In all cases, the simulation of the SUB instruction is correct: we start by activating the neuron $\sigma_{l_{i}}$, we subtract 1 from the contents of register $r$ (i.e., we remove 6 spikes from neuron $\sigma_{r}$ ) if this is possible, and we continue by activating neuron $\sigma_{l_{j}}$, or, if the register was empty, we just pass to activating neuron $\sigma_{l_{k}}$. No spike remains in any other neuron of the form $\sigma_{l_{s}}$ which was involved in this operation.

It is important to note that the neurons $\sigma_{l_{i}}$ associated with ADD instructions are different from those associated with SUB instructions: in the first case we have
to produce six spikes, in the latter case four. In Figures 9 and 10 we have indicated this by writing the respective rules in the form $a^{11} \rightarrow a^{\delta\left(l_{j}\right)}, a^{10} \rightarrow a^{\delta\left(l_{j}\right)}$, and $a^{6} \rightarrow a^{\delta\left(l_{j}\right)}$, where

$$
\delta(l)= \begin{cases}6 & \text { if } l \text { is the label of an ADD instruction, } \\ 4 & \text { if } l \text { is the label of a SUB instruction }\end{cases}
$$

The simulation of instructions of $M_{u}$ is achieved in this way. The computation in our SN P system halts if and only if the computation in $M_{u}$ halts, which means that the halting instruction is reached.

We have now to see how the INPUT and the OUTPUT modules look like in the case of extended rules. Figures 11 and 12 present these modules. We leave to the reader the task of checking the functioning of the INPUT module (note that $l_{0}$ is the label of a SUB instruction of $M_{u}$ ), and we only briefly describe here the work of the OUTPUT module.

We start by activating neuron $\sigma_{l_{h}}$ associated with the halt label of $M_{u}$. (From Figure 1 we know that $l_{h}$ is present only in a SUB instruction of $M_{u}$ as an output label, that is why we do not need a rule $a^{6} \rightarrow a^{3}$ in this neuron.) When firing, $\sigma_{l_{h}}$ produces 3 spikes, which are sent to neuron $\sigma_{0}$. The number of spikes from $\sigma_{0}$ is of the form $6 m+3, m \geq 0$, hence (i) the rules mentioned in Figure 12 for $\sigma_{0}$ can fire, but (ii) no rule used for SUB instructions (like in Figure 10) can fire (they need $6 m+4$ spikes).

This way to avoid the conflict in using the same neuron in two types of operations is the basis for avoiding the two additional instructions of $M_{u}^{\prime}$ in comparison with $M_{u}$, as well as the additional register 8 .

Now, if register 0 is empty, then we use the rule $a^{3} \rightarrow a^{3}$ of $R_{0}$ immediately after activating neuron $\sigma_{l_{h}}$; the system spikes only once, hence it outputs the number 0 . If register 0 is not empty, then for each unit (for each six spikes from $\sigma_{0}$ ) we use once the rule $a^{3}\left(a^{6}\right)^{+} / a^{6} \rightarrow a^{2}$. This rule does not change the arity of the number of spikes, hence it is used until only 3 spikes remain in $\sigma_{0}$. When the first two spikes arrive in $\sigma_{\text {out }}$, this neuron spikes. All subsequent pairs of spikes sent from $\sigma_{0}$ to $\sigma_{\text {out }}$ are forgotten. The last time when $\sigma_{0}$ spikes, it uses the rule $a^{3} \rightarrow a^{3}$, hence again $\sigma_{\text {out }}$ spikes - and then the system halts. In this way, we get the spike train $10^{n-1} 1$, encoding the number $n$ as the result of the computation.

From Figures 11 and 12 one sees that, in comparison with Figures 4 and 5, we save two neurons in the first case and one in the second.

The same happens with both intermediate neurons in the ADD + ADD module from Figure 7 (using the ADD +ADD module instead of two ADD modules, a label-neuron is saved): we directly send 6 spikes to each neuron $\sigma_{l_{18}}, \sigma_{2}, \sigma_{3}$ from Figure 7.

In this way, our system will contain


Fig. 12. The OUTPUT module in the case of extended rules.

| 8 neurons | for the 8 registers, |
| ---: | :--- |
| 22 neurons | for the 22 labels (one is saved in the ADD + ADD module), |
| 13 neurons | for the 13 SUB instructions, |
| 5 neurons | in the INPUT module, |
| 1 neuron | in the OUTPUT module, |

which means in total 49 neurons.
It is also worth noting that all spiking rules from our system have no delay from firing to spiking.

Theorem 2. There is a universal computing $S N P$ system with extended rules (without delay) which has 49 neurons.

## 5 Universal SN P Systems as Number Generators

Let us now consider the case when with an SN P system $\Pi$ we associate a set $N(\Pi)$ of numbers as in [3]: the system starts working in its initial configuration;
because of the non-determinism in using the spiking rules, several computations are possible; any halting computation provides a result, in the form of the number of time units between the first two steps when any spike exits the system. Note that this definition covers both the case of restricted rules, with only one spike emitted in a time unit by the output neuron, and the case of extended rules, where it is possible that several spikes are emitted at the same time (they are perceived in the environment of the system as a single spike; however, in order to avoid any complication, in the constructions below we make sure that the output neuron produces always only one spike).

In this framework, an SN P system $\Pi_{u}$ is universal if, given a fixed admissible enumeration of the unary partial recursive functions, $\left(\varphi_{0}, \varphi_{1}, \ldots\right)$, there is a recursive function $g$ such that for each natural number $x$, if we input the number $g(x)$ in $\Pi_{u}$, by "reading" the sequence $10^{g(x)-1} 1$ from the environment, the set of numbers generated by the system is equal to $\left\{n \in \mathbf{N} \mid \varphi_{x}(n)\right.$ is defined $\}$. Otherwise stated, after introducing the "code" $g(x)$ of the partial recursive function $\varphi_{x}$ in a specified neuron, the system generates (hence halts sometimes after sending two spikes out) all numbers $n$ for which $\varphi_{x}(n)$ is defined.

This time, the strategy followed by the universal system is the following:

1. Read the string $10^{g(x)-1} 1$ from the environment and load $2 g(x)$ spikes in neuron $\sigma_{1}$.
2. Load neuron $\sigma_{2}$ non-deterministically with an arbitrary natural number $n$ (in the case of using restricted rules this means to introduce $2 n$ spikes in neuron $\sigma_{2}$ and in the case of extended rules means to introduce $6 n$ spikes); at the same time, output the spike train $10^{n-1} 1$ (hence the number $n$ ).
3. Check whether the function $\varphi_{x}$ is defined for $n$. To this aim, start the register machine $M_{u}$ from Figure 1, with $g(x)$ in register 1 and $n$ in register 2. If the computation in $M_{u}$ halts, then also the computation in our SN P system halts, hence $n$ is introduced in the set of generated numbers.
It is worth noting that there is an essential difference between number generating and function computing: we no longer need to output a result after halting the computation, but we have to randomly generate a number at the beginning of the computation. In this way, we have two important consequences for our construction, a simplification and a supplementary task. First, no separate output module is necessary, the additional register 8 can be omitted, and the simulation of the last SUB instruction used in a halting computation, $l_{18}:\left(\operatorname{SUB}(4), l_{0}, l_{h}\right)$, can be simplified, just ignoring $l_{h}$ and halting. On the other hand, the input module should be combined with the output one, at the same time non-deterministically producing the number $n$.

The combined INPUT-OUTPUT module for the case of restricted rules is presented in Figure 13.

After loading neuron $\sigma_{1}$ with $2 g(x)$ spikes, we start loading neuron $\sigma_{2}$ with an arbitrary number of spikes, by means of neurons $\sigma_{c_{4}}$ and $\sigma_{c_{5}}$, at the same time sending out the respective number as the distance between two spikes emitted by


Fig. 13. The INPUT-OUTPUT module for the number generating universal SN P systems
neuron $\sigma_{\text {out }}$. The work of neurons $\sigma_{c_{4}}, \sigma_{c_{5}}$ stops when neuron $\sigma_{c_{3}}$ uses the rule $a^{2} \rightarrow a ; 1$, and only after that (after having two spikes emitted by $\sigma_{\text {out }}$ ) we load neuron $\sigma_{l_{0}}$ with two spikes (via neurons $\sigma_{c_{7}}, \sigma_{c_{8}}$ ) and in this way we start the work of the register machine $M_{u}$.

In turn, the simplified module for simulating the instruction $l_{18}:\left(\operatorname{SUB}(4), l_{0}, l_{h}\right)$ is given in Figure 14: when the subtraction is no longer possible, we just halt.

Consequently, the obtained system contains


Fig. 14. The simplified module for simulating $l_{18}:\left(\operatorname{SUB}(4), l_{0}, l_{h}\right)$

8 neurons for the 8 registers,
22 neurons for the 22 labels ( $l_{h}$ is saved),
42 neurons for the 21 ADD and SUB instructions,
1 neuron for the special SUB instruction (Figure 14),
10 neurons in the INPUT-OUTPUT module,
which means in total 83 neurons. From them, 7 neurons can be saved in the way we have proceeded in the end of Section 3, hence we can conclude with the following result:

Theorem 3. There is a universal number generating SN $P$ system with standard rules having 76 neurons.

Passing now to extended rules, we can have the INPUT-OUTPUT module as shown in Figure 15.

This time the system contains 8 neurons for registers, 21 neurons for labels (besides the label saved in the ADD +ADD module, we also save $l_{h}$ ), 13 for SUB instructions, and 8 neurons in the INPUT-OUTPUT module, in total 50 neurons.

Again, the rules use no delay between firing and spiking.
Theorem 4. There is a universal number generating SN P system with extended rules (without delay) having 50 neurons.

## 6 Closing Remarks

It remains as an open problem to decrease the number of neurons from our universal SN P systems. Is this possible in the setups used here? As said in the Introduction, we conjecture that significant improvements are not possible.


Fig. 15. The INPUT-OUTPUT module in the extended case

Another direction of research is to look for the borderline between universality and non-universality also starting from below: what is the number of neurons for which we can prove that an SN P system is not universal? Besides trivial observations (at least three neurons are necessary, one input, one output, and one "working" neuron) we do not have any better estimation at this moment.

Of course, some neurons can be saved if the input to the universal SN P system and its output are not introduced/emitted by means of input or output neurons as above, but simply placed in the necessary neurons. Input-output modules are then saved, but we do not find such a definition "fair", because a "brain" should have interfaces with its environment.

Anyway, the results above look rather optimistic: there exist pretty small universal "brains" (it would be of interest to see where on the evolution scale there are animals with the brain of comparable sizes...).

Note. Useful discussions with Rudi Freund and Takashi Yokomori are gratefully acknowledged.

## References

1. E. Csuhaj-Varju, M. Margenstern, G. Vaszil, S. Verlan: Small computationally complete symport/antiport P systems. In volume I of the present proceedings.
2. O.H. Ibarra, A. Păun, Gh. Păun, A. Rodríguez-Patón, P. Sosik, S. Woodworth: Normal forms for spiking neural P systems. In the present volume.
3. M. Ionescu, Gh. Păun, T. Yokomori: Spiking neural P systems. Fundamenta Informaticae, 71, 2-3 (2006), 279-308.
4. I. Korec: Small universal register machines. Theoretical Computer Science, 168 (1996), 267-301.
5. W. Maass: Computing with spikes. Special Issue on Foundations of Information Processing of TELEMATIK, 8, 1 (2002), 32-36.
6. W. Maass, C. Bishop, eds.: Pulsed Neural Networks. MIT Press, Cambridge, 1999.
7. M. Minsky: Computation - Finite and Infinite Machines. Prentice Hall, Englewood Cliffs, New Jersey, 1967.
8. Gh. Păun: Membrane Computing - An Introduction. Springer-Verlag, Berlin, 2002.
9. Gh. Păun, M.J. Pérez-Jiménez, G. Rozenberg: Spike trains in spiking neural P systems. International Journal of Foundations of Computer Science, to appear (also available at [15]).
10. Gh. Păun, M.J. Pérez-Jiménez, G. Rozenberg: Infinite spike trains in spiking neural P systems. Submitted, 2006.
11. Y. Rogozhin: Small universal Turing machines. Theoretical Computer Science, 168 (1996), 215-240.
12. J. van Leeuwen, ed.: Handbook of Theoretical Computer Science. Elsevier, Amsterdam, 1990.
13. Y. Rogozhin, S. Verlan: On the rule complexity of universal tissue P systems. In Membrane Computing, International Workshop, WMC6, Vienna, Austria, 2005, Selected and Invited Papers (R. Freund, Gh. Păun, G. Rozenberg, A. Salomaa, eds.), LNCS 3850, Springer-Verlag, Berlin, 2006, 356-363.
14. D. Wood: Theory of Computation. Harper and Row, New York, 1987.
15. The P Systems Web Page: http://psystems.disco.unimib.it.
