Article

# Spiking Neural P Systems for Basic Arithmetic Operations 

Xiong Chen and Ping Guo *<br>College of Computer Science, Chongqing University, Chongqing 400044, China; 202214131129@stu.cqu.edu.cn<br>* Correspondence: guoping@cqu.edu.cn; Tel.: +86-137-5298-5479

Citation: Chen, X.; Guo, P. Spiking Neural P Systems for Basic Arithmetic Operations. Appl. Sci. 2023, 13, 8556. https://doi.org/ 10.3390/app13148556

Academic Editor: Christos Bouras
Received: 10 June 2023
Revised: 12 July 2023
Accepted: 22 July 2023
Published: 24 July 2023


[^0]
#### Abstract

As a novel biological computing device, the Spiking Neural P system (SNPS) has powerful computing potential. The application of SNPS in the field of arithmetic operation has been a hot research topic in recent years. Researchers have proposed methods and systems for implementing basic arithmetic operations using SNPS. This paper studies four basic arithmetic operations, improves the parallelization of addition and multiplication methods, and designs more effective natural number addition and multiplication SNPS, as well as SNPS for subtraction and for division of natural numbers based on multiple subtractions. The effectiveness of the proposed SNPS is verified by example. Compared with the same kind of SNPS, for the addition operation the number of neurons used in our system is reduced by $50 \%$ and the time overhead is reduced by $33 \%$, while for the multiplication operation the number of neurons is reduced by $40 \%$.


Keywords: arithmetic operations; spiking neural p systems; membrane computing; numerical computing

## 1. Introduction

Membrane computing [1] is a branch of natural computing inspired by the structure and functionality of living cells. In a research report in 1998, Gh. Păun, a member of the Romanian Academy, proposed the P system, a distributed and parallel computing model. Each membrane of a biological cell can be regarded as a separate computing unit to perform the corresponding calculation. With the incredible number of cells in living organisms and the low energy requirements for biochemical reactions, one of the greatest advantages of membrane computing is that it enables corresponding computations with maximum parallelism. The literature [2] shows that membrane computing is equivalent to Turing machines, and its powerful parallel computing capability can effectively solve the computing bottlenecks faced by current electronic computers. Research on arithmetic operations based on membrane computing has been performed in cell-like P systems, tissue-like $P$ systems, and neural-like $P$ systems.

In [3], the authors implemented arithmetic operations based on a membrane P System; However, its membrane system structure was complex and did not make full use of the maximum parallelism of membrane computation; In [4], the authors designed a natural coding-based arithmetic P System to implement arithmetic operations, which greatly simplified the membrane system structure; In [5], the authors designed a multi-layer membrane $P$ System to implement unsigned quadratic operations, which reduced the computational complexity, while the authors of [6] designed a single-layer membrane P System to implement arithmetic operations, further simplifying the membrane structure and improving computational efficiency. The authors of [7] designed a multi-layer membrane P System to implement arithmetic operations with signed numbers, improving the application range and execution efficiency of basic operations, while in [8-10] the authors designed a singlelayer membrane P System to implement expression evaluation in the domain of integers. Reference [11] implemented basic arithmetic operations by the P System in the domain of rational numbers, expanding the scope of application of arithmetic operations in P System to further enhance the computing power of biological computers, while [12] investigated
the computational power of tissue $P$ systems where each rule was assigned either a label chosen from the alphabet or an empty label. The sequence of labels of rules applied during halting of computation was defined as the result of the computation, and the set of all results computed by a given tissue $P$ system was called the control language. The results indicated that the rule complexity is crucial in order for tissue $P$ systems to achieve the desired computational power. In [13], the authors constructed a novel computational model called a homeostasis tissue-like P system. Based on the model, it solved the three-coloring problem in linear time within the standard timeframe. Additionally, it addressed the SAT problem using communication rules and multiset rewriting rules with a maximum length of 3 in time-free mode.

In 2006, Dr. M. Ionescu et al. proposed the Spiking Neural P system [14], which utilizes the phenomenon of neurons sending spikes to connected neurons through synapses. The SNPS is composed of a set of neurons and their connections, which are typically abstracted as a directed graph. Neurons are viewed as nodes in the graph, and the connections between neurons are considered as directed edges. Under the control of the system clock and the internal excitation rules of neurons, spike signals propagate along the synapses (represented as directed arcs in the graph) to connected neurons. The execution of the forgetting rules inside neurons simply consumes spikes. In the basic SNPS [14,15], all spikes are indistinguishable and denoted by the same symbol " $a$ ". The operation of the system is synchronous and parallel, which means that all neurons with applicable rules should be executed [16] at each time slice. This distributed and parallel computing model has been shown to be computationally complete $[15,17,18]$.

SNPS research in theory and application has achieved significant results, including generating numbers and languages, simulating logic circuits, system universality, and variants of spiking neural P systems. In [15], the authors showed that the basic SNPS as a device for generating sets of numbers is computationally complete in both generation mode and acceptance mode. In [16], the authors studied the language-generating capacity of SNPS; the recursively enumerable languages are the inverse image projection of the languages generated by SNPS. In [19], the authors investigated the minimum universality of SNPS as a device for computing functions and generating numbers and provided the minimum number of neurons to produce a universal SNPS using extension rules and standard rules. A restricted-rule universal system requires 76 neurons, while a universal system with extension rules only requires 50 neurons. In [20], the authors introduced a variant of SNP where neurons only contain spikes and the rules are on synapses. When the number of spikes in a given neuron matches the rule on the synapse, the rule is triggered. Compared with the SNPS in [19], a number generator constructed based on this variant SNPS requires only 39 neurons to achieve universality under standard rules, and only 30 neurons are needed when using extension rules. Many variants of SNPS have been proven to be Turing universal, such as the asynchronous spiking neural $P$ system with local synchronization introduced in [21] and the SNPS with weights introduced in [22], where the applicability of the spike rules is controlled by a given discharge threshold. When integers are used to represent the weight, potential, and threshold parameters, this SNPS is universal. When natural numbers are used for these parameters, the characteristic of natural semilinear sets can be obtained. In [23], the aim was to address the limitations of current SNP systems in handling specific real-world data technology. Neural network structures and data processing methods were considered as a reference to improve upon these limitations. By integrating these concepts with membrane computing, spiking neural membrane computing models (SNMC models) were proposed. The paper successfully demonstrated the Turing universality of the SNMC model as a number generator and acceptor. The authors of [24] introduced neuron division and neuron budding into the framework of the spiking neural P system. A neuron can be divided into two and every budding can only produce one new neuron, proving that SNPS with neuron division and neuron budding can solve NP-complete problems in polynomial time. The Directed Hamiltonian Path (DHP) problem is an NP-hard problem, and the algorithm based on

SNPS proposed by [25] effectively reduces the time complexity through massive parallelism. In [26], the authors introduced fuzzy reasoning in SNPS to establish a connection between $P$ systems and fault diagnosis applications for the automatic implementation of complex power system fault diagnosis. Reference [27] introduced a Spiking Neural P System with spikes and anti-spikes. Biologically, spikes represent neural excitation while anti-spikes represent neural inhibition. When a spike meets an anti-spike, they cancel each other out and disappear. Based on this rule, the proof of Turing completeness of SNPS and the required rules are simplified: all rules have a singleton regular expression that precisely indicates the number of spikes or anti-spikes to be consumed.

Implementing addition, subtraction, multiplication and division on SNPS is the basis for designing a biological CPU based on the SNP system. By encoding the number as the time interval between two spikes, the literature [28] constructed four SNP systems for calculating addition, subtraction, multiplication, and division, respectively. In [29], the author encoded the number as spike sequences and designed an operation model based on SNPS to realize the addition and subtraction of two natural numbers, the multiplication of a fixed multiplicand, an arbitrary multiplier, and judging whether two numbers are equal. The SNPS operation model designed in [30] can solve the product of any two natural numbers with a binary bit length of $k$ bits, and can solve the summation problem of $n$ natural numbers. In [31], simple arithmetic problems were addressed using the spiking neural p system, including binary complement conversion, addition and subtraction of signed integers, and multiplication of any two natural numbers.

The motivation of the present study is to design arithmetic SNPS that are fast and contain fewer neurons and rule types. We encoded numbers as spike sequences and utilized a single input neuron and a single output neuron to design a complete set of addition, subtraction, multiplication, and division operations in SNPS based on extended rules. We analyzed the number of neurons, types of rules, and required time slices for each system. The main contributions of this paper include:
(1) Designing the SNPS $\Pi_{B A S N P}$ for k-bit binary addition. The system can complete the addition of two $k$-bit binary numbers in $2 \mathrm{k}+4$ time slices using $\mathrm{k}+8$ neurons, three types of instantaneous firing rules, and three types of forgetting rules.
(2) Designing the SNPS $\Pi_{B S S N P}$ for k-bit binary subtraction. The system can complete the subtraction of two $k$-bit binary numbers in $2 k+3$ time slices using $k+13$ neurons, seven types of instantaneous firing rules, and four types of forgetting rules.
(3) Designing the SNPS $\Pi_{B M S N P}$ for k-bit binary multiplication. The system can complete the multiplication of two k -bit binary numbers in $3 \mathrm{k}+5$ time slices using $3 \mathrm{k}+8$ neurons, five types of instantaneous firing rules, and four types of forgetting rules.
(4) Designing the SNPS $\Pi_{B D S N P}$ for k-bit binary division. The system can complete the division of two k-bit binary numbers in $2 k+$ quotient +4 time slices using $5 k+12$ neurons, sixteen types of instantaneous firing rules, and thirteen types of forgetting rules.

Based on instance-based analysis, the effectiveness of the four SNPS designed in this paper is verified. The rest of the paper is organized as follows. Section 2 briefly introduces the basic knowledge and related research on SNPS, Section 3 presents the designed addition, subtraction, multiplication, and division SNPS and instance analysis, and Section 4 summarizes and analyzes various known arithmetic SNPS from multiple dimensions. Finally, Section 5 summarizes the whole work.

The SNP operation model proposed in this paper uniformly uses a single input and output neuron, and a new way of input data construction was constructed. In the addition and multiplication computational models we constructed, we reduce the number of neurons used compared to the addition and multiplication proposed in [30]. Based on multiple subtraction operations, in this we paper achieve the division of any two natural numbers, and the running time of this division model is positively correlated with the size of the quotient.

## 2. Related Research

Spiking neural P (SN P) systems are a class of discrete neuron-inspired computation models where information is encoded by the numbers of spikes in neurons and the timing of spikes. In a spiking neural P system a spike refers to an object in a neuron, which represents the substance in a neuronal cell. In a spiking neural $P$ system only one object is allowed in each neuron; the number of objects (spikes) is used to encode (represent) the corresponding information, such as the summand and addend in addition.

### 2.1. Spiking Neural P Systems

A Spiking Neural $P$ system of degree $m(m \geq 1)$ is formally defined as Formula (1) [14,17,29-32]:

$$
\begin{equation*}
\Pi=\left(\mathrm{O}, \sigma_{1}, \sigma_{2}, \ldots, \sigma_{m}, \text { syn, in, out }\right) \tag{1}
\end{equation*}
$$

where:
(1) $\mathrm{O}=\{a\}$ is a singleton alphabet, where $a$ is called a spike; $\sigma_{1}, \sigma_{2}, \ldots, \sigma_{m}$ are neurons of the form $\sigma_{i}=\left(\mathrm{n}_{i}, \mathrm{R}_{i}\right)$ in the $\Pi$ system, with $1 \leq i \leq \mathrm{m}$. Where $\mathrm{n}_{i} \geq 0$ is the number of spikes in neuron $\sigma_{i}$ in the initial configuration, $\mathrm{R}_{i}$ is a finite set of rules of the following two forms:
(i) spiking rule: $\mathrm{E} / a^{c} \rightarrow a^{p} ; d$, where E is a regular expression over O , and $c \geq 1$, $d \geq 0, p \geq 1, c \geq p ;$
(ii) forgetting rule: $\mathrm{E}^{\prime} / a^{\mathrm{s}} \rightarrow \lambda$, where $\mathrm{E}^{\prime}$ is a regular expression over $\mathrm{O}, \mathrm{s} \geq 1$, furthermore, for each rule $\mathrm{E} / a^{c} \rightarrow a^{p} ; d$ in the rule set $\mathrm{R}_{i}$ of type (i), it holds that $L(E) \cap L\left(E^{\prime}\right)=$, where $L(E)$ is the language generated by $E$.
(2) $\operatorname{syn} \subseteq\left\{\sigma_{1}, \sigma_{2}, \ldots, \sigma_{m}\right\} \times\left\{\sigma_{1}, \sigma_{2}, \ldots, \sigma_{m}\right\}$ is a finite set of synapses between neurons. $\left(\sigma_{i}, \sigma_{j}\right) \in \operatorname{syn}$ means that there is a synaptic connection from $\sigma_{i}$ to neuron $\sigma_{j}$. For any $i$, $1 \leq i \leq m,\left(\sigma_{i}, \sigma_{i}\right) \notin s y n ;$
(3) in, out $\in\left\{\sigma_{1}, \sigma_{2}, \ldots, \sigma_{m}\right\}$ indicate the input and output neurons, respectively. In particular, we use $\sigma_{0}$ to denote the environment of the system.
The explanation of the rules is as follows: if a firing rule $\mathrm{E} / a^{\mathrm{C}} \rightarrow a^{p} ; d$ satisfies $p=1$ and a forgetting rule $\mathrm{E}^{\prime} / a^{\mathrm{s}} \rightarrow \lambda$ satisfies $\mathrm{E}^{\prime}=a^{\mathrm{s}}$, they are respectively called a standard firing rule and standard forgetting rule. If the firing rule $\mathrm{E} / a^{c} \rightarrow a^{p} ; d$ satisfies $\mathrm{E}=a^{c}$, it is usually written as $a^{c} \rightarrow a^{p} ; d$. If the firing rule $\mathrm{E} / a^{\mathrm{c}} \rightarrow a^{p} ; d$ satisfies $d=0$, it is called a no-delay firing rule and written as $\mathrm{E} / a^{c} \rightarrow a^{p}$. If the firing rule $\mathrm{E} / a^{c} \rightarrow a^{p} ; d$ satisfies both $\mathrm{E}=a^{c}$ and $d=0$, it is abbreviated as $a^{c} \rightarrow a^{p}$. Similarly, if the forgetting rule $\mathrm{E}^{\prime} / a^{s} \rightarrow \lambda$ satisfies $\mathrm{E}^{\prime}=a^{s}$, it can be abbreviated as $a^{s} \rightarrow \lambda$.

The usage of a spiking rule is as follows: at a certain moment, if the neuron $\sigma_{i}$ contains spikes and there exists $a^{k} \in \mathrm{~L}(\mathrm{E})$ and $k \geq c$, then the neuron $\sigma_{i}$ can activate the spiking rule $\mathrm{E} / a^{c} \rightarrow a^{p} ; d$, consuming $c$ spikes (leaving $k-c$ spikes), and after $d$ time slices, emit $p$ spikes to all the neurons it is connected to. Additionally, during the period of sending $d$ spikes after using this rule, the neuron $\sigma_{i}$ is in a closed state, which means it cannot use any rules or receive spikes from other neurons. Only after $\sigma_{i}$ becomes open (after $d$ time slices) can it use rules and receive spikes. If a neuron sends spikes to a closed neuron, these spikes will naturally disappear. For an output neuron, it can send spikes to the environment.

The usage of the forgetting rule is as follows: at a certain moment, if the neuron $\sigma_{i}$ contains $k^{\prime}$ spikes and satisfies $a^{k^{\prime}} \in \mathrm{L}\left(\mathrm{E}^{\prime}\right)$ and $k^{\prime} \geq \mathrm{s}$, this neuron can use the forgetting rule $\mathrm{E}^{\prime} / a^{\mathrm{s}} \rightarrow \lambda$, which consumes $s$ spikes and does not generate new spikes.

If multiple spiking rules are satisfied in a single neuron, it will randomly choose one of them to execute. For example, if there are two spiking rules in neuron $\sigma_{i}, \mathrm{E}_{1} / a^{c} \rightarrow \mathrm{a}^{p 1}$; $d_{1}$ and $\mathrm{E}_{2} / a^{c 2} \rightarrow a^{p 2} ; d_{2}$, with $\mathrm{L}(\mathrm{E} 1) \cap \mathrm{L}(\mathrm{E} 2) \neq, \sigma_{i}$ can only randomly choose one of them to use. This is the uncertainty of rule usage. While the usage of rules in a single neuron is serial, all neurons in the entire system work in parallel.

To describe the temporal evolution of each neuron in the SNP system, it is assumed that there is a unified clock in the system and timing is done using time slice. Its pattern at time slice $k$ can be defined as $\mathrm{C}_{\mathrm{k}}=\left(\mathrm{r}_{1}{ }^{(k)} / \mathrm{t}_{1}{ }^{(k)}, \mathrm{r}_{2}{ }^{(k)} / \mathrm{t}_{2}{ }^{(k)}, \ldots, \mathrm{r}_{m}{ }^{(k)} / \mathrm{t}_{m}{ }^{(\mathrm{k})}\right)$. Here, $\mathrm{r}_{i}{ }^{(k)}(1 \leq i \leq m)$ denotes the number of spikes contained in neuron $\sigma_{i}$ at time $k$ and $\mathrm{t}_{i}{ }^{(k)}$ represents the number of time slices needed for $\sigma_{i}$ to reach an open state starting from time slice $k$. In particular, the initial pattern of the system can be represented as $C_{0}=\left\{r_{1}{ }^{(0)} / 0, r_{2}{ }^{(0)} / 0, \ldots, r_{m}{ }^{(0)} / 0\right\}$. Through the execution of rules, the transformation of the pattern of the $\Pi$ system is called computation. A pattern in which all neurons in the system are in an open state and no rules can be used is called a termination pattern, and a computation that can reach a termination pattern is called a terminable computation.

In terminating computations, there are two encoding methods for representing the computation result $[32,33]$. The first method represents an operandas the number of time slices between two spikes (one binary " 1 " is represented as one spike). The second method represents the generated spike sequence as the computation result (one spike represents the binary digit 1 , and no spike represents the binary digit 0 ), thereby obtaining a binary string. These results can be stored in the neurons of the SNPS or output to the environment.

### 2.2. Research on Arithmetic Operation of SNP

Arithmetic operations are the basis for solving other complex problems and have always been a focus of SNPS research. In [28], the authors encoded the number as the time interval between two spikes to construct four SNP systems for calculating addition, subtraction, multiplication, and division. The number of neurons used was $10,12,22$, and 24 , respectively, and there were $4,4,12$, and 15 rule types, respectively. In [29], numbers were coded into spike sequences and realized in three parts: the addition and subtraction of two natural numbers, the multiplication of fixed multiplicands and arbitrary multipliers, and the judgment of whether two numbers were equal. In this operation model, the addition of two natural numbers used three neurons and three rule types, subtraction used 1 ten neurons and six rule types, and multiplication used thirteen neurons and three rule types. In particular, the multiplier was fixed at 26 and used three neurons and two rule types to judge whether two numbers are equal. This article raised the open problem of how to design SNPS to solve the multiplication of two arbitrary natural numbers. In [30], the authors better answered the question about multiplication proposed by [29]. The designed operation model can solve the product of any two natural numbers of k-bit length binary digits (using $\mathrm{k}^{2}+5 \mathrm{k}+3$ neurons and ten rule types while taking $4 \mathrm{k}+2$ time slices) and designed an operation model that can solve the sum of $n$ natural numbers (using $3 k+5$ neurons and nine rule types). In [31], simple arithmetic problems were addressed using SNPS, including binary complement conversion (using six neurons and four rule types), addition and subtraction of signed integers (using seven neurons and six rule types), and the multiplication of any two natural numbers (using $\mathrm{k}^{2} / 2+15 \mathrm{k} / 2+4$ neurons and six rule types). The operation of signed numbers in [31] was realized based on the sign bit and complement, and the subtraction operation was realized by adding the opposite number of the addend. In [28,29,31], the system had multiple input neurons, while in [30] there was only a single input neuron. In the SNP system mentioned above, the rules in neurons are all executed within one time slice. However, the time required for different biological operations is different as well. In [34], the authors introduced an SNP system with no time limit. This system's rule execution is time-independent and always produces the same result, and it was proven that a time-free SNP system with extended rules is Turing-complete. In [35], the authors studied and designed an adder, subtractor, multiplier, and divider based on the non-time-limited SNP system proposed in [34] using $2,2,11$, and 10 neurons and 2,6 , 15 , and 16 rule types, respectively. In [36], the authors designed the adder and multiplier of the SNPS with rules and weights using $2 k+4,5 k$ neurons and $13, k+14$ rule types, respectively. Based on the SNPS with anti-spikes introduced in [27], the authors of [37] considered the design of general-purpose AND gates, OR gates, and NOT gates for symmetric ternary systems. The three states correspond well to the 1,0 , and -1 of the symmetric
ternary system, which could effectively solve the representation and operation of negative integers. In [37], the authors realized the addition and subtraction of signed integers with an anti-spike neural p system.

In this paper, we only deal with arithmetical operations between natural numbers. For example, when a natural number $n$ is represented in Formula (2), we obtain the corresponding binary string $b_{k-1} \ldots \ldots b_{1} b_{0}$, where $b_{0}$ is the least significant bit, $b_{k-1}$ is the most significant bit, and $2^{i}$ is the order of $2^{i}$, with $0 \leq i \leq k-1$.

$$
\begin{equation*}
n=b_{\mathrm{k}-1} 2^{\mathrm{k}-1}+\ldots \ldots+b_{1} 2^{1}+b_{0} 2^{0}, \quad 0 \leq b_{\mathrm{i}} \leq 1,0 \leq i \leq k-1 \tag{2}
\end{equation*}
$$

## 3. Arithmetic Operation in Spiking Neural P Systems

This part discusses in detail the four arithmetic SNPS designed in this paper. To perform arithmetical operations on SNPS, we input the natural numbers into the system which to be computed and output the computation results. In this paper, we use binary strings to represent natural numbers, and we make the following assumptions:
(1) A unified clock is used to manage and maintain the operation process, with the unit of time being the time slice. The execution of each rule in the SNPS only requires one time slice.
(2) The binary strings involved in the operations have $k$ digits. If a string has less than k digits, it is padded with leading zeros to reach k digits.
(3) The SNPS can accept one binary digit per time slice. When a binary digit of 1 is received, this means the system has received a spike; otherwise, no spike is received. The system receives the input binary string from the least significant bit to the most significant bit.
(4) In the addition, subtraction, and multiplication SNPS the system operation result is outputted by the output neurons from low to high bits in the form of a binary string. In the division SNPS the operation result is stored in a set of result neurons.
(5) In our designed SNPS we set parameter $d$ in the rule description of Formula (1) to 0. This means that both the spiking rule and the forgetting rule will be executed immediately once the conditions are satisfied.
The four SNP operational models proposed in this paper have all been proven to function correctly. Our proof strategy involves tracking the changes in the number of spikes in key neurons over time slices and providing spike count diagrams for the critical patterns of neurons when necessary. For example, Section 3.1 illustrates the pattern of the adder at $\mathrm{t}=\mathrm{k}+2$, where the augend has already been input into the augend cache neuron group. Finally, the system provides the computation result for each digit over the time slice.

### 3.1. Binary Addition in SNP Systems

The addition operation is the foundation of arithmetic operations. It involves adding two binary numbers with the same order while considering the possibility of a carry from the lower order. The basic idea of our designed binary addition SNPS is:
(1) By inputting the binary string of the addend from the lowest bit to the highest bit using the input neuron $\sigma_{\text {input }}$, if the $i$-th bit $(0 \leq i \leq k-1)$ in the input string is 1 , the neuron $\sigma_{\text {input }}$ generates one spike; otherwise, it generates no spike.
(2) After each bit of the augend is input, it is buffered in the system and waits for the input of the addend. When the highest bit of the augend is input, the addend is immediately input.
(3) When the $i$-th bit $(0 \leq i \leq k-1)$ of the augend reaches the addition neuron $\sigma_{\text {Add }}$, the $i$-th bit of the addend is taken out from the buffer and input to $\sigma_{\text {Add }}$. The addition operation is performed by the rules in $\sigma_{\text {Add }}$.
Therefore, the spike neural p system $\Pi_{B A S N P}$ for the k-bit binary number addition designed in this paper includes an input neuron, addition neuron, auxiliary neuron group, augend input auxiliary neuron group, addend input auxiliary neuron group, and augend
cache group of neurons. $\Pi_{B A S N P}$ is defined as in Formula (3), and the membrane structure is shown in Figure 1.


Figure 1. $\Pi_{\text {BASNP }}$ structure diagram.
In particular, in order to simplify the complex connections between neurons, the following conventions are used in the SNPS structure diagram in this paper:

- Neuron-to-neuron connections are indicated by thin arrows, for example, the connection between $\sigma_{a u x 1}$ and $\sigma_{a u x 2}$ in Figure 1.
- Connections of neurons to groups of neurons are indicated by thick arrows. Specifically, if the front end of the thick arrow is a single neuron $\sigma_{0}$, and the end is a neuron group $\sigma_{\mathrm{x}}=\left\{\sigma_{1}, \sigma_{2}, \ldots, \sigma_{n}\right\}$, this means that each neuron $\sigma_{i}(1 \leq i \leq \mathrm{n})$ in neuron $\sigma_{0}$ is connected to neuron group $\sigma_{x}$; on the contrary, if the front end of the thick arrow is a neuron group $\sigma_{x}$, and the end is a single neuron $\sigma_{0}$, this means that each neuron in the neuron group $\sigma_{x}$ has a connection to neuron $\sigma_{0}$.
- Group-to-neuron connections are indicated by thick arrows. If the front end of the thick arrow is a neuron group $\sigma_{x}=\left\{\sigma_{1}, \sigma_{2}, \ldots, \sigma_{n}\right\}$ and the end is a neuron group $\sigma_{x^{\prime}}=\left\{\sigma_{1^{\prime}}, \sigma_{2^{\prime}}, \ldots, \sigma_{n^{\prime}}\right\}$, then two neurons in the same order from the group $\sigma_{x}$ to the neuron group $\sigma_{x^{\prime}}$ are connected, that is, there is a connection from $\sigma_{i}$ to $\sigma_{i^{\prime}}, 1 \leq i \leq \mathrm{n}$.

$$
\begin{equation*}
\Pi_{B A S N P}=\left(\mathrm{O}, \sigma_{a u x 1}, \sigma_{a u x 2}, \ldots, \sigma_{a u x 6}, \sigma_{n u m 1}, \sigma_{n u m 2}, \ldots, \sigma_{n u m k}, \text { syn }, \text { in }, \text { out }\right) \tag{3}
\end{equation*}
$$

where:
(1) $\mathrm{O}=\{a\}$;
(2) $\sigma_{\text {Input }}=\left(0, \mathrm{R}_{\text {Input }}\right), \mathrm{R}_{\text {Input }}=\{a \rightarrow a\}$;
(3) $\sigma_{a u x 1}=\left(1, \mathrm{R}_{a u x 1}\right), \mathrm{R}_{a u x 1}=\{a \rightarrow a\}$;
(4) $\sigma_{a u x 2}=\left(1, \mathrm{R}_{a u x 2}\right), \mathrm{R}_{a u x 2}=\{a \rightarrow a\}$;
(5) $\sigma_{a u x 3}=\left(0, \mathrm{R}_{\text {aux } 3}\right), \mathrm{R}_{\text {aux } 3}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(6) $\sigma_{\text {aux } 4}=\left(0, \mathrm{R}_{\text {aux } 4}\right), \mathrm{R}_{\text {aux } 4}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(7) $\sigma_{a u x 5}=\left(0, \mathrm{R}_{a u x 5}\right), \mathrm{R}_{a u x 5}=\left\{a \rightarrow a ; a^{3} / a \rightarrow \lambda\right\}$;
(8) $\sigma_{a u x 6}=\left(0, \mathrm{R}_{\text {aux6 } 6}\right), \mathrm{R}_{a u x 6}=\left\{a \rightarrow \lambda ; a^{3} / a \rightarrow a\right\}$;
(9) $\sigma_{\text {num } \mathrm{i}}=\left(0, \mathrm{R}_{\text {numi }}\right), \mathrm{R}_{\text {numi }}=\{a \rightarrow a\}, i \in\{1,2, \cdots, k\}$;
(10) $\sigma_{\text {Add }}=\left(0, \mathrm{R}_{\text {Add }}\right), \mathrm{R}_{\text {Add }}=\left\{a \rightarrow a ; a^{2} / a \rightarrow \lambda ; a^{3} / a^{2} \rightarrow a\right\}$;
(11) syn $\left.=\left\{\left(\text { Input, }^{\text {sux }}\right)_{i}\right) \mid i \in\{5,6\}\right\} \cup\left\{\left(a u x_{1}, a u x_{2}\right)\right\} \cup\left\{\left(a u x_{2}, a u x_{i}\right) \mid i \in\{1,3,4\}\right\} \cup$ $\left\{\left(a u x_{3}, a u x_{6}\right)\right\} \cup\left\{\left(a u x_{4}, a u x_{i}\right) \mid i \in\{2,5\}\right\} \cup\left\{\left(a u x_{5}\right.\right.$, num $\left.\left._{1}\right)\right\} \cup\left\{\left(\right.\right.$ num $\left.\left.\left._{i}, n u m_{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\}\right\}$ $\cup\left\{\left(n u m_{k}, A d d\right)\right\} ;$
(12) in $=\sigma_{\text {input }}$;
(13) out $=\sigma_{0}$ (indicates that the system outputs the calculation results to the environment) In $\Pi_{\text {BASNP }}$, we divide the neurons except $\sigma_{\text {Input }}$ and $\sigma_{\text {Add }}$ into several groups (see the dashed box in Figure 1), and their functions are as follows:

- Neuron Input. The Input neuron receives binary strings from the environment and converts them to spikes in $\Pi_{B A S N P}$.
- Neuron Add. The bit-by-bit addition of binary strings is realized by spiking rules and forgetting rules.
- Auxiliary neuron groups ( $a u x_{1}, a u x_{2}$ ). Continuously send one spike to neurons $a u x_{3}$ and $a u x_{4}$ at each time slice.
- The augend is input to the auxiliary neuron group. Accurately input the spike train representing the augend into the augend cache neuron group, and shield the interference when the augend spike train is input.
- Addend input to auxiliary neuron group. Shield the input of the addend spike train, and accurately input the spike train representing the addend to the neuron Add.
- The augend cache neuron group. Buffer the augend spike train, and send the augend spike train to the neuron Add for operation in due course.
For $\Pi_{B A S N P}$, Theorem 1 can be obtained.
Theorem 1. Input two natural numbers of length $k(k \geq 2)$ to the input neuron $\sigma_{\text {Input }}$ of $\boldsymbol{\Pi}_{\text {BASNP }}$ sequentially from low to high in binary form; this system can correctly calculate the sum of these two natural numbers.

Proof of Theorem 1. Let $t$ represent the system time and the unit be a time slice, that is, the value of $t$ increases by one every time a time slice is passed. Here, $X$ and $Y$ are any two binary natural numbers with no more than $k$ digits, and $\mathrm{X}=\sum_{i=0}^{k-1} x_{i} 2^{i}, \mathrm{Y}=\sum_{i=0}^{k-1} y_{i} 2^{i}$. We provide input to $\Pi_{B A S N P}$ sequentially from low bit to high bit in binary form. When the binary number received by $\Pi_{B A S N P}$ is 1 , a spike $a$ appears in $\sigma_{\text {Input }}$; otherwise, no spike appears in $\sigma_{\text {Input }}$. From $t=1$ to $t=2 k, \Pi_{B A S N P}$ receives spikes corresponding to $x_{0}$ to $x_{k-1}$ and $\mathrm{y}_{0}$ to $\mathrm{y}_{k-1}$ in sequence. When $\mathrm{t}>2 \mathrm{k}+1, \Pi_{B A S N P}$ will not accept input. We use $s p-x_{i}$ to represent the spike corresponding to the binary number $\mathrm{x}_{i}$, that is, when $\mathrm{x}_{i}=1, s p-x_{i}=\{a\}$; otherwise, $s p-x_{i}=\{\lambda\}$. Similarly, $s p-y_{i}$ is used to represent the spike corresponding to the binary number $\mathrm{y}_{i}$, which will be used in the following proofs. The execution process of $\Pi_{B A S N P}$ is as follows.
(1) $t=0$, start sending the corresponding spike $s p-x_{0}$ of the lowest bit $\mathrm{x}_{0}$ of $X$ to $\sigma_{\text {Input }}$.
(2) From $t=1$ to $t=k$, the regular execution of $\Pi_{B A S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $\mathrm{sp}-\mathrm{x}_{i}(0 \leq i \leq k-1)$ and applies the corresponding rules to send $s p-x_{i}$ to $\sigma_{a u x 5}$. During this period, $\sigma_{a u x 5}$ can only receive the spikes sent by $\sigma_{\text {Input }}$, and apply the rules to send the received spikes to $\sigma_{n u m 1}$ in turn. Similarly, $\sigma_{\text {numj }}(1 \leq \mathrm{j} \leq \mathrm{k}-2)$ sends the received spikes to $\sigma_{\text {numj }+1}$ in sequence.
(ii) $\quad \sigma_{a u x 6}$ accepts the spikes sent by $\sigma_{\text {Input }}$, if $s p-x_{i}(0 \leq i \leq \mathrm{k}-2)=\{a\}$, use the rule $a \rightarrow \lambda$ to forget this spike.
(iii) $\sigma_{a u x 1}$ and $\sigma_{a u x 2}$ (starting to work at $\mathrm{t}=1$ ) each maintain one spike, and $\sigma_{a u x 3}$ and $\sigma_{\text {aux }}$ each maintain $\mathrm{k}-1$ spikes at $\mathrm{t}=\mathrm{k}$.
(iv) There is no spike in $\sigma_{\text {Add }}$.
(3) At time $t=k+1$, the rule execution of $\Pi_{B A S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{a u x 6}$ accepts $s p-x_{k-1}$ and forgets $s p-x_{k-2}$.
(ii) $\sigma_{a u x 1}$ and $\sigma_{a u x 2}$ keep one spike each, $\sigma_{a u x 3}$ and $\sigma_{a u x 4}$ keep k spikes and apply the rule $a^{\mathrm{k}} \rightarrow a^{2}$ to send two spikes to $\sigma_{a u x 5}$ and $\sigma_{a u x 6}$ respectively.
(iii) There is no spike in $\sigma_{\text {Add }}$.
(4) At time $t=k+2$, the rule execution of $\Pi_{B A S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-y_{1}$ and sends $s p-y_{0}$ to $\sigma_{a u x 5} . \sigma_{a u x 5}$ sends $s p-x_{k-1}$ to $\sigma_{n u m 1}$ while receiving $s p-y_{0}$ and $\left\{a^{2}\right\}$ from $\sigma_{a u x 4} . \sigma_{n u m j}(1 \leq j \leq k-1)$ accepts $s p-x_{k-j}$ and sends $s p-x_{k-j-1}$, and $\sigma_{n u m k}$ accepts $s p-x_{0}$.
(ii) $\quad \sigma_{a u x 6}$ forgets $s p-x_{k-1}$ accepts both $s p-y_{0}$ (from $\sigma_{\text {Input }}$ ) and $\left\{a^{2}\right\}$ (from $\sigma_{a u x 3}$ ).
(iii) $\sigma_{a u x 1}$ holds one spike, $\sigma_{a u x 2}$ gets three spikes (one spike from $\sigma_{a u x 1}$ and two spikes from $\left.\sigma_{a u x 4}\right), \sigma_{a u x 3}$ and $\sigma_{a u x 4}$ hold one spike.
(iv) There is no spike in $\sigma_{\text {Add }}$.

At this point, the augend has been input into the augend cache neuron group and we can obtain Figure 2, which shows the spikes contained in each neuron in the configuration $\mathrm{C}_{\mathrm{k}+2}$.
(5) From $\mathrm{t}=\mathrm{k}+3$ to $\mathrm{t}=2 \mathrm{k}+2$, the rule execution of $\Pi_{B A S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ sequentially accepts $s p-y_{j}(2 \leq j \leq k-1)$ and simultaneously applies the rules to send $s p-y_{j-1}$ to $\sigma_{a u x 5}$ and $\sigma_{a u x 6}$. When the number of spikes in $\sigma_{a u x 5}$ is three, the rule $a^{3} / a \rightarrow \lambda$ is activated and consumes one spike, so there will always be two spikes in $\sigma_{a u x 5}$ and no spikes will be sent.
(ii) Since $\sigma_{a u x 6}$ keeps two spikes, when it receives a spike from $\sigma_{\text {Input }}$, it will apply the rule $a^{3} / a \rightarrow a$ to consume one spike and send one spike to $\sigma_{A d d}$, and make $\sigma_{\text {aux } 6}$ keep two spikes.
(iii) $\sigma_{a u x 1}$ sends 1 spike to $\sigma_{a u x 2}, \sigma_{a u x 2}$ receives one spike, $\sigma_{a u x 3}$ and $\sigma_{a u x 4}$ keep one spike.
(iv) Starting from time $\mathrm{t}=\mathrm{k}+3, \sigma_{\text {Add }}$ receives $s p-x_{i}$ and $s p-y_{i}(0 \leq i \leq k-1)$ at the same time. Readers can refer to [29] for details of the addition operation in $\sigma_{\text {Add }}$.
(v) From time $\mathrm{t}=\mathrm{k}+4$, the environment starts to receive calculation results in sequence.
(vi) From $t=2 \mathrm{k}+1$ time slice, $\sigma_{\text {Input }}$ no longer accepts the input of the environment, and only sends the spikes it contains to $\sigma_{a u x 5}$ and $\sigma_{a u x 6}$ by using the rules.
(vii) At $\mathrm{t}=2 \mathrm{k}+2$, the highest bit $x_{k-1}$ of X and $y_{k-1}$ of Y reach the neuron $\sigma_{\text {Add }}$, if $\mathrm{X}+\mathrm{Y}<2^{\mathrm{k}+1}$, the system will reach the termination pattern at $\mathrm{t}=2 \mathrm{k}$ +3 ; If $X+Y \geq 2^{k+1}$, the system will eventually reach the termination pattern at $\mathrm{t}=2 \mathrm{k}+4$.

Based on the above description, readers can verify that for $\mathrm{k} \geq 2$, the SNPS $\Pi_{B A S N P}$ for addition constructed above can correctly solve the sum of two natural numbers with a binary length of $k$, and the proof is complete.

Figure 3 shows a $\Pi_{B A S N P}$ structure for three-bit binary addition. Based on this $\Pi_{B A S N P}$, the addition process of the natural numbers 7 and 5 is listed in Table 1, which shows the number of spikes contained in each neuron in $\Pi_{B A S N P(7,5)}$. The two natural numbers expressed in binary form are $111_{2}, 101_{2}$, and $111_{2}+101_{2}=1100_{2}$. In Figure 3, the augend and the addend are input through the neuron Input, the auxiliary neuron group (aux $x_{1}, a u x_{2}$ ) continuously sends a spike to the neuron $a u x_{3}, a u x_{4}$ respectively, the auxiliary neuron group ( $a u x_{4}, a u x_{5}$ ) controls the input of the augend 7 (111) to the augend cache neuron group ( num $_{1}$, num $_{2}$, num $_{3}$ ), and the auxiliary neuron group ( $a u x_{3}$, aux $x_{6}$ ) controls the input of the addend 5 (111) to the neuron Add. Finally, the addition operation is performed in the neuron Add.


Figure 2. The pattern $\mathrm{C}_{\mathrm{k}+2}$ of $\Pi_{B A S N P}$ at $\mathrm{t}=\mathrm{k}+2$.


Figure 3. $\Pi_{B A S N P}$ for adding two three-digit numbers.
In Table 1, the first column represents the system moment, and the second to the last column represent each neuron in the system. Each row of Table 1 represents the number of spikes in each neuron in the system at the corresponding moment. For example, the number in the first column of the sixth row (step $t=5$ ) is 0 , indicating that the binary bit currently input to the neuron Input is 0 . The number from the eighth column to the tenth
column is 1 , which successively indicates that the binary bit of the augend buffer neuron group (num ${ }_{1}$, num $_{2}$, num $\left._{3}\right)$ is 1 and the input of the augend 7 has been completed.

Table 1. $\Pi_{B A S N P}$ calculation process of the instance $111_{2}+101_{2}=1100_{2}$.

| Step t | Input | $\boldsymbol{a u x}_{\mathbf{1}}$ | $\boldsymbol{a u x}_{\mathbf{2}}$ | $\boldsymbol{a u x}_{\mathbf{3}}$ | $\boldsymbol{a u x}_{\mathbf{4}}$ | $\boldsymbol{a u x}_{\mathbf{5}}$ | $\boldsymbol{a u x}_{\mathbf{6}}$ | num $_{\mathbf{1}}$ | num $_{\mathbf{2}}$ | $\boldsymbol{n u m}_{\mathbf{3}}$ | Add | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | - | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | - |
| 3 | 1 | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 0 | 0 | 0 | - |
| 4 | 1 | 1 | 1 | 3 | 3 | 1 | 1 | 1 | 1 | 0 | 0 | - |
| 5 | 0 | 1 | 3 | 1 | 1 | 3 | 3 | 1 | 1 | 1 | 0 | - |
| 6 | 1 | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 1 | 1 | 2 | - |
| 7 | - | 0 | 4 | 1 | 1 | 3 | 3 | 0 | 0 | 1 | 2 | $\mathbf{0}$ |
| 8 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 3 | $\mathbf{0}$ |
| 9 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 1 | $\mathbf{1}$ |
| 10 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | $\mathbf{1}$ |

The $\Pi_{B A S N P}$ designed in this section can complete the addition of two k-bit binary numbers within $2 k+4$ time slices, and the number of neurons used is $k+8$. The neurons in $\Pi_{B A S N P}$ use three types of non-delay spiking rules and three types of forgetting rules.

### 3.2. Binary Subtraction in SNP Systems

Subtraction is another basic binary arithmetic operation. The idea is to subtract the subtrahend from the minuend. Considering whether there is a borrow in the lower bit, we subtract the values of the same order from two binary numbers. The idea of our designed binary subtraction SNPS is:
(1) Through the input neuron Input, input the binary string of the minuend from the lowest bit to the highest bit. When the $i$-th bit $(0 \leq i \leq k-1)$ in the input string is 1 , the neuron Input gets one spike, otherwise it does not get a spike.
(2) After each digit of the subtrahend is input, it will be cached in the system, waiting for the input of the subtrahend. Input the subtrahend immediately after the highest bit of the minuend is input.
(3) When the $i$-th bit of the subtrahend $(0 \leq i \leq k-1)$ reaches the subtraction neuron Sub, the $i$-th bit of the minuend in the cache is taken out and put into the Sub, and the subtraction operation is performed according to the rules in the Sub.
(4) Before the $i$-th bit of the minuend $(0 \leq i \leq k-1)$ reaches the subtraction neuron $S u b$, 3 spikes represent the number 1, and 0 spikes represent the number 0 .
Therefore, the SNPS $\Pi_{B S S N P}$ for binary subtraction designed in this paper includes input neuron, subtraction neuron, auxiliary neuron group, subtrahend input auxiliary neuron group, subtrahend input auxiliary neuron group, and minuend cache group of neurons. The structure of $\Pi_{B S S N P}$ is shown in Figure 4, and its formal definition is shown in Formula (4).

$$
\begin{equation*}
\Pi_{B S S N P}=\left(\mathrm{O}, \sigma_{a u x 1}, \sigma_{a u x 2}, \ldots, \sigma_{a u x 9}, \sigma_{n u m 1}, \sigma_{n u m 2}, \ldots, \sigma_{n u m \mathrm{k}-1}, \sigma_{n u m \mathrm{k}, 1}, \sigma_{n u m \mathrm{k}, 2}, \sigma_{n u m \mathrm{k}, 3}, \text { syn }, \text { in }, \text { out }\right) \tag{4}
\end{equation*}
$$

where
(1) $\mathrm{O}=\{a\}$;
(2) $\sigma_{\text {Input }}=\left(0, \mathrm{R}_{\text {Input }}\right), \mathrm{R}_{\text {Input }}=\{a \rightarrow a\}$;
(3) $\sigma_{a u x 1}=\left(1, \mathrm{R}_{a u x 1}\right), \mathrm{R}_{a u x 1}=\{a \rightarrow a\}$;
(4) $\sigma_{a u x 2}=\left(1, \mathrm{R}_{a u x 2}\right), \mathrm{R}_{a u x 2}=\{a \rightarrow a\}$;
(5) $\sigma_{a u x 3}=\left(0, \mathrm{R}_{a u x 3}\right), \mathrm{R}_{a u x 3}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(6) $\sigma_{\text {aux } 4}=\left(0, \mathrm{R}_{\text {aux } 4}\right), \mathrm{R}_{\text {aux } 4}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(7) $\sigma_{a u x 5}=\left(0, \mathrm{R}_{\text {aux } 5}\right), \mathrm{R}_{a u x 5}=\left\{a \rightarrow a ; a^{3} / a \rightarrow \lambda\right\}$;
(8) $\sigma_{\text {aux6 }}=\left(0, \mathrm{R}_{\text {aux6 }}\right), \mathrm{R}_{\text {aux6 }}=\left\{a \rightarrow \lambda ; a^{3} / a \rightarrow a\right\}$;
(9) $\sigma_{\text {aux } 7}=\left(1, \mathrm{R}_{\text {aux } 7}\right), \mathrm{R}_{a u x 7}=\{a \rightarrow a\}$;
(10) $\sigma_{\text {aux } 8}=\left(1, \mathrm{R}_{\text {aux8 }}\right), \mathrm{R}_{\text {aux } 8}=\{a \rightarrow a\}$;
(11) $\sigma_{\text {aux } 9}=\left(0, \mathrm{R}_{\text {aux9 } 9}\right), \mathrm{R}_{a u x 9}=\left\{a^{2 \mathrm{k}+1} \rightarrow a^{2}\right\}$;
(12) $\sigma_{n u m \mathrm{i}}=\left(0, \mathrm{R}_{n u m \mathrm{i}}\right), \mathrm{R}_{n u m \mathrm{i}}=\{a \rightarrow a\}, i \in\{1,2, \cdots, k-1\}$;
(13) $\sigma_{n u m \mathrm{k}, \mathrm{i}}=\left(0, \mathrm{R}_{n u m \mathrm{k}, \mathrm{i}}\right), \mathrm{R}_{n u m \mathrm{k}, \mathrm{i}}=\{a \rightarrow a\}, i \in\{1,2,3\}$;
(14) $\sigma_{\text {Sub }}=\left(0, \mathrm{R}_{\text {Sub }}\right), \mathrm{R}_{\text {Sub }}=\left\{a \rightarrow \lambda ; a^{2} / a \rightarrow a ; a^{3} / a^{2} \rightarrow \lambda ; a^{4} \rightarrow a ; a^{5} \rightarrow \lambda ; a^{6} / a^{5} \rightarrow a\right\}$;
(15) syn $=\left\{\left(\right.\right.$ Input, aux $\left.\left.x_{i}\right) \mid i \in\{5,6\}\right\} \cup\left\{\left(\right.\right.$ aux $\left.\left._{1}, a u x_{2}\right)\right\} \cup\left\{\left(\right.\right.$ aux $\left.\left.x_{2}, a u x_{i}\right) \mid i \in\{1,3,4\}\right\} \cup$ $\left\{\left(a u x_{3}, a u x_{6}\right)\right\} \cup\left\{\left(a u x_{4}, a u x_{i}\right) \mid i \in\{2,5\}\right\} \cup\left\{\left(a u x_{6}, S u b\right)\right\} \cup\left\{\left(a u x_{7}, a u x_{8}\right)\right\} \cup\left\{\left(a u x_{7}, a u x_{9}\right)\right\} \cup$ $\left\{\left(a u x_{7}, S u b\right)\right\} \cup\left\{\left(a u x_{8}, a u x_{7}\right)\right\} \cup\left\{\left(a u x_{9}\right.\right.$, aux $\left.\left._{7}\right)\right\} \cup\left\{\left(\right.\right.$ aux $_{5}$, num $\left.\left._{1}\right)\right\} \cup\left\{\left(\right.\right.$ num $_{i}$, num $\left._{i+1}\right) \mid i \in$ $\{1,2, \ldots, k-2\}\}\} \cup\left\{\left(\right.\right.$ num $_{k-1}$, num $\left.\left._{k, i}\right) \mid i \in\{1,2,3\}\right\} \cup\left\{\left(\right.\right.$ num $_{k, i}$ Sub $\left.) \mid i \in\{1,2,3\}\right\} ;$
(16) in = input;
(17) out $=\sigma_{0}$;


Figure 4. $\Pi_{B S S N P}$ structure diagram.
In $\Pi_{B S S N P}$, the functions of each neuron (neuron group) are as follows:

- Input neuron Input. Input receives binary strings from the environment and converts them to spikes in $\Pi_{B S S N P}$.
- Subtractive neuron Sub. The binary strings of the subtrahend and the minuend are subtracted bit by bit in the neuron Sub.
- Auxiliary neuron groups ( $a u x_{1}, a u x_{2}, a^{\prime} x_{7}, a u x_{8}, a u x_{9}$ ). Continuously send a spike to neurons $a u x_{3}, a u x_{4}$, and Sub at each time slice.
- Minuend input auxiliary neuron group. The subtrahend is controlled to be accurately input into the minuend cache neuron, and the interference when the subtrahend is input is shielded.
- Minus input auxiliary neuron group. The subtrahend is controlled to be accurately input to the neuron $S u b$, and the interference when the subtrahend is input is shielded.
- Minuend cache neuron groups. The minuend is cached so that the corresponding binary bits of the minuend and the subtrahend are synchronously sent to the neuron Sub for operation.
It can be seen from the following theorem that $\Pi_{B S S N P}$ can complete the subtraction of two k-bit binary strings as input.

Theorem 2. For the binary subtractor implemented by the SNPS shown in Figure 4, two natural numbers of length $k(k \geq 2)$ are input to its input neuron $\sigma_{\text {Input }}$ in binary form from low to high, and this system can find the difference between two natural numbers.

Proof of Theorem 2. Let $t$ represent the time slice length, $t=0$ be the initial state of the system, X and Y be two arbitrary natural numbers, and $\mathrm{X}=\sum_{i=0}^{k-1} x_{i} 2^{i}, \mathrm{Y}=\sum_{i=0}^{k-1} y_{i} 2^{i}$. Readers can easily find that the input device composed of neurons $\sigma_{\text {Input }}$ and neurons $\sigma_{a u x 1}, \sigma_{a u x 2}, \ldots, \sigma_{a u x 6}$ is the same as in Section 3.1; will not be repeated here. $\Pi_{B S S N P}$ implementation process is different from the adder in Section 3.1 as follows.
(1) $\mathrm{t}=\mathrm{k}+1$, the spike in $\sigma_{\text {num }}(1 \leq j \leq k-1)$ is $s p-x_{k-j-1}$, and at the next time slice, $\sigma_{n u m k-1}$ will move to $\sigma_{n u m k, 1}, \sigma_{n u m k, 2}, \sigma_{n u m k, 3}$ send spikes in $\sigma_{n u m k-1}$, respectively.
(2) $\sigma_{a u x 7}, \sigma_{a u x 8}$ maintain a spike and $\sigma_{a u x 7}$ sends a spike to $\sigma_{S u b}$ at each time slice. At $\mathrm{t}=\mathrm{k}+1$, there are k spikes in $\sigma_{a u x 9}$. There are no spikes in $\sigma_{S u b}$.
(3) When $t=k+2$, the minuend is input into the minuend cache neuron group, and the pattern $\mathrm{C}_{\mathrm{k}+2}$ of $\Pi_{B S S N P}$ is as shown in Figure 5 .
(4) From $\mathrm{t}=\mathrm{k}+3$ to $2 \mathrm{k}+2$, $\sigma_{S u b}$ simultaneously receives $s p-x_{i}$ and $s p-y_{i}(0 \leq i \leq k-1)$ sequentially. Readers can refer to [13] for details of the subtraction operation in $\sigma_{S u b}$.
(5) Starting from time $t=k+4$, the environment starts to receive the calculation results in sequence.
(6) $\mathrm{t}=2 \mathrm{k}+2$, there are $2 \mathrm{k}+1$ spikes in $\sigma_{\text {aux9 }}$, and the rule $a^{2 \mathrm{k}+1} \rightarrow a^{2}$ is executed, which will consume $2 \mathrm{k}+1$ spikes and send two spikes to $\sigma_{\text {aux }}$.
(7) $\mathrm{t}=2 \mathrm{k}+3$, there is 1 spike in $\sigma_{a u x 9}$, three spikes in $\sigma_{a u x 7}$, and one spike in $\sigma_{a u x 8}$, which will not change after that.
Because subtraction does not need to consider the carry operation of adding the highest digits of two natural numbers, there is no need to wait another time for the system to reach the termination pattern. It is not difficult for readers to verify that the system will reach the termination pattern at $\mathrm{t}=2 \mathrm{k}+3$.

Based on the above description, readers can verify that for $\mathrm{k} \geq 2$, the SNPS $\Pi_{B S S N P}$ for subtractor constructed above can correctly solve the difference between two natural numbers with a binary length of $k$, and the proof is complete.

Figure 6 shows a $\Pi_{B S S N P}$ structure for a three-bit binary subtraction. Based on this $\Pi_{\text {BSSNP }}$, the subtraction process of natural numbers 5 and 2 is listed in Table 2, which shows the number of spikes contained in each neuron in $\Pi_{B S S N P}(5,2)$. The two natural numbers expressed in binary form are: $101_{2}, 010_{2}$, and $101_{2}-010_{2}=011_{2}$. In Figure 6, the augend and the addend are input through the neuron Input, the auxiliary neuron group ( $a u x_{1}, a u x_{2}$ ) continuously sends a spike to the neuron $a u x_{3}, a u x_{4}$, respectively, and the auxiliary neuron group ( $a u x_{1}, a u x_{2}$ ) continuously sends a spike to the subtraction neuron Sub, the subtrahend input auxiliary neuron group ( $a u x_{4}, a u x_{5}$ ) controls the subtrahend 5 (101) input to the subtrahend cache neuron group ( num $_{1}$, num $_{2}$, num $_{3,1}$, num $_{3,2}$, num $_{3,3}$ ), the subtrahend input auxiliary neuron group $\left(a u x_{3}, a u x_{6}\right)$ controls subtrahend $2(010)$ input to neuron $S u b$, and finally subtraction operation is performed in neuron $S u b$.

In Table 2 column 1 likewise represents the system moment and columns $2-1$ represent each neuron in the system. Each row of Table 2 represents the number of spikes in each neuron in the system at the corresponding moment. For example, the number in the first column of row 6 (step $t=5$ ) is 1 , indicating that the binary bit currently input to the neuron Input is 1 . The numbers from the 11 th column to the 13 th column are $1,0,1$, respectively, indicating that the binary bits of the minuend cache neuron group (num, num $_{2}$, num $_{3,1}$, num $_{3,2}$, num $_{3,3}$ ) are $1,0,1$ respectively, and the input of minuend 5 (101) has been completed.


Figure 5. The pattern $\mathrm{C}_{\mathrm{k}+2}$ of $\Pi_{B S S N P}$ at $\mathrm{t}=\mathrm{k}+2$.
Table 2. $\Pi_{B S S N P}$ calculation process of the instance $101_{2}-010_{2}=011_{2}$.

| Step t | Input | $a u x_{1}$ | $a u x_{2}$ | $a u x_{3}$ | $a u x_{4}$ | $a u x_{5}$ | $a u x_{6}$ | $a u x_{7}$ | $a u x_{8}$ | $a u x_{9}$ | num ${ }_{1}$ | num $_{2}$ | пum $_{3}, \mathrm{i}(\mathrm{i}=1,2,3)$ | Sub | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | - | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | - |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | - |
| 2 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | - |
| 3 | 1 | 1 | 1 | 2 | 2 | 0 | 1 | 1 | 1 | 2 | 1 | 0 | 0 | 1 | - |
| 4 | 0 | 1 | 1 | 3 | 3 | 1 | 1 | 1 | 1 | 3 | 0 | 1 | 0 | 1 | - |
| 5 | 1 | 1 | 3 | 1 | 1 | 2 | 2 | 1 | 1 | 4 | 1 | 0 | 1 | 1 | - |
| 6 | 0 | 0 | 4 | 1 | 1 | 3 | 3 | 1 | 1 | 5 | 0 | 1 | 0 | 4 | - |
| 7 | - | 0 | 4 | 1 | 1 | 2 | 2 | 1 | 1 | 6 | 0 | 0 | 1 | 2 | 1 |
| 8 | - | 0 | 4 | 1 | 1 | 2 | 2 | 1 | 1 | 7 | 0 | 0 | 0 | 5 | 1 |
| 9 | - | 0 | 4 | 1 | 1 | 2 | 2 | 3 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |

The $\Pi_{B S S N P}$ designed in this section can complete the subtraction of two k-bit binary numbers within $2 \mathrm{k}+3$ time slices, and the number of neurons used is $\mathrm{k}+13$. The neurons in $\Pi_{B S S N P}$ use a total of seven types of non-delay spiking rules and four types of forgetting rules.


Figure 6. $\Pi_{B S S N P}$ for subtraction of two three-digit numbers.

### 3.3. Binary Multiplication in SNP Systems

The basic idea of multiplication is to multiply each bit of two binary numbers, and the multiplied results will be added to be the final result according to the weight. In [30], the authors provide an SNPS for solving the product of any natural number within two k-bits. The SNPS for multiplication in their paper uses a large number of neurons, and the total time required for the calculation is not provided in detail. The basic idea of the binary multiplicative SNPS we designed is:
(1) Through the input neuron Input, inputting the binary string of the multiplicand from the lowest bit to the highest bit. When the $i$-th bit $(0 \leq i \leq k-1)$ in the input string is 1, the neuron Input gets one spike; otherwise, it does not get a spike.
(2) After each bit of the multiplicand is input, it is cached in the system. When all bits of the multiplicand are input, store the multiplicand in the multiplicand neuron group and wait for the input of the multiplier. After inputting the highest bit of the multiplicand, the multiplier is entered immediately.
(3) After each bit of the multiplier is input, it is cached in the system and sent to the multiplicand neuron to perform multiplication with the corresponding binary bit of the multiplicand.
(4) The stored multiplicand information in the multiplicand neuron group is not changed by the operation in (3).
(5) Neuron Add calculates a binary bit of the multiplication result at every moment.

Therefore, the binary SNPS $\Pi_{B M S N P}$ for multiplication designed in this paper includes input neurons, addition neurons, auxiliary neuron groups, multiplicand input auxiliary neuron groups, and multiplier input auxiliary neuron groups, along with a multiplicand cache neuron group, multiplicand neuron group, and multiplier cache neuron group. The structure of $\Pi_{B M S N P}$ is shown in Figure 7, and its formal definition is shown in Formula (5).


Figure 7. $\Pi_{B M S N P}$ structure diagram.
$\Pi_{B M S N P}=\left(\mathrm{O}, \sigma_{a u x}, \sigma_{a u x 2}, \ldots, \sigma_{a u x 6}, \sigma_{c a n d 1}, \sigma_{c a n d 2}, \ldots, \sigma_{c a n d \mathrm{k}}, \sigma_{m u t}, \sigma_{m u t 2}, \ldots, \sigma_{m u t \mathrm{k}}, \sigma_{b i t 1}, \sigma_{b i t 2}, \ldots, \sigma_{b i t \mathrm{k}}\right.$, syn, in, out $)$
where
(1) $\mathrm{O}=\{a\}$;
(2) $\sigma_{\text {Input }}=\left(0, \mathrm{R}_{\text {Input }}\right), \mathrm{R}_{\text {Input }}=\{a \rightarrow a\}$;
(3) $\sigma_{a u x 1}=\left(1, \mathrm{R}_{\text {aux } 1}\right), \mathrm{R}_{a u x 1}=\{a \rightarrow a\}$;
(4) $\sigma_{a u x 2}=\left(1, \mathrm{R}_{\text {aux } 2}\right), \mathrm{R}_{a u x 2}=\{a \rightarrow a\}$;
(5) $\sigma_{a u x 3}=\left(0, \mathrm{R}_{\text {aux }}\right), \mathrm{R}_{\text {aux } 3}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(6) $\sigma_{\text {aux } 4}=\left(0, \mathrm{R}_{\text {aux } 4}\right), \mathrm{R}_{\text {aux } 4}=\left\{a^{\mathrm{k}} \rightarrow a^{2}\right\}$;
(7) $\sigma_{a u x 5}=\left(0, \mathrm{R}_{a u x 5}\right), \mathrm{R}_{a u x 5}=\left\{a \rightarrow a ; a^{3} / a \rightarrow \lambda\right\}$;
(8) $\sigma_{a u x 6}=\left(0, \mathrm{R}_{\text {aux6 } 6}\right), \mathrm{R}_{\text {aux } 6}=\left\{a \rightarrow \lambda ; a^{3} / a \rightarrow a\right\}$;
(9) $\sigma_{\text {candi }}=\left(0, \mathrm{R}_{\text {candi }}\right), \mathrm{R}_{\text {candi }}=\left\{a \rightarrow a ; a^{2} \rightarrow \lambda ; a^{3} \rightarrow a^{2}\right\}, i \in\{1,2, \cdots, k\}$;
(10) $\sigma_{m u t \mathrm{i}}=\left(0, \mathrm{R}_{m u t \mathrm{i}}\right), \mathrm{R}_{m u t \mathrm{i}}=\{a \rightarrow a\}, i \in\{1,2, \cdots, k\}$;
(11) $\sigma_{b i t \mathrm{i}}=\left(0, \mathrm{R}_{b i t \mathrm{i}}\right), \mathrm{R}_{b i t \mathrm{i}}=\left\{a \rightarrow \lambda ; a^{3} / a \rightarrow a\right\}, i \in\{1,2, \cdots, k\}$;
$\sigma_{\text {Add }}=\left(0, \mathrm{R}_{\text {Add }}\right), \mathrm{R}_{\text {Add }}=\left\{a^{2 \mathrm{j}} / a^{\mathrm{j}} \rightarrow \lambda ; a^{2 \mathrm{j}+1} / a^{\mathrm{j}+1} \rightarrow a\right\}, j \in\{0,1,2, \cdots, n\} ;$
(13) syn $\left.=\left\{\left(\text { Input, }^{\text {sux }}\right)_{i}\right) \mid i \in\{5,6\}\right\} \cup\left\{\left(a u x_{1}, a u x_{2}\right)\right\} \cup\left\{\left(a u x_{2}, a u x_{i}\right) \mid i \in\{1,3,4\}\right\} \cup$ $\left\{\left(a u x_{3}, a u x_{6}\right)\right\} \cup\left\{\left(a u x_{4}, a u x_{i}\right) \mid i \in\{2,5\}\right\} \cup\left\{\left(a u x_{4}\right.\right.$, cand $\left.\left._{i}\right) \mid i \in\{1,2, \cdots, k\}\right\} \cup$ $\left\{\left(\right.\right.$ aux $_{5}$, cand $\left.\left._{1}\right)\right\} \cup\left\{\left(\right.\right.$ aux $_{6}$, mut $\left.\left._{1}\right)\right\} \cup\left\{\left(\right.\right.$ cand $_{1}$, cand $\left.\left._{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup\left\{\left(\right.\right.$ mut $\left._{i}, m u t_{i+1}\right) \mid i \in$ $\{1,2, \ldots, k-1\}\} \cup\left\{\left(b i t_{i}, b i t_{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup\left\{\left(\right.\right.$ cand $\left.\left._{i}, b i t_{k-i+1}\right) \mid i \in\{1,2, \ldots, k\}\right\}$ $\cup\left\{\left(m u t_{i}, b t_{i}\right) \mid i \in\{1,2, \ldots, k\}\right\} \cup\left\{\left(b i t_{i}, A d d\right) \mid i \in\{1,2, \ldots, k\}\right\} ;$
(14) in = input;
(15) out = Add;

In $\Pi_{B M S N P}$, the functions of each neuron (neuron group) are as follows:

- Input neuron Input. Input receives binary strings from the environment and converts them to spikes in $\Pi_{B M S N P}$.
- Addition neuron Add. The result of multiplying the multiplier by the multiplicand's bits is summed in the Add neuron.
- Auxiliary neuron groups (aux $x_{1}, a u x_{2}$ ). Continuously send a spike to neurons $a u x_{3}$ and $a u x_{4}$ at each time slice.
- The multiplicand is input to the auxiliary neuron group. Control the multiplicand to be accurately input into the summand buffer neuron, shield the interference during multiplication input, and save the multiplicand in the multiplicand neuron group when the input of the highest bit of the multiplicand is completed.
- Multiply the input auxiliary neuron group. The control multiplier is accurately input into the multiplier cache neuron group, and the interference when the multiplier is input is shielded.
- Group of multiplicand cache neurons. Cache multiplicand.
- Group of multiplier cache neurons. The multiplier is buffered, and each binary bit of the control multiplier is multiplied by the multiplicand.
- Group of multiplicand neurons. The multiplicand is stored, and the multiplication operation of the multiplier and each binary bit of the multiplicand is performed.
It can be seen from the following theorem that $\Pi_{B M S N P}$ can complete the multiplication of two k-bit binary strings as input.

Theorem 3. For the binary multiplier realized by the SNPS shown in Figure 7, two natural numbers of length $k(k \geq 2)$ are input to its input neuron $\sigma_{\text {Input }}$ in binary form from low to high, and this system can correctly calculate the product of two natural numbers.

Proof of Theorem 3. Let $t$ represent the time slice length, $t=0$ the initial state of the system, X and Y two arbitrary natural numbers, and m and n two natural numbers less than or equal to $k$; then:

$$
\begin{gathered}
\mathrm{X}=\sum_{\dot{i}=0}^{m-1} x_{i} 2^{i}, \mathrm{Y}=\sum_{j=0}^{n-1} y_{j} 2^{j}, \mathrm{Z}=\mathrm{X} \times \mathrm{Y} \\
\mathrm{X} \times \mathrm{Y}=\left(\sum_{\dot{i=0}}^{m-1} x_{i} 2^{i}\right) \times\left(\sum_{\dot{i}=0}^{n-1} y_{j} 2^{j}\right) \\
=\sum_{i=0}^{m-1} \sum_{j=0}^{n-1} x_{i} y_{j} 2^{i+j}=\sum_{\dot{i}=0}^{m-1} y_{0} x_{i} 2^{i+0}+\sum_{\dot{i}=0}^{m-1} y_{1} x_{i} 2^{i+1}+\ldots+\sum_{i=0}^{m-1} y_{n-1} x_{i} 2^{i+n-1}
\end{gathered}
$$

From the above formula, it can be concluded that the operation of solving $\mathrm{X} \times \mathrm{Y}$ can be converted into solving $n$ times the product of $m$ digits and 1 digits, and the result of the product is shifted to the left by $j$ bits according to the weight $j$ of the multiplier $\mathrm{y}_{j}$; then, the result of $n$ times is shifted to the left summation. In fact, in the [30] the author did the same, using $\mathrm{k}^{2}$ neurons to store the results of the n operations, and the storage process required k auxiliary neurons. The left shift of the product of the m -bit and 1-bit is achieved by adjusting the connections of neurons and finally adding the corresponding results n times.

In the SNPS for multiplication designed in this section, $\mathrm{k}^{2}$ neurons are not used to store the results of these $n$ operations. This paper uses a new control method to make full use of the parallelism of neuron calculations, and sequentially outputs the converted
operation results Z from low to high. Finally, the correct operation result is obtained. The operation process of the SNPS multiplier shown in Figure 7 can be divided into the following three parts:

- Input the natural number X;
- Compute each bit of $Z$ in parallel while inputting $Y$;
- Output each bit of $Z$ from low to high in turn.

The execution process of $\Pi_{B M S N P}$ is as follows:
(1) From $t=0$ to $t=k+1$, the regular execution of $\Pi_{B M S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-x_{i}(0 \leq i \leq k-1)$ and applies the corresponding rules to send $s p-x_{i}$ to $\sigma_{a u x 5}$. During this period, $\sigma_{a u x 5}$ can only receive the spikes sent by $\sigma_{\text {Input }}$, and apply the rules to send the received spikes to $\sigma$ cand1 in turn. Similarly, $\sigma_{\text {cand }}(1 \leq j \leq k-2)$ sends the received spikes to $\sigma_{\text {cand } j+1}$ and $\sigma_{b i t j}$ respectively.
(ii) $\sigma_{a u x 6}$ accepts the spikes sent by $\sigma_{\text {Input }}$, if $s p-x_{i}(0 \leq i \leq k-1)=\{a\}$, use the rule $a \rightarrow \lambda$ to forget this spike.
(iii) $\quad \sigma_{b i t j}(1 \leq j \leq \mathrm{k}-2)$ accepts spikes sent by $\sigma_{c a n d j}(1 \leq j \leq k-2)$ and forgets them using the rule $a \rightarrow \lambda$.
(iv) $\sigma_{a u x 1}$ and $\sigma_{a u x 2}$ (starting to work at $\mathrm{t}=1$ ) each maintain one spike, and $\sigma_{a u x 3}$ and $\sigma_{a u x 4}$ each maintain k spikes at $\mathrm{t}=\mathrm{k}+1$.
(v) $\quad \mathrm{t}=\mathrm{k}+1, \sigma_{\text {aux } 3}$ use the rule $a^{\mathrm{k}} \rightarrow a^{2}$ to send two spikes to $\sigma_{a u x 6}$, and $\sigma_{\text {aux }}$ use the rule $a^{\mathrm{k}} \rightarrow a^{2}$ to send two spikes to $\sigma_{a u x 5}$ and $\sigma_{\text {candj }}(1 \leq j \leq k)$ respectively. $\sigma_{\text {Input }}$ accepts $s p-y_{0}$ and sends $s p-y_{0}$ to $\sigma_{a u x 6}$ according to the corresponding rules.
(vi) There is no spike in $\sigma_{\text {add }}, \sigma_{\text {muti }}(1 \leq i \leq k)$.
(2) $\mathrm{t}=\mathrm{k}+2$, the rule execution of $\Pi_{B M S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-y_{1}$ and sends $s p-y_{0}$ to $\sigma_{a u x 5}, \sigma_{a u x 6}$ respectively. $\sigma_{a u x 5}$ sends $s p-x_{k-1}$ to $\sigma_{\text {cand } 1}$ while receiving $s p-y_{0}$ and $\left\{\mathrm{a}^{2}\right\}$ from $\sigma_{\text {aux } 4} . \sigma_{\text {cand } j}(1 \leq j \leq k-1)$ accepts $s p-x_{k-j}$ and sends $s p-x_{k-j-1}$, and $\sigma_{c a n d k}$ accepts $s p-x_{0} . \sigma_{c a n d j}(1 \leq j \leq k)$ receives the two spikes sent by $\sigma_{a u x 4}$, and $\sigma_{\text {candj }}(1 \leq j \leq k)$ use the rule $a^{3} \rightarrow a^{2}$ or $a \rightarrow \lambda$ to send $s p-x_{j-1}$ to $\sigma_{b i t j}$.
(ii) $\quad \sigma_{a u x 6}$ forgets $s p-x_{k-1}$ accepts both $s p-y_{0}$ (from $\sigma_{\text {Input }}$ ) and $\left\{a^{2}\right\}$ (from $\sigma_{a u x 3}$ ).
(iii) $\sigma_{a u x 1}$ holds one spike, $\sigma_{a u x 2}$ gets three spikes (one spike from $\sigma_{a u x 1}$, two spikes from $\left.\sigma_{a u x 4}\right), \sigma_{a u x 3}$ and $\sigma_{a u x 4}$ hold one spike.
(iv) There is no spike in $\sigma_{a d d}, \sigma_{m u t i}(1 \leq i \leq k)$. At this point, the multiplicand has been input into the multiplicand cache neuron group, and we can get Figure 8, which shows the spikes contained in each neuron in the pattern $\mathrm{C}_{\mathrm{k}+2}$.
(3) $t=k+3$, the multiplicand has been input into the multiplicand neuron group, and the spike changes in each neuron of $\Pi_{B M S N P}$ are shown in Figure 9:
(i) $\sigma_{\text {Input }}$ accepts $s p-y_{2}$ and sends $s p-y_{1}$ to $\sigma_{a u x 5}$ and $\sigma_{a u x 6}$, respectively.
(ii) There are no spikes in $\sigma_{a u x 1}$ and four spikes in $\sigma_{a u x 4}$.
(iii) $\sigma_{a u x 3}$ and $\sigma_{a u x 4}$ maintain one spike each.
(iv) $\sigma_{a u x 5}$ receives the $s p-y_{1}$ sent by $\sigma_{\text {Input }}$, and use the corresponding rules in $\sigma_{a u x 5}$ to forget $s p-y_{0}$.
(v) $\sigma_{a u x 6}$ receives the $s p-y_{1}$ sent by $\sigma_{\text {Input }}$ and applies the corresponding rules in $\sigma_{a u x 6}$ to send $s p-y_{0}$ to $\sigma_{m u t 1}$.
(vi) $\sigma_{m u t 1}$ receives $s p-y_{0}$ sent by $\sigma_{a u x 6}$.
(vii) There is no spike in $\sigma_{\text {candi }}(1 \leq i \leq k), \sigma_{m u t j}(2 \leq j \leq k)$.
(viii) $s p-x_{i-1}$ is received in $\sigma_{b i t i}(1 \leq i \leq k)$.
(4) From $\mathrm{t}=\mathrm{k}+4$ to $3 \mathrm{k}+5$, the rule execution of $\Pi_{B M S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ sequentially accepts $s p-y_{j}(3 \leq j \leq k-1)$ and simultaneously use the rules to send $s p-y_{j-1}$ to $\sigma_{a u x 5}$ and $\sigma_{a u x 6}$.
(ii) When the number of spikes in $\sigma_{a u x 5}$ is 3, the rule $a^{3} / a \rightarrow \lambda$ is activated and consumes one spike, so there will always be two spikes in $\sigma_{a u x 5}$ and no spikes will be sent.
(iii) There is no spike in $\sigma_{\text {candi }}(1 \leq i \leq k)$.
(iv) $\quad \sigma_{a u x 6}$ sends $s p-y_{j}(1 \leq j \leq k-1)$ to $\sigma_{m u t 1}$ sequentially.
(v) $\quad \sigma_{m u t i}(1 \leq i \leq k)$ sends $s p-y_{t+i-(k+5)}$ to $\sigma_{m u t i+1}$ and $\sigma_{b i t \mathrm{i}}$ respectively. Where t is the current moment of $\Pi_{B M S N P}$. If $\mathrm{t}+i-(k+5)<0$, it means that there is no spike in $\sigma_{m u t i}$, and no spike will be sent to $\sigma_{m u t i+1}$ and $\sigma_{b i t i}$.
(vi) $\quad \mathrm{t}=\mathrm{k}+4, \sigma_{b i t 1}$ receives the $s p-y_{0}$ sent by $\sigma_{m u t 1}$, and performs the product operation of $s p-y_{0}$ and $s p-x_{0}$ in $\sigma_{\text {bit1 }}$, and sends the operation result to $\sigma_{\text {Add }}$ at the next time slice. Note that after the operation in $\sigma_{b i t 1}, s p-x_{0}$ is still stored in the neuron.
(vii) $\mathrm{t}=\mathrm{k}+5, \sigma_{b i t 1}$ receives the $s p-y_{1}$ sent by $\sigma_{m u t 1}$, performs the product operation of $s p-y_{1}$ and $s p-x_{0}$ in $\sigma_{b i t 1}$, and sends the operation result to $\sigma_{A d d}$ at the next time slice. $\sigma_{\text {Add }}$ receives the product operation result of $s p-y_{0}$ and $s p-x_{0}$, namely $z_{0}$, and sends $z_{0}$ to the environment at the next time slice.
(viii) $\mathrm{t}=\mathrm{k}+6, z_{0}$ is received in the environment. $\sigma_{\text {Add }}$ is summing the following operation results: $s p-y_{0} \times s p-x_{1}, s p-y_{1} \times s p-x_{0}$, the summation result is $z_{1}$, and the carry is kept in $\sigma_{A d d}$. The ongoing multiplication operation of $\Pi_{B M S N P}$ : $s p-y_{0} \times s p-x_{2}, s p-y_{1} \times s p-x_{1}, s p-y_{2} \times s p-x_{0}$ they will be sent to $\sigma_{A d d}$ for summing operation at the next time, and the operation result is $z_{2}$.
(ix) Similarly, $\mathrm{t}=\mathrm{k}+7, z_{1}$ is received in the environment. $\mathrm{t}=\mathrm{k}+8, z_{2}$ is received in the environment. $\mathrm{t}=\mathrm{k}+i(9 \leq i \leq 2 k+3), z_{i-6}$ is received in the environment. $\mathrm{t}=3 \mathrm{k}+4, z_{2 k-2}$ is received in the environment. Considering that a carry may occur when operating $z_{2 k-2}$, the system reaches the termination configuration at $\mathrm{t}=3 \mathrm{k}+5$. Based on the above description, readers can verify that, for $k \geq 2$, the SNPS multiplication constructed above can correctly solve the product of two natural numbers with a binary length of $k$, and the proof is complete.

Figure 10 shows a $\Pi_{B M S N P}$ structure for three-bit binary multiplication. Based on this $\Pi_{B M S N P}$, the multiplication process of the natural numbers 7 and 5 is listed in Table 3, which displays the spike counts in each neuron for each configuration in $\Pi_{B M S N P(7,5)}$. These two natural numbers are expressed in binary form as: $111_{2}, 101_{2}$, and $111_{2} \times 101_{2}=100011_{2}$. In Figure 10, the multiplicand and the multiplier are input through the neuron Input, the auxiliary neuron group ( $a u x_{1}, a u x_{2}$ ) continuously sends a spike to neurons $a u x_{3}$ and $a u x_{4}$ respectively, the multiplicand is input to the auxiliary neuron group ( $a u x_{4}, a u x_{5}$ ) to control the multiplicand 7 (111) to be input to the multiplicand cache neuron group (cand ${ }_{1}$, cand $_{2}$, cand $_{3}$ ), and after inputting the highest bit of the multiplier, it is stored in the multiplicand neuron group ( $b i t_{1}, b i t_{2}, b i t_{3}$ ) and the multiplier is input to the auxiliary neuron group $\left(a u x_{3}, a u x_{6}\right)$ to control the multiplier 5 (101) input to the multiplier cache neuron group mut $_{1}, m u t_{2}, m u t_{3}$. Multiplication is performed in the multiplier neuron, and the final neuron Add sums the results and outputs them to the environment.

In Table 3, column 1 likewise represents the system moment and columns 2 to last represent each neuron in the system. Each row of Table 3 represents the number of spikes in each neuron in the system at the corresponding moment. For example, the number in the first column of row 9 (step $t=8$ ) is 0 , indicating that the binary bit currently input to the neuron Input is 0 . During the computation process of $111_{2} \times 101_{2}$, from $t=1$ to $t=3$, each binary digit of the multiplicand 111 appears in the neuron input sequentially from low to high. At $t=6$, the multiplicand is stored in the multiplier neuron group (bit $\left.{ }_{1}, b i t_{2}, b i t_{3}\right)$. From $t=4$ to $t=6$, each binary digit of the multiplier 101 appears in the neuron input sequentially from low to high. At $t=8$, the spike count from the 12th column to the 14 th column ( $m u t_{1}, m u t_{2}, m u t_{3}$ ) is $1,0,1$ respectively, representing the multiplier as 101. In the
last column, from $t=9$, the numbers $1,1,0,0,0,1$ are sequentially output to represent the final calculation result of 100011.


Figure 8. The pattern $\mathrm{C}_{\mathrm{k}+2}$ of $\Pi_{B M S N P}$ at $\mathrm{t}=\mathrm{k}+2$.


Figure 9. The pattern $\mathrm{C}_{\mathrm{k}+3}$ of $\Pi_{B M S N P}$ at $\mathrm{t}=\mathrm{k}+3$.


Figure 10. $\Pi_{B M S N P}$ of multiplying two three-digit numbers.

Table 3. $\Pi_{B M S N P}$ calculation process of the instance $111_{2} \times 101_{2}=100011_{2}$.

| Step t | Input | $a u x_{1}$ | $a u x_{2}$ | $a u x_{3}$ | $a u x_{4}$ | $a u x_{5}$ | $a u x_{6}$ | cand $_{1}$ | cand $_{2}$ | cand $_{3}$ | $m u t_{1}$ | $m u t_{2}$ | $m u t_{3}$ | $b i t_{1}$ | $b i t_{2}$ | bit $_{3}$ | Add | Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | - | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 3 | 1 | 1 | 1 | 2 | 2 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 4 | 1 | 1 | 1 | 3 | 3 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 5 | 0 | 1 | 3 | 1 | 1 | 3 | 3 | 3 | 3 | 3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 6 | 1 | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 1 | 0 | 0 | 2 | 2 | 2 | 0 | - |
| 7 | - | 0 | 4 | 1 | 1 | 3 | 3 | 0 | 0 | 0 | 0 | 1 | 0 | 3 | 2 | 2 | 0 | - |
| 8 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 1 | 0 | 1 | 2 | 3 | 2 | 1 | - |
| 9 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 1 | 0 | 3 | 2 | 3 | 1 | 1 |
| 10 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 1 | 2 | 3 | 2 | 2 | 1 |
| 11 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 2 | 3 | 2 | 0 |
| 12 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 2 | 2 | 2 | 0 |
| 13 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 2 | 2 | 1 | 0 |
| 14 | - | 0 | 4 | 1 | 1 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 2 | 2 | 0 | 1 |

The $\Pi_{B M S N P}$ designed in this section can complete the multiplication of two k-bit binary numbers within $3 k+5$ time slices, and the number of neurons used is $3 k+8$. The neurons in $\Pi_{B M S N P}$ use a total of five types of non-delay spiking rules and four types of forgetting rules.

### 3.4. Binary Division in SNP Systems

Division is a basic method of arithmetic operation. The basic idea of division operations is to subtract the divisor from the dividend until the remainder is less than the divisor. At present, nobody has proposed an SNPS which encodes numbers as spike sequences for division. The basic idea of the binary division SPNS designed in this paper is as follows:
(1) Through the input neuron, input the binary string of the dividend from the lowest bit to the highest bit. When the $i$-th bit $(0 \leq i \leq k-1)$ in the input string is 1 , the neuron input gets one spike; otherwise, it does not get one spike.
(2) After each digit of the dividend is input, it will be cached in the system. When all digits of the dividend are input, the dividend is stored in the dividend neuron group. Wait for the input of the divisor. Input the divisor immediately after the highest digit of the dividend is input.
(3) After the divisor input is completed, save the divisor in the divisor neuron group. After the highest digit of the divisor is input, the control neuron group immediately sends the divisor to the dividend neuron group for subtraction. The stored dividend information in the dividend neuron group will be changed due to the subtraction operation.
(4) For each subtraction operation, send a spike to the resulting neuron group.
(5) Continue to carry out (4) in parallel until the highest bit of the dividend neuron group sends a borrow message to the control neuron group.
Therefore, the binary SNPS $\Pi_{B D S N P}$ for division designed in this paper includes input neurons, result neuron groups, auxiliary neuron groups, dividend input auxiliary neuron groups, divisor input auxiliary neuron groups, and dividend cache neuron groups, along with a divisor neuron group, divisor cache neuron group, and divisor neuron group. The structure of $\Pi_{B D S N P}$ is shown in Figure 11, and its formal definition is shown in Formula (6).
where
(1) $\mathrm{O}=\{a\}$;
(2) $\sigma_{\text {Input }}=\left(0, \mathrm{R}_{\text {Input }}\right), \mathrm{R}_{\text {Input }}=\left\{a \rightarrow a ; a^{3} \rightarrow a ; a^{5} \rightarrow \lambda\right\}$;
(3) $\sigma_{a u x 1}=\left(1, \mathrm{R}_{a u x 1}\right), \mathrm{R}_{a u x 1}=\{a \rightarrow a\}$;
(4) $\sigma_{a u x 2}=\left(1, \mathrm{R}_{\text {aux } 2}\right), \mathrm{R}_{a u x 2}=\{a \rightarrow a\}$;
(5) $\sigma_{a u x 3}=\left(0, \mathrm{R}_{\text {aux } 3}\right), \mathrm{R}_{\text {aux } 3}=\left\{a^{2 \mathrm{k}-1} \rightarrow a\right\}$;
(6) $\sigma_{\text {aux } 4}=\left(0, \mathrm{R}_{\text {aux4 }}\right), \mathrm{R}_{\text {aux } 4}=\{a \rightarrow a\}$;
(7) $\quad \sigma_{a u x 5}=\left(0, \mathrm{R}_{a u x 5}\right), \mathrm{R}_{a u x 5}=\left\{a \rightarrow a ; a^{2} \rightarrow \lambda ; a^{3} \rightarrow a ; a^{5} \rightarrow \lambda\right\}$;
(8) $\sigma_{a u x 6}=\left(0, \mathrm{R}_{\text {aux6 } 6}\right), \mathrm{R}_{a u x 6}=\left\{a^{\mathrm{k}} \rightarrow a^{2} ; a^{\mathrm{k}+1} \rightarrow a^{3}\right\}$;
(9) $\sigma_{a u x 7}=\left(0, \mathrm{R}_{\text {aux } 7}\right), \mathrm{R}_{a u x 7}=\left\{a^{2} \rightarrow \lambda ; a^{3} \rightarrow a^{3}\right\}$;
(10) $\sigma_{\text {aux } 8}=\left(2, \mathrm{R}_{\text {aux } 8}\right), \mathrm{R}_{\text {aux } 8}=\left\{a^{4} \rightarrow \lambda\right\} \cup\left\{a^{\mathrm{i}} \rightarrow a^{5}, i \in\{5,6\}\right\} \cup\left\{a^{9} \rightarrow \lambda\right\}$;
(11) $\sigma_{a u x 9}=\left(0, \mathrm{R}_{\text {aux9 }}\right), \mathrm{R}_{\text {aux } 9}=\left\{a^{\mathrm{i}} \rightarrow \lambda \mid i \in\{1,2,4\}\right\} \cup\left\{a^{\mathrm{i}} \rightarrow a^{5} \mid i \in\{5,6,7,8\} ; a^{9} \rightarrow \lambda\right\}$;
(12) $\sigma_{\text {aux } 10}=\left(0, \mathrm{R}_{\text {aux } 10}\right), \mathrm{R}_{\text {aux } 10}=\left\{a^{4} \rightarrow \lambda ; a^{5} \rightarrow a ; a^{9} \rightarrow \lambda\right\}$;
(13) $\sigma_{a u x 11}=\left(0, \mathrm{R}_{a u x 11}\right), \mathrm{R}_{\text {aux } 11}=\left\{a \rightarrow a ; a^{4} \rightarrow \lambda ; a^{5} \rightarrow \lambda\right\}$;
(14) $\quad \sigma_{s \mathrm{i}}=\left(0, \mathrm{R}_{s \mathrm{i}}\right), \mathrm{R}_{s i}=\left\{a \rightarrow a ; a^{2} \rightarrow \lambda ; a^{3} \rightarrow a^{2} ; a^{4} \rightarrow a^{3}\right\} \cup\left\{a^{\mathrm{j}} \rightarrow \lambda \mid j \in\{5,7,8\}\right\} \mid i \in\{1,2, \cdots, k\}$;
(15) $\sigma_{\text {divs } 1}=\left(0, \mathrm{R}_{\text {divs } 1}\right), \mathrm{R}_{\text {divs } 1}=\left\{a^{j} \rightarrow \lambda \mid j \in\{1,2\}\right\} \cup\left\{a^{5} \rightarrow a^{4} ; a^{8} / a^{5} \rightarrow a^{5}\right\}$
(16) $\sigma_{\text {divsi }}=\left(0, \mathrm{R}_{\text {divsi }}\right), \mathrm{R}_{\text {divsi }}=\left\{a^{\mathrm{j}} \rightarrow \lambda \mid j \in\{1,2\}\right\} \cup\left\{a^{\mathrm{j}} \rightarrow a^{4} \mid j \in\{5,6\}\right\} \cup\left\{a^{\mathrm{j}} / a^{5} \rightarrow a^{5} \mid\right.$ $j \in\{8,9\}\} \mid i \in\{2,3, \cdots, k\} ;$
(17) $\sigma_{c t r \mathrm{i}}=\left(0, \mathrm{R}_{\text {ctri }}\right), \mathrm{R}_{\text {ctri }}=\left\{a^{4} \rightarrow \lambda ; a^{5} \rightarrow a ; a^{9} \rightarrow \lambda\right\} \mid i \in\{1,2, \cdots, k\}$;
(18) $\sigma_{\text {divd } 1}=\left(0, \mathrm{R}_{\text {divd } 1}\right), \mathrm{R}_{\text {divd } 1}=\left\{a \rightarrow \lambda ; a^{\mathrm{j}} / a \rightarrow \lambda \mid j \in\{3,5\}\right\} \cup\left\{a^{\mathrm{j}} / a^{5} \rightarrow \lambda \mid j \in\{7,9\}\right\} \cup$ $\left\{a^{8} / a^{4} \rightarrow a^{4} ; a^{10} / a^{8} \rightarrow \lambda\right\} ;$
(19) $\quad \sigma_{\text {divdi }}=\left(0, \mathrm{R}_{\text {divdi }}\right), \mathrm{R}_{\text {divdi }}=\left\{a \rightarrow \lambda ; a^{\mathrm{j}} / a \rightarrow \lambda \mid j \in\{3,5\} ; a^{\mathrm{j}} / a^{5} \rightarrow \lambda, j \in\{7,9\} ; a^{8} / a^{4} \rightarrow a^{4}\right.$; $\left.a^{10} / a^{8} \rightarrow \lambda ; a^{11} / a^{7} \rightarrow a^{4} ; a^{\mathrm{j}} / a^{10} \rightarrow a^{4} \mid j \in\{12,14\} ; a^{13} / a^{11} \rightarrow \lambda\right\}, i \in\{2,3, \cdots, k\} ;$
(20) $\sigma_{a n s \mathrm{i}}=\left(0, \mathrm{R}_{a n s \mathrm{i}}\right), \mathrm{R}_{a n s \mathrm{i}}=\left\{a^{2} \rightarrow a\right\}, i \in\{1,2, \cdots, k\}$;
(21) syn $\left.=\left\{\left(\text { Input }^{\text {aux }}\right)_{5}\right)\right\} \cup\left\{\left(a u x_{1}, a u x_{i}\right) \mid i \in\{2,6\}\right\} \cup\left\{\left(\right.\right.$ aux $\left.\left._{2}, a u x_{i}\right) \mid i \in\{1,3\}\right\} \cup\left\{\left(a u x_{3}, a u x_{i}\right) \mid i \in\right.$ $\{4,6\}\} \cup\left\{\left(a u x_{4}, a u x_{5}\right)\right\} \cup\left\{\left(a u x_{5}, s_{\mathrm{k}}\right)\right\} \cup\left\{\left(a u x_{6}, a u x_{i}\right) \mid i \in\{1,5,7\}\right\} \cup\left\{\left(a u x_{6}, s_{i}\right) \mid i \in\{1,2, \ldots, k\}\right\}$ $\cup\left\{\left(a u x_{7}, a u x_{i}\right) \mid i \in\{9,10\}\right\} \cup\left\{\left(a u x_{8}, a u x_{9}\right)\right\} \cup\left\{\left(a u x_{8}, c t r_{1}\right)\right\} \cup\left\{\left(a u x_{9}, a u x_{8}\right)\right\} \cup$ $\left\{\left(a u x_{9}\right.\right.$, divs $\left.\left._{1}\right)\right\} \cup\left\{\left(a u x_{10}, a u x_{11}\right)\right\} \cup\left\{\left(a u x_{11}, a n s_{1}\right)\right\} \cup\left\{\left(s_{1}, a u x_{9}\right)\right\} \cup\left\{\left(s_{i+1}, s_{i}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup$ $\left\{\left(s_{i}, \operatorname{divd}_{i}\right) \mid i \in\{1,2, \ldots, k\}\right\} \cup\left\{\left(s_{i}, \operatorname{divs}_{i}\right) \mid i \in\{1,2, \ldots, k\}\right\} \cup\left\{\left(\operatorname{divs}_{i}, \operatorname{divs}_{i+1}\right) \mid i \in\right.$ $\{1,2, \ldots, k-1\}\} \cup\left\{\left(\right.\right.$ divs $_{i}$, divd $\left.\left._{i}\right) \mid i \quad \in \quad\{1,2, \ldots, k\}\right\} \cup$ $\left\{\left(\operatorname{ctr}_{i}, \operatorname{divs}_{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup\left\{\left(\right.\right.$ ctr $_{i}$, ctr $\left.\left._{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup\left\{\left(\operatorname{ctr}_{i}, \operatorname{divd}_{i}\right) \mid\right.$ $i \in\{1,2, \ldots, k\}\} \cup\left\{\left(\right.\right.$ ctr $_{\mathrm{k}}$, aux $\left.\left._{11}\right)\right\} \cup\left\{\left(\right.\right.$ divd $_{i}$, divd $\left.\left._{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} \cup\left\{\left(\operatorname{divd}_{\mathrm{k}}, c t r_{i}\right) \mid i \in\right.$ $\{1,2, \ldots, k\}\} \cup\left\{\left(\right.\right.$ divd $\left.\left._{\mathrm{k}}, a u x_{i}\right) \mid i \in\{9,10,12\}\right\} \cup\left\{\left(\right.\right.$ ans $_{i}$, ans $\left.\left._{i+1}\right) \mid i \in\{1,2, \ldots, k-1\}\right\} ;$
(22) in = input;
(23) out $=$ ans $_{\mathrm{i}} \mid i \in\{1,2, \cdots, k\}$;


Figure 11. $\Pi_{B M S N P}$ structure diagram.
In $\Pi_{B D S N P}$, the functions of each neuron (neuron group) are as follows:

- Input neuron Input. Input receives binary strings from the environment and converts them to spikes in $\Pi_{B D S N P}$.
- Cache groups of neurons. Temporarily cache the dividend and the divisor. After the highest digit of the dividend is input into the system, the auxiliary neuron will save the dividend in the dividend neuron group. After the highest digit of the divisor is input into the system, the auxiliary neuron will save the divisor in the divisor neuron group.
- Auxiliary neuron group. The control dividend and divisor are stored in the dividend neuron group and the divisor neuron group, respectively.
- Dividend neuron group. Save the dividend, perform the operation of subtracting the divisor, and send a signal to the control neuron group if the subtraction is not enough.
- Divisor group of neurons. Save the divisor, and send the divisor to the dividend neuron group for subtraction.
- Groups of control neurons. Control the process of subtracting the dividend and the divisor, and stop when the result of the subtraction operation is less than the divisor.
- Resulting neuron groups. Counts the number of subtraction operations performed.

It can be seen from the following theorem that $\Pi_{B D S N P}$ can complete the division of two k-bit binary strings as input.

Theorem 4. For the binary divider realized by the SNPS shown in Figure 11, two natural numbers of length $k(k \geq 2)$ are input to its input neuron $\sigma_{\text {Input }}$ in binary form from low to high, and this system can correctly calculate the quotient of two natural numbers.

Proof of Theorem 4. Let $t$ represent the time slice length, $t=0$ the initial state of the system, $X$ and $Y$ any two natural numbers, $X$ the dividend, and $Y$ the divisor. Because division can be regarded as subtraction of the same number continuously, as shown in Figure 11, the binary divider is designed based on the idea of multiple subtraction; its operation process can be divided into the following three parts:

- Input dividend $X$ and divisor $Y$;
- Loop controls the dividend to subtract the divisor until the dividend is smaller than the divisor;
- Count the number of subtractions, and convert the result into a binary form.

The execution process of $\Pi_{B D S N P}$ is as follows:
(1) $t=0$, start sending the corresponding spike $s p-x_{0}$ of the lowest bit $x_{0}$ of $X$ to $\sigma_{\text {Input }}$.
(2) From $t=1$ to $t=k$, the regular execution of $\Pi_{B D S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-x_{i}(0 \leq i \leq \mathrm{k}-1)$ and use the corresponding rules to send $s p-x_{i}$ to $\sigma_{a u x 5}$. During this period, $\sigma_{a u x 5}$ will only receive the spikes sent by $\sigma_{\text {Input }}$, and use the rules to send the received spikes to $\sigma_{s \mathrm{~s}}$ in turn. Similarly, $\sigma_{s j}(3 \leq j \leq k)$ sends the received spikes to $\sigma_{s j-1}$ in sequence.
(ii) $\sigma_{a u x 1}$ and $\sigma_{a u x 2}$ maintain one spike each.
(iii) $\mathrm{t}=\mathrm{k}, \sigma_{a u x 3}$ and $\sigma_{a u x 6}$ each contain $\mathrm{k}-1$ spikes.
(iv) There are no spikes in $\sigma_{s 1}, \sigma_{s 2}, \sigma_{a u x \mathrm{i}} \mid i \in\{4,5,7,8,9,10,11\}, \sigma_{\text {divsi }}, \sigma_{c t r i}, \sigma_{\text {divdi }}$, $\sigma_{a n s i} \mid i \in\{1,2, \ldots, k\}$.
(3) $t=k+1$, the rule execution of $\Pi_{B D S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-y_{0}$ and sends $s p-y_{0}$ to $\sigma_{a u x 5}$ according to the corresponding rules. $\sigma_{a u x 5}$ accepts $s p-x_{k-1}$ and sends $s p-x_{k-2}, \sigma_{s j}(3 \leq j \leq k)$ accepts $s p-x_{k-j}$ and sends $s p-x_{k-j-1}$, and $\sigma_{s 2}$ accepts $s p-x_{0}$.
(ii) There are k spikes in $\sigma_{a u x 3}$
(iii) There are k spikes in $\sigma_{a u x 6}$, and the rule $a^{\mathrm{k}} \rightarrow a^{2}$ will be used to send two spikes each to $\sigma_{\text {auxi }} \mid i \in\{1,5,7\}$ and $\sigma_{s j}(1 \leq j \leq k)$.
(4) $t=k+2$, the rule execution of $\Pi_{B D S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{\text {Input }}$ accepts $s p-y_{1}$ and sends $s p-y_{0}$ to $\sigma_{a u x 5} \cdot \sigma_{a u x 5}$ sends $s p-x_{\mathrm{k}-1}$ to $\sigma_{s \mathrm{k}}$ while receiving $s p-y_{0}$ and $\left\{a^{2}\right\}$ from $\sigma_{a u x 6} . \sigma_{s j}(1 \leq j \leq k)$ receives $s p-x_{j-1}$ and $\left\{a^{2}\right\}$ from $\sigma_{\text {aux } 6}$.
(ii) There are three spikes in $\sigma_{a u x 1}$ and $\mathrm{k}+1$ spikes in $\sigma_{a u x 3}$.
(iii) There is one spike in $\sigma_{a u x 6}$. There are two spikes in $\sigma_{a u x 7}$, and we use the rule $a^{2} \rightarrow \lambda$ to forget these two spikes. At this time, the dividend has been input into the cache neuron group, and they will be sent to the dividend neuron group for storage at the next moment.
(5) $\mathrm{t}=\mathrm{k}+3, \sigma_{\text {divdj }}(1 \leq j \leq k)$ receives $s p-x_{j-1}$, at this time $s p-x_{j-1}=\left\{a^{2}\right\}$ means $x_{j-1}$ is 1 , $s p-x_{j-1}=\{\lambda\}$ means that $x_{j-1}$ is 0 .
(6) From $t=k+4$ to $t=2 k+3$, the regular execution of $\Pi_{B D S N P}$ and the change of spikes in each neuron include:
(i) $\quad \sigma_{s j}(1 \leq j \leq k)$ sends the received spikes to $\sigma_{s j-1}$ in sequence.
(ii) $\mathrm{t}=2 \mathrm{k}$, there are $2 \mathrm{k}-1$ spikes in $\sigma_{a u x 3}$, the rule $a^{2 \mathrm{k}-1} \rightarrow a$ executes, sending one spike to $\sigma_{\text {aux } 4}$.
(iii) $\mathrm{t}=2 \mathrm{k}+1$, there are $\mathrm{k}+1$ spikes in $\sigma_{\text {aux } 6}$, the rule $a^{\mathrm{k}+1} \rightarrow a^{3}$ is executed, and they are sent to $\sigma_{a u x_{\mathrm{i}}} \mid i \in\{1,5,7\}$ and $\sigma_{s j}(1 \leq j \leq k)$ respectively two spikes.
(iv) When $\mathrm{t}=2 \mathrm{k}+2, \sigma_{a u x 5}$ receives three spikes from $\sigma_{a u x 6}$ and one spike from $\sigma_{a u x 4}$. There are four spikes in $\sigma_{a u x 1}$. There are three spikes in $\sigma_{a u x 7} \cdot \sigma_{s j}(1 \leq j \leq k)$ will receive three spikes from $s p-y_{j-1}$ and $\sigma_{a u x 6}$. $\sigma_{s j}(1 \leq j \leq k)$ will send two spikes to $\sigma_{d i v d j}$ and $\sigma_{a u x 9}$. At this point, the divisors have been entered into the cache neuron group, and they will be sent to the divisor neuron group for storage at the next moment. $s p-y_{j-1}(1 \leq j \leq k)=\left\{a^{3}\right\}$ means that $x_{j-1}$ is 1 , and $s p-x_{j-1}=\{\lambda\}$ means that $x_{j-1}$ is 0 .
(v) $\quad \mathrm{t}=2 \mathrm{k}+3, \sigma_{\text {divs } j}(1 \leq j \leq k)$ receives the $s p-y_{j-1}$ sent by $\mathrm{s}_{j}$, and the divisor is stored in the divisor neuron group. There are five spikes in $\sigma_{a u x 9}$ (three from $\sigma_{a u x 7}$ and two from itself). There are five spikes in $\sigma_{a u x 10}$ (three from $\sigma_{a u x 7}$ and two from $\left.\sigma_{s 1}\right)$. There are no spikes in $\sigma_{c t r j}(1 \leq j \leq k) . \sigma_{\text {divdj }}$ ( $1 \leq j \leq k$ ), receiving two spikes sent by $s_{j}$, after executing the corresponding rules in $\sigma_{\text {divdj }} s p-x_{j-1}=\left\{a^{4}\right\}$ it means that $x_{j-1}$ is 1 , and $s p-x_{j-1}=\left\{a^{2}\right\}$ means that $x_{j-1}$ is 0 . We can obtain Figure 12 now that both the dividend and the divisor have been entered into the system, which shows the spikes contained within the individual neurons in the pattern $\mathrm{C}_{2 \mathrm{k}+3}$.
(7) After $\mathrm{t}=2 \mathrm{k}+4$, the regular execution of $\Pi_{B D S N P}$ and the change of spikes in each neuron include:
(i) $\mathrm{t}=2 \mathrm{k}+4, \sigma_{\text {divs } 1}$ receives five spikes from $\sigma_{\text {aux } 10}, \sigma_{\text {divs } 1}$ receives five spikes from $\sigma_{a u x 9}$, and prepares to send $s p-y_{0}$ to $\sigma_{\text {divs } 1} . \sigma_{c t r 1}$ sends one spike to $\sigma_{\text {divs } 2}$ and $\sigma_{\text {divd } 1}$ and $\sigma_{c t r 2}$, respectively.
(ii) $\quad \mathrm{t}=2 \mathrm{k}+5$, the difference operation between $s p-x_{0}$ and $s p-y_{0}$ is being performed in $\sigma_{\text {divd } 1}$, and the operation result is kept in $\sigma_{\text {divd } 1}$. If a borrow occurs, four spikes will be sent to $\sigma_{d i v d 2}$ to participate in the calculation of $s p-x_{1}$ and $s p-y_{1}$ at the next time slice. $\sigma_{\text {divs } 2}$ receives four spikes from $\sigma_{\text {divs } 1}$ and one spike from $\sigma_{c t r 1}$, and prepares to send $s p-y_{1}$ to $\sigma_{d i v s 2} . \sigma_{c t r 2}$ sends one spike to $\sigma_{d i v s 3}$ and $\sigma_{d i v d 2}$ and $\sigma_{c t r 3}$, respectively.
(iii) $\quad \mathrm{t}=2 \mathrm{k}+6$, the difference operation between $s p-x_{1}$ and $s p-y_{1}$ is being performed in $\sigma_{\text {divd } 2}$, and the operation result is kept in $\sigma_{\text {divd } 2}$. If a borrow occurs, four spikes will be sent to $\sigma_{d i v d 3}$ to participate in the calculation of $s p-x_{2}$ and $s p-y_{2}$ at the next time slice.
(iv) Similarly, it is not difficult to verify that $t=3 \mathrm{k}+4$, the difference operation of $s p-x_{k-1}$ and $s p-y_{k-1}$ is going on in $\sigma_{d i v d k}$. So far, the first subtraction operation is completed. If $\sigma_{\text {divd }}$ does not send 4 spikes to $\sigma_{a u x 12}(\mathrm{X} \geq \mathrm{Y}), \sigma_{a u x 11}$ will send one spike to $\sigma_{a u x 12}$, and $\sigma_{a u x 12}$ will send this spike to $\sigma_{a n s 1}$ at the next time slice.
(v) Because the neurons of $\sigma_{\text {divdi }}(1 \leq i \leq k)$ work in parallel, when $\mathrm{t}=3 \mathrm{k}+5$, the second subtraction operation is completed. If $\sigma_{d i v d \mathrm{k}}$ does not send four spikes to $\sigma_{a u x 12}(\mathrm{X} \geq \mathrm{Y}), \sigma_{a u x 11}$ will send one spike to $\sigma_{a u x 12}$, and $\sigma_{a u x 12}$ will send this spike to $\sigma_{a n s 1}$ at the next time slice.
(vi) The system will keep running until $\sigma_{\text {divdk }}$ sends four spikes to $\sigma_{a u x 12}$, indicating that the current dividend is smaller than the divisor.


Figure 12. The pattern $\mathrm{C}_{2 \mathrm{k}+3}$ of $\Pi_{B D S N P}$ at $\mathrm{t}=2 \mathrm{k}+3$.
Through the above description, it is not difficult to see that the number of subtractions performed by this system will be sent to the neuron $\sigma_{\text {ans1 }}$ successively over time, and the rule in the neuron $\sigma_{\text {ansi }}(1 \leq i \leq k)$ is $a^{2} \rightarrow a$, which means every 2 enters 1 ; then, when the system reaches the termination pattern, the result of $X$ quotient $Y$ is stored in the neurons $\sigma_{\text {ans } 1}, \sigma_{\text {ans } 2}, \ldots, \sigma_{\text {ansk }}$ in binary form from low to high.

Based on the above description, readers can verify that for $k \geq 2$ the SNP divider constructed above can correctly solve the quotient of two natural numbers with binary length $k$, and the proof is completed.

Figure 13 shows the structure of a $\Pi_{B D S N P}$ for three-digit binary division. Based on this $\Pi_{B D S N P}$, the division process of natural numbers 6 and 2 is listed in Table 4 which shows the number of spikes contained in each neuron in $\Pi_{B D S N P(6,2)}$. These two natural numbers are expressed in binary form: $110_{2}, 010_{2}, 110_{2} \div 010_{2}=011_{2}$. In Figure 13, the dividend and the divisor are input through the neuron Input, and both the dividend and the divisor are input to the cache neuron through the input auxiliary neuron group Tuple $\left(s_{1}, s_{2}, s_{3}\right)$. The dividend is stored in the dividend neuron group ( $\left.\operatorname{div}_{1}, d i v_{2}, d i v_{3}\right)$, while the divisor is stored in the divisor neuron group ( divs $_{1}, \operatorname{divs}_{2}, \operatorname{divs}_{3}$ ), and the control neuron after the input is completed The group immediately sends the divisor to the dividend neuron group for continuous subtraction operations and sends one spike to the result neuron group each time until the highest bit of the dividend neuron group sends a borrow message to the control neuron group, and the final result is stored in the result group of neurons.

In Table 4, likewise, column 1 represents the system moment and columns 2 to 1 represent each neuron in the system. Each row of Table 4 represents the number of spikes in each neuron in the system at the corresponding moment. It is not difficult to see that when $t=18$ the resulting neuron group (the last three columns) in Table 4 has calculated the result (011) of dividing the last column of natural numbers 6 and 2.


Figure 13. $\Pi_{B S S N P}$ for subtraction of two three-digit numbers.
Table 4. $\Pi_{B D S N P}$ calculation process of the instance $110_{2} \div 010_{2}=011_{2}$.

| Step t | Input | $a u x_{5}$ | $a u x_{6}$ | $a u x_{7}$ | $a u x_{8}$ | aux9 | $s_{3}$ | $s_{2}$ | $s_{1}$ | $\operatorname{divs}_{1}$ | $\operatorname{divs}_{2}$ | $\operatorname{divs}_{3}$ | $\operatorname{divd}_{1}$ | $\mathrm{divd}_{2}$ | $\mathrm{divd}_{3}$ | $a u x_{10}$ | $a u x_{11}$ | $\mathrm{ans}_{3}$ | $a n s_{2}$ | $a n s{ }_{1}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | - | 0 | 0 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 2 | 1 | 0 | 1 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 3 | 1 | 1 | 2 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 4 | 0 | 1 | 3 | 0 | 2 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 5 | 1 | 0 | 1 | 2 | 2 | 0 | 3 | 3 | 2 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 6 | 0 | 1 | 2 | 0 | 2 | 0 | 0 | 0 | 0 | 2 | 2 | 2 | 0 | 2 | 2 | 0 | 0 | 0 | 0 | 0 |
| 7 | - | 0 | 4 | 0 | 2 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 2 | 0 | 0 | 0 | 0 | 0 |
| 8 | - | 4 | 1 | 3 | 2 | 0 | 3 | 4 | 3 | 0 | 0 | 0 | 0 | 2 | 2 | 0 | 0 | 0 | 0 | 0 |
| 9 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 2 | 3 | 2 | 2 | 5 | 4 | 0 | 0 | 0 | 0 | 0 |
| 10 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 3 | 0 | 2 | 4 | 4 | 0 | 0 | 0 | 0 | 0 |
| 11 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 0 | 7 | 4 | 4 | 0 | 0 | 0 | 0 | 0 |
| 12 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 10 | 4 | 0 | 0 | 0 | 0 | 0 |
| 13 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 8 | 9 | 1 | 0 | 0 | 0 | 0 |
| 14 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 10 | 13 | 1 | 1 | 0 | 0 | 0 |
| 15 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 8 | 7 | 1 | 1 | 0 | 0 | 1 |
| 16 | - | 0 | 1 | 0 | 5 | 5 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 10 | 11 | 1 | 1 | 0 | 0 | 2 |
| 17 | - | 0 | 1 | 0 | 9 | 9 | 0 | 0 | 0 | 5 | 8 | 6 | 7 | 8 | 9 | 5 | 5 | 0 | 1 | 1 |
| 18 | - | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 3 | 5 | 8 | 10 | 12 | 0 | 0 | 0 | 1 | 1 |

The $\Pi_{B D S N P}$ designed in this section can complete the division of two k-bit binary numbers within $2 k+4$ time slices, and the number of neurons used is $5 k+12$. The neurons in $\Pi_{B D S N P}$ use a total of sixteen types of non-delay spiking rules and thirteen types of forgetting rules.

## 4. Comparison of Arithmetic Operations Realized by Various SNP Systems

In this section, we analyze and compare the excellent SNPS proposed in recent years for basic arithmetic operations; the results are shown in Table 5. The statistical dimensions include the number of input neurons (NIN), the encoding method of operands (Encoding),
the number of neurons used by the four basic operations (addition, subtraction, multiplication, and division), the number of time slices required to complete the operation, and the number of rule types (NRT). In operand input, when one input neuron is used it takes a long time to input two operands sequentially, but fewer neurons are used. When two input neurons are used, the input time consumed by parallel input of two operands is short, while the number of neurons is increased. There are two commonly used operand encodings: spike time interval-based encoding and spike sequence-based encoding. Spike time interval-based encoding is the conversion of a numerical value into time slices in the interval between two spikes, while spike sequence-based encoding is the conversion of numeric values into a specific sequence of characters, such as a binary sequence. When the system is input, the operand (value) is encoded into a corresponding spike sequence or spike interval. The calculation process is to process the spike. When the system outputs, the spike sequences or spike interval is decoded into a value. The number of rule types used refers to the number of rules using different representations, e.g., the rule $a \rightarrow a$ is only considered as 1 rule type even if it occurs in multiple neurons. The statistical results in bold in Table 5 are taken from the literature, while the rest are taken from the present study.

Table 5. The number of neurons, time slices required, and number of rule types used for four arithmetic approaches.

| Article | Input Type | Encoding | Add | Sub | Mut | Div | Rule Types |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| [28] | multiple inputs | time interval | 10/- | 12/- | 21/- | 25/- | 4/4/12/15 |
| [35] | multiple inputs | time-free | 2/- | 2/- | 11/- | 10/- | 2/6/15/16 |
| [29] | multiple inputs | spike train | $3 /(\mathrm{k}+1)$ | 10/(k+2) | 13/(k+7) | -/- | 3/6/3/- |
| [31] | multiple inputs | spike train | $7 /(\mathrm{k}+2)$ | $7 /(\mathrm{k}+2)$ | $\begin{gathered} \left(\mathrm{k}^{2} / 2+15 \mathrm{k} / 2+4\right) / \\ (2 \mathrm{k}+5) \end{gathered}$ | -/- | 6/6/6/- |
| [30] | single input | spike train | $(3 \mathrm{k}+5) /(3 \mathrm{k}+4)$ | -/- | $\left(\mathrm{k}^{2}+5 \mathrm{k}+3\right) /(4 \mathrm{k}+2)$ | -/- | 9/-/10/- |
| [36] | single input | spike train | $(2 \mathrm{k}+4) /(3 \mathrm{k}+1)$ | -/- | $5 \mathrm{k} /(3 \mathrm{k}+5)$ | -/- | $\begin{aligned} & (5 \mathrm{k}-1) /- \\ & /(9 / 2 \mathrm{k}+7) /- \end{aligned}$ |
| This work | single input | spike train | $(\mathrm{k}+8) /(2 \mathrm{k}+4)$ | $(\mathrm{k}+13) /(2 \mathrm{k}+3)$ | $(3 \mathrm{k}+8) /(3 \mathrm{k}+5)$ | $\begin{gathered} (5 \mathrm{k}+12) / \\ (4 \mathrm{k}+\text { quotient }+4) \end{gathered}$ | 6/11/9/29 |

Note: A/B, A represents the number of neurons used, B represents the number of time slices required for the operation. C/D/E/F, C represents the number of rules used for addition. Similarly, D, E, and F denote the number of rules used for subtraction, multiplication, and division, respectively.

In Table 5, for example, the SNPS designed in [29] has multiple input neurons and the digital encoding method is spike sequences. The additive SNP system uses three neurons, the time required for the addition of two natural numbers with a length of $k$ bits is $k+1$, and the number of rules is three. Note that while the number of neurons required for multiplication in [29] is thirteen and the time required is $k+7$, this multiplication SNPS can only fix one of the multipliers, which is fixed at 26 . Due to the lack of an SNPS for implementing division operations in [29], the number of neurons, computation time, and number of rule types required for the division operation are marked with ' - '.

In [28], the authors used the time interval encoding method, and the input number was represented by the time interval between two spike signals received by the input neuron. This is because the required time is related to the value of the input number, not its binary length, meaning that it cannot obtain the number of time slices required for the calculation. Similarly, [35] used the time-free encoding method to remove the precise execution time of the rules, making the solution of the problem independent of the execution time of the rules; thus, the time required for calculation cannot be obtained.

Refs. $[17,31]$ used spike sequence encoding and two input neurons, meaning that the two operands do not need to be stored in the provided system, ensuring that the number of neurons used by addition and subtraction operations is constant and the calculation consumes a number of time slices $\mathrm{k}+1$ (or $\mathrm{k}+2$ ). The difference between the multiplication of [29] and [15] is that in [29] a multiplier is fixed to 26, while in [31] both multipliers can be input by input neurons, meaning that there is a significant number difference between the neurons and the time slices of consumption. Neither [29] nor [31] provide an SNPS for the division operation.

The work in $[30,36]$ and in this paper, all of which employ spike sequence encoding and one input neuron, are comparable. Because the SNPS in this paper only saves the first operand, the calculation starts when the second operand arrives, which time improves the parallelism of the relevant neurons in the calculation process. Thus, for the number of neurons used in this paper both the time and computation time are less than the results in $[30,36]$. In addition, this paper presents SNPS for subtraction and division operations, which solves the open problem of how to design a divider based on the SNP system proposed in [30].

On the other hand, in the SNPS with one input neuron, the input of two k-bit operands requires 2 k spikes; thus, considering the transmission of spikes and the output of calculation results, the basic arithmetic operation SNPS requires at least $2 \mathrm{k}+2$ time slices, meaning that the SNPS addition and multiplication designed in this paper have reached the optimum in terms of time consumption. Because the first operand of the input needs to be saved, and considering both the input neuron and the calculation neuron, the SNPS needs at least $k+2$ neurons; thus, the SNPS addition and multiplication designed in this paper use a number of neurons that is close to optimum.

From the above analysis, we can see that, under the same encoding and input approach, the basic arithmetic operation SNPS designed in this paper has obvious advantages.

## 5. Conclusions and Future Work

Basic arithmetic operations are the basis of numerical calculations. In basic arithmetic operations, it is of great significance to study the simplification of computing components, reduce computing resources, and improve computing efficiency. Based on this, the present paper studies the problem of constructing a family of SNPS to realize the four basic arithmetic operations of addition, subtraction, multiplication, and division using only a single input neuron. Specifically: (1) by improving the parallelism of addition, this paper constructs a k-bit binary addition and multiplication with one input neuron. Among them, the number of neurons used by the adder is $\mathrm{k}+8$ and it takes $2 \mathrm{k}+4$ time slices, which is $50 \%$ and $33 \%$ less than similar systems, respectively; (2) the number of neurons used in the multiplication constructed in this paper is $3 \mathrm{k}+8$, and it takes $3 \mathrm{k}+5$ time slices, while the number of neurons used is $40 \%$ less than that of similar excellent systems; (3) a subtractive SNPS is designed, in which the number of neurons used and the time consumption are $k+13$ and $2 k+3$ time slices, respectively; (4) based on multiple subtraction, an SNPS for division for solving the quotient of two natural numbers of any binary length is constructed. The number of neurons required is $5 k+13$ and the maximum time-consuming is $4 \mathrm{k}+$ quotient +4 time slices, which solves the open problem proposed in [30] of how to design an SNPS to compute the division of two natural numbers. This paper designs a complete set of basic arithmetic operation SNPS, and has obvious advantages in the same type of system.

The system designed in this paper only considers the basic arithmetic operations of natural numbers, and further research can extend it to integers and even decimals. On the other hand, the SNPS for division that we have designed here is not optimal, and further work could optimize the system to reduce the time consumption and the number of neurons used. We are currently developing software for simulating the operation process of SNPS to accelerate the development of related SNPS systems and verify whether these systems are effective. In addition, an SNPS for expression evaluation, which requires the system to take different operations to complete compound operations, is being further developed.

Author Contributions: Conceptualization, X.C. and P.G.; Formal analysis, X.C. and P.G.; Investigation, P.G.; Methodology, P.G.; Supervision, P.G.; Validation, X.C.; Writing—original draft, X.C.; Writing-review and editing, X.C. and P.G. All authors have read and agreed to the published version of the manuscript.

Funding: This research received no external funding.
Institutional Review Board Statement: Not applicable.

Informed Consent Statement: Not applicable.
Data Availability Statement: Contact the authors for the full dataset.
Conflicts of Interest: The authors declare no conflict of interest.

## References

1. Păun, G. Computing with membranes. J. Comput. Syst. Sci. 2000, 61, 108-143. [CrossRef]
2. Păun, G. A Quick Introduction to Membrane Computing. J. Logic. Algebr. Progr. 2010, 79, 291-294. [CrossRef]
3. Atanasiu, A. Arithmetic with Membranes. In Proceedings of the Workshop on Multiset Processing, Argeş, Romania, 21-25 August 2000.
4. Ciobanu, G. A Programming Perspective of the Membrane Systems. Int. J. Comput. Commun. 2006, 1, 13. [CrossRef]
5. Guo, P.; Chen, J. Arithmetic Operation in Membrane System. In Proceedings of the 2008 International Conference on BioMedical Engineering and Informatics, Sanya, China, 27-30 May 2008.
6. Guo, P.; Zhang, H. Arithmetic Operation in Single Membrane. In Proceedings of the 2008 International Conference on Computer Science and Software Engineering, Wuhan, China, 12-14 December 2008.
7. Guo, P.; Luo, M. Signed Numbers Arithmetic Operation in Multi-Membrane. In Proceedings of the 2009 First International Conference on Information Science and Engineering, Nanjing, China, 26-28 December 2009.
8. Guo, P.; Liu, S.J. Arithmetic Expression Evaluation in Membrane Computing with Priority. Adv. Mater. Res. 2011, 225-226, 1115-1119. [CrossRef]
9. Guo, P.; Chen, H.Z.; Zheng, H. Arithmetic Expression Evaluations with Membranes. Chin. J. Electron 2014, 23, 55-60.
10. Guo, P.; Chen, H.Z. Arithmetic Expression Evaluation by P Systems. Appl. Math. Inform. Sci. 2014, 7, 549-553. [CrossRef]
11. Guo, P.; Zhang, H.; Chen, H.Z.; Chen, J.X. Fraction Arithmetic Operations Performed by P Systems. Chin. J. Electron 2013, 22, 690-694.
12. Zhang, X.; Liu, Y.; Luo, B.; Pan, L. Computational Power of Tissue P Systems for Generating Control Languages. Inf. Sci. 2014, 278, 285-297. [CrossRef]
13. Ionescu, M.; Paun, G.; Yokomori, T. Spiking Neural P Systems. Fund. Inform. 2006, 71, 279-308.
14. Luo, Y.; Zhao, Y.; Chen, C. Homeostasis Tissue-Like P Systems. IEEE Trans. NanoBiosci. 2021, 20, 126-136. [CrossRef]
15. Păun, G. Spiking Neural P Systems. In Power and Efficiency; Springer: Berlin/Heidelberg, Germany, 2007; pp. 153-169.
16. Chen, H.; Freund, R.; Ionescu, M.; Paun, G.; Perez-Jimenez, M.J. On String Languages Generated by Spiking Neural P Systems. Fund. Inform. 2007, 75, 141-162.
17. Chen, H.; Ionescu, M.; Ishdorj, T.-O.; Păun, A.; Păun, G.; Pérez-Jiménez, M.J. Spiking Neural P Systems with Extended Rules: Universality and Languages. Nat. Comput. 2008, 7, 147-166. [CrossRef]
18. Metta, V.P.; Krithivasan, K.; Garg, D. Computability of spiking neural P systems with anti-spikes. New. Math. Nat. Comput. 2012, 8, 283-295. [CrossRef]
19. Păun, A.; Păun, G. Small Universal Spiking Neural P Systems. BioSystems 2007, 90, 48-60. [CrossRef]
20. Song, T.; Pan, L.; Păun, G. Spiking Neural P Systems with Rules on Synapses. Theor. Comput. Sci. 2014, 529, 82-95. [CrossRef]
21. Song, T.; Pan, L.; Păun, G. Asynchronous Spiking Neural P Systems with Local Synchronization. Inf. Sci. 2013, 219, 197-207. [CrossRef]
22. Wang, J.; Hoogeboom, H.J.; Pan, L.; Păun, G.; Pérez-Jiménez, M.J. Spiking Neural P Systems with Weights. Neural. Comput. 2010, 22, 2615-2646. [CrossRef]
23. Liu, X.; Ren, Q. Spiking Neural Membrane Computing Models. Processes 2021, 9, 733. [CrossRef]
24. Pan, L.; Păun, G.; Pérez-Jiménez, M.J. Spiking Neural P Systems with Neuron Division and Budding. Sci. China Inf. Sci. 2011, 54, 1596-1607. [CrossRef]
25. Xue, J.; Liu, X. Solving Directed Hamilton Path Problem in Parallel by Improved SN P System. In Proceedings of the International Conference on Pervasive Computing and the Networked World, Istanbul, Turkey, 28-30 November 2012; pp. 689-696. [CrossRef]
26. Rong, H.; Yi, K.; Zhang, G.; Dong, J.; Paul, P.; Huang, Z. Automatic Implementation of Fuzzy Reasoning Spiking Neural P Systems for Diagnosing Faults in Complex Power Systems. Complexity 2019, 2019, 2635714. [CrossRef]
27. Pan, L.; Păun, G. Spiking Neural P Systems with Anti-Spikes. Int. J. Comput. Commun. 2009, 4, 273. [CrossRef]
28. Zeng, X.; Song, T.; Zhang, X.; Pan, L. Performing Four Basic Arithmetic Operations with Spiking Neural P Systems. IEEE Trans. NanoBiosci. 2012, 11, 366-374. [CrossRef]
29. Naranjo, G.; Ángel, M.; Leporati, A. Performing Arithmetic Operations with Spiking Neural P Systems. In Proceedings of the Seventh Brainstorming, Sevilla, Spain, 27 February 2009.
30. Zhang, X.-Y.; Zeng, X.-X.; Pan, L.-Q.; Luo, B. A spiking neural P system for performing multiplication of two arbitrary natural numbers. Jisuanji Xuebao 2009, 32, 2362-2372.
31. Peng, X.-W.; Fan, X.-P.; Liu, J.-X.; Wen, H. Spiking Neural P Systems for Performing Signed Integer Arithmetic Operations. J. Chin. Comput. Syst. 2013, 34, 360-364.
32. Zhang, G.; Rong, H.; Paul, P.; He, Y.; Neri, F.; Pérez-Jiménez, M.J. A Complete Arithmetic Calculator Constructed from Spiking Neural P Systems and Its Application to Information Fusion. Int. J. Neural. Syst. 2021, 31, 2050055. [CrossRef]
33. Păun, G.; Pérez-Jiménez, M.J.; Rozenberg, G. Spike trains in spiking neural P systems. Int. J. Found. Comput. Sci. 2006, 17, 975-1002. [CrossRef]
34. Pan, L.; Zeng, X.; Zhang, X. Time-Free Spiking Neural P Systems. Neural. Comput. 2011, 23, 1320-1342. [CrossRef]
35. Liu, X.; Li, Z.; Liu, J.; Liu, L.; Zeng, X. Implementation of Arithmetic Operations with Time-Free Spiking Neural P Systems. IEEE Trans. NanoBiosci. 2015, 14, 617-624. [CrossRef] [PubMed]
36. Wang, H.; Zhou, K.; Zhang, G. Arithmetic Operations with Spiking Neural P Systems with Rules and Weights on Synapses. Int. J. Comput. Coттип. 2018, 13, 574. [CrossRef]
37. Peng, X.; Fan, X.; Liu, J.; Wen, H.; Liang, W. Spiking Neural P Systems with Anti-Spikes for Performing Balanced Ternary Logic and Arithmetic Operations. J. Chin. Comput. Syst. 2013, 34, 832-836. [CrossRef]

Disclaimer/Publisher's Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and / or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.


[^0]:    Copyright: © 2023 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https:// creativecommons.org/licenses/by/ 4.0/).

