Final project for jhuan35, nrking2, ep7, and av13. For this project we created algorithms to analyze web graphs from the Stanford Large Network Dataset Collection. Our data set is in a text file that can be viewed in the directory labeled "/data". Additionally our main project code can be found in three main directories. The header files are in the "/include" directory. Our source files are in the "/src" directory. Finally, our test files are in the "/test" directory. There is additionally, our "main.cpp" file on the top-level of the project. All output of this projects puts results directly into the console.
Link to presentation: https://youtu.be/HVypn0YL5H0
This project uses cmake to create a makefile and install catch2. Use the following commands to build and run the project:
- cd build
- cmake ..(need to use cmake3 instead if on EWS)
- make(additionally, you may use- make testor- make mainto make either executable individually)
- ./main
Please make sure to run any commands related to running the project within the build folder. Additionally, make sure to uncomment the correct lines from main in regards to file path when reading in the graph data.
Currently main will ingest the web graph from and run our algorithms on them. There are commented out lines to print more in-depth information that you can uncomment if you would like to print out the nodes of the graph or all of the connected components of the graph.
- g++ src/graph.cc src/connected-component.cc ./main.cpp -o main -std=c++11
- ./main
Note: Unfortunately, you will not be able to run the testing suite without cmake as cmake is used to install the catch2 dependency.
We have designed our Graph class to ingest graph data from text files. The data must be in the following format. Each line of the file is a node. The first character of the line is a number which is the location of the source node. Then there must be at least one space (there can be more than one space or a tab) then the destination node location is the second number on the line. For an example of this format, you can view datasets in our data folder.
To run the testing suite, follow the same instructions as above to build the make files, then simply run:
- cd build
- make test
- ./test
Results of tests should directly be shown in the console.