Neural Logic Machines
PyTorch implementation for the Neural Logic Machines (NLM). Please note that this is not an officially supported Google product.
Neural Logic Machine (NLM) is a neural-symbolic architecture for both inductive learning and logic reasoning. NLMs use tensors to represent logic predicates. This is done by grounding the predicate as True or False over a fixed set of objects. Based on the tensor representation, rules are implemented as neural operators that can be applied over the premise tensors and generate conclusion tensors.
Neural Logic Machines
Honghua Dong*,
Jiayuan Mao*,
Tian Lin,
Chong Wang,
Lihong Li, and
Denny Zhou
(*: indicates equal contribution.)
In International Conference on Learning Representations (ICLR) 2019
[Paper]
[Project Page]
@inproceedings{
dong2018neural,
title = {Neural Logic Machines},
author = {Honghua Dong and Jiayuan Mao and Tian Lin and Chong Wang and Lihong Li and Denny Zhou},
booktitle = {International Conference on Learning Representations},
year = {2019},
url = {https://openreview.net/forum?id=B1xY-hRctX},
}
Prerequisites
- Python 3
- PyTorch 0.4.0
- Jacinle. We use the version ed90c3a for this repo.
- Other required python packages specified by
requirements.txt
. See the Installation.
Installation
Clone this repository:
git clone https://github.com/google/neural-logic-machines --recursive
Install Jacinle included as a submodule. You need to add the bin path to your global PATH
environment variable:
export PATH=<path_to_neural_logic_machines>/third_party/Jacinle/bin:$PATH
Create a conda environment for NLM, and install the requirements. This includes the required python packages
from both Jacinle and NLM. Most of the required packages have been included in the built-in anaconda
package:
conda create -n nlm anaconda
conda install pytorch torchvision -c pytorch
Usage
This repo contains 10 graph-related reasoning tasks (using supervised learning) and 3 decision-making tasks (using reinforcement learning).
We also provide pre-trained models for 3 decision-making tasks in models directory,
Taking the Blocks World task as an example.
# To train the model:
$ jac-run scripts/blocksworld/learn_policy.py --task final
# To test the model:
$ jac-run scripts/blocksworld/learn_policy.py --task final --test-only --load models/blocksworld.pth
# add [--test-epoch-size T] to control the number of testing cases.
# E.g. use T=20 for a quick testing, usually take ~2min on CPUs.
# Sample output of testing for number=10 and number=50:
> Evaluation:
length = 12.500000
number = 10.000000
score = 0.885000
succ = 1.000000
> Evaluation:
length = 85.800000
number = 50.000000
score = 0.152000
succ = 1.000000
Please refer to the graph directory for training/inference details of other tasks.
Useful Command-line options
jac-crun GPU_ID FILE --use-gpu GPU_ID
instead ofjac-run FILE
to enable using gpu with idGPU_ID
.--model {nlm, memnet}
[default:nlm
]: choosememnet
to use (Memory Networks)[https://arxiv.org/abs/1503.08895] as baseline.--runs N
: takeN
runs.--dump-dir DUMP_DIR
: place to dump logs/summaries/checkpoints/plays.--dump-play
: dump plays for visualization in json format, can be visualized by our html visualizer. (not applied to graph tasks)--test-number-begin B --test-number-step S --step-number-end E
:
defines the range of the sizes of the test instances.--test-epoch-size SIZE
: number of test instances.
For a complete command-line options see jac-run FILE -h
(e.g. jac-run scripts/blocksworld/learn_policy.py -h
).