package de.lmu.ifi.dbs.elki.distance.similarityfunction; /* This file is part of ELKI: Environment for Developing KDD-Applications Supported by Index-Structures Copyright (C) 2015 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.data.type.TypeInformation; import de.lmu.ifi.dbs.elki.database.query.similarity.AbstractDBIDSimilarityQuery; import de.lmu.ifi.dbs.elki.database.relation.Relation; import de.lmu.ifi.dbs.elki.index.Index; import de.lmu.ifi.dbs.elki.index.IndexFactory; import de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizer; import de.lmu.ifi.dbs.elki.utilities.optionhandling.OptionID; import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.ObjectParameter; /** * Abstract super class for distance functions needing a preprocessor. * * @author Elke Achtert * * @apiviz.uses IndexFactory * @apiviz.has Instance oneway - - «create» * * @param object type * @param index type */ public abstract class AbstractIndexBasedSimilarityFunction implements IndexBasedSimilarityFunction { /** * Parameter to specify the preprocessor to be used. *

* Key: {@code -similarityfunction.preprocessor} *

*/ public static final OptionID INDEX_ID = new OptionID("similarityfunction.preprocessor", "Preprocessor to use."); /** * Parameter to specify the preprocessor to be used. *

* Key: {@code -similarityfunction.preprocessor} *

*/ protected IndexFactory indexFactory; /** * Constructor. * * @param indexFactory */ public AbstractIndexBasedSimilarityFunction(IndexFactory indexFactory) { super(); this.indexFactory = indexFactory; } @Override abstract public Instance instantiate(Relation database); @Override public boolean isSymmetric() { return true; } @Override final public TypeInformation getInputTypeRestriction() { return indexFactory.getInputTypeRestriction(); } /** * The actual instance bound to a particular database. * * @author Erich Schubert * * @apiviz.uses Index * * @param Object type * @param Index type */ abstract public static class Instance extends AbstractDBIDSimilarityQuery implements IndexBasedSimilarityFunction.Instance { /** * Parent index */ protected final I index; /** * Constructor. * * @param database Database * @param index Index to use */ public Instance(Relation database, I index) { super(database); this.index = index; } @Override public I getIndex() { return index; } } /** * Parameterization class. * * @author Erich Schubert * * @apiviz.exclude */ public abstract static class Parameterizer> extends AbstractParameterizer { /** * The index factory we use. */ protected F factory = null; /** * Get the index factory parameter. * * @param config Parameterization * @param restrictionClass Restriction class * @param defaultClass Default class */ protected void configIndexFactory(Parameterization config, final Class restrictionClass, final Class defaultClass) { final ObjectParameter param = new ObjectParameter<>(INDEX_ID, restrictionClass, defaultClass); if(config.grab(param)) { factory = param.instantiateClass(config); } } } }