Logic for Problem Solving
Total Page:16
File Type:pdf, Size:1020Kb
Load more
Recommended publications
-
Here the Handbook of Abstracts
Handbook of the 4th World Congress and School on Universal Logic March 29 { April 07, 2013 Rio de Janeiro, Brazil UNILOG'2013 www.uni-log.org Edited by Jean-Yves B´eziau,Arthur Buchsbaum and Alexandre Costa-Leite Revised by Alvaro Altair Contents 1 Organizers of UNILOG'13 5 1.1 Scientific Committee . .5 1.2 Organizing Committee . .5 1.3 Supporting Organizers . .6 2 Aim of the event 6 3 4th World School on Universal Logic 8 3.1 Aim of the School . .8 3.2 Tutorials . .9 3.2.1 Why Study Logic? . .9 3.2.2 How to get your Logic Article or Book published in English9 3.2.3 Non-Deterministic Semantics . 10 3.2.4 Logic for the Blind as a Stimulus for the Design of Inno- vative Teaching Materials . 13 3.2.5 Hybrid Logics . 16 3.2.6 Psychology of Reasoning . 17 3.2.7 Truth-Values . 18 3.2.8 The Origin of Indian Logic and Indian Syllogism . 23 3.2.9 Logical Forms . 24 3.2.10 An Introduction to Arabic Logic . 25 3.2.11 Quantum Cognition . 27 3.2.12 Towards a General Theory of Classifications . 28 3.2.13 Connecting Logics . 30 3.2.14 Relativity of Mathematical Concepts . 32 3.2.15 Undecidability and Incompleteness are Everywhere . 33 3.2.16 Logic, Algebra and Implication . 33 3.2.17 Hypersequents and Applications . 35 3.2.18 Introduction to Modern Mathematics . 36 3.2.19 Erotetic Logics . 37 3.2.20 History of Paraconsistent Logic . 38 3.2.21 Institutions . -
Logic-Based Technologies for Intelligent Systems: State of the Art and Perspectives
information Article Logic-Based Technologies for Intelligent Systems: State of the Art and Perspectives Roberta Calegari 1,* , Giovanni Ciatto 2 , Enrico Denti 3 and Andrea Omicini 2 1 Alma AI—Alma Mater Research Institute for Human-Centered Artificial Intelligence, Alma Mater Studiorum–Università di Bologna, 40121 Bologna, Italy 2 Dipartimento di Informatica–Scienza e Ingegneria (DISI), Alma Mater Studiorum–Università di Bologna, 47522 Cesena, Italy; [email protected] (G.C.); [email protected] (A.O.) 3 Dipartimento di Informatica–Scienza e Ingegneria (DISI), Alma Mater Studiorum–Università di Bologna, 40136 Bologna, Italy; [email protected] * Correspondence: [email protected] Received: 25 February 2020; Accepted: 18 March 2020; Published: 22 March 2020 Abstract: Together with the disruptive development of modern sub-symbolic approaches to artificial intelligence (AI), symbolic approaches to classical AI are re-gaining momentum, as more and more researchers exploit their potential to make AI more comprehensible, explainable, and therefore trustworthy. Since logic-based approaches lay at the core of symbolic AI, summarizing their state of the art is of paramount importance now more than ever, in order to identify trends, benefits, key features, gaps, and limitations of the techniques proposed so far, as well as to identify promising research perspectives. Along this line, this paper provides an overview of logic-based approaches and technologies by sketching their evolution and pointing out their main application areas. Future perspectives for exploitation of logic-based technologies are discussed as well, in order to identify those research fields that deserve more attention, considering the areas that already exploit logic-based approaches as well as those that are more likely to adopt logic-based approaches in the future. -
By Robert Kowalski
Edinburgh Research Explorer Review of "Computational logic and human thinking: How to be artificially intelligent" by Robert Kowalski Citation for published version: Bundy, A 2012, 'Review of "Computational logic and human thinking: How to be artificially intelligent" by Robert Kowalski', Artificial Intelligence, vol. 191-192, pp. 96-97. https://doi.org/10.1016/j.artint.2012.05.006 Digital Object Identifier (DOI): 10.1016/j.artint.2012.05.006 Link: Link to publication record in Edinburgh Research Explorer Document Version: Early version, also known as pre-print Published In: Artificial Intelligence General rights Copyright for the publications made accessible via the Edinburgh Research Explorer is retained by the author(s) and / or other copyright owners and it is a condition of accessing these publications that users recognise and abide by the legal requirements associated with these rights. Take down policy The University of Edinburgh has made every reasonable effort to ensure that Edinburgh Research Explorer content complies with UK legislation. If you believe that the public display of this file breaches copyright please contact [email protected] providing details, and we will remove access to the work immediately and investigate your claim. Download date: 27. Sep. 2021 Review of \Computational Logic and Human Thinking: How to be Artificially Intelligent" by Robert Kowalski Alan Bundy School of Informatics, University of Edinburgh, Informatics Forum, 10 Crichton St, Edinburgh, EH8 9AB, Scotland 1 August 2012 Abstract This is a review of the book \Computational Logic and Human Thinking: How to be Artificially Intelligent" by Robert Kowalski. Keywords: computational logic, human thinking, book review. -
7. Logic Programming in Prolog
Artificial Intelligence 7. Logic Programming in Prolog Prof. Bojana Dalbelo Baˇsi´c Assoc. Prof. Jan Snajderˇ University of Zagreb Faculty of Electrical Engineering and Computing Academic Year 2019/2020 Creative Commons Attribution{NonCommercial{NoDerivs 3.0 v1.10 Dalbelo Baˇsi´c, Snajderˇ (UNIZG FER) AI { Logic programming AY 2019/2020 1 / 38 Outline 1 Logic programming and Prolog 2 Inference on Horn clauses 3 Programming in Prolog 4 Non-declarative aspects of Prolog Dalbelo Baˇsi´c, Snajderˇ (UNIZG FER) AI { Logic programming AY 2019/2020 2 / 38 Outline 1 Logic programming and Prolog 2 Inference on Horn clauses 3 Programming in Prolog 4 Non-declarative aspects of Prolog Dalbelo Baˇsi´c, Snajderˇ (UNIZG FER) AI { Logic programming AY 2019/2020 3 / 38 Logic programming Logic programming: use of logic inference as a way of programming Main idea: define the problem in terms of logic formulae, then let the computer do the problem solving (program execution = inference) This is a typical declarative programming approach: express the logic of computation, don't bother with the control flow We focus on the description of the problem (declarative), rather than on how the program is executed (procedural) However, we still need some flow control mechanism, thus: Algorithm = Logic + Control Different from automated theorem proving because: 1 explicit control flow is hard-wired into the program 2 not the full expressivity of FOL is supported Dalbelo Baˇsi´c, Snajderˇ (UNIZG FER) AI { Logic programming AY 2019/2020 4 / 38 Refresher: Declarative programming -
Inconsistency Robustness for Logic Programs Carl Hewitt
Inconsistency Robustness for Logic Programs Carl Hewitt To cite this version: Carl Hewitt. Inconsistency Robustness for Logic Programs. Inconsistency Robustness, 2015, 978-1- 84890-159. hal-01148496v6 HAL Id: hal-01148496 https://hal.archives-ouvertes.fr/hal-01148496v6 Submitted on 27 Apr 2016 HAL is a multi-disciplinary open access L’archive ouverte pluridisciplinaire HAL, est archive for the deposit and dissemination of sci- destinée au dépôt et à la diffusion de documents entific research documents, whether they are pub- scientifiques de niveau recherche, publiés ou non, lished or not. The documents may come from émanant des établissements d’enseignement et de teaching and research institutions in France or recherche français ou étrangers, des laboratoires abroad, or from public or private research centers. publics ou privés. Copyright Inconsistency Robustness for Logic Programs Carl Hewitt This article is dedicated to Alonzo Church and Stanisław Jaśkowski Abstract This article explores the role of Inconsistency Robustness in the history and theory of Logic Programs. Inconsistency Robustness has been a continually recurring issue in Logic Programs from the beginning including Church's system developed in the early 1930s based on partial functions (defined in the lambda calculus) that he thought would allow development of a general logic without the kind of paradoxes that had plagued earlier efforts by Frege, etc.1 Planner [Hewitt 1969, 1971] was a kind of hybrid between the procedural and logical paradigms in that it featured a procedural embedding of logical sentences in that an implication of the form (p implies q) can be procedurally embedded in the following ways: Forward chaining When asserted p, Assert q When asserted q, Assert p Backward chaining When goal q, SetGoal p When goal p, SetGoal q Developments by different research groups in the fall of 1972 gave rise to a controversy over Logic Programs that persists to this day in the form of following alternatives: 1. -
Axiomatization of Logic. Truth and Proof. Resolution
H250: Honors Colloquium – Introduction to Computation Axiomatization of Logic. Truth and Proof. Resolution Marius Minea [email protected] How many do we need? (best: few) Are they enough? Can we prove everything? Axiomatization helps answer these questions Motivation: Determining Truth In CS250, we started with truth table proofs. Propositional formula: can always do truth table (even if large) Predicate formula: can’t do truth tables (infinite possibilities) ⇒ must use other proof rules Motivation: Determining Truth In CS250, we started with truth table proofs. Propositional formula: can always do truth table (even if large) Predicate formula: can’t do truth tables (infinite possibilities) ⇒ must use other proof rules How many do we need? (best: few) Are they enough? Can we prove everything? Axiomatization helps answer these questions Symbols of propositional logic: propositions: p, q, r (usually lowercase letters) operators (logical connectives): negation ¬, implication → parentheses () Formulas of propositional logic: defined by structural induction (how to build complex formulas from simpler ones) A formula (compound proposition) is: any proposition (aka atomic formula or variable) (¬α) where α is a formula (α → β) if α and β are formulas Implication and negation suffice! First, Define Syntax We define a language by its symbols and the rules to correctly combine symbols (the syntax) Formulas of propositional logic: defined by structural induction (how to build complex formulas from simpler ones) A formula (compound proposition) is: any -
A Program for the Semantics of Science
MARIO BUNGE A PROGRAM FOR THE SEMANTICS OF SCIENCE I. PROBLEM, METHOD AND GOAL So far exact semantics has been successful only in relation to logic and mathematics. It has had little if anything to say about factual or empirical science. Indeed, no semantical theory supplies an exact and adequate elucidation and systematization of the intuitive notions of factual referen- ce and factual representation, or of factual sense and partial truth of fact, which are peculiar to factual science and therefore central to its philosophy. The semantics of first order logic and the semantics of mathematics (i.e., model theory) do not handle those semantical notions, for they are not interested in external reference and in partial satisfaction. On the other hand factual science is not concerned with interpreting a theory in terms of another theory but in interpreting a theory by reference to things in the real world and their properties. Surely there have been attempts to tackle the semantic peculiarities of factual science. However, the results are rather poor. We have either vigorous intuitions that remain half-baked and scattered, or rigorous formalisms that are irrelevant to real science. The failure to pass from intuition to theory suggests that semanticists have not dealt with genuine factual science but with some oversimplified images of it, such as the view that a scientific theory is just a special case of set theory, so that model theory accounts for factual meaning and for truth of fact. If we wish to do justice to the semantic peculiarities of factual science we must not attempt to force it into any preconceived Procrustean bed: we must proceed from within science. -
Development of Logic Programming: What Went Wrong, What Was Done About It, and What It Might Mean for the Future
Development of Logic Programming: What went wrong, What was done about it, and What it might mean for the future Carl Hewitt at alum.mit.edu try carlhewitt Abstract follows: A class of entities called terms is defined and a term is an expression. A sequence of expressions is an Logic Programming can be broadly defined as “using logic expression. These expressions are represented in the to deduce computational steps from existing propositions” machine by list structures [Newell and Simon 1957]. (although this is somewhat controversial). The focus of 2. Certain of these expressions may be regarded as this paper is on the development of this idea. declarative sentences in a certain logical system which Consequently, it does not treat any other associated topics will be analogous to a universal Post canonical system. related to Logic Programming such as constraints, The particular system chosen will depend on abduction, etc. programming considerations but will probably have a The idea has a long development that went through single rule of inference which will combine substitution many twists in which important questions turned out to for variables with modus ponens. The purpose of the combination is to avoid choking the machine with special have surprising answers including the following: cases of general propositions already deduced. Is computation reducible to logic? 3. There is an immediate deduction routine which when Are the laws of thought consistent? given a set of premises will deduce a set of immediate This paper describes what went wrong at various points, conclusions. Initially, the immediate deduction routine what was done about it, and what it might mean for the will simply write down all one-step consequences of the future of Logic Programming. -
Towards a Unified Theory of Intensional Logic Programming
J. LOGIC PROGRAMMING 1992:13:413-440 413 TOWARDS A UNIFIED THEORY OF INTENSIONAL LOGIC PROGRAMMING MEHMET A. ORGUN AND WILLIAM W. WADGE D Intensional Logic Programming is a new form of logic programming based on intensional logic and possible worlds semantics. Intensional logic allows us to use logic programming to specify nonterminating computations and to capture the dynamic aspects of certain problems in a natural and problem-oriented style. The meanings of formulas of an intensional first- order language are given according to intensional interpretations and to elements of a set of possible worlds. Neighborhood semantics is employed as an abstract formulation of the denotations of intensional operators. Then we investigate general properties of intensional operators such as universality, monotonicity, finitariness and conjunctivity. These properties are used as constraints on intensional logic programming systems. The model-theoretic and fixpoint semantics of intensional logic programs are developed in terms of least (minimum) intensional Herbrand models. We show in particular that our results apply to a number of intensional logic programming languages such as Chronolog proposed by Wadge and Tem- plog by Abadi and Manna. We consider some elementary extensions to the theory and show that intensional logic program clauses can be used to define new intensional operators. Intensional logic programs with inten- sional operator definitions are regarded as metatheories. a 1. INTRODUCTION Intensional logic programming (ILP) is a new form of logic programming based on intensional logic and possible world semantics. Intensional logic [20] allows us to describe context-dependent properties of certain problems in a natural and prob- Address correspondence to M. -
Copyright by Amelia J. Harrison 2017
Copyright by Amelia J. Harrison 2017 The Dissertation Committee for Amelia J. Harrison certifies that this is the approved version of the following dissertation: Formal Methods for Answer Set Programming Committee: Vladimir Lifschitz, Supervisor Robert S. Boyer Isil Dillig Warren A. Hunt, Jr. Torsten Schaub Formal Methods for Answer Set Programming by Amelia J. Harrison Dissertation Presented to the Faculty of the Graduate School of The University of Texas at Austin in Partial Fulfillment of the Requirements for the Degree of Doctor of Philosophy The University of Texas at Austin December 2017 To Grandmother Betsy Acknowledgments It’s not an exaggeration to say that were it not for many people other than myself this document would not exist. This is by no means an exhaustive list. I’ve had the opportunity to collaborate with many wonderful and talented colleagues. Among them are Daniel Bailey, Martin Gebser, Yuliya Lierler, Roland Kaminski, Julian Michael, David Pearce, Dhananjay Raju, Mirek Truszczynski, Agustin Valverde, and Fangkai Yang. Without friends to help maintain balance, it’s entirely unclear if I would have been able to see this through. Backyard barbecues and Game of Thrones viewing parties have been essential. I feel especially lucky to have met early on, and shared much of this journey with Hannah Alpert-Abrams and Kate Mesh. My family has been a constant source of reassurance and has helped me nav- igate many of the inevitable bouts of self-doubt that arise in the process of a Ph.D. This includes my parents, Jack and Betsy Harrison, who have always unequivocally encouraged me to find my own path. -
CSCI 334: Principles of Programming Languages Lecture 21: Logic
Announcements CSCI 334: Principles of Programming Languages Be a TA! Lecture 21: Logic Programming Instructor: Dan Barowy Announcements Logic Programming • Logic programming began as a collaboration between AI researchers (e.g., John McCarthy) and logicians (e.g., John Alan Robinson) to solve problems in artificial intelligence. • Cordell Green built the first “question and answer” system using Robinson’s “unification algorithm,” demonstrating that it was practical to prove theorems automatically. Prolog Declarative Programming • Alain Colmerauer and Phillippe Roussel at Aix- Marseille University invented Prolog in 1972. • Declarative programming is a very different style of programming than • They were inspired by a particular formulation of you have seen to this point. logic, called “Horn clauses,” popularized by the • Mostly, you have seen imperative programs. logician Robert Kowalski. • In imperative-style programming, the programmer instructs the • Horn clauses have a “procedural interpretation,” computer how to compute the desired result. meaning that they suggest a simple procedure for • In declarative-style programming, the computer already knows how solving them, called “resolution.” to compute results. • John Alan Robinson’s unification algorithm is an • Instead, the programmer asks the computer what to compute. efficient algorithm for doing resolution, and this is essentially the algorithm used by Prolog. Declarative Programming Prolog • The goal of AI is to enable a computer to answer declarative queries. • Most of you have probably been CS majors for long enough that we • I.e., it already knows how to answer you. have sufficiently damaged your brain such that you do not recognize • Prolog was an attempt to solve this problem. the difference between these two concepts. -
Parallel Execution of Logic Programs
Parallel Execution of Logic Programs John S. Conery University of Oregon Copyright c 1994 by John S. Conery ii For Leslie ♥ iv Contents List of Figures ix Preface xi 1 Introduction 3 2 Logic Programming 7 2.1 Syntax ............................... 8 2.2 Semantics ............................. 12 2.3 Control .............................. 16 2.4 Prolog ............................... 19 2.4.1 Evaluable Predicates and Arithmetic .......... 19 2.4.2 Higher Order Functions ................. 21 2.4.3 The Cut Symbol ..................... 22 2.5 Alternate Control Strategies ................... 26 2.5.1 Selection by Number of Solutions ............ 27 2.5.2 Selection by Number of Uninstantiated Variables . 28 2.5.3 Intelligent Backtracking ................. 29 2.5.4 Coroutines ........................ 30 2.6 Chapter Summary ........................ 33 3 ParallelisminLogicPrograms 35 3.1 Models for OR Parallelism .................... 37 3.1.1 Pure OR Parallelism ................... 39 3.1.2 OR Processes ....................... 42 3.1.3 Distributed Search .................... 45 3.1.4 Summary ......................... 47 3.2 Models for AND Parallelism ................... 48 3.2.1 Stream Parallel Models ................. 48 3.2.2 AND Processes ...................... 52 3.2.3 AND Parallelism in the Goal Tree ........... 56 v vi Contents 3.2.4 Summary ......................... 56 3.3 Low Level Parallelism ...................... 57 3.4 Chapter Summary ........................ 59 4 The AND/OR Process Model 63 4.1 Oracle ..............................