学生実験2 : 探索アルゴリズムその2・ニューラルネットワーク






更新情報
  • [2011-12-22] 作成中。
  • [2011-12-23] 仮公開。課題&サンプルソースの修正と、レポート骨組みも更新。
  • [2012-01-16] Level3の課題説明文を修正。




進め方

内容と目標
  • 探索アルゴリズム1の目標に加えて、
  • (計算機実験を通して探索や最適化のイメージを掴む。)
  • (計算機実験を効率良く実施するために何を考慮すべきかを理解する。)
  • システムの挙動を観察し、入出力特性を考察する能力を養う。
課題と提出方法
  • オプションを除く全ての Level にトライし、レポートとしてまとめよ。なお、演習課題についてはレポートに書く必要はありません。口頭試問は希望するグループのみやります(加点対象)。
  • 1グループ1レポート提出。
  • メンバ(氏名・学籍番号)と担当内容を記載すること。
  • 提出物は以下の2つです。それらを「groupX」というフォルダに準備し、規定の場所に提出(アップロード)してください。印刷する必要はありません。
    • 提出物1: レポートファイル

      補足:LaTeXで作成し、PDF化したもの。

    • 提出物2: プログラム等の関連ファイル一式を圧縮したもの

      補足:tar.gz で圧縮する事。

  • 提出(アップロード)の手順:3ステップあり。

    [手順1] 上記2つを「shell:~tnal/2011-search2-xxx/」に rsync で提出してください。保存する際のディレクトリ名は「groupX」のようにグループ名を使用する事。
    例えば、MacBook 上の ~/group1/ に提出物を保存しているならば、以下のように rsync する事で提出できます。 rsync 自体の説明は例えばここを参照してください。

    # 実施日によってアップロード先が異なります!
    # 月曜日のクラスは「2011-search2-mon」へ。
    prompt> rsync -auvze ssh ~/group1/ \
    e1057xx@shell:/net/home/teacher/tnal/2011-search2-mon/group1/
    
    # 金曜日のクラスは「2011-search2-fri」へ。
    prompt> rsync -auvze ssh ~/group1/ \
    e1057xx@shell:/net/home/teacher/tnal/2011-search2-fri/group1/
    
    # 注意:
    # ・スラッシュの有無で引数の意味が大きく異なります。
    # ・アップロードはグループ代表者一人が行ってください。
    # ・パーミッションの都合上、レポート修正した後の再アップロードも
    #  同じ代表者じゃないとアップロードできません。
    

    [手順2] 提出後、提出報告をメールにて連絡ください。

    メールの件名は「(search2/mon/group1)」のように、テーマ名(search2)、 曜日(monもしくはfri)」、グループ番号、を含めるようにしてください。

    [手順3] メールと提出ファイル一式を確認次第リプライを返します。

  • プログラムのソースをレポート中に含める場合には、必要十分に留めること。不必要に全ソースを掲載するのは×。
  • レポート提出期限:予備日(レポート作成日)である1/23(月)、1/27(金)とする。(探索アルゴリズム1も同一日です)

    提出期限を過ぎたら、原則的に、受け取りません。 期限内に仕上げる事も重要なタスクです。 ただし、一般社会でも通用する理由で遅れてしまう場合にはこの限りではありませんので、なるべく早く相談してください。

  • (希望グループのみ)口頭試問期限:レポート提出時が望ましいが別日程にて行う場合には、レポート提出から1週間を目安に予約する事。
  • 採点後、優秀なレポートを期間限定で公表します。

1. ニューラルネットワークとは?

人の脳を情報処理モデルとして単純化したシステムで、ニューロンと呼ばれる脳細胞を結合したネットワークの総称がニューラルネットワークである。 様々なモデルがあるが、目標の一つは「人間の脳そのものの処理をコンピュータで表現する事で、それまでコンピュータが不得手としていた/解けない問題を解決する」ことである。

各ニューロンは、入力信号 xi に重要度(重み) wi を掛け合わせた値の総和を算出し、その値に応じて自身が興奮(発火)するか否かを決定するシンプルな機械として定義される。

学習・探索のイメージ
単一のニューロン(単純パーセプトロン)のみで構成される2入力1出力の例を示す。 入力と出力は 0 or 1 を取るとした時、入力 x1, x2 の AND を出力させるように学習させる事は、「w1, w2, θをどのように設定するのが最適か(最も適切に分類する線引きをするためのパラメータ値の組み合わせは何か)?」という探索問題として定式化することができる。

Level 0: 実験環境の準備
  1. 作業用ディレクトリの作成。
    prompt> cd
    prompt> mkdir info2
    prompt> cd info2
    
  2. リポジトリのクローンを作成。

    下記コマンド中の「e105700」は各自のアカウント名に変更すること。

    prompt> hg clone ssh://e105700@shell//home/hg/teacher/tnal/nn nn
    prompt> cd nn
    prompt> ls
    
  3. 正常にクローンを作成できていれば、~/info2/nn 以下に3つのディレクトリ".hg"(Mercurial管理用)、"bp_mo"(Level 1, 2用), "nn_num"(Level 3用) が作成されているはずです。("nn_char_ja"は使いません)
  4. hg でダウンロードできない人はここのリポジトリからダウンロードしてください。

2. 動作確認実験

Level 1: 線形分離可。  (8点)

実験内容

ソースのあるディレクトリ(~/info2/nn/bp_mo/)に移動し、以下の実験(演習課題、Level 1)を実施せよ。

  1. 演習課題: サンプルソース(bp_mo.c)は「OR問題」を設定している。この問題においてシード値を変更して適当回数実行し、大抵の場合簡単に解けている事を確認せよ。

    コメント:初期重みを設定している乱数シード値を 100,200,...,1000 と変更し、実行し、重みが変わったとしても数100回程度の学習で誤差がほぼゼロになる事を確認する。なお、通常はシード値は適宜自由に変更して実行するが、今回の実験に限ってはシード値を「100,200,300,400,500,600,700,800,900,1000」の10パターンとして指定する。(Level2,3に共通の指定です)

    使い方:
      prompt> gcc bp_mo.c -lm
      prompt> ./a.out $random_seed
    

  2. Level 1: 「OR問題」を学習させた際の学習の推移をグラフ化せよ。ただし、横軸は学習回数、縦軸は誤差とする。

    コメント:学習結果をグラフ化する際には、(a)シード値を変更して得られた10回分の学習結果と、(b)10回分の学習結果を平均した結果、の2つのグラフを作成すること。shell/perl等のスクリプト言語/表計算ソフト/gnuplot等を利用すると楽になるでしょう。ソースファイルそのものを改変するのもOK。

Level 2: 線形分離不可  (12点)

実験内容

bp_mo.c をコピーして bp_mo_exor.c を作成し、以下の演習課題と Level 2 を実施せよ。

  1. 演習課題: bp_mo_exor.c を編集して「ExOR問題」へ変更し、シード値を変更して複数回実行せよ。OR問題と異なり、そのままでは学習が適切に収束しない事を確認せよ。
  2. Level 2: 「ExOR問題」をうまく学習する為に、以下に示す各パラメータを変更して実験せよ。最も効率良く学習が収束する組み合わせを検討せよ。また、そのパラメータを用いた際の学習曲線(10試行平均値)を描け。

    パラメータ変更目安
    学習係数 ETA0以上〜2.0未満
    慣性項 ALPHA0以上〜1.0未満
    中間層のユニット数 HIDDEN1以上

    コメント:「最も効率良く学習が収束するパラメータの組み合わせ」を探し出すには、どのように実験を進めれば良いだろうか?

  3. (オプション)どうやれば効率良く最適な組み合わせを探すことができるか?可能な限り人の手間を省いて自動化する方法を検討し、実験せよ。

3. 応用事例(文字認識)

Level 3: 文字認識サンプル  (15+15+10+10=50点)

実験内容

ソースのあるディレクトリ(~/info2/nn/nn_num/)に移動し、以下の実験(演習課題、Level 3.1 〜 3.4)を実施せよ。

動かし方は 0README_ja.txt を参照。
  1. 演習課題: サンプルソースを動かし、『A、B、C、D、E、F、G、H、I、J』の文字を認識するように重みを学習させよ。本プログラムでは、学習用には learn0.txt ... learn9.txt を用いているが、類似した文字 eva1-1.txt, eva1-2.txt を適切に『B』として認識するか、確認せよ。

    コメント:eva1-1.txt, eva1-2.txt で確認する前に、『A〜J』を認識出来るように学習を収束させる必要があります。そのためには、中間層(デフォルトでは1)を増やした上で、数千〜数万回程度学習させてみてください。

  2. Level3.1: 文字認識サンプルにおいて、Level 2 と同様にパラメータを調整し、学習後の誤差が最も早く収束する(=学習に向いているパラメータの)組み合わせを検討せよ。また、そのパラメータを用いた際の学習に要した回数(10回分+平均値)を示すと共に、学習曲線(10試行平均値のみ)を描け。

    コメント:指定したシード値10パターンによる収束度合いが最速のグループには、ボーナスポイントとして基準点がAになるように「加点+20」を与えます!

  3. Level3.2: Level 3.1 のパラメータ調整を通してどのような傾向が見られたのか、実験結果を数例示すと共に、パラメータと収束能力の関連性について考察せよ。

    コメント:パラメータの影響を観察するためには、どのような実験計画を立てれば良いだろうか?

  4. Level3.3: 各自で任意の評価用データを複数作成し、学習時のデータとの違いが少ないほど認識率が高い事を示せ。
  5. Level3.4: 下図のように入力されたデータが想定していた入力と比べてサイズが異なったり、位置がずれている等、文字の一部が欠けている以外にも多様な要因によるデータ(情報)の劣化が考えられる。認識率を高めるにはどのような点を工夫すれば良いか?どのような方法でも構わないので、検討せよ。



4. オプション課題例

Level X: オプション課題例
  • Level3関連
    • Level 3.1, 3.2 における複数シミュレーションを効率良く行い、集計するスクリプト作成やプログラム修正等。
    • Level 3.4 にて検討した事項の実装。
    • 「文字認識サンプル」を画像ファイルの読み込みに対応させる(簡易バージョンでも良いし、画像ファイル or 疑似画像ファイルを読「サンプルプログラムの読み込みフォーマット」に変換するプログラムの作成でも良い。)。
    • 「文字認識サンプル」におけるパラメータのチューニングを効率良く行うための工夫。
    • 「文字認識サンプル」を利用した他のアプリケーションへの適用(利用しにくい場合にはゼロから書き直しても ok)。


5. 補足

Level X: 補足

実験の内容・進め方に関するコメント等

  1. 今後の為に参考にしたいので、情報工学実験2・探索アルゴリズム1〜2で扱った内容、実験の進め方等について意見があれば書いてください(当然、どのような意見であってもレポートの評価を下げる事はしません。)。「授業評価アンケート」の際に書いてもらっても構いません。参考までに、今回の実験では以下の点を考慮した内容のつもりで実施しました。
    • 扱った内容:探索アルゴリズムの考え方、NN。
    • 中心課題:

      (1)計算機実験を実施するにあたっての考え方、特に、実験計画・実験・結果収集・結果解析・レポート作成までの一連の作業をするにあたって考慮すべき点の発見と、対処方法の検討。

      (2)(1)の実験を効率良く実施する為に検討すべき項目の調査と、それを解決する手段に関する検討。

      (3)パラメータ・チューニングの必要性やそれらを効率的に実現する為の前処理・後処理のためのテキスト処理や自動化に関する考え方、

      (4)(主題ではないですが)サンプル・ソフトウェアの利用を通した、システム設計面における外部設計指針、マニュアル整備等の必要性確認。

    • 進め方

      (1)「解説→グループ討論/実施→全体討論」という形式を取り、他の人/グループが同じテーマを与えられた時にどのような事を考え、アイデアを整理し、どのように発表するのかについて、学生全員が実験時間中に把握出来るように心がけた。

      (2)「共同作業(グループ制)」とする事で、個人レベルでの理解度の底上げに努めた。これは、解説の段階で理解度の早い学生は他の人へ教示する事でそのスキルとより理解度が深まる上に、理解度が不十分であった学生は同環境にいる学生の視点からの教示により理解しやすくなる事を期待して実施した。

      (3)(2)の間接的な効果として、自分の意見を第三者へ伝えるコミュニケーション能力・レポート作成技術の向上が挙げられます。

  2. 今後、実施を検討している以下の項目に関する、賛成/反対等の意見。

    (1)レポートの開示。取りあえず、今回の分については採点後、評価の高いレポートについて了承を得てから開示の有無を決定するつもりです。

    (2)最急降下法、NN、(GA)以外のアルゴリズムを用いた実験(「アルゴリズムとデータ構造」等、他の講義で出てくるアルゴリズムを利用した実験等)。

  3. やって欲しかった内容、その他に関する意見。




7. Tips

gnuplot を用いた作図方法

  1. Excel等の表計算ソフトでデータを収集・解析した結果をグラフ化する。

    gnuplot 等 EPS 形式で出力出来る図作成ソフトを利用する。 gnuplot の場合なら、それが読み込める形式(text)に保存し、以下の手順にて図を作成し、LaTeX に取り込む。

    Excel等のEPS出力できないソフトを使う場合には「直接PDF出力」した上で、Bounding Boxのサイズを取得するebbコマンドで hoge.bb ファイルを生成した状態でPDFファイルを読み込ませてください。「直接」というのが重要です。間接的に出力、例えば一旦JPEG等の非ベクター形式で保存したものをPDF形式に変換しても、ベクタデータが壊れてしまっているので画質が劣化してしまいます。原則としてはベクターイメージとしてlatexに組み込むようにしてください。レポート骨組みでもそうしています。

  2. LaTex に gnuplot の図を取り込む。
    1. グラフ化するデータを準備する。
    2. gnuplot でグラフ化する。以下は result.dat 内のデータを線グラフ化する例。ここでは LaTeX 用に eps 形式で作成しています。
      gnuplot> set terminal postscript eps
      gnuplot> set output "result.eps"
      gnuplot> set title "figure title..."
      gnuplot> set xlabel "x title..."
      gnuplot> set ylabel "y title..."
      gnuplot> plot "result.dat" with line
      
    3. LaTeX に取り込む。
      \documentclass[a4paper,10pt]{jarticle}
      \usepackage{graphicx}
      
      \begin{document}
      \begin{figure}
       \begin{center}
        \includegraphics[scale=0.5]{result.eps}
        \caption{図のテスト}
        \label{fig:result}
       \end{center}
      \end{figure}
      
      \end{document}
      




    7. レポート骨組み

    レポート作成を分担して進めやすくするために、レポートの骨組みを用意しました。具体的には、input コマンドを用いて複数ファイルを読み込んで、一つのレポートを生成するようにしてあります。分類はあくまでも例ですので、分け方を変更してもらっても構いません。





    参考文献・サイト