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
For executing the node centric Betweenness Centrality code, please follow the steps below :
- Navigate to the code location
cd /location_of_code
- Compile the code with nvcc
nvcc HP3_nodeCentricBC.cu -o node-centricBC
- 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:
- Login to the Gmail Account with the following credentials: emailID: eightsemprojects@gmail.com password: 8thsemprojects
- Go to HP3 folder
- Go to Betweenness_Centrality folder
- Change Runtime type to GPU
- Open work_efficient.ipynb and click on Run All to run work efficient betweenness centrality code
- Open HP3_EdgeCentricBC_Group5.ipynb and click on Run All to run work efficient betweenness centrality code
- Please note in both 5 and 6, you need to mount the drive. All the folder hierarchies are already maintained.
- All the required packages have been already included in the .ipynb file
- This should be enough to run both the codes.
-
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
-
- set the path to input file and output file in
input_file[]
&output_file[]
array inmain()
function nvcc node_centric.cu -o rank.out
./rank.out
- set the path to input file and output file in