arXiv Analytics

Sign in

arXiv:2405.06399 [cs.LG]AbstractReferencesReviewsResources

Program Synthesis using Inductive Logic Programming for the Abstraction and Reasoning Corpus

Filipe Marinho Rocha, Inês Dutra, Vítor Santos Costa

Published 2024-05-10Version 1

The Abstraction and Reasoning Corpus (ARC) is a general artificial intelligence benchmark that is currently unsolvable by any Machine Learning method, including Large Language Models (LLMs). It demands strong generalization and reasoning capabilities which are known to be weaknesses of Neural Network based systems. In this work, we propose a Program Synthesis system that uses Inductive Logic Programming (ILP), a branch of Symbolic AI, to solve ARC. We have manually defined a simple Domain Specific Language (DSL) that corresponds to a small set of object-centric abstractions relevant to ARC. This is the Background Knowledge used by ILP to create Logic Programs that provide reasoning capabilities to our system. The full system is capable of generalize to unseen tasks, since ILP can create Logic Program(s) from few examples, in the case of ARC: pairs of Input-Output grids examples for each task. These Logic Programs are able to generate Objects present in the Output grid and the combination of these can form a complete program that transforms an Input grid into an Output grid. We randomly chose some tasks from ARC that dont require more than the small number of the Object primitives we implemented and show that given only these, our system can solve tasks that require each, such different reasoning.

Related articles: Most relevant | Search more
arXiv:2103.16080 [cs.LG] (Published 2021-03-30)
Geometry of Program Synthesis
arXiv:1402.5988 [cs.LG] (Published 2014-02-24, updated 2014-11-22)
Incremental Learning of Event Definitions with Inductive Logic Programming
arXiv:2106.08064 [cs.LG] (Published 2021-06-15)
Generating Contrastive Explanations for Inductive Logic Programming Based on a Near Miss Approach