package dataBase.search.distance;

import dataBase.subPicture.Pixel;
import dataBase.subPicture.SubPicture;

public abstract class AbstractDistance {

	/**
	 * @param p1
	 * @param p2
	 * @return distance between SubPictures
	 */
	public float getDistance(SubPicture p1, SubPicture p2) {

		float sum=0;
		Pixel[][] pixelsA = p1.pixels;
		Pixel[][] pixelsB = p2.pixels;
		int partsX = SubPicture.partsX;
		int partsY = SubPicture.partsY;

		for(int i=0; i<partsY; i++){
			for(int j=0; j<partsX; j++){
				sum += getDistance(pixelsA[i][j],pixelsB[i][j]);
			}
		}
		return sum;
	}
	
	/**
	 * Distance between single Pixel objects.
	 * @param a
	 * @param b
	 * @return
	 */
	abstract public float getDistance(Pixel a, Pixel b);
}
