This repository contains the code for the research paper "A Graph Diffusion Scheme for Decentralized Content Search based on Personalized PageRank", which was presented in the 2022 IEEE ICDCSW workshop.
Maintainers: Emmanouil (Manios) Krasanakis, Nikolaos (Nikos) Giatsoglou
License: Apache 2.0
Clone this repository and install dependencies with pip install -r requirements.txt
.
Then run one of the following scripts,
A simulation that verifies the convergence of the asynchronously diffused embeddings to their analytical counterparts. It justifies using the analytical embeddings in other simulations for significant speed-ups.
python -m simulations.check_ppr_convergence -a 0.5 -nd 1000 -ni 5 -tol 0.0000001 -d glove -g fb
-a
is the diffusion rate of the personalized PageRank scheme
-nd
is the number of documents to spread to the graph
-ni
is the number of convergence experiments to iterate (use a small number, they are slow!)
-tol
is the numerical tolerance at which the diffusion stops
-d
is the document dataset (currently only glove
is available)
-g
is the graph structure from fb
, gnutella
, internet
, toy_erdos
, toy_watts_strogatz
-me
is the maximum number of epochs to wait in one iteration for convergence (increase if convergence is slow)
-s
is the simulation seed
A simulation that computes the search hit rate of queries as a function of the hop distance between the query and the gold document.
python -m simulations.hit_rate_analysis -a 0.5 -nd 1000 -ni 500 -d glove -g fb -t 50
-a
is the diffusion rate of the personalized PageRank scheme
-nd
is the number of documents to spread to the graph
-ni
is the number of iterations to simulate through
-d
is the document dataset (currently only glove
is available)
-g
is the graph structure from fb
, gnutella
, internet
, toy_erdos
, toy_watts_strogatz
-t
is the time-to-live field of query messages
-s
is the simulation seed
A simulation that compares the hit rate performance for multiple diffusion rates (the alpha parameter of the personalized PageRank).
python -m simulations.hit_rate_analysis_many_alpha -a 0.1 0.5 0.9 -nd 1000 -ni 500 -d glove -g fb -t 50
-a
is a list of diffusion rates for the personalized PageRank scheme
-nd
is the number of documents to spread to the graph
-ni
is the number of iterations to simulate through
-d
is the document dataset (currently only glove
is available)
-g
is the graph structure from fb
, gnutella
, internet
, toy_erdos
, toy_watts_strogatz
-t
is the time-to-live field of query messages
-s
is the simulation seed
A simulation that computes descriptive statistics for the hop count of successful walks from the querying node until the node with the gold document.
python -m simulations.hop_count_analysis -a 0.5 -nd 1000 -nm 10 -ni 500 -d glove -g fb -t 50
-a
is the diffusion rate of the personalized PageRank scheme
-nd
is the number of documents to spread to the graph
-nm
is the number of messages per query to spread to the graph in one iteration
-ni
is the number of iterations to simulate through
-d
is the document dataset (currently only glove
is available)
-g
is the graph structure from fb
, gnutella
, internet
, toy_erdos
, toy_watts_strogatz
-t
is the time-to-live field of query messages
-s
is the simulation seed
The topic of our paper is decentralized search, which requires new algorithms as the calls for a decentralized Web are mounting. Indeed, the Web is now highly centralized, marked by the dominance of global-scale social media networks and platforms. It wasn't always like this though; in the 2000s, decentralized applications and peer-to-peer networks were popular with pioneers like Gnutella, BitTorrent, and Freenet. These applications have since fallen out of favor, partly, for technical reasons, as lack of coordination brings forth significant challenges. Resource discovery in particular forces queries to traverse the network based on limited knowledge of what resources are stored at each node. Distributed hash tables are more efficient and scalable but support search via identifiers at the expense of richer queries.
In this context, our work revisits the classic problem of decentralized search, giving it a fresh twist. Inspired by the emergence of graph signal processing and embedding-based retrieval, we propose a graph diffusion scheme based on the personalized PageRank algorithm for the nodes to advertise their stored resources to their peers in the form of dense vector representations, called embeddings. The diffused embeddings can then guide queries towards more promising nodes, increasing the efficiency of the search. This formulation is attractive as the diffused embeddings can be proven to converge to stable values even if the nodes operate asynchronously (see the p2pgnn work in the Acknowledgements), as is typical of peer-to-peer applications. The performance of our scheme is evaluated via the simulations contained in this repository.
Our code is written in Python, making extensive use of the numpy
and networkx
libraries to simulate an information retrieval application over a peer-to-peer network. It contains the following modules:
p2psearch.ir: Generates and loads an information retrieval dataset. For simplicity, the dataset is emulated through a careful selection of Glove word embeddings to create queries, documents, and judgements.
p2psearch.network: Loads a peer-to-peer network based on a selection of graph datasets. It abstracts the network and the nodes via the P2PNetwork
and Node
classes where the latter can be extended to support different node behaviors.
p2psearch.datatypes: Contains the main data objects of our simulation, namely the documents and the queries, abstracted by the Document
, Query
, QuerySearch
, and QueryMessage
classes. It is worth highlighting the difference between the 3 query classes, which can be a point of confusion. Query
represents a query sample from a dataset, QuerySearch
a search operation in the network, and QueryMessage
the actual messages that are passed among the nodes. This division allows the modeling of different search operations for the same query that bifurcate into multiple parallel walks.
simulations: Contains scripts for the experiments conducted in the paper receiving arguments via the argparse
interface. The Quickstart section describes how to run the scripts.
Experiments are described in the following paper, also available in Arxiv.
N. Giatsoglou, E. Krasanakis, S. Papadopoulos and I. Kompatsiaris,
"A Graph Diffusion Scheme for Decentralized Content Search based on Personalized PageRank,"
2022 IEEE 42nd International Conference on Distributed Computing Systems Workshops (ICDCSW), Bologna, Italy, 2022, pp. 53-59
EU project acknowledgements: AI4Media (GA 951911), MediaVerse (GA 957252) and HELIOS (GA 825585)
Proof of the convergence for the asynchronous graph diffusion:
E. Krasanakis, S. Papadopoulos, and I. Kompatsiaris,
“p2pgnn: A decentralized graph neural network for node classification in peer-to-peer networks,”
IEEE Access, vol. 10, pp. 34 755–34 765, 2022.
Glove dataset - available via https://nlp.stanford.edu/projects/glove/ and the Gensim library
Jeffrey Pennington, Richard Socher, and Christopher D. Manning. 2014. GloVe: Global Vectors for Word Representation.
Facebook combined ego graph - http://snap.stanford.edu/data/ego-Facebook.html
J. Leskovec en R. Sosič,
“SNAP: A General-Purpose Network Analysis and Graph-Mining Library”,
ACM Transactions on Intelligent Systems and Technology (TIST), vol 8, no 1, bl 1, 2016.