# 混合雑音が重畳した画像復元に関するハードウェア実装の研究

中村 幸弘<sup>†</sup> 橋本 健太郎<sup>†</sup> 木村 誠聡<sup>†</sup>
†神奈川工科大学 情報学部 情報工学科 〒243-0209 神奈川県厚木市下荻野 1030
E-mail: {s055112, kimura}@cce.kanagawa-it.ac.jp

**あらまし** 撮像素子は画像を取得する際,レンズによるボケ,機器からの雑音の影響を受け,取得画像が劣化する.このた め画像のボケと雑音の除去を行うためにフィルタによる処理が必要となる.また,これらの処理を実時間で行うためには,ハー ドウェアによる処理回路が必要となる.本稿ではそのうちのガウス性雑音とインパルス性雑音の混合雑音が重畳した画像におけ る雑音除去のハードウェアの開発を行う.

開発するハードウェアはFPGAを用い画像の実時間処理を行うものであり、ファジー推論を用いた雑音除去フィルタと周辺 処理の回路について言及するものである.本稿ではこれらのハードウェアを実装し、そのシミュレーション波形から仕様と合わ せて問題が無いことを確認した.

キーワード 混合雑音, FPGA, ファジー推論

## Mixed Noise Removal Hardware using FPGA

Yukihiro Nakamura<sup>†</sup> Kentaroh Hashimoto<sup>†</sup> Tomoaki Kimura<sup>†</sup>

† Department of Information Engineering, Kanagawa Institute of Technology

1030 Simoogino, Atsugi-shi, Kanagawa, 243-0292 Japan E-mail: {s055112, kimura}@cce.kanagawa-it.ac.jp

**Abstract** An image is degraded by noise in the case of image acquisition. For this reason, filter process is needed in order to perform the remove of noise. And, real time processing of this process is needed hardware circuit. This paper states that hardware's development of image sensor's input and output We proposed image filter's real time processing hardware by using FPGA. The circuits of this filter are the noise removal circuit by using Fuzzy inference. In this paper, we explain this hardware by FPGA, and we verified from simulation waveform about validity of this embedded hardware.

Keyword Mixed Noise, FPGA, Fuzzy inference

## 1. まえがき

撮像素子は携帯電話やディジタルカメラなどで用 いられており,その後の画像処理の部分は実時間での 処理を行うことが要求されている.この撮像素子には 特殊な用途を除けば CCD 撮像素子,CMOS 撮像素子の 2 種類が存在するが,画像を取得する際に暗電流や伝 送経路の影響によりガウス性雑音やインパルス性雑音 が重畳する問題がある[1,2].また被写体を画像として 取得する際に光学的に撮像素子の前にレンズが存在す る.このレンズのために画像のボケによる劣化が存在 する.すなわち,撮像素子によって取得した画像には, レンズによる画像の劣化,および,ガウス雑音やイン パルス性雑音の重畳があるため,これらの問題を実時 間にて処理する必要がある[2].つまり,ボケの復元と 雑音の除去を実時間で行える方法が望まれる. 画像のボケとガウス性雑音の除去の両方を行うた め、一般的にはウィナーフィルタが用いられている[2]. このウィナーフィルタはレンズの点広がり関数(PSF) と画像に重畳する雑音の状況によって最適なフィルタ 係数を得るものの、除去できる雑音としてはガウス性 雑音が対象となる.つまり、インパルス性雑音が重畳 した画像から雑音を除去するためにはウィナーフィル タに代表される一般的な時不変線形フィルタでは不十 分であることが知られている[2].そこで、ウィナーフ ィルタの他にインパルス性雑音を除去するフィルタが 必要となる.文献[3]ではインパルス性雑音とガウス性 雑音(混合雑音)の両方の除去に対応するため、複数 の情報をファジー推論によって関連付け、双方の雑音 の除去を成し得ている.よって、文献[3]のファジー推 論を用いる方法とボケ復元の方法を組み合わせること でレンズを通した画像の復元が可能と考えられる.そ こで、本稿ではレンズによるボケの復元のためにウィ ナーフィルタとガウス性雑音とインパルス性雑音の除 去が可能な文献[3]による方法の組み合わせを行う.し かしながら、これらの処理は処理点のみならず近傍領 域の計算をも含むため、ソフトウェア処理では実時間 の処理は困難である.そこで、画像のボケと混合雑音 除去を実時間で行う方法が望まれる.

本稿では先に示した処理を実時間で行うためにウ ィナーフィルタとファジー推論を用いた雑音除去フィ ルタおよびその周辺の処理をハードウェア化すること を提案し試みる. これらのハードウェアの規模は大き く,複数に分割して処理を進める必要がある.よって この2つの処理のうち本稿において述べるのはファジ 一推論における処理と、その周辺の処理とする. つま り、本稿では「ファジー推論を用いた雑音除去フィル タ」と「周辺処理」に関してのみ述べるものとする. ファジー推論による処理では、文献[3]で示されている 任意の2点間の画素の差分情報と距離情報の2つをフ ァジー推論で関連付けた処理の実現を行う.そして, ファジー推論で用いるファジー集合を LUT(Look Up Table)化することで処理の高速化を試みる.また,各 差分情報を求める回路では並列化させることで、ハー ドウェアの高速化を試み、提案する方法の実現化につ いて具体的な回路の仕様を明らかにし、提案する方法 の有効性を示す.

## 2. ファジー推論を用いた雑音除去法

文献[3]で示されている雑音除去フィルタは,任意の 2 点間の差分情報と,距離情報を関連付けることでガ ウス性雑音とインパルス性雑音で重畳された画像(混 合雑音画像)の雑音除去を成し遂げている.差分情報と 距離情報の2つの情報はファジー推論によって関連付 けられており,差分が小さく,かつ処理点からの距離 が短いときに処理点における平滑化処理に含まれると いうものである.言い換えれば,インパルス性雑音が 重畳している画素やエッジ等で変化が大きい画素は処 理対象となる処理の平滑化に含まれれば,これらのこ とを式で示すと以下の式で表される.

$$y = \frac{\sum_{k} \sum_{l} W() \cdot u()}{\sum_{k} \sum_{l} u()}$$
(1)

ここで、u()は各フ<sup>\*</sup><sub>ア</sub>ジー集合の適合度であり、W()はフィルタ荷重である.さらにW()は、各情報量E(), e(), d()によって算出される.E()は処理点と周辺画素 との差分情報であり、次式によって求められる.

$$E(k,l) = \frac{1}{p^2} \left\{ \sum_{m=-Q}^{Q} \sum_{n=-Q}^{Q} e(k,l,m,n) \right\}$$
(2)

e()は、ある点と点のとの差分情報であり、次式によって求められる.

$$e(k,l,m,n) = |x(i+k,j+l) - x(i+m,j+n)|$$
(3)

d()は、距離情報であり、次式によって求められる.

$$d(\kappa,\lambda) = \sqrt{k^2 + l^2} \tag{4}$$

以上の情報を用いてこれらを以下のルールによって関連付ける.

| if   | E(0,0)     | is | S            |     |
|------|------------|----|--------------|-----|
|      | e(k,l,0,0) | is | {S,M,L}      |     |
|      | d(?,?)     | is | {N,NF,F}     |     |
| then | w(k,l)     | is | Wi(i=1,,9)   |     |
| if   | E(0,0)     | is | L            |     |
|      | E(k,l)     | is | {S,M,L}      |     |
|      | d(?,?)     | is | {N,NF,F}     |     |
| then | w(k,l)     | is | Wi(i=10,,18) | (5) |
|      |            |    |              | (3) |

式(5)の上のif の項は,処理点 E(0,0)にインパルス性 雑音が重畳していない時のルールである.この時は処 理点を中心とした近傍領域内の画素と処理点との差分 値を求める.もし,差分値が大きい時には,その近傍 領域の画素は平滑化に用いないことを表している.式 (5)の下のif の項は,処理点 E(0,0)にインパルス性雑音 が重畳していた場合のルールである.この時は近傍領 域内の各画素同士の差分値を求め,その差分絶対和が 一番小さい画素がこの近傍領域内のメジアン値である [3].よって,この任意の2点間の差分値を求めること で対象となる画素の近傍領域内におけるインパルス性 雑音の影響等を取り除くことが出来る.

各式により求められた情報量に対するファジー集 合を図.1~3 に示す. 各情報量に対応する適合度 $\mu$ [E(0,0)],  $\mu$ [E(k,l)],  $\mu$ [e(k,l,0,0)],  $\mu$ [d( $\lambda$ ,  $\kappa$ )]はこの ファジー集合によって求められる.



求められた適合度を用いて,各ルールに対する 適合度を次式で表す min 演算で算出する.

$$\mu_{1} = \min\{\mu_{s}[E(0,0)], \mu_{s}[e()], \mu_{N}[d()] \\ \mu_{2} = \min\{\mu_{s}[E(0,0)], \mu_{s}[e()], \mu_{NF}[d()] \\ \mu_{3} = \min\{\mu_{s}[E(0,0)], \mu_{s}[e()], \mu_{F}[d()]$$
(6)

 $\mu_{18} = \min\{\mu_L[E(0,0)], \mu_L[e()], \mu_F[d()]\}$ 

各ルールに対する適合度とそのルールに対する後見 部実数値を用い,次式で示す非ファジー化手続きによ り式(1)におけるフィルタ係数 W(k,l)が算出されるこ とになる.

$$W(k,l) = \frac{\sum_{q=1}^{n} u_{q} \cdot w_{q}}{\sum_{q=1}^{n} u_{q}}$$
(7)

なお、表1に後件部実数値を示す.

表 1. ファジールールのルールテーブル

|        | E(0,0)     |            |            |             |             |             |  |
|--------|------------|------------|------------|-------------|-------------|-------------|--|
| d(k,1) | Small      |            |            | Large       |             |             |  |
|        | e(k,1,0,0) |            |            | E(k,l)      |             |             |  |
|        | s          | М          | L          | s           | М           | L           |  |
| Ν      | w1<br>1.00 | w4<br>0.50 | w7<br>0.25 | w10<br>1.00 | w13<br>0.50 | w16<br>0.25 |  |
| NF     | w2<br>0.75 | w5<br>0.50 | w8<br>0.00 | w11<br>0.75 | w14<br>0.50 | w17<br>0.00 |  |
| F      | w3<br>0.50 | w6<br>0.25 | w9<br>0.00 | w12<br>0.50 | w15<br>0.25 | w18<br>0.00 |  |

文献[3]では以上の様に2つの情報を関連付ける ことで混合雑音の除去を成し得ている.

なお,文献[3]ではファジー集合や閾値のパラメータ は定まっているが,本稿ではこれを特に定めず,ハー ドウェアとして可変可能としておくことで柔軟な対応 がとれる様にする.

## 3. 実装するハードウェアの構成

ここでは、2 章で説明したファジー推論による雑音 除去フィルタを実時間処理する為にハードウェア化す ることを試みる.ハードウェア化する為にハードウェ アの内容がプログラマブルに書き換え可能な LSI であ る FPGA(Field Programmable Gate Array)を用いる.この 時演算回路を効率化するために積和演算機能のハード ウェアブロックが搭載された Xilinx 社製 「Spartan3-3400-DSP」が実装された東京エレクトロン デバイス社製のボード「TB-3S-3400DSP-IMG」を使用 する(図.4).なお用いる言語は VHDL とする.

このボードにカメラ入力のインターフェースとデ ィスプレイ出力のDVIインターフェースを付属するこ とで,カメラ入力された画像を処理しディスプレイに 表示するハードウェアが実現可能となる.



図.4 評価ボード

## 3.1. ファジー推論による雑音除去フィルタの実装

ここでは、ファジー推論における具体的な回路について述べる.図.5はファジー推論部の全体の構成である.図.5の構成はさらに差分情報を求めるブロック、各ファジー集合の適合度を求めるブロック、各適合度のMIN演算のブロックらで構成される.

以下は各々のブロックについて説明を述べる.



図.5 Fuzzy Filter の構成

### 3.1.1. 差分情報を求める回路

この回路は図.6に示すように処理点と周辺画素との 差分情報を求める部分と図.7に示すように任意の2点 間の差分情報を求める部分とに分かれる.前者は2章 で述べたように処理点にインパルス性雑音の影響が無 い場合であり,後者は処理点がインパルス性雑音であ る可能性が良い場合である.図.8,図.9は,

その具体的な回路である.図.6は処理点とその近傍 領域との差分情報であり、回路としては単なる絶対差 分となっている.

図.7 は任意の2点間の差分情報であり,ある点と処理点近傍の9点の信号との絶対差分和である.この回

路も単純ではあるが、その回路規模は図.6に示すもの より大きくなる.





図 9. 任意の二点間の差分値を求める具体的回路例

## 3.1.2. 各ファジー集合の適合度を求める回路

適合度の値を順序回路にて構成すると非常に多く の遅延が発生すると考えられるため、各ファジー集合 の適合度を、各差分情報を元にLUT(Look Up Table)方 式を用いて求める方式とする.LUT は基本的にメモリ であり、アドレスに対応したデータを出力する.LUT を用いる理由として、非常に高速で適合度を求めるこ とが要求されるためである.つまりLUT の場合、メモ リアクセスの遅延時間のみとなるため、高速になるこ とは理解できよう.







図 12. d()の LUT 回路



図 13. E(0,0)の LUT 回路

図.10~13 はその模式図である.LUTのアドレス部に 差分情報,又は距離情報を入力することで,その情報 に対応した適合度を出力する.具体的には各情報量 E(k,l),e(k,l,0,0),d(κ,λ)を各LUTにそれぞれ入れる ことで適合度が求まる.図.10~13の各LUTは,ファジ ー集合の各メンバシップ関数である.しかしながら, このLUTにメンバシップ関数の細かいデータを入力 することはメモリの増大をまねく.よって,メモリの 消費を抑えるためにメンバシップ関数を段階的に表現 することを考える.図.14~16 は段階的に表現したメン バシップ関数である.この精度は計算上10%以内の誤 差に抑えることができることが判明しており,シミュ レーション上計算した適合度とほとんど変わりが無い ことが分かっている.





このメンバシップ関数を段階的に表現したのちに LUT 化を行う.具体的に各メンバシップ関数を LUT 化したものの例として E()を図.17に示す.

| E(0,0)  | S      | L      |
|---------|--------|--------|
| α以下     | 1.0    | 0.0    |
| α +a    | 0.9375 | 0.0625 |
| α +2a   | 0.875  | 0.125  |
| α +3a   | 0.8125 | 0.1875 |
| α +4a   | 0.75   | 0.25   |
| α +5a   | 0.6875 | 0.3125 |
| α +6a   | 0.625  | 0.375  |
| α +7a   | 0.5625 | 0.4375 |
| α +8a   | 0.5    | 0.5    |
| α +9a   | 0.4375 | 0.5625 |
| α+10a   | 0.375  | 0.625  |
| α+11a   | 0.3125 | 0.6875 |
| α+12a   | 0.25   | 0.75   |
| α +13a  | 0.1875 | 0.8125 |
| α +14a  | 0.125  | 0.875  |
| α +15a  | 0.0625 | 0.9375 |
| α+16a以上 | 0.0    | 1.0    |

図.17 数値化したメンバシップ関数 E()

## 3.1.3. MIN 演算回路

各 LUT により求められた情報量を用いて, それぞれの MIN 回路に流して適合度を求める.図.21 に MIN 演算回路のブロック図を示す.この回路は E(0,0), e(), d()から出力された適合度の中で一番小さい値を選択するものである.この一番小さい値を選択する回路の具体的な回路を図.22 に示す.

最初に e()と d()を比較し,小さい方の値を次の回路 へ伝える. 比較として補数を用いた加算回路, つまり e()-d()の引き算回路を用いる. 図.22 において Carry が立った時には, e()か d()より小さいことを示し, そ の際には e()のデータを次段に伝える.

次に, e()又は, d()のデータと E(0,0)を同様に比較 する. その結果出力には一番小さいデータが出力され ることになる. 最終的に一つの画素の差分情報にに対 して9つの比較回路が必要となる.



図.21 MIN 演算回路のブロック図



図.22 MIN 演算回路の具体例

## 3.1.4. ファジーフィルタの出力

3.3.1~3.3.3 までに述べたように各々のブロックにて ファジー推論に必要なデータがそろうことになる. 最 終的には図.5 の最終段にあるように,表1に示す後見 部実数値を各々の適合度と乗算し,その総和をとる. そして W(k,l)にて正規化を行うことで処理における雑 音除去の結果が得られることになる.

#### 4. シミュレーション結果

表2は, Fuzzy Filter の差分を求める回路の論理合成 結果であり,ボードに搭載されている Xilinx 社 FPGA 「Spartan3A-DSP」の全体中の消費%を示している.

#### 表 2. 差分回路の論理合成結果

| Slice数 | 4932 | 20% |
|--------|------|-----|
| FF数    | 1808 | 3%  |

図.20 に Fuzzy Filter の差分情報を求める回路の RTL 生成結果の一部抜粋したものを,図.21 にシミュレー ション波形の結果を載せる.RTL 生成結果とシミュレ ーション結果により,差分情報を求める回路の確認が できた.



図.23 差分情報を求める回路の RTL 生成結果(抜粋)



図.24 差分情報を求める回路のシミュレーション結果

#### 5. まとめ

本稿では、ボケと混合雑音で劣化画像の実時間に よる復元処理のハードウェアについて提案を行い、 その仕様を明らかにした.提案する方法では種々の 周辺回路とファジーフィルタの高速化について提案 し、その実現方法について言及した.

### 参考文献

[1]R.C.Gonzales, R.E.Woods, "Digital Image Processing", Addison-Wesley Publishing, Massachusetts, 1993
[2]A.Rosenfeld, "Digital Picture Processing", Academic Press, Inc, 1976

[3]木村誠聡,田口亮,濱田敬,村田裕,"混合雑音重畳画 像復元のためのファジーフィルタの提案",電子情報 通信学会技術報告,DSP98-28,May., 1998.