Skip to content

yanxinzhangcs/Top-r-Influential-Community-Search-in-Bipartite-Graphs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Top-R Influential Community Search in Bipartite Graph

This repository provides the implementation of multiple algorithms for finding the top-r influential communities in a bipartite graph. The code includes both accurate and approximate solutions, using different methods to enhance efficiency and accuracy. Below is a structured overview of the project.

Paper Link: https://arxiv.org/abs/2412.06216

Project Structure

TopRInfluentialCommunity/

├── all_mains/
│ ├── main.cpp # Naive solution
│ ├── main_bound.cpp # Naive solution + Upper Bound
│ ├── main_fit.cpp # Naive solution + SlimTree
│ └── main_fit_bound.cpp # Combination of all advanced methods

├── include/ # Header files for data structures used in bipartite graph implementation
│ └── …

├── src/ # Source files for core graph functionality
│ └── …

├── New_framework_beta.cpp # Approximate solution with optimizations
├── newframeworks.cpp # Approximate solution using naive method
└── README.md # Project documentation (you’re reading this!)

Overview Diagram

QQ_1728232914648

Contents

1. Accurate Methods (all_mains/)

This folder contains four different codes, each designed to solve the problem with increasing efficiency and complexity. Each file in this folder employs a specific combination of advanced methods:

  • main.cpp: Implements the naive solution for finding the top-r influential community in the bipartite graph.
  • main_bound.cpp: Enhances the naive method by adding an upper bound to improve the search efficiency.
  • main_fit.cpp: Combines the naive method with the SlimTree technique to efficiently prune the solution space.
  • main_fit_bound.cpp: A combination of all the above advanced methods, including naive, upper bound, and SlimTree optimizations, to provide a comprehensive and accurate solution.

2. Graph Data Structure (include/ and src/)

  • The include/ folder contains the header files, while the src/ folder includes the source code files that provide the data structures needed to represent and work with bipartite graphs.
  • These components abstract the internal representation and operations related to the bipartite graph, such as adding nodes, edges, and maintaining graph properties.

3. Approximate Methods

These files provide approximate solutions for faster but less precise results:

  • newframeworks.cpp: Implements an approximate solution using a naive approach for finding the influential community.
  • New_framework_beta.cpp: An advanced version of newframeworks.cpp, this file employs additional optimization techniques to provide approximate results more efficiently.

How to Use

  1. Accurate Search:

    • For accurate results, use the codes in the all_mains/ folder.
    • The simplest approach can be found in main.cpp, while the most optimized one is in main_fit_bound.cpp.
  2. Approximate Search:

    • For faster, approximate results, you can use either newframeworks.cpp (naive approach) or New_framework_beta.cpp (optimized approach).

In our experiments, we use 10 real-world datasets, which can be found in KONECT (http://konect.cc/).

Contact Information

[email protected]

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages