# フリップフロップ組合せの状態正当化による 到達不能状態を用いた 順序回路のテスト不能故障判定法

二関森人<sup>†1</sup> 細川利典<sup>†2</sup> 吉村正義<sup>†3</sup> 山崎紘史<sup>†2</sup> 新井雅之<sup>†2</sup> 四柳浩之<sup>†4</sup> 橋爪正樹<sup>†4</sup>

テストコストの削減やセキュリティ向上のため、スキャン設計を用いない非スキャン設計ベースのテストの要望がある.しかしながら、順序回路のテスト生成では、高い故障検出効率を得るために多大なテスト生成時間を要する.特にテスト不能故障判定時間が支配的である.そのため、テスト生成の前処理で、テスト不能故障を判定することが重要である.本論文では、SATを用いて数個のフリップフロップ組合せの状態が到達不能状態か否かを判定し、その到達不能状態を用いたテスト不能故障判定法を提案する.また、既存の順序回路のテスト不能故障判定法と提案手法を組み合わせて、ISCAS'89及びITC'99ベンチマーク回路においてテスト不能故障を判定し、評価する.

# An Untestable Fault Identification Method for Sequential Circuits Using Unreachable States by Justification of State Cubes

MORITO NISEKI<sup>†1</sup> TOSHINORI HOSOKAWA<sup>†2</sup> MASAYOSHI YOSHIMURA<sup>†3</sup> HIROSHI YAMAZAKI<sup>†2</sup> MASAYUKI ARAI<sup>†2</sup> HIROYUKI YOTSUYANAGI<sup>†4</sup> MASAKI HASHIZUME<sup>†4</sup>

Non-scan based test generation is required for the purpose of resolving reduction of test cost and improvement of security. However, in the test generation of the sequential circuit, it consumes a lot of test generation time to obtain high fault efficiency. Especially, untestable fault identification time is dominant. Therefore, it is important to identify untestable faults in the pre-processing of the test generation. In this paper, an unreachable state identification method, which identifies whether states on a few flip-flops can be justified using SAT, and an untestable fault identification method using the unreachable states are proposed. Moreover, untestable faults are identified by applying the combination of conventional methods and our proposed method to ISCAS'89 and ITC'99 benchmark circuits, and the number of untestable faults is evaluated.

# 1. はじめに

近年,半導体微細化技術の進歩に伴って,設計される超 大規模集積回路(Very Large Scale Integrated circuits : VLSI) の大規模化・複雑化が進んでいる.これに伴い,VLSIのテ スト生成は益々困難な課題となってきている.特に順序回 路のテスト生成は問題の解空間が大きく,現実的な時間で 高い故障検出効率を達成することが困難である.そのため, テスト生成の高速化,容易化が求められている.

テスト生成を容易化する技術の一つとして、回路内のフ リップフロップ(Flip-Flop:FF)を外部から制御,観測可能 とするフルスキャン設計[1]が提案されている.フルスキャ ン設計を施すことにより、順序回路を疑似的に組合せ回路 として扱うことが可能となり、組合せ回路のテスト生成技 術が適用可能となる. 組合せ回路に関しては, 効率的なテ スト生成アルゴリズムが提案されており[2], 大規模・複雑 な回路に対しても, 現実的な時間で高い故障検出効率を達 成することができる. しかしながら, スキャン設計が施さ れた順序回路では, 面積, 遅延時間, 消費電力等のハード ウェアオーバヘッドが増大するという問題がある. また, 回路内のスキャン FF に値を設定, 観測するためのシフト 動作によるテスト実行時間の増加もテストコスト削減の観 点から問題視されている. さらに, 秘密情報を内部に保持 する暗号回路に対してスキャン設計が適用されると, スキ ャンチェインを利用した攻撃が可能となり, 秘密情報が外 部に漏洩する危険性があると指摘されている[3]. 上述の課 題を解決するために, スキャン設計を施さない順序回路の テスト生成[4]や, 機能動作時の状態のみを使用する擬似機 能テスト[5]の適用が求められている.

しかしながら、スキャン設計を施していない順序回路の テスト生成では、内部状態を外部入力のみから設定し、故 障の影響を外部出力のみで観測するため、テスト容易化設 計なしでは高い故障検出効率を得ることが困難である.ま た、テスト不能故障に対して順序回路のテスト生成を実行

<sup>†1</sup> 日本大学大学院 生産工学研究科

Graduate School of Industrial Technology, Nihon University.

<sup>†2</sup> 日本大学 生産工学部

College of Industrial Technology, Nihon University

<sup>†3</sup> 京都産業大学 コンピュータ理工学部

College of Faculty of Computer Science and Engineering, Kyoto Sangyo University

<sup>†4</sup> 徳島大学大学院 社会産業理工学研究部

Graduate School of Technology, Industrial and Social Sciences, Tokushima University

すると、テスト不能故障判定に多大な時間を必要とする. そのため、スキャン設計を施さずに高い故障検出効率を得 るためのレジスタ転送レベルでのテスト容易化設計手法 [6]とテスト生成法[6,7]や、テスト生成時間を削減するため に、テスト不能故障をあらかじめ判定する手法[8-12]が提 案されている.

テスト不能故障の一部を高速に判定する手法として,回 路構造に着目してテスト不能故障を判定する FIRE アルゴ リズム[8](以下, FIRE と略す)と拡張 FIRE アルゴリズム [9](以下,拡張 FIRE と略す)が提案されている.また,順 序回路の機能動作において遷移しえない状態(到達不能状 態)を判定し,判定された到達不能状態を用いてテスト不能 故障判定を行うアルゴリズムが提案されている[11,12].特 に,文献[12]では FIRE と到達不能状態を用いたテスト不能 故障判定を組み合せることにより,多くのテスト不能故障 を判定できることが報告されている.

しかしながら,文献[11,12]の手法では,実行時間の制約 や,扱うことのできる変数の数が少ないといった点から, 大規模な回路に対して部分回路に分割して判定処理を行う 必要がある.そのため,回路全体を対象とした判定が行わ れておらず,到達不能状態の一部を判定できない可能性が あり,これが課題となっている.この課題を解決した手法 として,文献[13]では,回路全体を対象とした到達不能状 態判定法が提案されている.しかしながら,文献[13]では, 判定した到達不能状態を逐次的に制約として付与すること ができず,判定された到達不能状態からのみ到達可能な状 態を判定できていない可能性がある.そのため,提案手法 では扱うことのできる変数の数が多く,逐次的に制約付与 が可能で,高速化の進む充足可能性問題(satisfiability problem:SAT)を用いる.

本論文では、文献[16]で提案したフリップフロップ組合 せの状態正当化に着目した到達不能状態判定法、得られた 到達不能状態を禁止状態制約とした順序回路のテスト不能 故障判定法とFIRE 及び拡張 FIRE と組み合わせてテスト不 能故障の判定数を評価する.

# 2. 従来のテスト不能故障判定法と到達不能状 態判定法

本章ではテスト不能故障判定法[8,11]と到達不能状態判 定法[13]の従来手法を説明する.2.1節に回路構造に着目し たテスト不能故障判定法である FIRE[8]について説明する. 2.2節に FF の値正当化を用いた到達不能状態判定法[13]と 到達不能状態を用いたテスト不能故障判定法[11]について 説明する.

#### 2.1 回路構造に着目したテスト不能故障判定法

文献[8]で提案されている FIRE は、回路構造に着目し、

ある信号線に0,1両方の値を割当てる必要のある故障をテ スト不能故障と判定する手法である.信号線が0,1両方の 値を同時に有することは不可能であり,相反する割当てを 必要とする故障はテスト不能故障と判定することができる.

図1にFIREによるテスト不能故障判定の例を示す.図1 の回路において信号線 a に 0,1 を割当てる必要のある故障 を考える.また,図1中の set[a,0]は信号線 a に 0 を割当て なければ励起・伝搬できない故障集合, set[a,1]は信号線 a に1を割当てなければ励起・伝搬できない故障集合とする. また, a/1 は信号線 a の1 縮退故障, a/0 は信号線 a の0 縮 退故障を表している.

まず信号線 a に 0 を割当てなければ励起できない故障集 合を求める.このとき図 1(a)に示すように信号線 a に 1 を 割当て,含意操作を行う.このとき,一意に値が割当てら れる信号線に対し,割当てられた値と同値の縮退故障が発 生したと仮定すると,それらの信号線の縮退故障は信号線 a に 0 を割当てなければ励起できない.そのため,信号線 a に 1 を割当て,含意操作を行うことで,信号線 a に 0 を割 当てなければ励起できない故障集合が得られる.図 1(a)の 例では信号線 a の 1 縮退故障,信号線 a に 0 を割当てなければ 励起できない故障となる.

同様に,信号線aに0を割当て,含意操作を行うことで, 信号線 a に 1 を割当てなければ励起できない故障集合を得 ることができる.このときの含意操作の結果を図 1(b)に示 す. この結果から信号線 a の 0 縮退故障, 信号線 a\_c の 0 縮退故障,信号線 c の1 縮退故障,信号線 e の0 縮退故障, 信号線fの0縮退故障,信号線gの0縮退故障が,信号線 aに1を割当てなければ励起できない故障となる.また, 図 1(b)の含意操作結果と同じ値割当ての図 1(c)において, 菱形で囲った信号線 a\_c, c, e, f に着目すると, 各ゲート に対する入力の制御値となっていることがわかる. そのた め、図1(c)の菱形に対する丸で囲った値割当ての行われて いない信号線 b, d, e, f に 0 縮退故障, 1 縮退故障があっ たとき,信号線 a に 0 が割当てられた場合,故障影響が伝 搬不能なため、丸で囲われている信号線の 0 縮退故障、1 縮退故障は信号線aに1を割当てなければ伝搬できない故 障となる.

最後に2つの故障集合 set[a,0]と set[a,1]の積集合からテス ト不能故障集合を得ることができる.図1の例では信号線 fの1縮退故障がテスト不能故障であると判定できる.図1 の例では信号線 a に着目していたが, FIRE では回路中のす べての信号線に対しテスト不能故障を判定する処理を行う.

また、文献[9]で提案されている拡張 FIRE は、FIRE を基 に発展させた手法であり、FIRE よりも多くのテスト不能故 障を判定可能である.本来の FIRE は順序回路の組合せ回 路部分に対してテスト不能故障判定を行っているが、拡張 FIRE では、順序回路をk時間展開した回路モデルを用いて テスト不能故障判定を行っている.また,FIRE ではテスト 不能故障を同一信号線の矛盾する割当てを用いて判定を行 っているが,拡張 FIRE では,判定対象として回路中に存 在する多入力論理ゲートも判定対象に追加しており, 多入力論理ゲートの入出力信号線の矛盾する組合せを必須

多八万冊建プードの八山万倍与緑の矛盾する組合せを必須 とする故障集合からテスト不能故障を判定する手法が提案 されている.

# 2.2 FFの値正当化を用いた到達不能状態判定法と到達不能状態を用いたテスト不能故障判定法

文献[13]は、回路内に存在するファンアウトが到達不能 状態を引き起こす原因であることを示し、ある FF に割当 てた値に対する正当化を行い、求められた正当化結果を用 いて到達不能状態を判定する手法を提案している.また、 文献[11]で提案されている到達不能状態を用いたテスト不 能故障判定法は、判定された到達不能状態を用いた場合の み検出可能な故障をテスト不能故障として判定する手法で ある.

図2に文献[13]の手法による到達不能状態判定の例を示 す.図2の回路において各FFの入力信号線に0,1を割当て, 値の正当化を行い,正当化結果から到達不能状態を求める.

文献[13]では,対象回路の FF の入出力線を擬似外部出力・入力とした組合せ回路を用いて到達不能状態判定を行っている.



set[a,0] = { a/1, a\_c/1, f/1 }

(a) a=1 による信号線割当て



set[a,1] = { a/0, a\_c/0, c/1, e/0, f/0, g/0 }





set[a,1] = { a/0, a\_c/0, b/0, b/1, c/1, d/0, d/1, e/0, e/1, f/0, f/1, g/0 }

(c) set[a,1]に故障の追加 図 1. FIRE によるテスト不能故障判定例 図 2 に, FF0 の入力信号線である f0 に 1, FF1 の入力信 号線である f1 に 1 を割当て,正当化を行った例を示す.

まず,f0に1を割当て,正当化を行った結果,ファンア ウトステムである信号線 in0 に 0,信号線 in1 に 0,信号線 in2 に 1 が割当てられた.

同様に, f1 に 1 を割当て,正当化を行った結果,ファン アウトステムである信号線 in0 に 0,信号線 in1 に 1,信号 線 in2 に 0 が割当てられた.

この結果から FF0 に 1 を割当てたときの正当化結果と FF1 に 1 を割当てたときの正当化結果を比較すると,ファ ンアウトステムである信号線 in1 と信号線 in2 で値が相反 していることが分かる.これより,FF0 と FF1 を同時に 1 に正当化することができないことがわかる.そのため,FF0 と FF1 に 1 が割当てられている状態は到達不能状態である ことがわかる.

表 1 に文献[10]の手法による到達不能状態を用いたテス ト不能故障判定例を示す.表 1 は FF0 の出力信号線 F0 に 1 を割当てる必要がある故障集合(set[F0,1]), FF1 の出力信号 線 F1 に 1 を割当てる必要がある故障集合(set[F1,1])をまと めたものである.

set[F0,1]と set[F1,1]の 2 つの故障集合に対し積集合をとる ことで、FF0 と FF1 ともに 1 が割当てられているときのみ 検出可能な故障集合を得ることができる. しかしながら, 前述の通り FF0 と FF1 をともに 1 に割当てることはできな いため、FF0 と FF1 ともに 1 が割当てられているときのみ 検出可能な故障集合に含まれている故障はテスト不能故障 と判定することができる. 表 1 の例では,信号線 g13\_0 の 0 縮退故障がテスト不能故障であると判定できる.



図 2.FF の値正当化による到達不能状態判定例

#### 表1. 到達不能状態を用いたテスト不能故障判定

| set[F0,1] | F0/0, g7_i/0, g7_o/1, f2/1, F2/1, g8_i/0, g8_o/1, g13_b/0, <b>g13_o/0</b> |
|-----------|---------------------------------------------------------------------------|
| set[F1,1] | F1/0, g12_i/0, g12_o/0, g13_a/0,<br>g13_o/0, g9_i/0, g9_o/1, g14_o/0      |

# 3. フリップフロップ組合せの状態正当化に基 づくテスト不能故障判定法

文献[11,12]の到達不能状態判定法では,実行時間の制 約や,扱うことのできる変数の数が少ないといった点から, 大規模な回路に対して部分回路に分割して判定処理を行う 必要がある.そのため,回路全体を対象とした判定が行わ れておらず,到達不能状態の一部を判定できない可能性が あり,これが課題となっている.この課題を解決した手法 として,文献[13]で回路全体を対象とした到達不能状態判 定法が提案されている.しかしながら,文献[13]では,判 定した到達不能状態を逐次的に制約として付与することが できず,判定された到達不能状態からのみ到達可能な状態 を判定できていない可能性がある.

一方,近年では衝突項の学習[14]や非辞書式バックトラ ック[15],ブール制約伝搬[15]の技術により,SAT ソルバー の処理速度が急速に進歩している.また,文献[11,12]で到 達不能状態判定の際に用いている二分決定グラフ(Binary Decision Diagram: BDD)では数百変数の論理式を扱うのが 限度であるが,SAT では数百万変数からなる論理式を扱う ことができる.さらに,充足可能性判定を行う CNF 式に対 して制約節を追加することで,逐次的に制約を付与するこ とが可能である.そのため,SAT を用いることで大規模な 回路において回路全体に対する判定を行うことができ,制 約を逐次的に付与しながら,高速に充足可能性判定を行う ことができる.

本章では文献[16]で提案したフリップフロップ組合せの 状態正当化に着目した到達不能状態判定法と,到達不能状 態を禁止状態制約とした順序回路のテスト不能故障判定法 を説明する.

# 3.1 フリップフロップ組合せの状態正当化による到達不 能状態判定法

本節で説明するアルゴリズムでは,FFペア(トリプル)と *k*時間展開モデルを用いている.FFペア(トリプル)とは, 順序回路内に存在する2個(3個)のFFの組合せのことであ る.また,*k*時間展開モデルとは順序回路の組合せ回路部 の接続関係を*k*時間展開した回路である.順序回路は時間 展開モデルで表現することによって,組合せ回路として扱 うことができる.

以下に,SATを用いた到達不能状態判定法のアルゴリズ ムについて説明する.

#### (Step1)

回路内に存在する FF ごとに影響外部入力 { 論理関数内に 含まれている(擬似)外部入力 } を調べる.

#### (Step2)

FF ペア(トリプル)の作成を行い, FF ペア(トリプル)同士 の共通の影響外部入力が存在するか調べ, 共通の影響外部

入力が存在していない FF ペア(トリプル)を FF ペア(トリプ ル)集合から削除する.

#### (Step3)

対象となる *k* 時間展開モデルの CNF 式を論理ゲートの CNF 変換規則に従い生成する.

#### (Step4)

Step3 で生成した k 時間展開モデルの CNF 式に共通の影響外部入力が存在している FF ペア(トリプル)のそれぞれの状態を制約として与え,充足可能性判定を行う.

充足不能性判定後,充足不能となった FF ペア(トリプル) の状態を用いて, CNF 式に対して禁止状態制約を追加する.

#### (Step5)

充足不能となった FF ペア(FF トリプル)の状態数の比較 を行う.新たに充足不能となった FF ペア(トリプル)の状態 が存在した場合,再度全ての FF ペア(FF トリプル)の状態 に対して充足可能性判定を行う.

#### (Step6)

充足不能と判定された FF ペア(トリプル)の状態を用い て到達不能状態の識別を行う.

図3を用いて本手法の到達不能状態判定例を説明する. まず,FFペアの生成を行う.例ではFFペアとして生成 されたペアである(G10,G11)が選択されている.なおこの例 ではFFペア共通の影響外部入力数の探索を省略している.

次に選択した FF ペアがとりうる状態の一つを選択し, 選択した状態を正当化できるかどうか判定する.例では, FF ペア(G10,G11)の状態(1,1)を正当化する際に矛盾が発生 しているため,FF ペア(G10,G11)の状態(1,1)が正当化不能 であることを示している.また,正当化不能と判定された FF ペアとその状態を用いて禁止状態制約を付与する.例で は,FFペア(G10,G11)の状態(1,1)が正当化不能だったため, (G10,G11)と接続関係にある(G5,G6)に対して状態(1,1)とな るような割当てを禁止する制約を付与している.

最後に正当化不能と判定された FF ペアとその状態を用いて到達不能状態を識別する.例では,FF ペア(G10,G11)が状態(1,1)だったとき正当化不能と判定されたため,(G10,G11)=(1,1)という割当てとなっている状態が到達不能状態と識別することができる.



例として対象回路の FF 数が 100 個だった場合,正当化不能になった FF ペアとその状態を用いることで2<sup>98</sup>の状態が 到達不能状態であることがわかる.

本手法の到達不能状態判定では,FFペア(トリプル)を用 いることで,充足不能となったFFペア(トリプル)の状態と いうわずかな情報で多数の到達不能状態を表すことが可能 である.また,判定された到達不能状態を禁止状態制約と して付与することで,既知の到達不能状態のみから到達可 能な状態を新たに到達不能状態と判定することが可能とな る.さらに,FFペア(トリプル)同士の共通の影響外部入力 が存在するか調べることで,充足不能と判定される可能性 がないFFペア(トリプル)を制限することが可能である.

# 3.2 到達不能状態を禁止状態制約とした順序回路のテス ト不能故障判定法

提案手法のテスト不能故障判定法では,対象回路モデル として,テスト不能故障判定のためのk時間展開モデル[10] を用いている.また,対象故障モデルを単一故障モデル[10] とした.



(a) テスト不能故障判定のための k 時間展開モデル



(b) 単一故障モデル

図4. 対象回路モデルと対象故障モデル



図 5. 本手法のテスト不能故障判定フロー

図 4(a)にテスト不能故障判定のための k 時間展開モデル について,図 4(b)に単一縮退モデルについて示す.テスト 不能故障判定のための k 時間展開モデルは,順序回路に対 して k 時間展開を行い,各時刻の外部入力および 1 時刻目 の疑似外部入力を制御可能とし,各時刻の外部出力および k 時刻目の疑似外部出力を観測可能としたモデルである.

また,単一故障モデルはテスト不能故障判定のための k 時 間展開モデルの k 時刻目にのみ故障を仮定し,それ以外の 時刻は正常回路とする故障モデルである.単一故障モデル は縮退故障モデルを仮定しており,この故障モデルにおい てテスト不能な故障は,順序回路においてもテスト不能と 判定することができる[10].

図5に本手法のテスト不能故障判定の流れを示す.また, 本手法の到達不能状態を禁止状態制約とした順序回路のテ スト不能故障判定の流れは以下の通りである.

#### (Step1)

テスト不能故障判定のためのk時間展開モデルのCNF式 を論理ゲートのCNF変換規則に従い生成する.

#### (Step2)

Step1 で生成された CNF 式に前述の手法で判定した到達 不能状態を禁止状態制約として付与する.

#### (Step3)

与えられた代表故障集合に対し、Step2で生成された CNF 式と SAT ソルバーを用いてテスト生成を行う.このとき, 充足不能と判定された故障はテスト不能故障と判定する.

## 4. 実験結果

フリップフロップ組合せの状態正当化による到達不能状 態判定法,到達不能状態を禁止状態制約とした順序回路の テスト不能故障判定法をC言語で実装した.

実験環境は Windows 8.1, メモリ 8GB, プロセッサ: Intel Core i7-4790, 3.6GHz. 対象回路は ISCAS' 89 及び ITC' 99 ベンチマーク回路である.

FF 数が 21 以下の回路に対しては 2 時間展開モデルで FF ペアと FF トリプルを探索し, 到達不能状態判定を行った. FF 数が 21 を超える回路に対しては 2 時間展開モデルで FF ペアを探索し, 到達不能状態判定及びテスト不能故障判定 を行った.また, FIRE 及び拡張 FIRE は時間展開数を 5 に 設定し, テスト不能故障判定を行った.

表2にFF数21以下の回路に対する到達不能状態判定数 を示す.表2は左から回路名,FF数,全内部状態数,文献 [12]の手法によって判定された到達不能状態数,文献[16] で提案したフリップフロップ組合せの状態正当化に着目し た到達不能状態判定法によって判定された到達不能状態数, 文献[16]で提案した到達不能状態判定法の実行時間である. この結果から,s208とs420の回路では文献[12]の手法と同 等の判定結果が得られたが,s298,s444,s526,s1196,s1238 の回路では文献[12]の手法よりも少ない判定結果となって いる.これは文献[12]の手法で判定された到達不能状態に FF ペアと FF トリプルといった FF の組合せだけでは判定 できない到達不能状態が存在しているためだと考えられる.

表3に文献[9]と本手法のテスト不能故障判定法により判 定されたテスト不能故障数を示す.表は左から回路名,代 表故障数,文献[9]で提案されている拡張 FIRE によって判 定されたテスト不能故障数,本手法で実装した到達不能状 態を禁止状態制約とした順序回路のテスト不能故障判定法 と本手法で実装した FIRE 及び拡張 FIRE を組合せることに よって判定されたテスト不能故障数,文献[9]の実行時間, 本手法の実行時間,判定数増加率である.この結果から, ISCAS'89 回路に対し,文献[9]と比較して最大 67.9%,平均 41.9%,多くのテスト不能故障を判定できた.これは回路 構造だけでなく,順序回路の通常の機能動作において遷移 しえない状態である到達不能状態に着目してテスト不能故 障判定を行ったためだと考えられる.

### 5. むすび

本論文では,到達不能状態判定のアルゴリズムを提案し, 到達不能状態を用いたテスト不能故障判定を行った.実験 結果では,いくつかの回路で従来手法と同等の到達不能状 態を判定できた.また,文献[9]と比較し,最大 67.9%,平 均 41.9%,多くのテスト不能故障を判定できた.

今後の課題として、より多くの到達不能状態を判定する ために FF の組合せの数を増加させること、テスト不能故 障判定のための k 時間展開モデルの時間展開数を増加させ ること、FIRE 及び拡張 FIRE を実行する際の間接含意量を 増加させること、より多くの到達不能状態及びテスト不能 故障を判定できるようなアルゴリズムの提案が挙げられる.

#### 参考文献

1) H. Fujiwara, *Logic Testing and Design for Testability*, The MIT Press, 1985.

 C. Wang, S. Reddy, I. Pomeranz, X. Lin, and J. Rajski, "Conflict driven techniques for improving deterministic test pattern generation," IEEE International Conference on Computer-Aided Design, pp. 87-93, Nov. 2002.

3) B. Yang, K. Wu, and R. Karri, "Scan Based Side Channel Attack on Dedicated Hardware Implementations of Data Encryption Standard," IEEE International Test Conference, pp. 339-344, Oct. 2004.

4) D. Xiang, Y. Xu, and H. Fujiwara, "Non scan Design for Testability for Synchronous Sequential Circuits Based on Conflict Resolution," IEEE Trans. on Computers, Vol. 52, No. 8, pp. 1063-1075, Aug. 2003.

5) Y. C. Lin, F. Lu, and K. T. Cheng, "Pseudo Functional Testing," IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, Vol. 25, No. 8, pp. 1535-1546, Aug. 2006.

6) K. Sugiki, T. Hosokawa, and M. Yoshimura, "A Test Generation Method for Data path Circuits Using Functional Time Expansion Models," IEEE Workshop on RTL and High Level Testing, pp. 39-44, Nov. 2008. 7) T. Masuda, J. Nishimaki, T. Hosokawa, and H. Fujiwara, "A Test Generation Method for Data Paths Using Easily Testable Functional Time Expansion Models and Controller Augmentation," IEEE Asian Test Symposium, pp. 37-42, Nov. 2015.

8) M. A. Iyer, and M. Abramvici, "FIRE: a Fault Independent Combinational Redundancy Identification Algorithm," IEEE Trans. on VLSI systems, Vol. 4, No. 2, pp. 295-301, June 1996.

9) M. Syal, and M. S. Hsiao, "New Techniques for Untestable Fault Identification in Sequential Circuits," IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, Vol. 25, No. 6, pp. 1117-1131, June 2006.

10) V. D. Agrawal, and S. T. Chakradhar, "Combinational ATPG Theorems for Identifying Untestable Faults in Sequential Circuits," IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, Vol. 14, No. 9, pp. 1155-1160, Sep. 1995.

 H. Yotsuyanagi, and K. Kinoshita, "Undetectable Fault Removal of Sequential Circuits Based on Unreachable States," IEEE VLSI Test Symposium, pp. 176-181, Apr. 1998.

12) D. E. Long, M. A. Iyer, and M. Abramovici, "FILL and FUNI : Algorithms to Identify Illegal States and Sequentially Untestable Faults," ACM Trans. on Design Automation of Electronic Systems, Vol. 5, No. 3,

pp. 631-657, July 2000.
F. Yuan, and Q. Xu, "On Systematic Illegal State Identification for Pseudo-Functional Testing," ACM/IEEE Design Automation Conference, pp. 702-707, July 2009.

14) J. P. Marques-Silva, and K. A. Sakallah, "GRASP: A Search Algorithm for Propositional Satisfiability," IEEE Trans. on Computers, Vol. 48, No. 5, pp. 506-521, May 1999.

15) M. W. Moskewicz, C. F. Madigan, Y. Zhao, L. Zhang, and S. Malik, "Chaff: Engineering an Efficient SAT Solver," IEEE Design Automation Conference, pp. 530-535, June 2001.

16) 二関森人,細川利典,吉村正義,新井雅之,四柳浩之,橋爪 正樹,"到達不能状態を用いた SAT ベース順序回路のテスト不能故 障判定法,"信学技報, vol. 116, no. 466, DC2016-79, pp. 29-34, 2017.

| 回路    | FF数 | 全内部       | 到達不能物     | 提案手法      |                |  |  |  |  |
|-------|-----|-----------|-----------|-----------|----------------|--|--|--|--|
| 名     |     | 状態数       | 文献[13]    | 提案手法      | 关1]时间<br>(sec) |  |  |  |  |
| s208  | 8   | 256       | 239       | 239       | 1.6            |  |  |  |  |
| s298  | 14  | 16,384    | 16,166    | 14,968    | 38.3           |  |  |  |  |
| s420  | 16  | 65,536    | 65,519    | 65,519    | 187.2          |  |  |  |  |
| s444  | 21  | 2,097,152 | 2,088,287 | 2,032,232 | 541.0          |  |  |  |  |
| s526  | 21  | 2,097,152 | 2,088,284 | 1,503,232 | 404.6          |  |  |  |  |
| s641  | 19  | 524,288   | 517,827   | 517,632   | 284.3          |  |  |  |  |
| s713  | 19  | 524,288   | 517,827   | 517,632   | 307.3          |  |  |  |  |
| s1196 | 18  | 262,144   | 259,528   | 254,334   | 147.0          |  |  |  |  |
| s1238 | 18  | 262,144   | 259,528   | 254,334   | 153.0          |  |  |  |  |

表 2. 到達不能状態判定結果

表 3. テスト不能故障判定結果

|        | 代表<br>故障数 | テスト不能故障判定数 |       | 実行時間(sec) |          | 判定数        |
|--------|-----------|------------|-------|-----------|----------|------------|
| 回路名    |           | 文献[10]     | 本手法   | 文献[10]    | 本手法      | 増加率<br>(%) |
| s9234  | 6,927     | 433        | 727   | 157.3     | 515.1    | 67.9       |
| s13207 | 9,815     | 822        | 1,345 | 201.8     | 43537.6  | 63.6       |
| s38417 | 31,180    | 491        | 604   | 570.3     | 10931.3  | 23.0       |
| s38584 | 36,303    | 1,916      | 2,166 | 2014.1    | 244372.5 | 13.1       |
| b14    | 22,802    | N/A        | 157   | N/A       | 5478.3   | N/A        |
| b15    | 21,988    | N/A        | 906   | N/A       | 9265.1   | N/A        |
| b20    | 45,459    | N/A        | 320   | N/A       | 42336.1  | N/A        |
| b21    | 46,154    | N/A        | 379   | N/A       | 51766.7  | N/A        |
| b22    | 67,536    | N/A        | 344   | N/A       | 102880.2 | N/A        |