This is by no means a complete answer, but if there are several images in tif, and if you know the size in advance, you can standardize image samples before classifying them. You would cut the image into all possible rectangles in tif.
Therefore, when you create a classifier (I do not mention methods here), the final result will be a synthesis of the classification of all the smaller rectangles.
So, if tif is specified, the arrow or flower images are 16 pixels by 16 pixels, say, you can use the Python PIL to create patterns.
from PIL import Image image_samples = [] im = Image.open("input.tif") sample_dimensions = (16,16) for box in get_all_corner_combinations(im, sample_dimensions): image_samples.append(im.crop(box)) classifier = YourClassifier() classifications = [] for sample in image_samples: classifications.append (classifier (sample)) label = fuse_classifications (classifications)
Again, I did not talk about the training phase of writing YourClassifier
. But hopefully this helps in identifying part of the problem.
There are many studies devoted to studying the classification of images, as well as work on cleaning noise in images before their classification.
Consider viewing this beautiful collection of existing Python learning libraries.
http://scipy-lectures.github.com/advanced/scikit-learn/index.html
There are many methods that also apply to images.
source share