Formal Languages and Automata

Total Page:16

File Type:pdf, Size:1020Kb

Formal Languages and Automata Formal Languages and Automata Stephan Schulz & Jan Hladik [email protected] [email protected] L ⌃⇤ ✓ with contributions from David Suendermann 1 Table of Contents Introduction Formal Grammars Lecture-specific material Organisation The Chomsky Lecture 1 Formal languages Hierarchy Lecture 2 overview Right-linear Grammars Lecture 3 Formal language Context-free Lecture 4 basics Grammars Lecture 5 Regular Languages and Push-Down Automata Lecture 6 Finite Automata Properties of Lecture 7 Regular Expressions Context-free Lecture 8 Finite Automata Languages Lecture 9 Non-Determinism Lecture 10 Parsers and Bison Regular Lecture 11 Turing Machines and expressions and Lecture 12 Languages of Type 1 and Finite Automata Lecture 13 0 Minimisation Lecture 14 Turing Machines Equivalence Lecture 15 Unrestricted The Pumping Lemma Lecture 16 Grammars Properties of Regular Lecture 17 Linear Bounded Languages Lecture 18 Scanners and Flex Automata Formal Grammars and Properties of Context-Free Languages Type-0-languages Selected Solutions 2 Outline Formal Grammars and Context-Free Introduction Languages Organisation Parsers and Bison Formal languages overview Formal language basics Turing Machines and Languages of Type 1 and 0 Regular Languages and Finite Automata Lecture-specific material Scanners and Flex Selected Solutions 3 Outline Formal Grammars and Context-Free Introduction Languages Organisation Parsers and Bison Formal languages overview Formal language basics Turing Machines and Languages of Type 1 and 0 Regular Languages and Finite Automata Lecture-specific material Scanners and Flex Selected Solutions 4 Introduction I Stephan Schulz I Dipl.-Inform., U. Kaiserslautern, 1995 I Dr. rer. nat., TU Munchen,¨ 2000 I Visiting professor, U. Miami, 2002 I Visiting professor, U. West Indies, 2005 I Lecturer (Hildesheim, Offenburg, . ) since 2009 I Industry experience: Building Air Traffic Control systems I System engineer, 2005 I Project manager, 2007 I Product Manager, 2013 I Professor, DHBW Stuttgart, 2014 Research: Logic & Automated Reasoning 5 Introduction I Jan Hladik I Dipl.-Inform.: RWTH Aachen, 2001 I Dr. rer. nat.: TU Dresden, 2007 I Industry experience: SAP Research I Work in publicly funded research projects I Collaboration with SAP product groups I Supervision of Bachelor, Master, and PhD students I Professor: DHBW Stuttgart, 2014 Research: Semantic Web, Semantic Technologies, Automated Reasoning 6 Literature I Scripts I The most up-to-date version of this document as well as auxiliary material will be made available online at http://wwwlehre.dhbw-stuttgart.de/ ˜sschulz/fla2017.html and http://wwwlehre.dhbw-stuttgart.de/ ˜hladik/FLA I Books I John E. Hopcroft, Rajeev Motwani, Jeffrey D. Ullman: Introduction to Automata Theory, Languages, and Computation I Michael Sipser: Introduction to the Theory of Computation I Dirk W. Hoffmann: Theoretische Informatik I Ulrich Hedtstuck:¨ Einfuhrung¨ in die theoretische Informatik 7 Computing Environment I For practical exercises, you will need a complete Linux/UNIX environment. If you do not run one natively, there are several options: I You can install VirtualBox (https://www.virtualbox.org) and then install e.g. Ubuntu (http://www.ubuntu.com/) on a virtual machine I For Windows, you can install the complete UNIX emulation package Cygwin from http://cygwin.com I For MacOS, you can install fink (http://fink.sourceforge.net/) or MacPorts (https://www.macports.org/) and the necessary tools I You will need at least flex, bison, gcc, grep, sed, AWK, make, and a good text editor 8 Outline of the Lecture Introduction Right-linear Grammars Lecture 1 Organisation Context-free Lecture 2 Formal languages Grammars Lecture 3 overview Push-Down Automata Lecture 4 Formal language Properties of Lecture 5 basics Context-free Lecture 6 Regular Languages and Languages Lecture 7 Finite Automata Parsers and Bison Lecture 8 Regular Expressions Turing Machines and Lecture 9 Finite Automata Languages of Type 1 and Lecture 10 The Pumping Lemma 0 Lecture 11 Properties of Regular Turing Machines Lecture 12 Languages Unrestricted Lecture 13 Scanners and Flex Grammars Lecture 14 Formal Grammars and Linear Bounded Lecture 15 Context-Free Languages Automata Lecture 16 Formal Grammars Properties of Lecture 17 The Chomsky Type-0-languages Lecture 18 Hierarchy Lecture-specific material Selected Solutions 9 Outline Formal Grammars and Context-Free Introduction Languages Organisation Parsers and Bison Formal languages overview Formal language basics Turing Machines and Languages of Type 1 and 0 Regular Languages and Finite Automata Lecture-specific material Scanners and Flex Selected Solutions 10 Formal language concepts Alphabet: finite set Σ of symbols (characters) a; b; c I f g Word: finite sequence w of characters (string) ab = ba I 6 Language: (possibly infinite) set L of words ab; ba = ba; ab I f g f g Formal: L defined precisely I opposed to natural languages, where there are borderline cases 11 Some formal languages Example I names in a phone directory I phone numbers in a phone directory I legal C identifiers I legal C programs I legal HTML 4.01 Transitional documents I empty set I ASCII strings I Unicode strings More? 12 Language classes This course: four classes of different complexity and expressivity 1 regular languages: limited power, but easy to handle I “strings that start with a letter, followed by up to 7 letters or digits” I legal C identifiers I phone numbers 2 context-free languages: more expressive, but still feasible I “every <token> is matched by </token>” I nested dependencies I (most aspects of) legal C programs I many natural languages (English, German) Jan says that we Jan sagt, dass wir let die Kinder the children dem Hans help das Haus Hans anstreichen paint helfen the house ließen 13 Language classes (cont’) 3 context-sensitive languages: even more expressive, difficult to handle computationally I “every variable has to be declared before it is used” (arbitrary sequence, arbitrary amounts of code in between) I cross-serial dependencies I (remaining aspects of) legal C programs I most remaining natural languages (Swiss German) Jan sait¨ das mer Jan says that we d’chind the children em Hans Hans es huus the house lond¨ let helfe help aastriche paint 4 recursively enumerable languages: most general (Chomsky) class; undecidable I all (valid) mathematical theorems (in first-order logic) I programs terminating on a particular input 14 Automata I abstract formal machine model, characterised by states, letters, transitions, and external memory I accept words For every language class discussed in this course, a machine model exists such that for every language L there is an automaton (L) that accepts exactly the words in L. A regular finite automaton/finite state machine context-free ; pushdown automaton context-sensitive ; linearly bounded Turing machine recursively enumerable ; (unbounded) Turing machine ; 15 Example: Finite Automaton Initial state Transitions click Off On click States 16 Example: Finite Automaton Formally: Initial state Transitions Q = Off; On is the set of states I f g Σ = click is the alphabet I f g click I The transition function δ is given by δ click Off On Off On click On Off I The initial state is Off I There are no accepting states States 17 ATC scenario Theoretische Grundlagen des Software Engineering Stephan Schulz • Aggregator ATC Center (controllers) • 3 18 ATC redundancy Theoretische Grundlagen des Software Engineering Stephan Schulz • Aktive server: - Accepts sensor data - Provides ASP ATC - Sends “alive” messages Passive server - Ignores sensor data Ser- Ser- - Monitors “alive” messages ver ver - Takes over in case of failure A B Sensors • 4 19 Theoretische Grundlagen des Software Engineering Stephan Schulz •Finite automaton to the rescue Zustandsdiagramm Zwei Eingaben (“Buchstaben”)! q0 ‣ timeout: 0.1 Sekunden sind timeout vergangen! I Two events (“letters”) alive 1 q I timeout‣ alive:: 0.1Andere seconds Server have passedist aktiv! timeout alive: message from active server I q , q , q : Server ist passiv! States‣ q 0q 1q :2 Server is passive alive q2 I 0; 1; 2 No processing of input timeout I • Keine Verarbeitung, keine I No sendingalives of! alive messages alive q3 I State q3: Server becomes active I Process‣ Wenn input, q3 erreicht provide output wird: to! ATC I Send alive messages every 0.1 timeout seconds• Übername als aktiver Server (schicke alives) • 5 20 Exercise: Finite automaton b d q i q g 2 3 n e n q0 q1 q4 Does this automaton accept the words begin; end; bind; bend? 21 Turing Machine “Universal computer” I Very simple model of a computer I Infinite tape, one read/write head I Tape can store letters from a alphabet I Finite automaton controls read/write and movement operations I Very powerful model of a computer I Can compute anything any real computer can compute I Can compute anything an “ideal” real computer can compute I Can compute everything a human can compute (?) 22 Formal grammars Formalism to generate (rather than accept) words over alphabet terminal symbols: may appear in the produced word (alphabet) non-terminal symbols: may not appear in the produced word (temporary symbols) production rules: l r means: l can be replaced by r anywhere in! the word Example Grammar for arithmetic expressions over 0; 1 f g Σ = 0; 1; +; ; (; ) N = fE · g P = fEg 0; E 1; fE ! (E) ! E ! E + E E ! E E ! · g 23 Exercise: Grammars Using I the non-terminal symbol S I the terminal symbols b; d; e; g; i; n I the production rules S begin; beg e; in ind; in n; eg
Recommended publications
  • Practical Experiments with Regular Approximation of Context-Free Languages
    Practical Experiments with Regular Approximation of Context-Free Languages Mark-Jan Nederhof German Research Center for Arti®cial Intelligence Several methods are discussed that construct a ®nite automaton given a context-free grammar, including both methods that lead to subsets and those that lead to supersets of the original context-free language. Some of these methods of regular approximation are new, and some others are presented here in a more re®ned form with respect to existing literature. Practical experiments with the different methods of regular approximation are performed for spoken-language input: hypotheses from a speech recognizer are ®ltered through a ®nite automaton. 1. Introduction Several methods of regular approximation of context-free languages have been pro- posed in the literature. For some, the regular language is a superset of the context-free language, and for others it is a subset. We have implemented a large number of meth- ods, and where necessary, re®ned them with an analysis of the grammar. We also propose a number of new methods. The analysis of the grammar is based on a suf®cient condition for context-free grammars to generate regular languages. For an arbitrary grammar, this analysis iden- ti®es sets of rules that need to be processed in a special way in order to obtain a regular language. The nature of this processing differs for the respective approximation meth- ods. For other parts of the grammar, no special treatment is needed and the grammar rules are translated to the states and transitions of a ®nite automaton without affecting the language.
    [Show full text]
  • CIT 425- AUTOMATA THEORY, COMPUTABILITY and FORMAL LANGUAGES LECTURE NOTE by DR. OYELAMI M. O. Introduction • This Course Cons
    CIT 425- AUTOMATA THEORY, COMPUTABILITY AND FORMAL LANGUAGES LECTURE NOTE BY DR. OYELAMI M. O. Status: Core Description: Words and String. Concatenation, word Length; Language Definition. Regular Expression, Regular Language, Recursive Languages; Finite State Automata (FSA), State Diagrams; Pumping Lemma, Grammars, Applications in Computer Science and Engineering, Compiler Specification and Design, Text Editor and Implementation, Very Large Scale Integrated (VLSI) Circuit Specification and Design, Natural Language Processing (NLP) and Embedded Systems. Introduction This course constitutes the theoretical foundation of computer science. Loosely speaking we can think of automata, grammars, and computability as the study of what can be done by computers in principle, while complexity addresses what can be done in practice. This course has applications in the following areas: o Digital design, o Programming languages o Compilers construction Languages Dictionaries define the term informally as a system suitable for the expression of certain ideas, facts, or concepts, including a set of symbols and rules for their manipulation. While this gives us an intuitive idea of what a language is, it is not sufficient as a definition for the study of formal languages. We need a precise definition for the term. A formal language is an abstraction of the general characteristics of programming languages. Languages can be specified in various ways. One way is to list all the words in the language. Another is to give some criteria that a word must satisfy to be in the language. Another important way is to specify a language through the use of some terminologies: 1 Alphabet: A finite, nonempty set Σ of symbols.
    [Show full text]
  • Theory of Computation
    Theory of Computation Todd Gaugler December 14, 2011 2 Contents 1 Mathematical Background 5 1.1 Overview . .5 1.2 Number System . .5 1.3 Functions . .6 1.4 Relations . .6 1.5 Recursive Definitions . .8 1.6 Mathematical Induction . .9 2 Languages and Context-Free Grammars 11 2.1 Languages . 11 2.2 Counting the Rational Numbers . 13 2.3 Grammars . 14 2.4 Regular Grammar . 15 3 Normal Forms and Finite Automata 17 3.1 Review of Grammars . 17 3.2 Normal Forms . 18 3.3 Machines . 20 3.3.1 An NFA λ ..................................... 22 4 Regular Languages 23 4.1 Computation . 24 4.2 The Extended Transition Function . 24 4.3 Algorithms . 26 4.3.1 Removing Non-Determinism . 26 4.3.2 State Minimization . 26 4.3.3 Expression Graph . 26 4.4 The Relationship between a Regular Grammar and the Finite Automaton . 26 4.4.1 Building an NFA corresponding to a Regular Grammar . 27 4.4.2 Closure . 27 4.5 Review for the First Exam . 28 4.6 The Pumping Lemma . 28 5 Pushdown Automata and Context-Free Languages 31 5.1 Pushdown Automata . 31 5.2 Variations on the PDA Theme . 34 5.3 Acceptance of Context-Free Languages . 36 3 CONTENTS CONTENTS 5.4 The Pumping Lemma for Context-Free Languages . 36 5.5 Closure Properties of Context- Free Languages . 37 6 Turing Machines 39 6.1 The Standard Turing Machine . 39 6.2 Turing Machines as Language Acceptors . 40 6.3 Alternative Acceptance Criteria . 41 6.4 Multitrack Machines . 42 6.5 Two-Way Tape Machines .
    [Show full text]
  • On the Complexity of Regular-Grammars with Integer Attributes ∗ M
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Elsevier - Publisher Connector Journal of Computer and System Sciences 77 (2011) 393–421 Contents lists available at ScienceDirect Journal of Computer and System Sciences www.elsevier.com/locate/jcss On the complexity of regular-grammars with integer attributes ∗ M. Manna a, F. Scarcello b,N.Leonea, a Department of Mathematics, University of Calabria, 87036 Rende (CS), Italy b Department of Electronics, Computer Science and Systems, University of Calabria, 87036 Rende (CS), Italy article info abstract Article history: Regular grammars with attributes overcome some limitations of classical regular grammars, Received 21 August 2009 sensibly enhancing their expressiveness. However, the addition of attributes increases the Received in revised form 17 May 2010 complexity of this formalism leading to intractability in the general case. In this paper, Available online 27 May 2010 we consider regular grammars with attributes ranging over integers, providing an in-depth complexity analysis. We identify relevant fragments of tractable attribute grammars, where Keywords: Attribute grammars complexity and expressiveness are well balanced. In particular, we study the complexity of Computational complexity the classical problem of deciding whether a string belongs to the language generated by Models of computation any attribute grammar from a given class C (call it parse[C]). We consider deterministic and ambiguous regular grammars, attributes specified by arithmetic expressions over {| |, +, −, ÷, %, ∗}, and a possible restriction on the attributes composition (that we call strict composition). Deterministic regular grammars with attributes computed by arithmetic expressions over {| |, +, −, ÷, %} are P-complete. If the way to compose expressions is strict, they can be parsed in L, and they remain tractable even if multiplication is allowed.
    [Show full text]
  • Computation of Infix Probabilities for Probabilistic Context-Free Grammars
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by St Andrews Research Repository Computation of Infix Probabilities for Probabilistic Context-Free Grammars Mark-Jan Nederhof Giorgio Satta School of Computer Science Dept. of Information Engineering University of St Andrews University of Padua United Kingdom Italy [email protected] [email protected] Abstract or part-of-speech, when a prefix of the input has al- ready been processed, as discussed by Jelinek and The notion of infix probability has been intro- Lafferty (1991). Such distributions are useful for duced in the literature as a generalization of speech recognition, where the result of the acous- the notion of prefix (or initial substring) prob- tic processor is represented as a lattice, and local ability, motivated by applications in speech recognition and word error correction. For the choices must be made for a next transition. In ad- case where a probabilistic context-free gram- dition, distributions for the next word are also useful mar is used as language model, methods for for applications of word error correction, when one the computation of infix probabilities have is processing ‘noisy’ text and the parser recognizes been presented in the literature, based on vari- an error that must be recovered by operations of in- ous simplifying assumptions. Here we present sertion, replacement or deletion. a solution that applies to the problem in its full generality. Motivated by the above applications, the problem of the computation of infix probabilities for PCFGs has been introduced in the literature as a generaliza- 1 Introduction tion of the prefix probability problem.
    [Show full text]
  • 1 Finite Automata and Regular Languages
    Aalto University Department of Computer Science CS-C2150 Theoretical Computer Science Solved Example Problems, Spring 2020 1 Finite Automata and Regular Languages 1. Problem: Describe the following languages both in terms of regular expressions and in terms of deterministic finite automata: (a) fw 2 f0; 1g∗ j w contains 101 as a substringg, (b) fw 2 f0; 1g∗ j w does not contain 101 as a substringg. Solution: (a) A regular expression for this language is easy to construct: (0j1)∗101(0j1)∗: A nondeterministic finite automaton is also easy to come up with: 0; 1 0; 1 1 0 1 start q0 q1 q2 q3 Let us then determinise this using the subset construction: 0 1 ! fq0g fq0g fq0; q1g fq0; q1g fq0; q2g fq0; q1g fq0; q2g fq0g fq0; q1; q3g f:::; q3g f:::; q3g f:::; q3g The last row of the table has been simplified based on the observation that from a set containing the accepting state q3, one always moves again to some set con- taining q3, and so all such states are equivalent. Thus, we obtain the following deterministic automaton: 1 0; 1 0 1 0 1 start fq0g fq0; q1g fq0; q2g f:::; q3g 0 (b) Observe that the language here is the complement of the language in part (a), and the DFA provided in part (a) is complete, i.e. all possible transitions are explicitly listed. Therefore, complementing the DFA from part (a) yields a DFA for this language: 0 1 0; 1 1 0 1 start q0 q1 q2 q3 0 All accepting states are inaccessible from state q3, thus we may ignore it.
    [Show full text]
  • Problem Book
    Faculty of Mathematics, Informatics and Mechanics, UW Computational Complexity Problem book Spring 2011 Coordinator Damian Niwiński Contributors: Contents 1 Turing Machines 5 1.1 Machines in general.........................................5 1.2 Coding objects as words and problems as languages.......................5 1.3 Turing machines as computation models..............................5 1.4 Turing machines — basic complexity................................7 1.5 One-tape Turing machines......................................7 1.6 Decidability and undecidability...................................7 2 Circuits 9 2.1 Circuit basics.............................................9 2.2 More on the parity function..................................... 11 2.3 Circuit depth and communication complexity........................... 12 2.4 Machines with advice......................................... 12 2.4.1 P-selective problems..................................... 13 3 Basic complexity classes 15 3.1 Polynomial time........................................... 15 3.2 Logarithmic space.......................................... 17 3.3 Alternation.............................................. 18 3.4 Numbers................................................ 19 3.5 PSPACE................................................ 20 3.6 NP................................................... 21 3.7 BPP.................................................. 21 3.8 Diverse................................................ 22 3 4 Chapter 1 Turing Machines Contributed: Vince Bárány,
    [Show full text]
  • Formal Languages and Automata Theory
    5Th Semester(COMPUTER SCIENCE AND ENGG .GCEKJR) Formal Languages and Automata Theory. Introduction -:Automata theory is a study of abstract machine , automat and a theoretical way solve computational problem using this abstract machine .It is the theoretical computer science .The word automata plural of automaton comes from Greek word ...which means “self making”. This automaton consists of states (represented in the figure by circles) and transitions (represented by arrows). As the automaton sees a symbol of input, it makes a transition (or jump) to another state, according to its transition function , which takes the current state and the recent symbol as its inputs. Automata theory is closely related to formal language theory. A formal language consist of word whose latter are taken from an alphabet and are well formed according to specific set of rule . so we can say An automaton is a finite representation of a formal language that may be an infinite set. Automata are often classified by the class of formal languages they can recognize, typically illustrated by the CHOMSKY HIERARCHY which describes the relations between various languages and kinds of formalized logics. Following are the few automata over formal language. Automaton Recognizable Language. Nondetermistic /Deterministic Finate Regular language. state Machine(FSM) Deterministic push down Deterministic context free language. automaton(DPDA) Pushdown automaton(PDA) Context_free language. Linear bounded automata(LBA) Context _sensitive language. Turing machine Recursively enumerable language. Why Study of automata theory is important? Because Automata play a major role in theory of computation, compiler construction, artificial intelligence , parsing and formal verification. Alphabets, Strings and Languages; Automata and Grammars-: Symbols and Alphabet: Symbol-: is an abstract user defined entity for example if we say pi(π) its value is 1.414.
    [Show full text]
  • Learning Finite-State Machines: Algorithmic and Statistical Aspects
    Learning Finite-State Machines Statistical and Algorithmic Aspects Borja de Balle Pigem Thesis Supervisors: Jorge Castro and Ricard Gavald`a Department of Software | PhD in Computing Thesis submitted to obtain the qualification of Doctor from the Universitat Polit`ecnicade Catalunya Copyright © 2013 by Borja de Balle Pigem This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-sa/3.0/. Abstract The present thesis addresses several machine learning problems on generative and predictive models on sequential data. All the models considered have in common that they can be defined in terms of finite-state machines. On one line of work we study algorithms for learning the probabilistic analog of Deterministic Finite Automata (DFA). This provides a fairly expressive generative model for sequences with very interesting algorithmic properties. State-merging algorithms for learning these models can be interpreted as a divisive clustering scheme where the \dependency graph" between clusters is not necessarily a tree. We characterize these algorithms in terms of statistical queries and a use this charac- terization for proving a lower bound with an explicit dependency on the distinguishability of the target machine. In a more realistic setting, we give an adaptive state-merging algorithm satisfying the strin- gent algorithmic constraints of the data streams computing paradigm. Our algorithms come with strict PAC learning guarantees. At the heart of state-merging algorithms lies a statistical test for distribu- tion similarity. In the streaming version this is replaced with a bootstrap-based test which yields faster convergence in many situations.
    [Show full text]
  • 13.2 Finite-State Machines with Output
    Discrete Mathematics Rosen and Its Applications Kenneth H. Rosen The Leading Text in Discrete Mathematics The seventh edition of Kenneth Rosen’s Discrete Mathematics and Its Applications is a substantial revision of the most widely used textbook in its field. This new edition refl ects extensive feedback from instructors, students, and more than 50 reviewers. It also reflects the insights of the author based on his experience in industry and academia. SEVENTH Key benefi ts of this edition are: EDITION and Its and Discrete Mathematics Applications MD DALIM 1145224 05/14/11 Discrete Mathematics CYAN and Its MAG Applications YELO BLACK SEVENTH EDITION TM P1: 1/1 P2: 1/2 QC: 1/1 T1: 2 FRONT-7T Rosen-2311T MHIA017-Rosen-v5.cls May 13, 2011 10:21 Discrete Mathematics and Its Applications Seventh Edition Kenneth H. Rosen Monmouth University (and formerly AT&T Laboratories) i P1: 1/1 P2: 1/2 QC: 1/1 T1: 2 FRONT-7T Rosen-2311T MHIA017-Rosen-v5.cls May 13, 2011 10:21 DISCRETE MATHEMATICS AND ITS APPLICATIONS, SEVENTH EDITION Published by McGraw-Hill, a business unit of The McGraw-Hill Companies, Inc., 1221 Avenue of the Americas, New York, NY 10020. Copyright © 2012 by The McGraw-Hill Companies, Inc. All rights reserved. Previous editions © 2007, 2003, and 1999. No part of this publication may be reproduced or distributed in any form or by any means, or stored in a database or retrieval system, without the prior written consent of The McGraw-Hill Companies, Inc., including, but not limited to, in any network or other electronic storage or transmission, or broadcast for distance learning.
    [Show full text]
  • Automata Theory
    Automata Theory About this Tutorial Automata Theory is a branch of computer science that deals with designing abstract self- propelled computing devices that follow a predetermined sequence of operations automatically. An automaton with a finite number of states is called a Finite Automaton. This is a brief and concise tutorial that introduces the fundamental concepts of Finite Automata, Regular Languages, and Pushdown Automata before moving onto Turing machines and Decidability. Audience This tutorial has been prepared for students pursuing a degree in any information technology or computer science related field. It attempts to help students grasp the essential concepts involved in automata theory. Prerequisites This tutorial has a good balance between theory and mathematical rigor. The readers are expected to have a basic understanding of discrete mathematical structures. Copyright & Disclaimer Copyright 2016 by Tutorials Point (I) Pvt. Ltd. All the content and graphics published in this e-book are the property of Tutorials Point (I) Pvt. Ltd. The user of this e-book is prohibited to reuse, retain, copy, distribute or republish any contents or a part of contents of this e-book in any manner without written consent of the publisher. We strive to update the contents of our website and tutorials as timely and as precisely as possible, however, the contents may contain inaccuracies or errors. Tutorials Point (I) Pvt. Ltd. provides no guarantee regarding the accuracy, timeliness or completeness of our website or its contents including this tutorial. If you discover any errors on our website or in this tutorial, please notify us at [email protected] i Automata Theory Table of Contents About this Tutorial ...........................................................................................................................................
    [Show full text]
  • Generalizing Input-Driven Languages: Theoretical and Practical Benefits
    Generalizing input-driven languages: theoretical and practical benefits Dino Mandrioli1, Matteo Pradella1,2 1 DEIB – Politecnico di Milano, via Ponzio 34/5, Milano, Italy 2 IEIIT – Consiglio Nazionale delle Ricerche, via Golgi 42, Milano, Italy {dino.mandrioli, matteo.pradella}@polimi.it Abstract. Regular languages (RL) are the simplest family in Chomsky’s hierar- chy. Thanks to their simplicity they enjoy various nice algebraic and logic prop- erties that have been successfully exploited in many application fields. Practically all of their related problems are decidable, so that they support automatic verifi- cation algorithms. Also, they can be recognized in real-time. Context-free languages (CFL) are another major family well-suited to formalize programming, natural, and many other classes of languages; their increased gen- erative power w.r.t. RL, however, causes the loss of several closure properties and of the decidability of important problems; furthermore they need complex pars- ing algorithms. Thus, various subclasses thereof have been defined with different goals, spanning from efficient, deterministic parsing to closure properties, logic characterization and automatic verification techniques. Among CFL subclasses, so-called structured ones, i.e., those where the typical tree-structure is visible in the sentences, exhibit many of the algebraic and logic properties of RL, whereas deterministic CFL have been thoroughly exploited in compiler construction and other application fields. After surveying and comparing the main properties of those various language families, we go back to operator precedence languages (OPL), an old family through which R. Floyd pioneered deterministic parsing, and we show that they offer unexpected properties in two fields so far investigated in totally independent ways: they enable parsing parallelization in a more effective way than traditional sequential parsers, and exhibit the same algebraic and logic properties so far ob- tained only for less expressive language families.
    [Show full text]