Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I detect / calculate if a small pictures is present inside a bigger picture?

What I am trying to accomplish in PHP with GD or ImageMagick is the following:

I have one large image (say 2000 x 2000 pixels).. I would like to check if a second, smaller image (say 50 x 50 pixels) appears somewhere inside the larger picture, and to what percentage the area is a match.. So, for example, there's a 95% match of the smaller image at that place in the larger image..

Is this possible? How could this be achieved?

Thanks!!!!

like image 297
Roel Krottje Avatar asked Jul 13 '11 13:07

Roel Krottje


People also ask

How do I search for a photo of another picture?

All you have to do is go to images.google.com, click the camera icon that appears in the search bar, and: Paste in the URL of an image that you have seen somewhere online, or. Manually upload an image from your computer that you have saved, or. Drag an image from another window.


2 Answers

I had a quick look in PHP's ImageMagick and GD and neither has a built in way of doing that. An approach could be to use ImageMagick to divide the larger image to smaller ones(same size as the smaller one) and start comparing them to the smaller one.

However this will be very slow I suppose.

You can do that with imagemagick if you use a system call in your PHP code. I don't know if you want to try this out but here is how it can be done:

<?php
//set a bigger time out limit because comparison takes a while
set_time_limit ( 275 ) ;

//the bigger image
$bigimage = "big.bmp";
//the smaller image
$smallimage = "small.bmp";
//result image
$resimg = "/tmp/similarity";

//system call
$output = shell_exec("(compare -metric AE -subimage-search ".$bigimage." ".$smallimage." ".$resimg."  > /dev/null) 3>&1 1>&2 2>&3");

//result is something like "0 @ 251,263"
$res = explode("@",$output);
if($res[0]==0)
{
    echo "Perfect match<br/>";
    $res = explode(",",$res[1]);

    echo "width: ".$res[0];
    echo "<br/>";
    echo "height: ".$res[1];
} else {
    echo "Not match";
}

?>

I have tested the above code in a linux box with XAMPP for Linux 1.7.3a and ImageMagick 6.7.1-0 2011-07-10 Q16.

About the comparison I use the metric AE(Absolute Error) which counts how many pixels differ. The result is printed to the error stream(STERR). More about imagemagick's subimage search you can find here.

Good luck :)

like image 138
Master_ex Avatar answered Oct 04 '22 16:10

Master_ex


Here is a good answer for C#: How to find one image inside of another?

While I'm pretty sure that it can be used for PHP too because it's just a generic algorithm it's quite bad idea to use PHP for image comparison.

Also refer to Wikipedia Template match article.

like image 29
WASD42 Avatar answered Oct 04 '22 16:10

WASD42