skmultilearn.cluster.IGraphLabelGraphClusterer(graph_builder, method)[source] ¶ Bases: skmultilearn.cluster.base.LabelGraphClustererBase
Clusters the label space using igraph community detection methods
This clusterer constructs an igraph representation of the Label Graph generated by graph builder and detects communities in it using community detection methods from the igraph library. Detected communities are converted to a label space clustering. The approach has been described in this paper concerning data-driven label space division.
| Parameters: |
|
|---|
graph_¶ the igraph Graph object containing the graph representation of graph builder’s adjacency matrix and weights
| Type: | igraph.Graph |
|---|
weights_¶ edge weights stored in a format recognizable by the igraph module
| Type: | { ‘weight’ : list of values in edge order of graph edges } |
|---|
Note
This clusterer is GPL-licenced and will taint your code with GPL restrictions.
References
If you use this clusterer please cite the igraph paper and the clustering paper:
@Article{igraph, title = {The igraph software package for complex network research}, author = {Gabor Csardi and Tamas Nepusz}, journal = {InterJournal}, volume = {Complex Systems}, pages = {1695}, year = {2006}, url = {http://igraph.org}, } @Article{datadriven, author = {Szymański, Piotr and Kajdanowicz, Tomasz and Kersting, Kristian}, title = {How Is a Data-Driven Approach Better than Random Choice in Label Space Division for Multi-Label Classification?}, journal = {Entropy}, volume = {18}, year = {2016}, number = {8}, article_number = {282}, url = {http://www.mdpi.com/1099-4300/18/8/282}, issn = {1099-4300}, doi = {10.3390/e18080282} }
Examples
An example code for using this clusterer with a classifier looks like this:
from sklearn.ensemble import RandomForestClassifier from skmultilearn.problem_transform import LabelPowerset from skmultilearn.cluster import IGraphLabelGraphClusterer, LabelCooccurrenceGraphBuilder from skmultilearn.ensemble import LabelSpacePartitioningClassifier # construct base forest classifier base_classifier = RandomForestClassifier(n_estimators=1000) # construct a graph builder that will include # label relations weighted by how many times they # co-occurred in the data, without self-edges graph_builder = LabelCooccurrenceGraphBuilder( weighted = True, include_self_edges = False ) # setup problem transformation approach with sparse matrices for random forest problem_transform_classifier = LabelPowerset(classifier=base_classifier, require_dense=[False, False]) # setup the clusterer to use, we selected the fast greedy modularity-maximization approach clusterer = IGraphLabelGraphClusterer(graph_builder=graph_builder, method='fastgreedy') # setup the ensemble metaclassifier classifier = LabelSpacePartitioningClassifier(problem_transform_classifier, clusterer) # train classifier.fit(X_train, y_train) # predict predictions = classifier.predict(X_test)
For more use cases see the label relations exploration guide.
fit_predict(X, y)[source] ¶ Performs clustering on y and returns list of label lists
Builds a label graph using the provided graph builder’s transform method on y and then detects communities using the selected method.
Sets self.weights_ and self.graph_.
| Parameters: |
|
|---|---|
| Returns: | label space division, each sublist represents labels that are in that community |
| Return type: | arrray of arrays of label indexes (numpy.ndarray) |