[編集] 画像比較用のコードを考案しました。マッチング部分はまだ少し欠陥があり、私はいくつかの支援が大好きです。プロジェクトは--GitHubにあります。
私はこれらの2つの画像Img1とImg2を持っています:
openCVで次のコマンドを使用すると
Mat img1 = Highgui.imread("mnt/sdcard/IMG-20121228.jpg");
Mat img2 = Highgui.imread("mnt/sdcard/IMG-20121228-1.jpg");
try{
double l2_norm = Core.norm( img1, img2 );
tv.setText(l2_norm+"");
} catch(Exception e) {
//image is not a duplicate
}
l2_normのdouble値を取得します。このdouble値は、重複する画像ペアによって異なります。ただし、画像が異なる場合は、例外がスローされます。これは、重複する画像を識別する方法ですか?それとももっと良い方法がありますか?私は広範囲にグーグルで検索しましたが、本当に説得力のある答えを見つけることができませんでした。true
2つの画像を比較し、画像のブール値またはfalse
画像に応じてブール値を取得する方法について、コードと説明をお願いします。
編集
Scalar blah= Core.sumElems(img2);
Scalar blah1=Core.sumElems(img1);
if(blah.equals(blah1))
{
tv.setText("same image");
}
}
私はこれを試しましたが、if
条件が満たされることはありません。いくつかの違いがあると思いますが、のcompare
関数はありませんScalar
。私は何をしますか?
編集
try{
Scalar blah= Core.sumElems(img2);
Scalar blah1=Core.sumElems(img1);
String b=blah.toString();
String b1=blah1.toString();
System.out.println(b+" "+b1);
double comp=b.compareTo(b1);
tv.setText(""+comp);
}
この方法にも欠陥があります。適切な精度で画像を比較するために使用できますが、画像のサイズが異なると失敗します。
画像のサイズが異なり、スカラー値を印刷すると、次のようになります。
[9768383.0, 1.0052889E7, 1.0381814E7, 0.0] [1.5897384E7, 1.6322252E7, 1.690251E7, 0.0]
同じサイズの画像を比較した場合と比べると、それほど大きくはありませんが、2番目と3番目の数値のばらつきはそれほど大きくありません。ただし、最初の番号は最も大きな変化を被ります。
2つの画像の内容を比較するための最良の最速の方法は何でしょうか?
[編集]
ここで見つけたコードを使用しています。
私が理解できないのは、MatOfKeyPoint
変数keypoints
とを初期化する方法logoKeypoints
です。これが私のコードスニペットです:
FeatureDetector detector = FeatureDetector.create(FeatureDetector.SURF);
//FeatureDetector detector = FeatureDetector.create(FeatureDetector.FAST);
//Imgproc.cvtColor(img1, img1, Imgproc.COLOR_RGBA2RGB);
//Imgproc.cvtColor(img2, img2, Imgproc.COLOR_RGBA2RGB);
DescriptorExtractor SurfExtractor = DescriptorExtractor
.create(DescriptorExtractor.SURF);
//extract keypoints
MatOfKeyPoint keypoints, logoKeypoints;
long time= System.currentTimeMillis();
detector.detect(img1, keypoints);
Log.d("LOG!", "number of query Keypoints= " + keypoints.size());
detector.detect(img2, logoKeypoints);
Log.d("LOG!", "number of logo Keypoints= " + logoKeypoints.size());
Log.d("LOG!", "keypoint calculation time elapsed" + (System.currentTimeMillis() -time));
//Descript keypoints
long time2 = System.currentTimeMillis();
Mat descriptors = new Mat();
Mat logoDescriptors = new Mat();
Log.d("LOG!", "logo type" + img2.type() + " intype" + img1.type());
SurfExtractor.compute(img1, keypoints, descriptors);
SurfExtractor.compute(img2, logoKeypoints, logoDescriptors);
Log.d("LOG!", "Description time elapsed" + (System.currentTimeMillis()- time2));
私は明らかに変数keypoints
を初期化することができず、 logoKeypoints
nullcuzにするとnullポインター例外を受け取ります。それらを初期化するにはどうすればよいですか?