4

2 つのソース イメージがあります。 最初のソース画像 2 番目のソース画像

それらは同等に見えますが、わずかにずれています。したがって、各画像との違いが色分けされた差分画像を作成しました(緑と赤)。

差分画像

私は次のように作成しました:

convert first.png second.png                      \
   \( -clone 0,1 -compose difference -composite   \
      -threshold 0 \)                             \
   \( -clone 0 -clone 2 -compose minus -composite \
      -threshold 0 -fill green1 -opaque white     \
      -channel rgba -fill none -opaque black \)   \
   \( -clone 1 -clone 2 -compose minus -composite \
      -threshold 0 -fill red -opaque white        \
      -channel rgba -fill none -opaque black \)   \
   \( -clone 0,1 -evaluate-sequence mean \)       \
   -delete 0-2      \
   -reverse         \
   -background none \
   -compose over    \
   -flatten         \
    multicolor_difference.png

ここで提案されているように:

http://www.imagemagick.org/discourse-server/viewtopic.php?t=26105

ここで、コードで操作できる形状のリストを取得できるように、さまざまな緑と赤の四角形の位置を取得したいと考えています。

画像をテキストに変換すると

# ImageMagick pixel enumeration: 2880,1370,255,srgb
0,0: (0,255,0)  #00FF00  lime
1,0: (0,255,0)  #00FF00  lime
2,0: (255,255,255)  #FFFFFF  white
3,0: (255,255,255)  #FFFFFF  white

色が緑がかった色または赤であるかどうかをチェックするすべてのピクセルを繰り返し処理します。これはもちろんパフォーマンスキラーです。

特定の形状を画像で検索するより良い方法はありますか? 特定の色の発生をチェックするだけでも、大きな改善になります。コードで解釈できるように、出力はテキストにする必要があります。

全体として、2 つの画像の違いをテキスト形式で説明したいと思います。最良の場合、すべての長方形に対して 10 個の出力しかありません。

4

1 に答える 1

2

私はあなたの質問を理解しているかどうか確信が持てませんが、おそらく答えに近づくことができると思います!

緑と赤のファイルを別々に生成するかもしれませんが、あなたが持っているものから始めましょう。赤とライムの差分ファイルを白黒PBMファイルに変換すると、それを渡すことができ、おそらく解析できるpotraceベクトル化されたファイルになります。SVG

convert difference.png    \
   -fill black            \
   +opaque lime           \
   -colorspace gray       \
   -threshold 1% pbm:- | potrace - -s -o green.svg

これにより、次のようになります。

<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 20010904//EN"
 "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">
<svg version="1.0" xmlns="http://www.w3.org/2000/svg"
 width="2880.000000pt" height="1370.000000pt" viewBox="0 0 2880.000000 1370.000000"
 preserveAspectRatio="xMidYMid meet">
<metadata>
Created by potrace 1.12, written by Peter Selinger 2001-2015
</metadata>
<g transform="translate(0.000000,1370.000000) scale(0.100000,-0.100000)"
fill="#000000" stroke="none">
<path d="M20 6875 l0 -6826 25 -24 24 -25 14366 0 14365 0 0 6850 0 6850
-14390 0 -14390 0 0 -6825z m7280 4505 l0 -160 7110 0 7110 0 0 -1180 0 -1180
-7110 0 -7110 0 0 -160 0 -160 4290 0 4290 0 0 -1780 0 -1780 2820 0 2820 0 0
-120 0 -120 -2830 0 -2830 0 0 1450 0 1450 -4270 0 -4270 0 0 -1320 0 -1320
4260 0 4260 0 0 -120 0 -120 -4270 0 -4270 0 0 1810 c0 1200 3 1810 10 1810 6
0 10 -37 10 -90 l0 -90 4270 0 4270 0 0 160 0 160 -4270 0 -4270 0 0 -60 c0
-53 -2 -60 -20 -60 -20 0 -20 7 -20 1570 0 1040 3 1570 10 1570 6 0 10 -60 10
-160z m8240 -4440 l0 -380 -3950 0 -3950 0 0 380 0 380 3950 0 3950 0 0 -380z
m-2260 -1160 l0 -460 -1700 0 -1700 0 0 460 0 460 1700 0 1700 0 0 -460z
m15505 -5759 c-3 -6 -11 -11 -16 -11 -5 0 -4 6 3 14 14 16 24 13 13 -3z"/>
<path d="M7400 10040 l0 -1080 7010 0 7010 0 0 1080 0 1080 -7010 0 -7010 0 0
-1080z"/>
<path d="M7420 7920 l0 -180 4170 0 4170 0 0 180 0 180 -4170 0 -4170 0 0
-180z"/>
<path d="M7680 6940 l0 -340 3910 0 3910 0 0 340 0 340 -3910 0 -3910 0 0
-340z"/>
<path d="M9980 5780 l0 -360 1600 0 1600 0 0 360 0 360 -1600 0 -1600 0 0
-360z"/>
</g>
</svg>
于 2015-05-07T10:06:21.340 に答える