Package org.hipparchus.clustering
Class DBSCANClusterer<T extends Clusterable>
- java.lang.Object
- 
- org.hipparchus.clustering.Clusterer<T>
- 
- org.hipparchus.clustering.DBSCANClusterer<T>
 
 
- 
- Type Parameters:
- T- type of the points to cluster
 
 public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> DBSCAN (density-based spatial clustering of applications with noise) algorithm.The DBSCAN algorithm forms clusters based on the idea of density connectivity, i.e. a point p is density connected to another point q, if there exists a chain of points pi, with i = 1 .. n and p1 = p and pn = q, such that each pair <pi, pi+1> is directly density-reachable. A point q is directly density-reachable from point p if it is in the ε-neighborhood of this point. Any point that is not density-reachable from a formed cluster is treated as noise, and will thus not be present in the result. The algorithm requires two parameters: - eps: the distance that defines the ε-neighborhood of a point
- minPoints: the minimum number of density-connected points required to form a cluster
 
- 
- 
Constructor SummaryConstructors Constructor Description DBSCANClusterer(double eps, int minPts)Creates a new instance of a DBSCANClusterer.DBSCANClusterer(double eps, int minPts, DistanceMeasure measure)Creates a new instance of a DBSCANClusterer.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description List<Cluster<T>>cluster(Collection<T> points)Performs DBSCAN cluster analysis.doublegetEps()Returns the maximum radius of the neighborhood to be considered.intgetMinPts()Returns the minimum number of points needed for a cluster.- 
Methods inherited from class org.hipparchus.clustering.Clustererdistance, getDistanceMeasure
 
- 
 
- 
- 
- 
Constructor Detail- 
DBSCANClustererpublic DBSCANClusterer(double eps, int minPts) throws MathIllegalArgumentExceptionCreates a new instance of a DBSCANClusterer.The euclidean distance will be used as default distance measure. - Parameters:
- eps- maximum radius of the neighborhood to be considered
- minPts- minimum number of points needed for a cluster
- Throws:
- MathIllegalArgumentException- if- eps < 0.0or- minPts < 0
 
 - 
DBSCANClustererpublic DBSCANClusterer(double eps, int minPts, DistanceMeasure measure) throws MathIllegalArgumentExceptionCreates a new instance of a DBSCANClusterer.- Parameters:
- eps- maximum radius of the neighborhood to be considered
- minPts- minimum number of points needed for a cluster
- measure- the distance measure to use
- Throws:
- MathIllegalArgumentException- if- eps < 0.0or- minPts < 0
 
 
- 
 - 
Method Detail- 
getEpspublic double getEps() Returns the maximum radius of the neighborhood to be considered.- Returns:
- maximum radius of the neighborhood
 
 - 
getMinPtspublic int getMinPts() Returns the minimum number of points needed for a cluster.- Returns:
- minimum number of points needed for a cluster
 
 - 
clusterpublic List<Cluster<T>> cluster(Collection<T> points) throws NullArgumentException Performs DBSCAN cluster analysis.- Specified by:
- clusterin class- Clusterer<T extends Clusterable>
- Parameters:
- points- the points to cluster
- Returns:
- the list of clusters
- Throws:
- NullArgumentException- if the data points are null
 
 
- 
 
-