Main Page   Packages   Class Hierarchy   Compound List   File List   Compound Members  

EuclideanDist.java

00001 /*
00002  *  Copyright 2006-2007 Columbia University.
00003  *
00004  *  This file is part of MEAPsoft.
00005  *
00006  *  MEAPsoft is free software; you can redistribute it and/or modify
00007  *  it under the terms of the GNU General Public License version 2 as
00008  *  published by the Free Software Foundation.
00009  *
00010  *  MEAPsoft is distributed in the hope that it will be useful, but
00011  *  WITHOUT ANY WARRANTY; without even the implied warranty of
00012  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013  *  General Public License for more details.
00014  *
00015  *  You should have received a copy of the GNU General Public License
00016  *  along with MEAPsoft; if not, write to the Free Software
00017  *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
00018  *  02110-1301 USA
00019  *
00020  *  See the file "COPYING" for the text of the license.
00021  */
00022 
00023 package com.meapsoft;
00024 
00033 public class EuclideanDist extends ChunkDist 
00034 {
00035     public EuclideanDist() {}
00036     public EuclideanDist(ChunkDist o) { super(o); }
00037     public EuclideanDist(int[] i) { super(i); }
00038     public EuclideanDist(ChunkDist o, int[] i) { super(o,i); }
00039 
00040     public double distance(Chunk ch1, Chunk ch2) 
00041     {
00042         FeatChunk c1 = null;
00043         FeatChunk c2 = null; 
00044 
00045         // this only works on FeatChunks
00046         try
00047         {
00048             c1 = (FeatChunk)ch1;
00049             c2 = (FeatChunk)ch2;
00050         }
00051         catch(ClassCastException e)
00052         {
00053             return super.distance(ch1, ch2);
00054         }
00055 
00056         double[] f1 = c1.getFeatures(featdim);
00057         double[] f2 = c2.getFeatures(featdim);
00058         double distSq = super.distance(c1, c2);
00059 
00060         for(int i=0; i<f1.length; i++)
00061             distSq += (f1[i] - f2[i]) * (f1[i] - f2[i]);
00062 
00063         return distSq;
00064     }
00065 }

Generated on Tue Feb 6 19:02:26 2007 for MEAPsoft by doxygen1.2.18