ゼミ資料(Colloquium Material)※ICL限定?

_

プログラミング課題1

 更新日 : 2011-04-09 (土) 14:03:45

_

課題1 モノクローム画像における統計量の測定

_

1. 輝度分布

 モノクローム画像 home, barbara, harbor の輝度分布を測定するプログラムを作成し,輝度分布のグラフを作成しなさい.ただし,輝度分布のグラフはX軸を輝度値とし,Y軸を出現頻度としてgnuplotを用いて作成しなさい.

_

2. 輝度の平均値,最大値,最小値,分散,電力,中央値および最頻値

 モノクローム画像 home, barbara, harbor における輝度の平均値,最大値,最小値,分散,電力,中央値および最頻値を測定するプログラムを作成しなさい.

平均値 μ最大値 Max最小値 Min分散 σ^2
mean.png
max.png
min.png
var.png
電力 P中央値最頻値
pow.png
昇順 (MN+1)/2 番目の輝度値 (MN : 奇数)
昇順 MN/2 番目の輝度値    (MN : 偶数)
輝度分布において最も多く出現する輝度値
I : 画像信号, x : 輝度値, M : 画像の水平方向サイズ, N : 画像の垂直方向サイズ
_

3. 1次元自己相関係数

 モノクローム画像 home, barbara, harbor における水平方向および垂直方向の自己相関係数を測定するプログラムを作成し,自己相関係数のグラフを作成しなさい.ただし,自己相関係数の計算において,画像外に相当する画素を使用する際,0として扱う場合と定義できる範囲内で計算する場合の2種類が考えられるので,両者の場合についてそれぞれ測定を行い,両者の結果を比較して考察を述べなさい.また,自己相関係数のグラフはX軸を画素間距離(0~20)とし,Y軸を自己相関係数としてgnuplotを用いて作成しなさい.

1次元自己相関関数1次元自己相関係数
rff1.png
ro1.png
j : 画素間距離, I : 画像信号, x : 輝度値, N : 画素数
_

4. 1次元自己共分散

 モノクローム画像 home, barbara, harbor における水平方向および垂直方向の自己共分散を測定するプログラムを作成し,自己共分散のグラフを作成しなさい.ただし,自己共分散の計算において,画像外に相当する画素を使用する際,0として扱う場合と定義できる範囲内で計算する場合の2種類が考えられるので,両者の場合についてそれぞれ測定を行いなさい.また,自己共分散のグラフはX軸を画素間距離(0~20)とし,Y軸を自己共分散としてgnuplotを用いて作成しなさい.さらに,自己共分散関数と自己相関関数との関係式を確認し,それに対する考察を述べなさい.

1次元自己共分散関数
cff1.png
j : 画素間距離, I : 画像信号, x : 輝度値, N : 画素数, μ : 輝度の平均値
_

5. 2次元自己相関係数

 モノクローム画像 home, barbara, harbor における2次元自己相関係数を測定するプログラムを作成し,自己相関係数のグラフを作成しなさい.ただし,自己相関係数の計算において,画像外に相当する画素を使用する際,0として扱う場合と定義できる範囲内で計算する場合の2種類が考えられるので,両者の場合についてそれぞれ測定を行いなさい.また,自己相関係数のグラフはX軸を水平方向の画素間距離(0~8)とし,Y軸を垂直方向の画素間距離(0~8)とし,Z軸を自己相関係数としてgnuplotを用いて作成しなさい.

2次元自己相関関数2次元自己相関係数
rff2.png
ro2.png
k : 水平方向の画素間距離, l : 垂直方向の画素間距離, I : 画像信号, x : 輝度値, M : 画像の水平方向サイズ, N : 画像の垂直方向サイズ
 
_

課題2 カラー画像における統計量の測定

 カラー画像 home, barbara に対してR-G間およびG-B間の2次元相互相関係数を測定するプログラムを作成し,相互相関係数のグラフを作成しなさい.ただし,2次元相互相関係数の計算において,画像外に相当する画素を使用する際,0として扱う場合と定義できる範囲内で計算する場合の2種類が考えられるので,両者の場合についてそれぞれ測定を行いなさい.また,相互相関係数のグラフはX軸を水平方向の画素間距離(0~8)とし,Y軸を垂直方向の画素間距離(0~8)とし,Z軸を相互相関係数としてgnuplotを用いて作成しなさい.

2次元相互相関関数2次元相互相関係数
rfg2.png
r2.png

 
_

課題3 Y,Cb,Cr 変換

_

1. R,G,B → Y,Cb,Cr

 カラー画像 home に対して R,G,B 成分を Y,Cb,Cr 信号に変換するプログラムを作成しなさい.

R,G,B → Y,Cb,Cr
(Y,Cb,Cr 変換)
Y,Cb,Cr → R',G',B'
(Y,Cb,Cr 逆変換)
ycbcr.png
rgb.png
_

2. Y,Cb,Cr 信号の確認

 上記の1で作成した Y,Cb,Cr 信号が正しい値であるかを確認するために,下記を実行しなさい.

(1)各 Y,Cb,Cr 信号をモノクローム画像としてディスプレイに表示させなさい.ただし,信号値をディスプレイに表示する際,ダイナミックレンジが0から255となるように変換しなさい.
(2)Y,Cb,Cr 信号を R,G,B 成分に逆変換するプログラムと画像間の PSNR を測定するプログラムを作成し,原画像と逆変換後の画像との PSNR を測定しなさい.このとき,原画像または原画像に近い輝度値に戻るかどうか確認しなさい.
(3)原画像と逆変換後の画像が完全に一致しない場合があるが,なぜそれが起こるのかを考察しなさい.また,原画像と逆変換後の画像が完全に一致しない場合,初めて不一致が発生した画素位置とその位置から4×4画素分の R,G,B 成分値,Y,Cb,Cr 信号値および逆変換後の R,G,B 成分値を出力しなさい.

_

3. R,G,B → Y,Cb,Cr (JPEG 2000 の可逆コンポーネント変換)

 カラー画像 home に対して JPEG 2000 の可逆コンポーネント変換を行うプログラムを作成しなさい.

R,G,B → Y,Cb,Cr
(JPEG 2000 の可逆コンポーネント変換)
Y,Cb,Cr → R',G',B'
(JPEG 2000 の可逆コンポーネント逆変換)
ycbcr_jpeg2000.png
rgb_jpeg2000.png
_

4. Y,Cb,Cr 信号の確認 (JPEG 2000 の可逆コンポーネント変換)

 上記の3で作成した Y,Cb,Cr 信号に対して,上記の2.(1),(2)と同様のことを実行し,上記1の場合と比較して考察を述べなさい.

 

 
_

注意事項

 プログラミング課題は各自,独力で作成し,記述言語はCまたはC++とすること.これ以外の言語で課題に取り組みたい場合はレポートチェック担当者の承諾を得ること.また,課題の分からない箇所は他人に相談してもよいが,他人のプログラムをコピーしないこと.また,レポートはプログラミング演習のレポート形式に従って作成するため,レポートには以下の項目をすべて含むことを条件とする.ただし,サンプルソースに記述してあるデータ構造および関数の説明は不要である.

 レポート必須項目
 ・課題概要
 ・ソースリスト
 ・データ構造の説明
  ・定数宣言 (マクロ,const)
  ・構造体 (typedef,struct)
  ・グローバル変数
 ・関数
  ・関数の説明
  ・引数
  ・戻り値
 ・実行結果
 ・考察

 

 
_

使用画像

 課題で使用する画像は共有サーバ prost にあるので,各自入手すること.

 URL : \\prost\共有フォルダ3\ICL\平成23年度\プログラミング課題\画像\

画像名画像サイズ
(水平×垂直)
階調数
home.256512×512256 level (8bit/pel)
barbara.256512×480256 level (8bit/pel)
harbor_y.raw4096×3072256 level (8bit/pel)
home.rgb512×512RGB各256 level (8bit/pel)
barbara.rgb512×480RGB各256 level (8bit/pel)
 

 
_

サンプルソース

 サンプルソースは共有サーバ prost にあるので,自由に使用してよい.また,各自,1から作成してもよい.

 URL : \\prost\共有フォルダ3\ICL\平成23年度\プログラミング課題\サンプルソース\

 

 
_

提出期限および提出先

 課題ごとにレポートを作成し,レポートが完成したら,以下の提出先に提出してからレポートチェック担当者にメールを出してレポートチェックを受けること.なお,レポートチェックを受けている間にも別の課題に取り組み,なるべく早めに課題を完了させること.また,レポートのファイル名は "[名前]_kadai[n]" とし,"doc" または "docx" 形式で提出すること.

 ※n : 課題番号

 課題1の提出先 : \\prost\共有フォルダ3\ICL\平成23年度\プログラミング課題\プログラミング課題1\課題1\
 課題2の提出先 : \\prost\共有フォルダ3\ICL\平成23年度\プログラミング課題\プログラミング課題1\課題2\
 課題3の提出先 : \\prost\共有フォルダ3\ICL\平成23年度\プログラミング課題\プログラミング課題1\課題3\

 最終期限 : 2011/05/02(月) 24:00 時間厳守

 

 

Top   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS