アカウント名:
パスワード:
本家のコメントhttp://entertainment.slashdot.org/comments.pl?sid=1474488&cid=30396686 [slashdot.org]がビンゴなのではと思います。JPEGと同じように120x160の画像を8x8のチャンクにしてそれぞれをcosine gradientで近似するとちょうど15x20ピースになるということです。おそらく核の部分はそのままJPEGのアルゴリズムを使っているのではないでしょうか?そうだとしても,それに着目したアイデアはすごいですね。
> JPEGと同じように120x160の画像を8x8のチャンクにしてそれぞれをcosine gradientで近似するとちょうど15x20ピースになるということです。
いや、細かいとこを見るとJPEGと全然違うというか「JPEG アルゴリズムを使う」なんてオーバースペックもいいとこですよ。
ジガゾーパズルのピースには、白黒を繰り返すようなピースはありません。四隅の色から、内部は単純に線形補間している感じです。 [nifty.com]
一方、JPEGの基本となるDCTの基底テーブル [iwate-u.ac.jp]を見れば分かりますが、DCTの基底は、基本的に白と黒を何度か繰り返してます。繰り返しが無いのは、DC成分(一番左上)の右隣と下隣の2つだけ。つまり、DCTを応用するとなると、この2つの8x8の64のパターンのうち、2パターンだけを使ってピースを表現するってことになります。そんなことのためにわざわざDCTを処理しなくても、画像を30x40に縮小して、それを15x20の「2×2ピクセルなブロック」に分けて考え、その四色をピース四隅の色に対応させるって処理で十分。
処理の流れとしてはこんな感じかな?
1. 画像解像度を30x40に縮小する2. 画像のコントラスト正規化、ヒストグラム平滑化を行う3. (2x2ピクセルで構成される)各ブロックをピースに割り当てていく。 ピースの種類が有限なため、誤差が最小になるように最適化問題を解く。
この3の処理は、JPEG圧縮よりも「パレットを割り当てて誤差拡散で減色する」処理の方が近いような気がします。
通常はパレットの種類だけの制限だけど(例えば16色のうちならどの色を何回使っても良い)、この場合は使用回数に制限がありますね。
より多くのコメントがこの議論にあるかもしれませんが、JavaScriptが有効ではない環境を使用している場合、クラシックなコメントシステム(D1)に設定を変更する必要があります。
UNIXはただ死んだだけでなく、本当にひどい臭いを放ち始めている -- あるソフトウェアエンジニア
グラデーションパーツ (スコア:2, 興味深い)
グラデーションパーツの存在が、完成状態をそれらしく見せるのにかなり貢献している気がします。
どうやって着想したんだろうか。
Re:グラデーションパーツ (スコア:4, 参考になる)
本家のコメント
http://entertainment.slashdot.org/comments.pl?sid=1474488&cid=30396686 [slashdot.org]
がビンゴなのではと思います。JPEGと同じように120x160の画像を8x8のチャンクにしてそれぞれをcosine gradientで近似するとちょうど15x20ピースになるということです。
おそらく核の部分はそのままJPEGのアルゴリズムを使っているのではないでしょうか?
そうだとしても,それに着目したアイデアはすごいですね。
Re:グラデーションパーツ (スコア:2, 興味深い)
> JPEGと同じように120x160の画像を8x8のチャンクにしてそれぞれをcosine gradientで近似するとちょうど15x20ピースになるということです。
いや、細かいとこを見るとJPEGと全然違うというか「JPEG アルゴリズムを使う」なんてオーバースペックもいいとこですよ。
ジガゾーパズルのピースには、白黒を繰り返すようなピースはありません。四隅の色から、内部は単純に線形補間している感じです。 [nifty.com]
一方、JPEGの基本となるDCTの基底テーブル [iwate-u.ac.jp]を見れば分かりますが、DCTの基底は、基本的に白と黒を何度か繰り返してます。繰り返しが無いのは、DC成分(一番左上)の右隣と下隣の2つだけ。
つまり、DCTを応用するとなると、この2つの8x8の64のパターンのうち、2パターンだけを使ってピースを表現するってことになります。
そんなことのためにわざわざDCTを処理しなくても、画像を30x40に縮小して、それを15x20の「2×2ピクセルなブロック」に分けて考え、その四色をピース四隅の色に対応させるって処理で十分。
処理の流れとしてはこんな感じかな?
1. 画像解像度を30x40に縮小する
2. 画像のコントラスト正規化、ヒストグラム平滑化を行う
3. (2x2ピクセルで構成される)各ブロックをピースに割り当てていく。
ピースの種類が有限なため、誤差が最小になるように最適化問題を解く。
この3の処理は、JPEG圧縮よりも「パレットを割り当てて誤差拡散で減色する」処理の方が近いような気がします。
Re:グラデーションパーツ (スコア:1)
参考になりました。
…となると、うまくやればもっと良いパズルを作ることもできそうですね。
アイデアもいろいろわいてきます。
Re: (スコア:0)
通常はパレットの種類だけの制限だけど(例えば16色のうちならどの色を
何回使っても良い)、この場合は使用回数に制限がありますね。
Re: (スコア:0)
ピクセルベースの発想ではなく、輝度勾配でマッチングさせているように思える。つまり輪郭をピースで書いている。
(たいした根拠なし)
Re: (スコア:0)
グラデーションパターンはいくつか前もって用意して、個数はサンプルから学習させたのではないでしょうか。
難しい問題をがんばって解いたにしろ、難しそうに見えて実は簡単だったと看破したにしろ、いずれにしても大したものです。