This package provides an exact densest subgraph extractor, using an incremental parametric implementation of pseudoflow for minimum cut on directed graphs.
In the proxy parametric minimum cut problem, the capacity of source-adjacent arcs is monotone non-increasing in the parameter lambda
whereas the capacity of sink-adjacent arcs is monotone non-decreasing in lambda
.
This solver requires that the weights of the arcs and the nodes be positive.
This implementation follows the procedure as described in:
D. S. Hochbaum, “Flow is best, fast and scalable: The incremental parametric cut for maximum density and other ratio subgraph problems,” in The 16th International Joint Conference on Knowledge Discovery, Knowledge Engineering and Knowledge Management (KDIR 2024), Porto-Portugal, 17-19 November, 2024, Proceedings, 2024.
The latest version of this software is available on GitHub. It can also be downloaded by clicking on the next link: [Incremental-parametric-hpf-for-densest-subgraph]
A makefile is provided. To compile the incremental
executable, use:
mkdir bin
make
The executable reads the input file from stdin. To execute one of the examples, use:
./bin/incremental < examples/example_unweighted.txt
--help
: Print a help message
--accuracy N
: Set the accuracy of the density to N decimal places. Note that a value of N too high may produce errors, especially on big graphs or graphs with big weights. By default, 4 decimal places are used.
--injectLambda L
: Start the incremental procedure with density L. Note that a value of L larger than the optimal may produce errors.
--weightedEdges
: Use this option if the edges have non-unitary benefits.
--weightedNodes
: Use this option if the nodes have non-unitary costs.
--dumpSourceSet FILE
: Dump the list of nodes that are in the optimal solution to FILE.
The input graph, with N nodes and M edges, is to be provided in the following text format:
N M
[WEIGHT_NODE_1]
[WEIGHT_NODE_2]
...
[WEIGHT_NODE_N]
FROM_EDGE_1 TO_EDGE_1 [WEIGHT_EDGE_1]
FROM_EDGE_2 TO_EDGE_2 [WEIGHT_EDGE_2]
...
FROM_EDGE_M TO_EDGE_M [WEIGHT_EDGE_M]
Remember that if the graph is weighted, option --weightedEdges
must be used if the edges have weights (non-unitary benefits) and --weightedNodes
if the nodes have weights (non-unitary costs).
See directory examples for sample input files.
The source code is subject to the following academic license. Note that this is not an open source license.
Copyright © 2024. The Regents of the University of California (Regents). All Rights Reserved.
Permission to use, copy, modify, and distribute this software and its documentation for educational, research, and not-for-profit purposes, without fee and without a signed licensing agreement, is hereby granted, provided that the above copyright notice, this paragraph and the following two paragraphs appear in all copies, modifications, and distributions. Contact The Office of Technology Licensing, UC Berkeley, 2150 Shattuck Avenue, Suite 510, Berkeley, CA 94720-1620, (510) 643-7201, for commercial licensing opportunities. Created by Quico Spaen and Dorit S. Hochbaum, Department of Industrial Engineering and Operations Research, University of California, Berkeley. This work is adapted from the Pseudoflow implementation by Bala Chandran and Dorit S. Hochbaum available at https://riot.ieor.berkeley.edu/Applications/Pseudoflow/maxflow.html
IN NO EVENT SHALL REGENTS BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF REGENTS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
REGENTS SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE AND ACCOMPANYING DOCUMENTATION, IF ANY, PROVIDED HEREUNDER IS PROVIDED “AS IS”. REGENTS HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.