Skip to content
/ apro Public

Java Affinity Propagation Library // Parallelized

License

Notifications You must be signed in to change notification settings

lovro-i/apro

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

APRO

Java Affinity Propagation Library // Parallelized

v1.0.6
http://www.apro.u-psud.fr

Apro is a Java implementation of Affinity Propagation clustering algorithm. It is parallelized for easy and efficient use on multicore processors and NUMA architectures (using libnuma native library). It mainly targets dense similarity matrices. Besides the basic (parallelized) algorithm, it also implements Hierarchical Affinity Propagation (HiAP), making it usable in practice even on huge datasets. Apro comes with a couple of ready to use datasource providers (for Delimiter Separated Values, MATLAB files, etc.).

1. About Affinity Propagation

Affinity Propagation (AP) is a clustering algorithm based on the concept of "message passing" between data points. Unlike clustering algorithms such as k-means or k-medoids, AP does not require the number of clusters to be determined or estimated before running the algorithm. AP finds "exemplars", members of the input set that are representative of clusters.

More about Affinity Propagation:

Hierarchical Affinity Propagation

Hierarchical AP (HiAP) solves large-scale clustering problem. It uses AP and Weighted AP (WAP) in the Divide-and-Conquer schema. It partitions the dataset, runs AP on each subset, and applies WAP to the collection of exemplars constructed from each subset. HiAP was shown to significantly decrease the computational cost (from quadratic to quasi-linear), with minimal distortion.

WAP integrates the neighboring points together and keeps spatial structure between them and other points. It makes sure that the clustering results of WAP on integrated points are equal to that of AP on non-integrated points.

  • Scaling analysis of affinity propagation. Cyril Furtlehner, Michèle Sebag, and Xiangliang Zhang. Phys. Rev. E 81, 066102 – Published 1 June 2010
  • Data Stream Clustering with Affinity Propagation. Xiangliang Zhang, Cyril Furtlehner, Cécile Germain-Renaud, Michèle Sebag. IEEE Transaction on Knowledge and Data Engineering

2. Apro Java Library

Apro is a Java implementation of Affinity Propagation clustering algorithm. It is efficiently parallelized for use on multicore processors and NUMA architectures (using libnuma native library), offering a simple API for easy use in your projects.

Main features of Apro

  • Basic parallelized version of AP (package fr.lri.tao.apro.ap)
  • Hierarchical Affinity Propagation (package fr.lri.tao.apro.hiap)
  • Data providers for different input formats (package fr.lri.tao.apro.data)
  • Builder classes for easy setting of running and input parameters (classes AproBuilder and HiAPBuilder). Comprehensive API of these classes allows you to set parallelization and NUMA parameters yourself, or let the builder set the parameters automatically. Builder's .build() method provides you a ready-to-use Apro class.

Used libraries

3. Getting Started

Here are step-by-step instructions how to run your first Apro example.

  1. Clone this project, and include Apro.jar and other required (and provided) .jars into your project.

  2. Download a sample dataset. You can start with FaceVideo dataset (9.5 MB, .mat format). More datasets are available here.

  3. Let's begin coding. First, we use MATLABProvider to load the similarity matrix and preferences from the MATLAB file. This particular example contains the structure with similarity matrix named S, but with zero main diagonal (preferences). Preferences should be set to the value that is contained separately in the structure, named pref:

File faceVideoFile = new File("/path/to/FaceVideo.mat");
MATLABProvider provider = new MATLABProvider(faceVideoFile, "S", "pref");
  1. Now that we have the input data, we need to create the object that will perform the Affinity Propagation algorithm. We can either construct an object of class fr.lri.tao.apro.ap.Apro directly, using its constructors, or use AproBuilder class from the same package as a helper class:
AproBuilder builder = new AproBuilder();      
Apro apro = builder.build(provider);

By default, AproBuilder will automatically set the number of threads to the number of available processors, and will not use NUMA unless you specify so. You can find more advanced examples in the next section.

  1. Now we execute the desired number of iterations:
apro.run(100);
  1. Finally, we get the clustering results from the Apro object:
int myExemplar = apro.getExemplar(42);

Method int Apro.getExemplar(int node) returns the 'representative' node (exemplar) of the node specified as a parameter. Nodes having the same exemplar are considered to be in the same cluster. You can also get the whole set of clustering results using methods Apro.getExemplars(), which returns the array of exemplars for all nodes, or Apro.getExemplarSet() to get the Set of exemplars. These methods are actually members of Apro's superclass AbstractApro, which provides some common code that can be used for other AP implementations if needed.

4. More Examples

4.1 Load Delimiter Separated Values

In the Preferences file, each line contains the preference of the corresponding node. The number of lines defines the number of nodes.

In the Similarities file, each line contains three delimiter separated values: node1, node2, similarity.

Default delimiters are comma, semicolon, tab and space, but you can provide your own custom string of delimiter characters in the DSVProvider constructor.

File preferences = new File("/path/to/preferences.csv");
File similarities = new File("/path/to/similarities.csv");
DSVProvider provider = new DSVProvider(preferences, similarities);    

4.2 Provide custom similarity matrix

If you want to use your own similarity matrix (with preferences on the main diagonal), you can just wrap it up using MatrixProvider.

double[][] s = new double[3][3];
s[0][0] = s[0][2] = s[2][0] = s[2][1] = 3;
s[0][1] = s[1][0] = 20;
s[1][1] = 7;
s[1][2] = s[2][2] = 15;

DataProvider provider = new MatrixProvider(s);

4.3 Specify the number of threads

By default, AproBuilder automatically detects the available number of processors (cores), and sets the threadCount to it. In certain cases, you may want to specify it yourself, using AproBuilder.setThreads(int threadCount), or use the detected value, as by default (AproBuilder.setThreadsAuto()).

AproBuilder builder = new AproBuilder();
builder.setThreads(1); // no parallelization
Apro apro = builder.build(provider);      

4.4 Specify NUMA parameters

By default, using NUMA library for thread management is switched off. You can either:

  • Manually set NUMA parameters by using AproBuilder.setNuma(Integer numNodes, Integer coresPerNode, Integer startNode), where numNodes is the number of NUMA nodes to be used, coresPerNode the number of threads on run on each node, and startNode is the NUMA node on which to start allocating threads. Specifying null for numNodes or coresPerNode autodetects the maximum value. Specifying null as the startNode, starts creating threads from the currently used node.
  • Automatically set NUMA parameters by calling AproBuilder.setNumaAuto(), which is the same as calling AproBuilder.setNuma(null, null, null).
  • Use full auto, where AproBuilder.setFullAuto() decides both NUMA parameters and the maximum number of threads.
  • Turn off using NUMA with AproBuilder.setNumaOff().
AproBuilder builder = new AproBuilder();
builder.setFullAuto(); // use all the available processors
Apro apro = builder.build(provider); 

4.5 Hierarchical Affinity Propagation

HiAP requires that similarity between any two nodes (points) can be calculated. The only DataProvider that HiAP currently supports is PointsProvider which for each line in the specified file creates a Point object with read numerical features (delimiter separated values). You can also specify a custom SimilarityMeasure between points (the default similarity is the negative squared Euclidean distance between points).

PointsProvider provider = new PointsProvider(new File("/path/to/points.csv"));

HiAPBuilder builder = new HiAPBuilder();
builder.setNumaAuto();
builder.setSplits(5); // specify the number of data partitions
builder.setWorkerIters(100); // set the number of iterations for the first-level AP
builder.setWAPIters(100); // set the number of iterations for the second-level AP

HiAP hiap = builder.build(provider);
hiap.run();
Point exemplar = hiap.getExemplar(5); // get the exemplar of the point with id 5

5. Contact

Lovro Ilijašić
[email protected]
http://lovroforsale.com

6. Acknowledgements

Apro library was implemented by Apprentissage & Optimisation Team (TAO) at the Laboratoire de Recherche en Informatique (LRI) at Paris, Saclay (France).

This work has been partially funded by the Région Île-de-France in the frame of the French cooperative project TIMCO, Pôle de Compétitivité Systematic (FUI 13).

For any information, comment or error report, you can contact Lovro Ilijašić, who implemented this library in collaboration with Cécile Germain, Xiangliang Zhang and Joël Falcou.

About

Java Affinity Propagation Library // Parallelized

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages