# 対称型 NOR アーキテクチャを用いた

# ハミング距離検索機能付き CAROM の提案

福原 雅朗\*1, 平谷 真之\*2, 杉山 健太郎\*2, 恩地 夏央\*2, 藏野 貴教\*2

## Proposal of a Hamming Distance Search CAROM with Symmetric NOR-Architecture

by

Masaaki FUKUHARA<sup>\*1</sup>, Masayuki HIRATANI<sup>\*2</sup>, Kentaro SUGIYAMA<sup>\*2</sup>, Nao ONJI<sup>\*2</sup> and Takanori KURANO<sup>\*2</sup>

(received on Mar.31, 2017 & accepted on May 23, 2017)

### あらまし

従来のNORアーキテクチャによるハミング距離検索機能付きCAROM (Content Addressable Read Only Memory:内容照合ROM)は、一致線及び参照線のトランジスタ数の差異や製造プロセスにおける特性ばらつきなどの影響下でも正常に照合動作を行うため、一致線及び参照線にそれぞれダミーキャパシタを付加していた.本文では、一致線及び参照線に接続されるトランジスタの数や寸法を均等にし、それらを対称的に配置することで、ダミーキャパシタを用いなくても、従来と同様の照合動作を安定して行える、新たなハミング距離検索機能付きCAROMを提案する.また、提案CAROMの照合動作をHSPICEシミュレーションにより検証し、その有用性を明らかにする.

#### Abstract

In conventional Hamming distance search CAROMs with NOR architecture, the dummy capacitors on a match line and reference line are required to stabilize the interrogation operations against the difference of the number of transistors and process variation. In this paper, we propose a new CAROM with the Hamming distance search function. The proposed CAROM can stably behave interrogation operations without the dummy capacitors by using symmetrical NOR-architecture. Also, the interrogation operations of the CAROM are confirmed by HSPICE simulations.

キーワード: 内容照合メモリ, CAROM, ハミング距離, あいまい検索, NOR 構造 Keywords: Content Addressable Memory, CAROM, Hamming distance, Fuzzy search, NOR-architecture

## 1. はじめに

あいまい検索が可能なハードウェアであるハミン グ距離検索機能付きCAM (Content Addressable Memory:内容照合メモリ)(以下,H-CAMと略記), あるいはメモリセル部にROMを適用したハミング距 離検索機能付きCAROM(以下,H-CAROM)は,画像 認識や辞書検索,パケットルーティングなどの分野で 有用とされており,ビッグデータの発展に伴いその重 要性が一層高まる現在,様々な回路が研究されている<sup>1)-4)</sup>. 文献 4)では,一致線 (Match line)にNORアーキテ クチャを用いた手法が提案されている.このNOR型回 路を用いると,記憶データと検索データ間のハミング 距離に対応したアナログ電圧が段階的に生成される.

\*2 情報通信学部組込みソフトウェア工学科 School of Information and Telecommunication Engineering, Department of Embedded Technology それらの一致線電圧を判別する方法として、(A)フラ ッシュ型ADC形式<sup>4)</sup>,(B)ニューロンCMOS型ADC形式<sup>5)</sup>, (C)アナログコンパレータ形式<sup>6)-9)</sup>などが報告され ている.(A)と(B)の場合には、チップ製造プロセスで 生じるしきい電圧や寄生容量のランダムばらつきの 影響で、実チップの一致線電圧が大きく変動するため、 設計が困難である.これに対し、(C)の場合には、一致 線電圧に対して一定の電位差が得られるよう設計さ れた基準電圧(参照線電圧)に基づいて判別するため、 (A)と(B)の手法に比べて安定した検索動作(照合動作) を行うことができる.また、一層の安定性を確保する ため、文献8)のH-CAM、及び低電力化のためプリチャ ージ回路を用いた文献9)のH-CAROMでは、一致線・ アース間及び参照線・アース間にダミーキャパシタを 挿入している.

本論文では、対称型NORアーキテクチャを用いた新 しいH-CAROMを提案する.提案回路は、一致線及び 参照線にNOR構造で接続されるトランジスタの個数 や寸法を均一にし、それらを対称的に配置することで、 ダミーキャパシタを用いなくても一致線電圧と参照 線電圧の電位差を確保し、より安定した照合動作が実 現できる.本文ではHSPICEシミュレーションにより、

<sup>\*1</sup> 情報通信学部組込みソフトウェア工学科 講師 School of Information and Telecommunication Engineering, Department of Embedded Technology, Junior Associate Professor





(b) Search for "Similar data" (example: D<sub>HR</sub>=1) (i=1,2, ..., n)Fig.1 Algorithm of Hamming distance search CAROM

Table 1 Relationships between  $D_{HSi}$ ,  $D_{HR}$ and V(OUTi) (i=1,2,...,n)

|        | Relationships between $D_{HSi}$ and $D_{HR}$ | Output voltage<br>V(OUTi) |
|--------|----------------------------------------------|---------------------------|
| Case-1 | $D_{HSi} \leq D_{HR}$                        | Logic "1" $(V_{DD})$      |
| Case-2 | $D_{HSi} > D_{HR}$                           | Logic "0" (0[V])          |

提案回路の動作を検証している.

## 2. 従来の NOR アーキテクチャ型 H-CAROM

## 2.1 H-CAROM におけるハミング距離検索動作

H-CAROM は、マスク ROM が持つ"記憶機能", "読み出し機能"に加えて、"ハミング距離検索機能" がある. "ハミング距離検索機能"は、メモリセルア レイの記憶データ(Stored data)と外部からの検索デー タ(Search data)とを並列に照合し、それらのハミング 距離が一定の値以内、すなわち検索データと類似した 記憶データを、高速かつ効率的に検索できる.

ここで、メモリセルアレイの構成としてビット長 m, ワード数 n の記憶データ a<sub>ij</sub> (i=1,2, ..., n, j=1,2, ..., m) を持つ H-CAROM に対し、ビット長 m の検索データ b<sub>j</sub> (j=1,2, ..., m)を外部から印加して、"ハミング距離検 索"を行う場合を考える.ハミング距離(Hamming distance)D<sub>HSi</sub> (i=1,2, ..., n)とは不一致ビットの総数であり、

$$D_{HSi} = \sum_{j=1}^{m} a_{ij} \oplus b_j$$
,  $(i = 1, 2, ..., n)$ 

で与えられる類似性の尺度である.式(1)において, ⊕ は EXOR (EXclusive-OR: 排他的論理和) 演算子であ



Fig.2 NOR-architecture circuit around match line in conventional H-CAM<sup>4)</sup> (*i*=1,2, ..., *n*)

り,  $a_{ij}$  と  $b_j$  の論理値が一致している場合は論理"0", 不一致の場合は論理"1"となる.式(1)より,  $D_{HSi}$  (i=1,2,…, n)が取り得る値は 0,1,2, …, m のいずれかである. 例えば, Fig.1(a)のように m=4 とし, i=1 ワード目の記 憶データ(" $a_{11}a_{12}a_{13}a_{14}$ "="0000")に対し検索データ (" $b_1b_2b_3b_4$ "="1000")を印加した場合のハミング距離  $D_{HS1}$ は 1 である.同様に, i=2の記憶データ (" $a_{21}a_{22}a_{23}a_{24}$ "="1000")は検索データと完全に一致し ているので,  $D_{HS2}=0$ となる. その他の  $D_{HSi}(i=3, ..., n)$ は Fig.1(a)中に示すとおりである. なお, ここでの説 明例では,検索データと完全一致の記憶データ ("1000")は2 ワード目にしかないものとする.

このとき、参照距離(Reference distance)  $D_{HR}$ を任意 の値に設定すると、CAROM は全ワードの  $D_{HSi}(i=1,2, ..., n)$ と  $D_{HR}$ とを一斉に比較し、Table 1 に基づいた論 理値を出力電圧 V(OUTi) (i=1,2,...,n)として出力する. 例えば、Fig.1(a)のように  $D_{HR}$ を 0 と設定した場合、2 ワード目のハミング距離  $D_{HS2}$ は 0 であり Case-1 を満 たすことから、V(OUT2)は論理"1"となる.一方、その 他のワードのハミング距離  $D_{HSi}(i=1,3,...,n)$ は 1 以上 であることから  $D_{HSi}>D_{HR}$  (i=1,3,...,n)は 1 以上 であることから V(OUTi) (i=1,3,...,n)は全て論理"0" を出力する.以上が"完全一致検索機能"である.

これに対し, Fig.1(b)のように *D<sub>HR</sub>*を1と設定した 場合, Table 1の条件から, 完全一致ワードの *V*(OUT2) だけでなく, ハミング距離が 1 である *V*(OUT1)と *V*(OUT3)などにもフラグが立つ.このように, 検索デ ータと完全一致の記憶データに加え, 任意に参照距離 を設定することで, 検索データと類似したデータを検 索できるのが"ハミング距離検索機能"である.

なお, H-CAM や H-CAROM を含む一般の CAM で は,記憶データとして論理"1"と"0"の2値だけで なく,第3の論理値ともいえる"\*(Don't care)"を扱 うことができる場合がある.また,検索データとして 特定のビットを検索対象から除外するマスク機能を 有する CAM や CAROM も存在する.これらの機能に ついては提案回路の項にて詳述する.

1)

| (* 1,2,,*)              |                                                |       |      |  |
|-------------------------|------------------------------------------------|-------|------|--|
| Symbol                  | Name                                           | Value | Unit |  |
| $V_{DD}$                | Power supply voltage                           | 5.0   | V    |  |
| т                       | Number of bits                                 | 4     | Bit  |  |
| $(W/L)_{MLij}$          | Width/Length of M <sub>MLi1</sub> ,            | 4/2   |      |  |
| (j=1,2,3,4)             | $M_{\rm MLi2},M_{\rm MLi3}$ and $M_{\rm MLi4}$ | 4/2   | μm   |  |
| $(W/L)_{\mathrm{MLD}i}$ | Width/Length of M <sub>MLDi</sub>              | 2/2   | μm   |  |
| $(W/L)_{\mathrm{MLU}i}$ | Width/Length of M <sub>MLUi</sub>              | 8/2   | μm   |  |
|                         |                                                |       |      |  |

Table 2 Device parameters and simulation conditions for Fig.3

n

(i-1, 2)



Fig.3 Simulated waveforms of conventional NOR-architecture circuit (i=1,2,...,n)

## 2.2 NOR アーキテクチャとハミング距離検索

"ハミング距離検索機能"を実現する CAM として、 検索用回路部分に NOR アーキテクチャを用いること が文献 4)で提案された. 文献 4)の回路の中で, NOR アーキテクチャで構成された一致線周辺の回路図を Fig.2 に示す. Fig.2 の回路に関して, i(i=1,2,...,n)ワ ード目の記憶データ aij (j=1,2, ..., m)と検索データ bj (j=1,2,...,m)とのハミング距離 D<sub>HSi</sub>に対する一致線電 圧 V(MLi)の変化を表すため, Table 2 の条件で HSPICE シミュレーションを行なった.また,デバイスパラメ ータは,北九州学術研究都市・共同研究開発センター (ひびきの)より提供されている,最小ゲート長 2µm, 2 層メタル,1 層ポリシリコン, CMOS プロセスのデ ータを用いた. なお, Fig.2 では EXOR ゲートによっ て検索データと記憶データの一致/不一致を求めてい るが、本シミュレーションでは、EXOR ゲートの出力 を NOR 型回路の入力信号(Input signals) INi (j=1,2,..., *m*, *m*=4)とみなし, Table 3 に示した電圧 V(INj) (j=1,2,3,4)を Fig.3(a)のタイミングで印加した.

この回路は、照合パルス $\overline{\phi_{IG}}$  (Fig.3(b)) がハイレベ

Table 3 Simulated results of Match line voltage. V(MLi)

| (i=1,2,,n)                           |                     |          |          |            |                                 |
|--------------------------------------|---------------------|----------|----------|------------|---------------------------------|
| Ham-                                 | Input signals Match |          |          | Match line |                                 |
| ming<br>distance<br>D <sub>HSi</sub> | <i>V</i> (IN1)      | V(IN2)   | V(IN3)   | V(IN4)     | Watch line<br>voltage<br>V(MLi) |
| 0                                    | 0[V]                | 0[V]     | 0[V]     | 0[V]       | 5.000 [V]                       |
| 1                                    | $V_{DD}$            | 0[V]     | 0[V]     | 0[V]       | 1.542 [V]                       |
| 2                                    | $V_{DD}$            | $V_{DD}$ | 0[V]     | 0[V]       | 0.672 [V]                       |
| 3                                    | $V_{DD}$            | $V_{DD}$ | $V_{DD}$ | 0[V]       | 0.433 [V]                       |
| 4                                    | $V_{DD}$            | $V_{DD}$ | $V_{DD}$ | $V_{DD}$   | 0.320 [V]                       |



Fig.4 V(MLi) and V(RLi) of conventional H-CAM (*i*=1,2, ..., *n*)

ルの間に入力信号 INj (j=1,2, ..., m)の電圧を確定させ ておき (Fig.3(a)),  $\overline{\phi_{IG}}$ がローレベルになるとその照 合結果が一致線電圧 V(MLi) (i=1,2, ..., n)として現れる (Fig.3(c)). Fig.3(c)より, ハミング距離 D<sub>HSi</sub> (i=1,2, ..., n)に対して一致線電圧 V(MLi)が段階的なアナログ 値として得られていることがわかる. V(MLi)の値を Table 3 にもまとめる. これらのアナログ電圧 V(MLi) を何らかの回路的手法で判別することで"ハミング距 離検索"が可能となる.

## 2.3 従来回路の問題点

NOR型回路が提案された文献4)では、これらのアナ

ログ電圧を判別する手段として、CMOSインバータを 複数並列に配置したフラッシュCMOS型AD変換回路 を使用することを述べている.また、設計容易性を向 上させたニューロンCMOS型AD変換回路を用いたも のも報告されている<sup>5)</sup>.しかし、これらのように一致 線電圧を直接AD変換回路で判別する場合、ICチップ 製造時のプロセスばらつきの影響で、一致線に接続さ れるプルアップpMOS及びプルダウンnMOSのしきい 電圧やドレイン容量を含めた寄生容量などが変動す ると、実機の一致線電圧が設計時と異なり設計通りに 判別できない場合がある.

これに対し、アナログコンパレータ型が報告されて いる.これは、一致線と同様の回路構成で、一致線電 圧に対して段階的な電圧差が生じる設計がなされた 参照線(Reference line)回路を用意し、そのiワード目の 参照線電圧V(RLi)と一致線電圧V(MLi)とをアナログ コンパレータで比較判定する.なお、参照線回路にお いて設定可能な参照距離の最大値は3または4程度と されている<sup>7)-9)</sup>.

ここで,一致線回路と参照線回路の電圧の過渡特性 をHSPICEシミュレーションにより検証した. Fig.4は ハミング距離DHSiと参照距離DHRをパラメータとし、 一致線電圧 V(MLi)と参照線電圧 V(RLi)が立ち上がる 瞬間をまとめた波形である. ビット長m=4とし, DHRの 最大値を3とした場合(Fig.4(a)), V(MLi)とV(RLi)の 大小関係は常に一定である.一方, m=32, D<sub>HR</sub>の最大 値が3の場合(Fig.4(b)), V(MLi)とV(RLi)が立ち上が るタイミングで波形が交錯し大小関係が入れ替わっ ている箇所がある. 仮に, V(MLi)とV(RLi)の大小関係 が反転しているタイミングでアナログコンパレータ を作動させると,所望の判定結果が得られなくなる可 能性がある.このような波形になる主な要因は,一致 線及び参照線に接続されるプルダウンnMOSの個数が 異なるため,寄生容量の差が生じているためであると 考えられる.

このような要因を考慮し、文献8)のH-CAM及び文 献9)のH-CAROMでは、安定した動作確保を目的とし て、一致線-アース間及び参照線-アース間にダミーキ ャパシタを設けている.しかし、キャパシタを集積化 することは設計上のコスト(レイアウト面積など)が かかることに加え、動作速度も遅くなる.

そこで本論文では、ダミーキャパシタを用いないこ とで文献8)よりも高速な検索を可能とし、ビット長が 大きい場合でも安定して検索動作ができる新たな回 路構成を提案する.

## 3. 提案回路の構成と照合特性

#### 3.1 回路の全体構成

提案するハミング距離検索機能付き CAROM (H-CAROM)のブロック図を Fig.5 に示す.提案 H-CAROM は、リセットパルス(Reset pulse) $\phi_{RS}$ ,照合パルス(Interrogation pulse) $\phi_{IG}$ ,比較判定パルス(Comparison pulse) $\phi_{CP}$ の3種類の制御信号で動作する.また、 $V_{DD}$ は電源電圧、GND は基準電圧である.この H-CAROM



Fig.5 Block diagram of proposed H-CAROM (i=1,2, ..., n)



Fig.6 Definition of Stored data (i=1,2, ..., n, j=1,2, ..., m)

は、2.1 節でも述べたように、ビット長 m、ワード数 n で構成される CAROM セルアレイ内の記憶データ aij (i=1,2,...,n, j=1,2,...,m)と、外部から印加するビット 長 mの検索データ bj (j=1,2,...,m)とを並列に照合し、 それらのハミング距離 DHSi (i=1,2,...,n)が、外部から 設定する参照距離 DHR よりも大きいか否かを判定し、 Table 1 の条件に応じた出力電圧 V(OUTi) (i=1,2,...,n) を得る回路である.提案回路は、一致線と参照線に接 続されるトランジスタの個数や寸法を対照的に配置 した、対称型 NOR アーキテクチャを用いている.

提案 H-CAROM の具体的な回路構成と照合動作特性について, CAROM セルアレイ,参照距離設定回路, 比較判定回路に分けて順に説明する.

Table 4 Definitions of search data (j=1,2,...,m)

| Operation  | V(BLj)   | V(BLbj)  |  |
|------------|----------|----------|--|
| "0" search | 0[V]     | $V_{DD}$ |  |
| "1" search | $V_{DD}$ | 0[V]     |  |
| Mask       | 0[V]     | 0[V]     |  |

#### 3.2 CAROM セルアレイ

CAROM セルアレイは *m×n* 個の CAROM セルがア レイ状に配置されている. 各 CAROM セルは一般的な マスク ROM 形式であり, ワード線 WLi (*i*=1,2, ..., *n*), ビット線対 BL*j*及び BLb*j*(*j*=1,2, ..., *m*), 読み出し用ト ランジスタ M<sub>RD*ij*</sub>(*i*=1,2, ..., *n*, *j*=1,2, ..., *m*), 照合用トラ ンジスタ M<sub>ML*ij*</sub>(*i*=1,2, ..., *n*, *j*=1,2, ..., *m*), 一致線 ML*i* (*i*=1,2, ..., *n*)で構成される.

Fig.6 は, 記憶状態に応じた各 CAROM セルの回路 構成を図示している. 論理"0"を記憶する場合 (Fig.6(a)), M<sub>RDij</sub>(*i*=1,2,...,*n*,*j*=1,2,...,*m*)のドレイン 及び M<sub>MLij</sub>(*i*=1,2,...,*n*,*j*=1,2,...,*m*)のゲートは BL*j* (*j*=1,2,...,*m*)に接続される. 一方,"1"記憶の場合 (Fig.6(b)), M<sub>RDij</sub>(*i*=1,2,...,*n*,*j*=1,2,...,*m*)のドレイン 及び M<sub>MLij</sub>(*i*=1,2,...,*n*,*j*=1,2,...,*m*)のゲートは BL*bj* (*j*=1,2,...,*m*)に接続される.

また、3値目の記憶状態である"\*(don't care)"を記 憶する場合(Fig.6(c))には、 $M_{RDij}$ (*i*=1,2, ..., *n*, *j*=1,2, ..., *m*)のドレイン及び $M_{MLij}$ (*i*=1,2, ..., *n*, *j*=1,2, ..., *m*)の ゲートを接地する.ここで、提案 H-CAROMでは一致 線のトランジスタを参照線と対称的に配置するため、 ゲート接地により常にオフ状態であっても $M_{MLij}$ (*i*=1,2, ..., *n*, *j*=1,2, ..., *m*)のドレインをMLi(*i*=1,2, ..., *n*) に接続する.この場合の $M_{MLij}$ (*i*=1,2, ..., *n*, *j*=1,2, ..., *m*) は ESD 保護ダイオードと同等の働きをする.

なお、本論文では照合特性について述べるため、読 み出し動作については説明を省略する.

提案 H-CAROM における検索データの定義は Table 4 のとおりである. 続いて,これらの検索データ と, Fig.5 の CAROM セルアレイに記述されている記 憶データとの照合動作について説明する. Fig.7 は, 読 み出し用トランジスタを省略した, i(i=2,3,4)ワード目 の一致線周辺の回路図である. この一致線回路は, 一 致線 ML*i* に対して, *m* 個のプルダウン nMOS トラン ジスタ M<sub>MLij</sub> (j=1,2,...,m)とプルアップ pMOS トラン ジスタ M<sub>MLij</sub> (j=1,2,...,m)とプルアップ pMOS トラン ジスタ M<sub>MLij</sub> が接続されている NOR 構造である. M<sub>MLij</sub> (j=1,2,...,m)は、検索データに応じて印加される ビット線対 (BL*j*, BL*bj*) (j=1,2,...,m)の電圧によって 駆動され, M<sub>MLij</sub> は別セット用 nMOS である.

まず,照合パルス $\overline{\phi_{IG}}$ がハイレベルである間に検索 データ"1000…0"を印加し,その検索データと2ワー ド目の記憶データ"1000…0"と照合する場合(Fig.7(a)), 一致線 ML2 に接続されるすべてのプルダウン nMOS がオフ状態となる.このとき,照合パルス $\overline{\phi_{IG}}$ をローレ ベルに下げると  $M_{MLU2}$ がオン状態になり,一致線電圧 V(ML2)は  $V_{DD}$ となる.

一方,上記と同じ検索データに対して,3ワード目



(d) Stored data is "1100...0" and search data is "\*\*\*0...0" Fig.7 Schematic around Match line of proposed CAROM

の記憶データ"1100…0"との照合の場合(Fig.7(b))に は、 $M_{ML32}$ のゲートが接続されている BLb2 に  $V_{DD}$ が 印加されるため  $M_{ML32}$ はオン状態となり、他のプルダ ウン nMOS は全てオフ状態となる.したがって、照合 パルス $\overline{\phi_{IG}}$ がローレベルに下がると、V(ML3)は  $V_{DD}$ よ りも低いアナログ電圧になる.このケースは、検索デ ータと記憶データの不一致ビットが 1 つ、すなわちハ ミング距離  $D_{HS3}=1$ の場合である.

同様に検討すると、ハミング距離の数だけプルダウン nMOS がオン状態となり、一致線電圧は、ハミング距離が大きくなるとその距離に応じて段階的に下がることがわかる.すなわち、ハミング距離に対するアナログ電圧が生成される.





(b) Number of reference signals is 3Fig.8 Reference circuit (*i*=1,2, ..., *n*)

| $D_{HR}$ | <i>V</i> (RF1) | V(RF2)   | <i>V</i> (RF3) |
|----------|----------------|----------|----------------|
| 0        | 0[V]           | 0[V]     | 0[V]           |
| 1        | $V_{DD}$       | 0[V]     | 0[V]           |
| 2        | $V_{DD}$       | $V_{DD}$ | 0[V]           |
| 3        | $V_{DD}$       | $V_{DD}$ | $V_{DD}$       |

記憶データの中に"\*(don't care)"が含まれる照合動 作の例として、Fig.7(c)では、検索データ"1000…0"と 4 ワード目の記憶データ"\*\*\*0…0"との照合の場合を 表している.このとき、一致線 ML4 に接続されるす べてのプルダウン nMOS がオフ状態となるため、 V(ML4)は Vonとなり、4 ワード目の記憶データと検索 データは完全一致と判定される.

また、検索データにおける Mask とは、特定のビットを照合の対象から除外することである.その具体例 として、Fig.7(d)では、3 ワード目の記憶データ"1100 …0"に対して、検索データ"\*\*\*0…0"を印加する場合 を表している.このときも、一致線 ML3 のプルダウン nMOS はすべてオフ状態となり、これらのデータも 完全一致と判定される.

なお,照合パルス $\overline{\phi_{IG}}$ がハイレベルのときは,M<sub>MLDi</sub> (*i*=1,2,...,*n*)によって全ワードの一致線 ML*i*(*i*=1,2,..., *n*)が接地される.また,後述する参照線回路と対称に するため,M<sub>MLDi</sub>(*i*=1,2,...,*n*)のチャネル幅は,他のプ ルダウン nMOS のチャネル幅の半分に設計される.

#### 3.3 参照距離設定回路

参照距離設定回路は、任意に設定する参照距離 (Reference distance)に応じて、CAROM セルアレイ側の 一致線回路のアナログ電圧を判別するための参照電 圧を生成する回路である.提案 H-CAROM では、一致 線と対称構造となる参照線(Reference line)RL を設け、 その参照線電圧を得る.Fig.5 ですでに示したように、 n個のワード全てに対して同一の参照距離設定回路が 並列に配置される.なお、H-CAROM セルアレイ側の

Table 6 Device parameters and simulation conditions for Fig. 9 and Fig. 11  $(i-1, 2, \dots, p)$ 

| Symbol                       | Name                                     | Value | Unit |
|------------------------------|------------------------------------------|-------|------|
| V <sub>DD</sub>              | Power supply voltage                     | 5.0   | V    |
| $(W/L)_{MLij}$<br>(j=1,2,,m) | Width/Length of $M_{MLij}$<br>(j=1,2,,m) | 4/2   | μm   |
| $(W/L)_{\mathrm{MLD}i}$      | Width/Length of M <sub>MLDi</sub>        | 2/2   | μm   |
| $(W/L)_{\mathrm{MLU}i}$      | Width/Length of $M_{MLUi}$               | 8/2   | μm   |
| $(W/L)_{RLij}$<br>(j=1,2,,m) | Width/Length of $M_{RLij}$<br>(j=1,2,,m) | 4/2   | μm   |
| $(W/L)_{\mathrm{RLD}i}$      | Width/Length of M <sub>RLDi</sub>        | 2/2   | μm   |
| $(W/L)_{\mathrm{RLU}i}$      | Width/Length of M <sub>RLUi</sub>        | 8/2   | μm   |

ー致線電圧はハミング距離に応じて m 通りの電圧値 になるため、その一致線電圧を判別する参照距離 D<sub>HR</sub> を設定する有効な範囲は 0~m-1 である.

i(i=1,2,...,n)番目のワードにおける参照距離設定回路の構成を Fig.8(a)に示す. この回路は、参照線 RL*i*に対して,*m* 個のプルダウン nMOS トランジスタ M<sub>RLij</sub>(*j*=1,2,...,*m*)とプルアップ pMOS トランジスタ M<sub>RLui</sub>が接続された NOR 構造である. M<sub>RLij</sub>(*j*=1,2,...,*m*)は、参照距離設定信号 RF*j*(*j*=1,2,...,*m*-1)によって駆動され、M<sub>RLui</sub>は照合パルス $\overline{\phi_{IG}}$ によって駆動される.また、M<sub>RLDi</sub>はリセット用 nMOS であり、参照線電圧 V(RL*i*)が一致線電圧 V(ML*i*)と一定の電位差となるよう、そのチャネル幅は、他のプルダウン nMOS のチャネル幅の半分に設計される.

ここで、類似データを検索するという観点から、文献 8)では  $D_{HR}=0\sim3$ 、文献 9)では  $D_{HR}=0\sim4$  としている.これにより、参照線プルダウン nMOS の個数が、 文献 8)では 4 個、文献 9)では 5 個であった.一方、 一致線プルダウン nMOS の個数は  $D_{HR}$  の値に依らず mである.仮に、一致線トランジスタ数 m が参照線ト ランジスタ数の 4 や 5 よりも十分に大きくなると、一 致線の寄生容量が参照線の寄生容量よりも大きくな り、一致線電圧の上昇速度が参照線電圧の上昇速度よ りも遅くなるため、検索動作が不安定になることを先 に指摘した(Fig.4(b)参照).

そこで本論文では、 $D_{HR}$ の設定可能範囲に依らず全 てのワードにおいて一致線のトランジスタと同数で ある m 個のプルダウン nMOS トランジスタと同数で に接続する対称配置を提案している. $D_{HR}$ の設定可能 範囲によって不要となるトランジスタについては、そ のトランジスタのゲートを接地する.例えば、参照距 離の設定可能範囲を  $D_{HR}=0~3$ とする場合、プルダウ ン nMOS トランジスタ  $M_{RLij}$  (j=1,2,...,m)のうち  $M_{RLij}$ (j=1,2,3)のゲートには参照距離設定信号 RFj (j=1,2,3) を接続し、 $M_{RLij}$  (j=4,5,...,m-1)は  $M_{RLij}$ と同様に、その ゲートを接地する (Fig.8(b)).以下では、設定可能な 参照距離の範囲を 0~3とする. Table 5 は、設定する 参照距離  $D_{HR}$ に対する参照距離設定信号 RFj (j=1,2,3) の電圧を定義したものである.



参照距離設定回路の動作は、CAROM セルアレイの 一致線回路と同様である.具体的には、i(i=1,2,...,n)ワード目の参照距離設定回路において、照合パルス  $\overline{\phi_{IG}}$ がハイレベルの間に、参照距離設定信号 RFij (j=1,2,3)の電圧を印加する.このとき、M<sub>RLDi</sub>によって参照線電圧 V(ML<math>i)は 0[V]にリセットされている.

続いて, $\phi_{IG}$ がローレベルになると,参照線電圧 V(RLi)は RFij (j=1,2,3)がハイレベルである個数によっ て段階的なアナログ電圧となる.なお,チャネル幅が 他のトランジスタのチャネル幅の半分である M<sub>RLDi</sub>が 常にオン状態であるため,参照線電圧 V(RLi)は一致線 電圧 V(MLi)に対して一定の電位差を生じる.

### 3.4 一致線電圧と参照線電圧の関係

3.2節及び 3.3節で求めた *i*(*i*=1,2, ..., *n*)ワード目の 一致線電圧 *V*(ML*i*)及び参照線電圧 *V*(RL*i*)について, Table 6 の条件で HSPICE シミュレーションを行なっ た. ハミング距離 *D*<sub>HSi</sub>及び参照距離 *D*<sub>HR</sub> をパラメー タとし, 横軸を時間, 縦軸を電圧とする. Fig.9(a)は, ビット長 *m*=4 としたときの提案 H-CAROM の *V*(ML*i*)



Fig.11 Simulated waveforms (i=1,2,...,n)

及び V(RLi)の波形であり, Fig.9(b)は, ビット長 m=32 の場合である. 従来 CAM のシミュレーションを行な った Fig.4(b)では, m=32 とすると波形の交錯が見られ たが, Fig.9(b)の場合にはどのタイミングにおいても 波形が交錯することなく V(MLi)と V(RLi)の大小関係 が一定であることが分かる.

また, Fig.9(a)と Fig.9(b)とを比べると, Fig.9(b)の方 が,電圧上昇速度が遅い.これは, Fig.9(a)の *m*=4 に 比べて, Fig.9(b)では *m*=32 であり一致線及び参照線に 接続されるトランジスタの数が多く,寄生容量が大き いためである.

Fig.9(a)及びFig.9(b)より,提案H-CAROMにおいて, V(RLi)はそれぞれのV(MLi)の中間の電圧値になって いる.したがって,ある時刻において,V(RLi)とV(MLi) とをアナログコンパレータで判定すれば,ハミング距 離検索のフラグを立てることができる.

#### 3.5 比較判定回路とハミング距離検索フラグ

Fig.10 にアナログコンパレータ(比較判定回路: Comparator)の回路図を示す. なお, pMOS の基板は 電源電圧  $V_{DD}$ , nMOS の基板は基準電圧 GND に接続 されるが, Fig.10 では省略している. この回路は, V(MLi) (*i*=1,2, ..., *n*)と V(RLi) (*i*=1,2, ..., *n*)の大小関係 の比較を行い, Table 1 に示す条件に基づいた出力電 圧 V(OUTi) (*i*=1,2, ..., *n*)を得る. ここで扱う比較判定 回路は, リセットパルス $\phi_{RS}$ , 照合パルス $\phi_{IG}$  ( $\overline{\phi_{IG}}$ ), 比較判定パルス $\phi_{CP}(\overline{\phi_{CP}})$ の3相の信号で駆動される. これらのパルスのタイミングを Fig.11(a),(b)及び(c)に 示す.

Fig.11(d)及び(e)は、参照距離  $D_{HR}=3$  と設定したとき の、比較判定回路の出力電圧(すなわち、提案 H-CAROMの出力フラグ)V(OUTi) (i=1,2,...,n)のシミュ レーション波形を表している.シミュレーション条件 は Table 6 のとおりである.Fig.11(d)のように、記憶 データと検索データ間のハミング距離  $D_{HSi}$  が 3 のと き、Fig.9(a)からも読み取れるように一致線電圧 V(MLi)は参照線電圧 V(RLi)よりも高いため、比較判定 回路の動作により、V(OUTi)はハイレベルを出力する.

一方, Fig.11(e)のように, ハミング距離  $D_{HR}$ が4の 場合には, Fig.9(a)より V(MLi)は V(RLi)より低い.し たがって, V(OUTi)はローレベルを出力する.これら の動作は Table 1 の動作条件を満たしており,提案 H-CAROM が理論通りの動作をしていることがわかる.

## 4. まとめと今後の課題

従来の NOR アーキテクチャを用いたハミング距離 検索機能付き CAM 及び CAROM の照合動作を HSPICE シミュレーションにより詳細に解析し,一致 線及び参照線のトランジスタ数の差異が大きい場合 には寄生容量の影響で照合動作が不安定になるため ダミーキャパシタが用いられた経緯を明確にした.そ のうえで,本論文では,一致線及び参照線のトランジ スタ数と寸法を同一にして対称的に配置することで, ダミーキャパシタを用いなくても安定した照合動作 が可能な,対称型 NOR アーキテクチャによる新たな ハミング距離検索機能付き CAROM を提案した.さら に,提案 H-CAROM の照合動作についてシミュレーシ ョンにより動作を検証した.

本論文中のシミュレーション検証において,2µmル ールや Vod=5[V]という条件や、メモリセル部に RAM でなく ROM を適用した要因は、素子数やピン数の制 約が厳しい北九州学術研究都市の共同研究開発セン ター(ひびきの)でのチップ試作を想定しているため である.今後は、同センターや VDEC を通して実機を 試作し評価するとともに,提案 H-CAROM あるいは H-CAM の具体的な応用について検討していく予定である.

#### 謝辞

本研究は東京大学大規模集積システム設計教育研 究センターを通し、シノプシス株式会社、及び日本 ケイデンス株式会社の協力で行われたものである. また、本研究は北九州学術研究都市の共同研究開発 センターの協力で行われたものである.

## 参考文献

- 大池祐輔,池田誠,浅田邦博:同期式高速ハミング距 離検索連想メモリ,電子情報通信学会 技術研究報告 ICD2002-4, pp.19-24, 2002年4月.
- 2) H.J. Mattausch, W. Imafuku, A. Kawabata, T. Ansari, M. Yasuda and T. Koide, "Associative Memory for Nearest-Hamming-Distance Search Based on Frequency Mapping," IEEE Journal of Solid-State Circuits, vol. 47, no. 6, pp. 1448-1459, June 2012.
- 3)原田裕二郎,藤本邦昭,福原雅朗,吉田正廣:ニューロンCMOSインバータを用いた最小ハミング距離検索連想メモリ,電気学会論文誌C,vol.136,no.1,pp.36-42,2016年1月.
- 4) W.R. Daasch and J. Lee, "A Word/Bit Parallel Inexact Match Content Addressable Memory," Proceedings of 7th Annual IEEE International ASIC Conference and Exhibit, pp. 25-28, Sept. 1994.
- 5) M. Urakami, M. Fukuhara and M. Yoshida, "A Proposal of a Hamming Distance Detector with a Neuron CMOS A/D Converter," International Journal of Information and Electronics Engineering, Vol. 5, No. 2, pp. 84-87, March 2015.
- 6)山岡寛明,池田誠,浅田邦博:しきい値論理回路を用いたハミング距離選択機能を有する高速機能メモリ,電子情報通信学会 技術研究報告 VLD2002-151, ICD2002-216, pp. 31-36, 2003年3月.
- 7) 近越一真,濱田芳隆,吉田正廣,鈴木八十二:ハミン グ距離検索機能を有するCMROMの照合特性,電子情報通 信学会 論文誌C, vol. J83-C, no. 7, pp. 658-659, 2000 年7月.
- 8)田中浩朗,福原雅朗,鈴木八十二,吉田正廣:大きな ノイズマージンを有するハミング距離検索機能付き内容 照合メモリ(CAM)の構成法とその照合特性,東海大学紀 要電子情報学部,vol.3, no.1, pp.35-39,2003年9月.
- 9) リキットキットワオラクル ナッチャー,福原雅朗,吉田正廣:ハミング距離検索機能を有する低消費電力 CAROMのレイアウト設計とその動作特性,東海大学紀要 情報理工学部, vol.6, no.1, pp.51-55, 2006年9月.