Skip to content

Latest commit

 

History

History
91 lines (69 loc) · 3.31 KB

README.md

File metadata and controls

91 lines (69 loc) · 3.31 KB

Update

An extended version is available on Mach. Learn. journal. Please refer to the updated version.


Neuro-Symbolic Forward Reasoner (NSFR)

This is the implementation of the paper:

nsfr

Installation

The packages are specified in requirements.txt. Please install the packages by:

pip install -r requirements.txt

Demo

To run the demo code on your computer (without GPUs):

Kandinsky Patterns Twopairs Dataset:

python src/predict_kandinsky.py --dataset twopairs --no-cuda --batch-size 2 --plot

CLEVR-Hans3 Dataset:

python src/predict_clevr.py --dataset clevr-hans3 --no-cuda --batch-size 2 --plot

The results are summarized in result/ folder, e.g.,

twopairs clevr-hans3 clevr-hans7

NSFR performs forward reasoning in first-order logic using rules (See data/lang). For example, the following rules are used:

Kandinsky Patterns Twopairs

kp(X):-in(O1,X),in(O2,X),in(O3,X),in(O4,X),same_shape_pair(O1,O2),same_color_pair(O1,O2),same_shape_pair(O3,O4),diff_color_pair(O3,O4).
same_shape_pair(X,Y):-shape(X,Z),shape(Y,Z).
same_color_pair(X,Y):-color(X,Z),color(Y,Z).
diff_color_pair(X,Y):-color(X,Z),color(Y,W),diff_color(Z,W).

CLEVR-Hans3

kp1(X):-in(O1,X),in(O2,X),size(O1,large),shape(O1,cube),size(O2,large),shape(O2,cylinder).
kp2(X):-in(O1,X),in(O2,X),size(O1,small),material(O1,metal),shape(O1,cube),size(O2,small),shape(O2,sphere).
kp3(X):-in(O1,X),in(O2,X),size(O1,large),color(O1,blue),shape(O1,sphere),size(O2,small),color(O2,yellow),shape(O2,sphere).

Kandinsky Patterns Dataset

The code for the generation of Kandinsky patterns used in the paper can be found here.

Citation

If this repository helps your work, please consider to cite the following papers:

@misc{shindo2021neurosymbolic,
      title={Neuro-Symbolic Forward Reasoning}, 
      author={Hikaru Shindo and Devendra Singh Dhami and Kristian Kersting},
      year={2021},
      eprint={2110.09383},
      archivePrefix={arXiv},
      primaryClass={cs.AI}
}

@inproceedings{shindo21aaai,
  author    = {Hikaru Shindo and Masaaki Nishino and Akihiro Yamamoto},
  title     = {Differentiable Inductive Logic Programming for Structured Examples},
  booktitle = {Thirty-Fifth {AAAI} Conference on Artificial Intelligence, {AAAI}
               2021},
  pages     = {5034--5041},
  year      = {2021},
}

LICENSE

See LICENSE. The src/yolov5 folder is following GPL3 license.