Skip to content

Non-Sampling Knowledge Graph Embedding

Notifications You must be signed in to change notification settings

HELL-TO-HEAVEN/NS-KGE

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Efficient Non-Sampling Knowledge Graph Embedding

If you use the code, please cite our paper:

 @inproceedings{li2021efficient,
   title={Efficient Non-Sampling Knowledge Graph Embedding},
   author={Li, Zelong and Ji, Jianchao and Fu, Zuohui and Ge, Yingqiang and Xu, Shuyuan and Chen, Chong and Zhang, Yongfeng},
   booktitle={Proceedings of the the Web Conference 2021},
   year={2021}
 }

and the following paper

 @inproceedings{han2018openke,
   title={OpenKE: An Open Toolkit for Knowledge Embedding},
   author={Han, Xu and Cao, Shulin and Lv Xin and Lin, Yankai and Liu, Zhiyuan and Sun, Maosong and Li, Juanzi},
   booktitle={Proceedings of EMNLP},
   year={2018}
 }

This package is mainly contributed by Zelong Li, Jianchao Ji, Yongfeng Zhang.

Overview

This is the implementation of the framework mentioned in our paper, Efficient Non-Sampling Knowledge Graph Embedding. Some parts of our work are based on the PyTorch version of OpenKE, which is an open source framework for Knowledge Embedding implemented with PyTorch.

We apply our framework to four embedded models, DistMult, SimplE, ComplEx, and TransE. The experimental results show that, compared with the model based on negative sampling, the model based on non-sampling has much higher training speed and better or competitive performance.

Parameter settings

  • Dataset: FB15K237, WN18RR
  • train_time: 2000
  • alpha: 0.0001
  • coefficient of regularization: [0.1, 0.01, 0.001, 0.0001]
  • weight_decay: [0.1, 0.3, 0.5, 0.7]
  • dim: 200
  • pos_para (i.e,, c+): 1
  • neg_para (i.e., c-): [0.1, 0.01, 0.001, 0.0001, 0.00001, 0.000001]

Models

Models Based on Negative Sampling (OpenKE, PyTorch):

  • RESCAL
  • DistMult, ComplEx, Analogy
  • TransE, TransH, TransR, TransD
  • SimplE
  • RotatE

Models Based on Non-Sampling (NS):

  • DistMult, SimplE, ComplEx, TransE

We welcome any issues and requests for model implementation and bug fix.

Installation

To run the model based on negative sampling, please follow the installation of OpenKE.

  1. Install PyTorch

  2. Clone the project:

git clone OpenKE-PyTorch https://github.com/rutgerswiselab/NS-KGE
cd Non-sampling-KB-embedding
cd openke
  1. Compile C++ files
bash make.sh
  1. Quick Start
cd ../
cp examples/train_NS_transe_FB15K237.py ./
python train_NS_transe_FB15K237.py

Experiments

We have provided the state-of-the-art performace (Hits@10 (filter)) on FB15K237 and WN18RR.

Model FB15K237 WN18RR
DistMult 0.345 0.461
NS-DistMult 0.373 0.462
SimplE 0.355 0.463
NS-SimplE 0.370 0.459
ComplEx 0.415 0.474
NS-ComplEx 0.390 0.485
TransE 0.316 0.145
NS-TransE 0.447 0.437

We are still trying more hyper-parameters and more training strategies for knowledge graph models. Hence, this table is still in change. We welcome everyone to help us update this table and hyper-parameters.

About

Non-Sampling Knowledge Graph Embedding

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 72.9%
  • C 14.1%
  • C++ 12.9%
  • Shell 0.1%