package ac.ooechs.oil.edgedetection;

import ac.essex.ooechs.imaging.commons.ColourChannels;
import ac.essex.ooechs.imaging.commons.PixelLoader;
import ac.essex.ooechs.imaging.commons.segmentation.Segmenter;
import ac.essex.gp.multiclass.BasicDRS;
import ac.essex.gp.multiclass.PCM;
import ac.essex.gp.multiclass.BetterDRS;

/**
 * <p/>
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version,
 * provided that any use properly credits the author.
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details at http://www.gnu.org
 * </p>
 *
 * @author Olly Oechsle, University of Essex, Date: 23-Jun-2008
 * @version 1.0
 */
public class NewEdgeSegmenter extends Segmenter {

    PCM pcm0 = new BetterDRS(17.520000457763672,455.55999755859375,new int[]{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2});;
    public int segment(PixelLoader image, int x, int y) {
        return pcm0.getClassFromOutput(image.get3x3Mean(x, y) + image.get3x3Range(x, y));
    }


}
