⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 distancefunction.java

📁 矩阵的QR分解算法
💻 JAVA
字号:
/* *    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. * *    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. * *    You should have received a copy of the GNU General Public License *    along with this program; if not, write to the Free Software *    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *//* *    DistanceFunction.java *    Copyright (C) 1999-2005 University of Waikato, Hamilton, New Zealand * */package weka.core;import weka.core.neighboursearch.PerformanceStats;/** * Interface for any class that can compute and return distances between two * instances. * * @author  Ashraf M. Kibriya (amk14@cs.waikato.ac.nz) * @version $Revision: 1.7 $  */public interface DistanceFunction extends OptionHandler {  /**   * Sets the instances.   *    * @param insts 	the instances to use   */  public void setInstances(Instances insts);  /**   * returns the instances currently set.   *    * @return 		the current instances   */  public Instances getInstances();  /**   * Sets the range of attributes to use in the calculation of the distance.   * The indices start from 1, 'first' and 'last' are valid as well.    * E.g.: first-3,5,6-last   *    * @param value	the new attribute index range   */  public void setAttributeIndices(String value);    /**   * Gets the range of attributes used in the calculation of the distance.   *    * @return		the attribute index range   */  public String getAttributeIndices();    /**   * Sets whether the matching sense of attribute indices is inverted or not.   *    * @param value	if true the matching sense is inverted   */  public void setInvertSelection(boolean value);    /**   * Gets whether the matching sense of attribute indices is inverted or not.   *    * @return		true if the matching sense is inverted   */  public boolean getInvertSelection();  /**   * Calculates the distance between two instances.   *    * @param first 	the first instance   * @param second 	the second instance   * @return 		the distance between the two given instances   */  public double distance(Instance first, Instance second);  /**   * Calculates the distance between two instances.   *    * @param first 	the first instance   * @param second 	the second instance   * @param stats 	the performance stats object   * @return 		the distance between the two given instances   * @throws Exception 	if calculation fails   */  public double distance(Instance first, Instance second, PerformanceStats stats)       throws Exception;  /**   * Calculates the distance between two instances. Offers speed up (if the    * distance function class in use supports it) in nearest neighbour search by    * taking into account the cutOff or maximum distance. Depending on the    * distance function class, post processing of the distances by    * postProcessDistances(double []) may be required if this function is used.   *   * @param first 	the first instance   * @param second 	the second instance   * @param cutOffValue If the distance being calculated becomes larger than    *                    cutOffValue then the rest of the calculation is    *                    discarded.   * @return 		the distance between the two given instances or    * 			Double.POSITIVE_INFINITY if the distance being    * 			calculated becomes larger than cutOffValue.    */  public double distance(Instance first, Instance second, double cutOffValue);  /**   * Calculates the distance between two instances. Offers speed up (if the    * distance function class in use supports it) in nearest neighbour search by    * taking into account the cutOff or maximum distance. Depending on the    * distance function class, post processing of the distances by    * postProcessDistances(double []) may be required if this function is used.   *   * @param first 	the first instance   * @param second 	the second instance   * @param cutOffValue If the distance being calculated becomes larger than    *                    cutOffValue then the rest of the calculation is    *                    discarded.   * @param stats 	the performance stats object   * @return 		the distance between the two given instances or    * 			Double.POSITIVE_INFINITY if the distance being    * 			calculated becomes larger than cutOffValue.    */  public double distance(Instance first, Instance second,       double cutOffValue, PerformanceStats stats);  /**   * Does post processing of the distances (if necessary) returned by   * distance(distance(Instance first, Instance second, double cutOffValue). It   * may be necessary, depending on the distance function, to do post processing   * to set the distances on the correct scale. Some distance function classes   * may not return correct distances using the cutOffValue distance function to    * minimize the inaccuracies resulting from floating point comparison and    * manipulation.   *    * @param distances	the distances to post-process   */  public void postProcessDistances(double distances[]);  /**   * Update the distance function (if necessary) for the newly added instance.   *    * @param ins		the instance to add   */  public void update(Instance ins);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -