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) 2013 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 de.lmu.ifi.dbs.elki.database.ids.DBIDRef; import de.lmu.ifi.dbs.elki.database.ids.distance.DistanceDBIDList; import de.lmu.ifi.dbs.elki.database.query.distance.PrimitiveDistanceQuery; import de.lmu.ifi.dbs.elki.distance.distancevalue.Distance; /** * Default linear scan range query class. * * Subtle optimization: for primitive distances, retrieve the query object only * once from the relation. * * @author Erich Schubert * * @apiviz.uses PrimitiveDistanceQuery * * @param Database object type * @param Distance type */ public class LinearScanPrimitiveDistanceRangeQuery> extends LinearScanRangeQuery { /** * Constructor. * * @param distanceQuery Distance function to use */ public LinearScanPrimitiveDistanceRangeQuery(PrimitiveDistanceQuery distanceQuery) { super(distanceQuery); } @Override public DistanceDBIDList getRangeForDBID(DBIDRef id, D range) { // Note: subtle optimization. Get "id" only once! return getRangeForObject(relation.get(id), range); } }