Skip to content

Latest commit

 

History

History
87 lines (67 loc) · 4.89 KB

README.md

File metadata and controls

87 lines (67 loc) · 4.89 KB

Learning Differentiable Logic Programs for Abstract Visual Reasoning

Hikaru Shindo, Viktor Pfanschilling, Devendra Singh Dhami, Kristian Kersting

Abstract

Visual reasoning is essential for building intelligent agents that understand the world and perform problem-solving beyond perception. Differentiable forward reasoning has been developed to integrate reasoning with gradient-based machine learning paradigms. However, due to the memory intensity, most existing approaches do not bring the best of the expressivity of first-order logic, excluding a crucial ability to solve abstract visual reasoning, where agents need to perform reasoning by using analogies on abstract concepts in different scenarios. To overcome this problem, we propose NEUro-symbolic Message-pAssiNg reasoNer (NEUMANN), which is a graph-based differentiable forward reasoner, passing messages in a memory-efficient manner and handling structured programs with functors. Moreover, we propose a computationally-efficient structure learning algorithm to perform explanatory program induction on complex visual scenes. To evaluate, in addition to conventional visual reasoning tasks, we propose a new task, visual reasoning behind-the-scenes, where agents need to learn abstract programs and then answer queries by imagining scenes that are not observed. We empirically demonstrate that NEUMANN solves visual reasoning tasks efficiently, outperforming neural, symbolic, and neuro-symbolic baselines.

neumann

NEUMANN solves Behind-the-Scenes task. Reasoning behind the scenes: The goal of this task is to compute the answer of a query, e.g., ``What is the color of the second left-most object after deleting a gray object?'' given a visual scene. To answer this query, the agent needs to reason behind the scenes and understand abstract operations on objects. In the first task, the agent needs to induce an explicit program given visual examples, where each example consists of several visual scenes that describe the input and the output of the operation to be learned. The abstract operations can be described and computed by first-order logic with functors. In the second task, the agent needs to apply the learned programs to new situations to solve queries reasoning about non-observational scenes.

How does it work?

NEUMANN compiles first-order logic programs into a graph neural network. Logical entailment is compted using probabilistic atoms and weighted rules using fuzzy logic operations. neumann

Relevant Repositories

Visual ILP: A repository of the dataset generation of CLEVR images for abstract operations.

Behind-the-Scenes: A repository for the generation of visual scenes and queries for the behind-the-scenes task.

Experiments

Prerequisites

Docker container is available in folder .devcontainer, which is compatible with packages (produced by pip freeze). The main dependent packages are:

pytorch
torch-geometric 
networkx

We used Python 3.8 for the experiments. See Dockerfile for more details.

Build a Docker container

Simply use VSCode to open the container, or build the container manually: To run on machines without GPUs

cp .devcontainer/Dockerfile_nogpu ./Dockerfile
docker build -t neumann .
docker run -it -v <local path to the repository>:/neumann --name neumann neumann

For example, the local path could be: /Users/username/Workspace/github/neumann. The path is where this repository has been cloned.

For the GPU-equipped machines, use:

cp .devcontainer/Dockerfile ./Dockerfile
docker build -t neumann .
docker run -it -v <local path to the repository>:/neumann --name neumann neumann

To open the container on machines without GPUs using VSCode, run

cp .devcontainer/Dockerfile_nogpu .devcontainer/Dockerfile

and use the VSCode remotehost extension (recommended).

Perform learning

For example, in the container, learning Kandinsky patterns on red triangle using the demo dataset can be performed:

cd /neumann
python3 src/train_neumann.py --dataset-type kandinsky --dataset red-triangle --num-objects 6 --batch-size 12 --no-cuda --epochs 30 --infer-step 4 --trial 5 --n-sample 10 --program-size 1  --max-var 6 --min-body-len 6 --pos-ratio 1.0 --neg-ratio 1.0

An exenplary log can be found redtrianlge_log.txt.

More scripts are available:

Learning kandinsky/clevr-hans patterns

Solving Behind-the-Scenes

LICENSE

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