package de.lmu.ifi.dbs.elki.database.query.range; /* This file is part of ELKI: Environment for Developing KDD-Applications Supported by Index-Structures Copyright (C) 2011 Ludwig-Maximilians-Universität München Lehr- und Forschungseinheit für Datenbanksysteme ELKI Development Team This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ import java.util.ArrayList; import java.util.Collections; import java.util.List; import de.lmu.ifi.dbs.elki.database.ids.DBID; import de.lmu.ifi.dbs.elki.database.query.DistanceResultPair; import de.lmu.ifi.dbs.elki.database.query.DoubleDistanceResultPair; import de.lmu.ifi.dbs.elki.database.query.LinearScanQuery; import de.lmu.ifi.dbs.elki.database.query.distance.DistanceQuery; import de.lmu.ifi.dbs.elki.database.query.distance.PrimitiveDistanceQuery; import de.lmu.ifi.dbs.elki.distance.distancefunction.PrimitiveDoubleDistanceFunction; import de.lmu.ifi.dbs.elki.distance.distancevalue.DoubleDistance; /** * Default linear scan range query class. * * @author Erich Schubert * * @apiviz.uses PrimitiveDoubleDistanceFunction * * @param Database object type */ public class LinearScanRawDoubleDistanceRangeQuery extends LinearScanRangeQuery implements LinearScanQuery { /** * Constructor. * * @param distanceQuery Distance function to use */ public LinearScanRawDoubleDistanceRangeQuery(DistanceQuery distanceQuery) { super(distanceQuery); } @Override public List> getRangeForDBID(DBID id, DoubleDistance range) { if(distanceQuery instanceof PrimitiveDistanceQuery && distanceQuery.getDistanceFunction() instanceof PrimitiveDoubleDistanceFunction) { @SuppressWarnings("unchecked") PrimitiveDoubleDistanceFunction rawdist = (PrimitiveDoubleDistanceFunction) distanceQuery.getDistanceFunction(); double epsilon = range.doubleValue(); O qo = relation.get(id); List> result = new ArrayList>(); for(DBID currentID : relation.iterDBIDs()) { double doubleDistance = rawdist.doubleDistance(qo, relation.get(currentID)); if(doubleDistance <= epsilon) { result.add(new DoubleDistanceResultPair(doubleDistance, currentID)); } } Collections.sort(result); return result; } else { return super.getRangeForDBID(id, range); } } @Override public List> getRangeForObject(O obj, DoubleDistance range) { if(distanceQuery instanceof PrimitiveDistanceQuery && distanceQuery.getDistanceFunction() instanceof PrimitiveDoubleDistanceFunction) { @SuppressWarnings("unchecked") PrimitiveDoubleDistanceFunction rawdist = (PrimitiveDoubleDistanceFunction) distanceQuery.getDistanceFunction(); double epsilon = range.doubleValue(); List> result = new ArrayList>(); for(DBID currentID : relation.iterDBIDs()) { double doubleDistance = rawdist.doubleDistance(obj, relation.get(currentID)); if(doubleDistance <= epsilon) { result.add(new DoubleDistanceResultPair(doubleDistance, currentID)); } } Collections.sort(result); return result; } else { return super.getRangeForObject(obj, range); } } }