Skip to content

Latest commit

 

History

History
56 lines (43 loc) · 2.32 KB

README.md

File metadata and controls

56 lines (43 loc) · 2.32 KB

reveal-graph-embedding

Implementation of community-based graph embedding for user classification.

Features

  • Graph-based, multi-label user classification experiment demo.
  • Implementation of the ARCTE (Absorbing Regularized Commute Times Embedding) algorithm for graph-based feature extraction.
  • Implementation of other feature extraction methods for graphs (Laplacian Eigenmaps, Louvain, MROC).
  • Evaluation score and time benchmarks.

Install

Required packages

  • numpy
  • scipy
  • h5py
  • scikit-learn
  • Cython
  • networkx
  • python-louvain

Installation

To install for all users on Unix/Linux:

python3.4 setup.py build
sudo python3.4 setup.py install

User Classification Experiments

Get datasets

  • SNOW2014Graph dataset: Included anonymized in this project.
  • The Arizona State University social computing data repository contains the ASU-Flickr and ASU-YouTube datasets.
  • The Insight Project Resources repository contains the Multiview datasets in which the PoliticsUK dataset can be found.

Feature extraction methods

User classification comparative study results

Experiments demo

  • Follow instructions on file: reveal_graph_embedding/experiments/demo.py

ARCTE algorithm

  • If you installed the package, you will have an installed script called arcte.
  • The source is located in reveal_graph_embedding/entry_points/arcte.py

Citation

If you find this code useful and use it in your research, please acknowledge its use and cite the following paper: Rizos, G., Papadopoulos, S., & Kompatsiaris, Y. (2017). Multilabel user classification using the community structure of online networks. PloS one, 12(3), e0173347.