Skip to content

CUDA optimized version of Page Rank and Betweenness Centrality Algorithms, tested on large graphs (Facebook, etc.)

License

Notifications You must be signed in to change notification settings

Shubham-Sahoo/CUDA-Optimized-Centrality-Measure

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CUDA-Optimized-Centrality-Measure

Repository for the term project of Group 5 for the course on High Performance Parallel Programming (CS61064) 2021

The code is supposed to implement algorithms, namely Pagerank and Betweenness centrality, on large graphs

Betweenness Centrality

For executing the node centric Betweenness Centrality code, please follow the steps below :

  1. Navigate to the code location
cd /location_of_code
  1. Compile the code with nvcc
nvcc HP3_nodeCentricBC.cu -o node-centricBC
  1. Execute the code by giving the location of the csr formatted graph
./node-centricBC name-of-graph-csr.txt

For Executing work efficient and edge centric Betweenness Centrality code, please follow the steps below:

  1. Login to the Gmail Account with the following credentials: emailID: [email protected] password: 8thsemprojects
  2. Go to HP3 folder
  3. Go to Betweenness_Centrality folder
  4. Change Runtime type to GPU
  5. Open work_efficient.ipynb and click on Run All to run work efficient betweenness centrality code
  6. Open HP3_EdgeCentricBC_Group5.ipynb and click on Run All to run work efficient betweenness centrality code
  7. Please note in both 5 and 6, you need to mount the drive. All the folder hierarchies are already maintained.
  8. All the required packages have been already included in the .ipynb file
  9. This should be enough to run both the codes.

PageRank

  • Kernels

    • NodeCentric.h - kernel for pagerank calculation using NodeCentric approach
    • EdgeCentric_phase1.h - kernel-1 for pagerank calculation using EdgCentric approach
    • EdgeCentric_phase2.h - kernel-2 for pagerank calculation using EdgeCentric approach
    • EdgeCentric_phase1_optimized.h - optimized version of kernel-1 of EdgeCentric approach
  • Dataset

    • amazon.txt
    • facebook.txt
  • Profiling - profiling report of all the 4 kernels on amazon dataset

  • node_centric.cu - Host code for PageRank using NodeCentric approach

  • edge_centric.cu - Host code for PageRank using EdgeCentric approach

  • edge_centric_optimized.cu - Host code for WorkEfficient implementation of PageRank using EdgeCentric

  • steps to execute

    1. set the path to input file and output file in input_file[] & output_file[] array in main() function
    2. nvcc node_centric.cu -o rank.out
    3. ./rank.out

About

CUDA optimized version of Page Rank and Betweenness Centrality Algorithms, tested on large graphs (Facebook, etc.)

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 53.7%
  • Cuda 25.3%
  • C++ 17.5%
  • C 3.5%