Class DBSCAN<T>

Type Parameters:
T - the type of input object.
All Implemented Interfaces:
Serializable

public class DBSCAN<T> extends Partitioning
Density-Based Spatial Clustering of Applications with Noise. DBSCAN finds a number of clusters starting from the estimated density distribution of corresponding nodes.

DBSCAN requires two parameters: radius (i.e. neighborhood radius) and the number of minimum points required to form a cluster (minPts). It starts with an arbitrary starting point that has not been visited. This point's neighborhood is retrieved, and if it contains sufficient number of points, a cluster is started. Otherwise, the point is labeled as noise. Note that this point might later be found in a sufficiently sized radius-environment of a different point and hence be made part of a cluster.

If a point is found to be part of a cluster, its neighborhood is also part of that cluster. Hence, all points that are found within the neighborhood are added, as is their own neighborhood. This process continues until the cluster is completely found. Then, a new unvisited point is retrieved and processed, leading to the discovery of a further cluster of noise.

DBSCAN visits each point of the database, possibly multiple times (e.g., as candidates to different clusters). For practical considerations, however, the time complexity is mostly governed by the number of nearest neighbor queries. DBSCAN executes exactly one such query for each point, and if an indexing structure is used that executes such a neighborhood query in O(log n), an overall runtime complexity of O(n log n) is obtained.

DBSCAN has many advantages such as

  • DBSCAN does not need to know the number of clusters in the data a priori, as opposed to k-means.
  • DBSCAN can find arbitrarily shaped clusters. It can even find clusters completely surrounded by (but not connected to) a different cluster. Due to the MinPts parameter, the so-called single-link effect (different clusters being connected by a thin line of points) is reduced.
  • DBSCAN has a notion of noise. Outliers are labeled as PartitionClustering.OUTLIER, which is Integer.MAX_VALUE.
  • DBSCAN requires just two parameters and is mostly insensitive to the ordering of the points in the database. (Only points sitting on the edge of two different clusters might swap cluster membership if the ordering of the points is changed, and the cluster assignment is unique only up to isomorphism.)
On the other hand, DBSCAN has the disadvantages of
  • In high dimensional space, the data are sparse everywhere because of the curse of dimensionality. Therefore, DBSCAN doesn't work well on high-dimensional data in general.
  • DBSCAN does not respond well to data sets with varying densities.

References

  1. Martin Ester, Hans-Peter Kriegel, Jorg Sander, Xiaowei Xu (1996-). A density-based algorithm for discovering clusters in large spatial databases with noise". KDD, 1996.
  2. Jorg Sander, Martin Ester, Hans-Peter Kriegel, Xiaowei Xu. (1998). Density-Based Clustering in Spatial Databases: The Algorithm GDBSCAN and Its Applications. 1998.
See Also:
  • Constructor Summary

    Constructors
    Constructor
    Description
    DBSCAN(int k, int[] group, boolean[] core, int minPoints, double radius, RNNSearch<T,T> nns)
    Constructor.
  • Method Summary

    Modifier and Type
    Method
    Description
    static DBSCAN<double[]>
    fit(double[][] data, int minPts, double radius)
    Clustering the data with KD-tree.
    static <T> DBSCAN<T>
    fit(T[] data, Distance<T> distance, int minPts, double radius)
    Clustering the data.
    static <T> DBSCAN<T>
    fit(T[] data, RNNSearch<T,T> nns, int minPts, double radius)
    Clustering the data.
    int
    Returns the minimum number of neighbors for a core data point.
    int
    Classifies a new observation.
    double
    Returns the neighborhood radius.

    Methods inherited from class smile.clustering.Partitioning

    group, group, k, size, size, toString

    Methods inherited from class java.lang.Object

    clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
  • Constructor Details

    • DBSCAN

      public DBSCAN(int k, int[] group, boolean[] core, int minPoints, double radius, RNNSearch<T,T> nns)
      Constructor.
      Parameters:
      k - the number of clusters.
      group - the cluster labels.
      core - the flag if the point is a core point.
      minPoints - the minimum number of neighbors for a core data point.
      radius - the neighborhood radius.
      nns - the data structure for neighborhood search.
  • Method Details

    • minPoints

      public int minPoints()
      Returns the minimum number of neighbors for a core data point.
      Returns:
      the minimum number of neighbors for a core data point.
    • radius

      public double radius()
      Returns the neighborhood radius.
      Returns:
      the neighborhood radius.
    • fit

      public static DBSCAN<double[]> fit(double[][] data, int minPts, double radius)
      Clustering the data with KD-tree. DBSCAN is generally applied on low-dimensional data. Therefore, KD-tree can speed up the nearest neighbor search a lot.
      Parameters:
      data - the observations.
      minPts - the minimum number of neighbors for a core data point.
      radius - the neighborhood radius.
      Returns:
      the model.
    • fit

      public static <T> DBSCAN<T> fit(T[] data, Distance<T> distance, int minPts, double radius)
      Clustering the data.
      Type Parameters:
      T - the data type.
      Parameters:
      data - the observations.
      distance - the distance function.
      minPts - the minimum number of neighbors for a core data point.
      radius - the neighborhood radius.
      Returns:
      the model.
    • fit

      public static <T> DBSCAN<T> fit(T[] data, RNNSearch<T,T> nns, int minPts, double radius)
      Clustering the data.
      Type Parameters:
      T - the data type.
      Parameters:
      data - the observations.
      nns - the data structure for neighborhood search.
      minPts - the minimum number of neighbors for a core data point.
      radius - the neighborhood radius.
      Returns:
      the model.
    • predict

      public int predict(T x)
      Classifies a new observation.
      Parameters:
      x - a new observation.
      Returns:
      the cluster label. Note that it may be Clustering.OUTLIER.