public void Cluster_NoiseNotEmpty() { var matrix = new[,] { {0.00, 0.09, 0.22}, {0.09, 0.00, 0.30}, {0.22, 0.30, 0.00} }; char[] objects = {'A', 'B', 'C'}; var clusterer = new DbscanClusterer<char>(o1 => objects.Where(o2 => matrix[o1 - 'A', o2 - 'A'] <= 0.2), 2); Cluster<char>[] clusters = clusterer.GenerateClusters(objects).ToArray(); Assert.That(clusters, Is.EquivalentTo(new[] {new Cluster<char>('A', 'B'), new Cluster<char>(new[] {'C'}, true)}).Using(new ClusterEqualityComparer<char>())); }
public void Cluster_AllObjectsInSameCluster() { var matrix = new[,] { {0.00, 0.09, 0.12}, {0.09, 0.00, 0.21}, {0.12, 0.21, 0.00} }; char[] objects = {'A', 'B', 'C'}; var clusterer = new DbscanClusterer<char>(o1 => objects.Where(o2 => matrix[o1 - 'A', o2 - 'A'] <= 0.2), 2); Cluster<char>[] clusters = clusterer.GenerateClusters(objects).ToArray(); Assert.That(clusters, Is.EquivalentTo(new[] {new Cluster<char>('A', 'B', 'C'), new Cluster<char>(Enumerable.Empty<char>(), true)}).Using(new ClusterEqualityComparer<char>())); }
public void Cluster_NoiseNotEmpty() { var matrix = new[, ] { { 0.00, 0.09, 0.22 }, { 0.09, 0.00, 0.30 }, { 0.22, 0.30, 0.00 } }; char[] objects = { 'A', 'B', 'C' }; var clusterer = new DbscanClusterer <char>(o1 => objects.Where(o2 => matrix[o1 - 'A', o2 - 'A'] <= 0.2), 2); Cluster <char>[] clusters = clusterer.GenerateClusters(objects).ToArray(); Assert.That(clusters, Is.EquivalentTo(new[] { new Cluster <char>('A', 'B'), new Cluster <char>(new[] { 'C' }, true) }).Using(new ClusterEqualityComparer <char>())); }
public void Cluster_AllObjectsInSameCluster() { var matrix = new[, ] { { 0.00, 0.09, 0.12 }, { 0.09, 0.00, 0.21 }, { 0.12, 0.21, 0.00 } }; char[] objects = { 'A', 'B', 'C' }; var clusterer = new DbscanClusterer <char>(o1 => objects.Where(o2 => matrix[o1 - 'A', o2 - 'A'] <= 0.2), 2); Cluster <char>[] clusters = clusterer.GenerateClusters(objects).ToArray(); Assert.That(clusters, Is.EquivalentTo(new[] { new Cluster <char>('A', 'B', 'C'), new Cluster <char>(Enumerable.Empty <char>(), true) }).Using(new ClusterEqualityComparer <char>())); }