Space of Optimal Solutions of the Correlation Clustering Problem
- Copyright 2020-21 Nejat Arınık
Sosocc 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. For source availability and license information see the file LICENCE
- Lab site: http://lia.univ-avignon.fr/
- GitHub repo: https://github.com/CompNet/Sosocc
- Contact: Nejat Arınık arinik9@gmail.com, Vincent Labatut vincent.labatut@univ-avignon.fr
This set of R
scripts was designed to analyze the space of Optimal Solutions of the Correlation Clustering Problem. When solving an instance of such problem, several or even many optimal solutions (i.e. partitions) may coexist. If multiple optimal partitions coexist, one can then wonder how different/diverse they are. Put differently, we want to know what we loose when considering only one solution, while there might be multiple ones. In order to answer these questions, one should ideally enumerate completely the space of optimal solutions, and perform its analysis. To this end, we propose a new efficient solution space enumeration method and a cluster analysis-based framework in order to first enumerate the space of optimal partitions and then empirically study such space.
In this repository, we are able to run three exact partitioning methods for the CC problem:
- ExCC: It is a method aiming to obtain a single optimal solution. Its source code is found on the ExCC repository. It first employs a root relaxation phase, where we add violated valid inequalities through Cutting Plane method, then it proceeds to the branching phase. Use
get.ExCC.code(enum.all=FALSE)
in the code. - OneTreeCC (also called ExCC-all): It is a solution space enumeration method incorprated in the commercial solver CPLEX. Its source code is found on the ExCC repository. This two-step method first build and explore the search tree, i.e. B&B tree, in order to find efficiently the first optimal solution, then enumerate all the other optimal solutions based on the same tree. Use
get.ExCC.code(enum.all=TRUE)
in the code. - EnumCC: It is a solution space enumeration method that we propose in [Arınık'23]. Its source code is found on the EnumCC repository. It takes in input a distance parameter
r_{max}
to explore the neighborhoof of an optimal solution. In our experiments, we have shown that it is more convenient to setr_{max}=3
in general. Useget.EnumCC.code(maxNbEdit=3)
in the code. Note that you need to runExCC
before callingEnumCC
, since the latter needs an already-found optimal solution.
If you use this software or the assocated data, please cite reference [Arınık'20]:
@Article{Arinik2020,
author = {Arınık, Nejat and Figueiredo, Rosa and Labatut, Vincent},
title = {Multiplicity and Diversity: Analyzing the Optimal Solution Space of the Correlation Clustering Problem on Complete Signed Graphs},
journal = {Journal of Complex Networks},
year = {2020},
volume = {8},
number = {6},
pages = {cnaa025},
doi = {10.1093/comnet/cnaa025},
}
Our tool is applied to a set of signed networks generated thanks to our signed graph generator, available on the SignedBenchmark repository. The details about the generator are explained here. You may consider downloading our generated signed graphs associated with our article [Arınık'20], which are in the folder Input Signed Networks.tar.gz
on Zenodo. The advantage of dowloading our data is that we also provide you with the optimal solutions for each signed network (in the folder All Partitions Results.tar.gz
on Zenodo.
Moreover, You may also consider downloading our second set of generated signed graphs (both complete and incomplete signed graphs) associated with our article [Arınık'23] on another Zenodo repository.
To show explicitly the folder structure used in the signed graph generation and for a quick test, we have already put some generated networks in in/random-networks
and some corresponding optimal partitions in out/partitions
.
Here are the folders composing the project:
- Folder
src
: contains the source code (R scripts). - Folder
in
: contains the generated signed networks. - Folder
lib
: contains executable files related to the used external partitioning methods.- Folder
ExCC
: Executable file of the methodExCC
whose the name will becplex-partition.jar
. See the Installation section for more details.
- Folder
- Folder
out
: contains the folders and files produced by our scripts. See the Use section for more details.
- Install the
R
language - Install the following R packages:
- Install
IBM CPlex
. Tested with the versions 12.8 and 20.1. Set correctly the variableCPLEX.BIN.PATH
indefine-algos.R
(e.g./opt/ibm/ILOG/CPLEX_Studio128/cplex/bin/x86-64_linux/
).- For ubuntu, type the following command:
sudo ./cplex_studio<YOUR_VERSION>.linux-x86-64.bin
- The default installation location for education version is:
/opt/ibm/ILOG/CPLEX_Studio<YOUR_VERSION
. - The default installation location for trial version is:
/opt/ibm/ILOG/CPLEX_Studio_Community<YOUR_VERSION/cplex/bin/x86-64_linux/
.
- The default installation location for education version is:
- For ubuntu, type the following command:
- Download the project of
ExCC
on GitHub. First, configure and then compile it. To test it, you can run the filerun.sh
.If everything works (i.e. if a filesol0.txt
created in the output folder), move the executable fileExCC.jar
, which is inexe
, into thelib/ExCC
folder in this project. - Download the project of
EnumCC
on GitHub. Move the executable filesClusteringEditDist.jar
into the libfolder
in this project. This jar file allows to compute the edit distance between membership vectors. - Download the signed networks on Zenodo or generate your own signed networks based on our SignedBenchmark.
- Set correctly the variables
CPLEX.BIN.PATH
. - Open the
R
console. - Set the current directory as the working directory, using
setwd("<my directory>")
. - Run the main script
src/main.R
.
The script will produce the following subfolders in the folder out
:
partitions
: Folder containing all obtained partitions. Note that we prefer to use the term module in the same sense of cluster in this level in order to distinguish it from the term cluster used in k-medoids clustering analysis.n=<GRAPH_SIZE>_l0=<NB_INIT_MODULES>_dens=<DENSITY>
: A subfolder for specific values of graph size, number of initial modules in the network and density.propMispl=<PROP_MISPL>
: A subfolder for a specific value of proportion of misplaced links, which is used for signed network generation.propNeg=<PROP_NEG>
: A subfolder for a specific value of proportion of negative linksnetwork=<NETWORK_ID>
: A subfolder for a specific value of network id (for replication pruposes).<CC_ALGO_NAME>
: A subfolder for a specific partitioning method solving the CC problem.<GRAPH_TYPE>
: A subfolder for a specific network type, e.g.signed_unweighted
. The distinction of this level is actually useless for now.
evaluate-partitions
: Folder containing all results in csv format.n=<GRAPH_SIZE>_l0=<NB_INIT_MODULES>_dens=<DENSITY>
: A subfolder for specific values of graph size, number of initial modules in the network and density.propMispl=<PROP_MISPL>
: A subfolder for a specific value of proportion of misplaced links, which is used for signed network generation.propNeg=<PROP_NEG>
: A subfolder for a specific value of proportion of negative links<K_DESC>
: This folder is used to distinguish two cases: 1) All, 2)k=<K_VALUE>-<COMP_MEASURE>
. The former exists for the case where the notion of solution classs is not considered. In the latter, the networks are reorganized based on the detected number of solution classes. This is convenient to see and plot the results.network=<NETWORK_ID>
: A subfolder for a specific value of network id (for replication pruposes).<CC_ALGO_NAME>
: A subfolder for a specific partitioning method solving the CC problem.<GRAPH_TYPE>
: A subfolder for a specific network type, e.g.signed_unweighted
. The distinction of this level is actually useless for now.
detectedImbalance=<IMB_PROP_INTERVAL>
: This folder allows to regroup the networks for a specific interval of detected imbalance (e.g. 0.05-0.1). This is different frompropMispl
. In other words, this folder does not contain new information compared topropMispl=<PROP_MISPL>
, it is just a reorganization of results by a different aspect. This is convenient to see and plot the results.propNeg=<PROP_NEG>
: A subfolder for a specific value of proportion of negative links.<K_DESC>
: This folder is used to distinguish two cases: 1) All, 2)k=<K_VALUE>-<COMP_MEASURE>
. The former exists for the case where the notion of solution classs is not considered. In the latter, the networks are reorganized based on the detected number of solution classes. This is convenient to see and plot the results.network=<NETWORK_ID>
: A subfolder for a specific value of network id (for replication pruposes). Note that, network ids might be differant than those inpropMispl=<PROP_MISPL>
. So, they are renumbered.<CC_ALGO_NAME>
: A subfolder for a specific partitioning method solving the CC problem.<GRAPH_TYPE>
: A subfolder for a specific network type, e.g.signed_unweighted
. The distinction of this level is actually useless for now.
cluster-analysis
: Folder containing the results related to k-medoids clustering analysis.n=<GRAPH_SIZE>_l0=<NB_INIT_MODULES>_dens=<DENSITY>
: A subfolder for specific values of graph size, number of initial modules in the network and density.propMispl=<PROP_MISPL>
: A subfolder for a specific value of proportion of misplaced links, which is used for signed network generation.propNeg=<PROP_NEG>
: A subfolder for a specific value of proportion of negative linksnetwork=<NETWORK_ID>
: A subfolder for a specific value of network id (for replication pruposes).<CC_ALGO_NAME>
: A subfolder for a specific partitioning method solving the CC problem.<GRAPH_TYPE>
: A subfolder for a specific network type, e.g.signed_unweighted
. The distinction of this level is actually useless for now.<COMP_MEASURE>
: A subfolder for a specific value of external comparison measure, e.g.NMI
k=<K_VALUE>-sil=<SILHOUETTE_SCORE>
: A subfolder containing the results of the k-medoids clustering result for a specific value ofk
, wherek
is the desired number of solution classes.clu<SOLUTION_CLASS_ID>
: In this subfolder(s) the partition files related to a given signed network are divided intok
folders. We create those subfolder(s) only for the value ofk
which is associated with the best silhouette score.
cluster-characterization
: Folder containing the results related tocluster characterization process. 1) core part, 2) representativen=<GRAPH_SIZE>_l0=<NB_INIT_MODULES>_dens=<DENSITY>
: A subfolder for specific values of graph size, number of initial modules in the network and density.propMispl=<PROP_MISPL>
: A subfolder for a specific value of proportion of misplaced links, which is used for signed network generation.propNeg=<PROP_NEG>
: A subfolder for a specific value of proportion of negative linksnetwork=<NETWORK_ID>
: A subfolder for a specific value of network id (for replication pruposes).<CC_ALGO_NAME>
: A subfolder for a specific partitioning method solving the CC problem.<GRAPH_TYPE>
: A subfolder for a specific network type, e.g.signed_unweighted
. The distinctin of this level is actually useless for now.<COMP_MEASURE>
: A subfolder for a specific value of external comparison measure, e.g.NMI
k=<K_VALUE>-sil=<SILHOUETTE_SCORE>
: A subfolder containing the results of the k-medoids clustering result for a specific value ofk
, wherek
is the desired number of solution classes. Note that Silhouette is not defined fork=1
andk=n
.core-part=<CORE_PART_THRESHOLD>
: In this subfolder, the core part of each solution class, as well as all the partitions, are shown. Our definition of core part depends onCORE_PART_THRESHOLD
. If this value equals 1, this means that the core part of a solution class consists of being groups of nodes that are always together over all considered partitions. Actually, this value should be always 1 if one wants to have only a single core part structure.representative-partitions
: In this subfolder, the optimal partitions that are considered representative for each solution class are found. By representative, we mean the partition which is most similar to others in the same solution class. Additionnaly, we place in this folder the presentative partition of all the partitions. Note that, even though there are multiple candidates to satisfy our definition of representative, we keep only a single one (but this is rare)
layout-plots
: The subfolder hierarchy is similar to the previous folders. This folder will contain the plots of type layout, i.e. each plot contains several subplots corresponding to an input parameter, and each subplot is divided into multiple parts corresponding to different values of a second input parameter. Therefore, in each plot file, two input parameters are investigated, the other parameters are fixed. Note that we also make distinction of two cnocepts: 1) single network layout plot, and 2) summary network layout plot. In the former, each network is treated separately. Although this is good to plot, what is most interesting is the latter, which corresponds to a combination of all networks under the same input parameter set.output-csv-data
: Some results are recorded in csv format (e.g. number of optimal solutions per network).
- [Arınık'20] N. Arınık & R. Figueiredo & V. Labatut. Multiplicity and Diversity: Analyzing the Optimal Solution Space of the Correlation Clustering Problem, Journal of Complex Networks, 8(6):cnaa025, 2020. DOI: https://doi.org/10.1093/comnet/cnaa025 ⟨hal-02994011⟩
- [Arınık'23] N. Arınık & R. Figueiredo & V. Labatut. Efficient Enumeration of the Optimal Solutions to the Correlation Clustering problem, Journal of Global Optmization 86:355-391, 2023. DOI: 10.1007/s10898-023-01270-3 ⟨hal-03935831⟩