All Downloads are FREE. Search and download functionalities are using the official Maven repository.

weka.core.neighboursearch.kdtrees.KDTreeNode Maven / Gradle / Ivy

/*
 *   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 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 General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program.  If not, see .
 */

/*
 * KDTreeNode.java
 * Copyright (C) 2007-2012 University of Waikato, Hamilton, New Zealand
 */

package weka.core.neighboursearch.kdtrees;

import java.io.Serializable;

import weka.core.RevisionHandler;
import weka.core.RevisionUtils;

/**
 * A class representing a KDTree node. A node does not explicitly
 * store the instances that it contains. Instead, it only stores 
 * the start and end index of a portion in a master index array. Each
 * node is assigned a portion in the master index array that stores 
 * the indices of the instances that the node contains. Every time a 
 * node is split by the KDTree's contruction method, the instances of 
 * its left child are moved to the left and the instances of its 
 * right child are moved to the right, in the portion of the master 
 * index array belonging to the node. The start and end index in each
 * of its children are then set accordingly within that portion so 
 * that each have their own portion which contains their instances.   
 * P.S.: The master index array is only stored in KDTree class.
 * 
 * @author Ashraf M. Kibriya (amk14[at-the-rate]cs[dot]waikato[dot]ac[dot]nz)
 * @version $Revision: 8034 $
 */
public class KDTreeNode
  implements Serializable, RevisionHandler {
   
  /** for serialization. */
  private static final long serialVersionUID = -3660396067582792648L;

  /** node number (only for debug). */
  public int m_NodeNumber;

  /** left subtree; contains instances with smaller or equal to split value. */
  public KDTreeNode m_Left = null;

  /** right subtree; contains instances with larger than split value. */
  public KDTreeNode m_Right = null;

  /** value to split on. */
  public double m_SplitValue;

  /** attribute to split on. */
  public int m_SplitDim;

  /**
   * lowest and highest value and width (= high - low) for each
   * dimension.
   */
  public double[][] m_NodeRanges;

  /** 
   * The lo and high bounds of the hyper rectangle described by the
   * node.
   */
  public double[][] m_NodesRectBounds;

  /**
   * The start index of the portion of the master index array, 
   * which stores the indices of the instances/points the node 
   * contains.
   */
  public int m_Start = 0;
  
  /**
   * The end index of the portion of the master index array, 
   * which stores indices of the instances/points the node 
   * contains.
   */
  public int m_End = 0;

  /**
   * Constructor.
   */
  public KDTreeNode() {}

  /**
   * Constructor.
   * 
   * @param nodeNum The node number/id.
   * @param startidx The start index of node's portion 
   * in master index array.
   * @param endidx The start index of node's portion 
   * in master index array.
   * @param nodeRanges The attribute ranges of the 
   * Instances/points contained in this node.
   */
  public KDTreeNode(int nodeNum, int startidx, int endidx, double[][] nodeRanges) {
    m_NodeNumber = nodeNum;
    m_Start = startidx; m_End = endidx;
    m_NodeRanges = nodeRanges;
  }

  /**
   * 
   * @param nodeNum The node number/id.
   * @param startidx The start index of node's portion 
   * in master index array.
   * @param endidx The start index of node's portion 
   * in master index array.
   * @param nodeRanges The attribute ranges of the 
   * Instances/points contained in this node.
   * @param rectBounds The range of the rectangular 
   * region in the point space that this node 
   * represents (points inside this rectangular
   * region can have different range).
   */
  public KDTreeNode(int nodeNum, int startidx, int endidx, double[][] nodeRanges, double[][] rectBounds) {
    m_NodeNumber = nodeNum;
    m_Start = startidx; m_End = endidx;
    m_NodeRanges = nodeRanges;
    m_NodesRectBounds = rectBounds;
  }

  /**
   * Gets the splitting dimension.
   * 
   * @return 		splitting dimension
   */
  public int getSplitDim() {
    return m_SplitDim;
  }

  /**
   * Gets the splitting value.
   * 
   * @return 		splitting value
   */
  public double getSplitValue() {
    return m_SplitValue;
  }

  /**
   * Checks if node is a leaf.
   * 
   * @return 		true if it is a leaf
   */
  public boolean isALeaf() {
    return (m_Left == null);
  }         

  /**
   * Returns the number of Instances 
   * in the rectangular region defined 
   * by this node.
   * @return The number of instances in
   * this KDTreeNode.
   */
  public int numInstances() {
    return (m_End-m_Start+1);
  }
  
  /**
   * Returns the revision string.
   * 
   * @return		the revision
   */
  public String getRevision() {
    return RevisionUtils.extract("$Revision: 8034 $");
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy