1 research outputs found
Enhancing magic sets with an application to ontological reasoning
Magic sets are a Datalog to Datalog rewriting technique to optimize query
answering. The rewritten program focuses on a portion of the stable model(s) of
the input program which is sufficient to answer the given query. However, the
rewriting may introduce new recursive definitions, which can involve even
negation and aggregations, and may slow down program evaluation. This paper
enhances the magic set technique by preventing the creation of (new) recursive
definitions in the rewritten program. It turns out that the new version of
magic sets is closed for Datalog programs with stratified negation and
aggregations, which is very convenient to obtain efficient computation of the
stable model of the rewritten program. Moreover, the rewritten program is
further optimized by the elimination of subsumed rules and by the efficient
handling of the cases where binding propagation is lost. The research was
stimulated by a challenge on the exploitation of Datalog/\textsc{dlv} for
efficient reasoning on large ontologies. All proposed techniques have been
hence implemented in the \textsc{dlv} system, and tested for ontological
reasoning, confirming their effectiveness.
Under consideration for publication in Theory and Practice of Logic
Programming.Comment: Paper presented at the 35th International Conference on Logic
Programming (ICLP 2019), Las Cruces, New Mexico, USA, 20-25 September 2019,
16 page