Abstract-According to the development of information technologies, a high-speed similar data retrieval system is becoming important to retrieve similar data from mass data in database for character recognition, fingerprint recognition, data compression, color image recognition, and so on. However, the conventional similar data retrieval system implemented by software or hardware using conventional memory is slow, because a computer must compare the called data sequentially. For this reason, in order to retrieve similar data, an associative memory has been studied in recent years. In this paper, by utilizing a neuron CMOS inverter, we propose a novel minimum 
I. INTRODUCTION
According to the development of information technologies, a high-speed similar data retrieval system is becoming important to retrieve similar data from mass data in a database. For example, the similar data retrieval system is utilized for character recognition, fingerprint recognition, data compression, color image recognition, and so on. For this reason, the improvement in speed performance of the similar data retrieval system is strongly recommended. In the measurement of similarity between stored data and input data, the Hamming distance or the Manhattan distance is commonly used [1] . For example, the Hamming distance is used for the recognition such as character, fingerprint, and so on. On the other hand, the Manhattan distance is used for data compression and color image recognition. However, the similar data retrieval system implemented by software is slow, because a computer must compare the called data sequentially. Also, basic process is the same as in the case of software implementation even when it is implemented with hardware using the conventional memory. In these methods, the retrieval time increases in proportion to the increase of data volume. For this reason, in order to retrieve similar data, an associative memory has been studied in recent years [2] - [6] . However, the conventional methods are of no practical use. Unlike the conventional retrieval system, humans can instantly retrieve for the data showing features which are most similar to the inputs among data which have been already stored in the brain.
By utilizing a neuron CMOS inverter which has similar characteristics to a brain neuron [7] , we propose a minimum Manhattan distance retrieving circuit as an important functional block of the associative memory. Due to the influence of the initial charge and the variation of threshold voltage in neuron MOS transistors, a malfunction is occurred in conventional circuits using neuron MOS transistors [8] - [10] . In the proposed circuit, the voltage of the floating gate of neuron CMOS inverters is equal to its threshold voltage by connecting the output to the floating gate of neuron CMOS inverters before retrieving process. Owing to this operation, the influences of the initial charge and the variation of threshold voltage can be eliminated. The proposed circuit also achieves high retrieving speed by using fully parallel processing. Furthermore, the proposed circuit can retrieve not only the completely matched data but also the most similar data. To confirm the validity of the proposed circuit, Simulation Program with Integrated Circuit Emphasis (SPICE) simulations are performed.
II. CIRCUIT CONFIGURATION OF THE DATA COINCIDENCE DETECTOR
First, we describe a data coincidence detector using a neuron CMOS inverter. In the proposed minimum Manhattan distance retrieving circuit, the data coincidence detector is one of the most important building blocks. The Manhattan distance between (A 1 , …, A j , …, A M ) and (B 1 , …, B j , …, B M ) is defined as follows:
In (1), A j and B j (j = 1, 2, …, M) are binary data with N-bits (N = 1, 2, …) and M-elements (M = 1, 2, …). Fig. 1 shows the circuit configuration of the data coincidence detector using a neuron CMOS inverter, where the input data and the reference data are expressed as (A 1 , …, A j , …, A M ) and (B 1 , …, B j , …, B M ), respectively. In Fig. 1 , V DD is the supply voltage, F is the control voltage to start the retrieving for the matching data, G is the control voltage for the most similar data retrieving, SW 1 is the switch to set the floating gate voltage V F of the neuron CMOS inverter νCMOS to the threshold voltage V TH , and SW 2 is the switch to enable the retrieving for the matching data. In the neuron CMOS inverter νCMOS, the capacitances C 0,j , C i,j (i = 1, 2, …, N) and C H between the floating gate and the input terminal of νCMOS are designed to satisfy the following conditions:
and Figure 1 . Circuit configuration of the data coincidence detector using a neuron CMOS inverter.
In (2)- (4), C denotes a unit capacitance. In Fig. 1 , the output of the Sub j , D j , is expressed as:
Next, the output D j of the Sub j is inverted by the Inv j as follows:
In other words, |A j -B j | in (1) is calculated by Sub j 's and Inv j 's. If D j is a negative value, it is necessary to further add 1 to the inverted value. However, by connecting borrow j to the neuron CMOS inverter, the proposed circuit doesn't require the circuit to calculate two's-complement values. The operation principle of this circuit is as follows: First, the control voltage F is set to a low level, G is set to a high level, the switch SW 1 is turned "ON," and the SW 2 is connected to the lower side. In this case, the floating gate voltage V F of νCMOS is expressed as:
here, all the outputs of NAND become a high level and the output OUT becomes a low level, because F is at a low voltage level. Next, the SW 2 is connected to the upper side after the SW 1 is turned "OFF". Here, we consider about the floating gate voltage V F of νCMOS. When the voltage of the input terminal that has the capacitance C x between the input terminal and the floating gate is changed by ΔV, the amount of change in the voltage V F , ΔV F , is expressed as:
In (8), C T is the total of the capacitance between the input terminal and the floating gate of νCMOS and the capacitance C P between the floating gate and the substrate. The total capacitance C T is expressed as:
When the SW 2 is connected to the upper side, the voltage of the lowest input terminal V H of the νCMOS changes from V TH to V DD . Therefore, from (4), (7) and (8), the floating gate voltage V F is obtained as:
In this case, the output of νCMOS becomes a low level, because V F exceeds the threshold voltage V TH as shown in (10) .
Next, the control voltage F is set to a high level. When the i-th bit e i,j of the j-th element E j or borrow j are at a high level, the output V i,j of NAND or V 0,j become 0V from the supply voltage V DD . In this case, we define the floating gate voltage V F as V F '. From (2), (3), (8) , and (10), the voltage V F ' is expressed as:
Then, (11) is rewritten as:
As (12) voltage of the floating gate, V F , does not change from (10) , because all the outputs of NAND remain a high level and the output of νCMOS also remains a low level. Therefore, the output OUT becomes a high level. As explained above, the proposed circuit can detect the coincidence between (A 1 , …, A j , …, A M ) and (B 1 , …,  B j , …, B M ) .
As (12) 
By substituting (12) into (13), the time T is expressed as:
As we can see from (14), the time T is invariant to the parasitic capacitance and the initial charge. When the difference of the Manhattan distance is 1, the time lag ΔT is expressed as:
From (15), the change of the threshold voltage V TH doesn't affect the time lag for the difference of the Manhattan distance.
III. CIRCUIT CONFIGURATION OF THE MINIMUM
MANHATTAN DISTANCE RETRIEVING CIRCUIT Fig. 2 shows the circuit configuration of the proposed minimum Manhattan distance retrieving circuit. The proposed circuit is constituted by arraying L (= 2, 3, …) data coincidence detectors when the number of words is L. The control voltage G of the data coincidence detector is connected to the output of the multi-input OR. In Fig. 2 , H is the control voltage to retrieve the most similar data. The data retrieval is started when the H becomes a low level.
The operation principle of the proposed circuit will be described. The operation of the proposed circuit can be divided into three cases: Figure 2 . Circuit configuration of the minimum Manhattan distance retrieving circuit using neuron CMOS inverters.
By above-mentioned operations, the proposed circuit can find out the matching data from the input data when the control voltage F is set to a high level. Furthermore, the proposed circuit can find out the reference data which is the most similar to the input data when the control voltage H is set to a low level.
IV. SIMULATION
As an example of the proposed minimum Manhattan distance retrieving circuit, we performed the HSPICE simulations concerning the proposed circuit with 4-bits, 2-elements, and 8-words. In these simulations, we assumed a ROHM 0.18μm CMOS process as a transistor model. The conditions of the SPICE simulations are as follows: V DD is 1.8V and the threshold voltage of the floating gate of neuron CMOS inverters, V TH , is 0.9V. Fig. 3 shows the simulation results when the reference data with Manhattan distance 0-15 is inputted. In this figure, t 1 denotes the point when the control voltage F is set to a low level, SW 1 is turned "ON" and SW 2 is connected to the lower side, t 2 denotes the point when SW 1 is turned "OFF" and SW 2 is connected to the upper side, and t 3 denotes the point when the control voltage F is set to a high level. As Fig. 3 shows, the floating gate voltage V F is equal to the threshold voltage V TH at the point t 1 . At the point t 2 , V F exceeds V TH . And the floating gate voltage V F decreases in proposition to the Manhattan distance at the point t 3 . Fig. 4 shows the floating gate voltage V F as a function of the Manhattan distance. In this figure, the floating gate voltage V F satisfies (12) and is expressed as a linear function of the Manhattan distance. inputted. Fig. 6 shows the retrieval time as a function of the Manhattan distance, where the ordinate represents the time when V F reaches V TH . As Fig. 5 and Fig. 6 show, the retrieval time increases linearly in proportion to the Manhattan distance. In this simulation, the retrieval time is 32.3ns when the Manhattan distance is 16. Table I .
International Journal of Electronics and Electrical Engineering Vol. 4, No. 4, August 2016
©2016 Int. J. Electron. Electr. Eng. Fig. 7 shows the simulated output waveform, where the relationships of I/O data were set as shown in Table I.  As Table I shows, the input data A completely matches the reference data B 2 . In Fig. 7 , the output OUT 2 is a high level after the control voltage F becomes a high level. Therefore, we can confirm that the proposed circuit is able to find out the matched data. Fig. 8 shows the simulated output waveform, where the relationships of I/O data were set as shown in Table II.  As Table II shows, the reference data B 2 and B 3 have the minimum Manhattan distance. In Fig. 8 , the outputs OUT 2 and OUT 3 are a high level after the control voltage H becomes a low level. Therefore, we can confirm that the proposed circuit is able to find out the most similar data.
V. CONCLUSION
In this paper, we proposed a novel minimum Manhattan distance retrieving circuit using neuron CMOS inverters. By converting the Manhattan distance to the time, the proposed circuit can retrieve for the data with the minimum Manhattan distance using a fully parallel operation. Unlike conventional circuits, the proposed circuit is less affected by the initial charge of the floating gate and the variation of threshold voltage. The validity of the proposed circuit was confirmed through SPICE simulations.
In a future study, we will apply the proposed circuit to associative memories and confirm the operation by experiments using an integrated circuit.
