Lecture 01: Theory of Automata:2013 Asif Nawaz Theory of Automata.

Slides:



Advertisements
Similar presentations
Formal Languages Languages: English, Spanish,... PASCAL, C,... Problem: How do we define a language? i.e. what sentences belong to a language? e.g.Large.
Advertisements

1 1 CDT314 FABER Formal Languages, Automata and Models of Computation Lecture 3 School of Innovation, Design and Engineering Mälardalen University 2012.
Finite Automata Great Theoretical Ideas In Computer Science Anupam Gupta Danny Sleator CS Fall 2010 Lecture 20Oct 28, 2010Carnegie Mellon University.
1 Introduction to Computability Theory Lecture3: Regular Expressions Prof. Amos Israeli.
Regular Languages Sequential Machine Theory Prof. K. J. Hintz Department of Electrical and Computer Engineering Lecture 3 Comments, additions and modifications.
Cohen, Chapter 61 Introduction to Computational Theory Chapter 6.
COMMONWEALTH OF AUSTRALIA Copyright Regulations 1969 WARNING This material has been reproduced and communicated to you by or on behalf of Monash University.
Regular Languages Sequential Machine Theory Prof. K. J. Hintz Department of Electrical and Computer Engineering Lecture 3 Comments, additions and modifications.
CS5371 Theory of Computation Lecture 4: Automata Theory II (DFA = NFA, Regular Language)
Languages and Machines Unit two: Regular languages and Finite State Automata.
Great Theoretical Ideas in Computer Science.
Theory Of Automata By Dr. MM Alam
Theory Of Automata By Dr. MM Alam
CS490 Presentation: Automata & Language Theory Thong Lam Ran Shi.
Lecture # 1 (Automata Theory)
Theory of Automata.
1 Welcome to ! Theory Of Automata. 2 Text and Reference Material 1.Introduction to Computer Theory, by Daniel I. Cohen, John Wiley and Sons, Inc., 1991,
Module 2 How to design Computer Language Huma Ayub Software Construction Lecture 7 1.
CSC312 Automata Theory Lecture # 2 Languages.
L ECTURE 1 T HEORY OF A UTOMATA. P RAGMATICS  Pre-Requisites  No Pre-Requisite  Text book  Introduction to Computer Theory by Daniel I.A. Cohen 
Formal Methods in SE Theory of Automata Qasiar Javaid Assistant Professor Lecture # 06.
Lecture Two: Formal Languages Formal Languages, Lecture 2, slide 1 Amjad Ali.
Introduction to Theory of Automata
Introduction to CS Theory Lecture 3 – Regular Languages Piotr Faliszewski
1 Language Definitions Lecture # 2. Defining Languages The languages can be defined in different ways, such as Descriptive definition, Recursive definition,
Recap Lecture-2 Kleene Star Closure, Plus operation, recursive definition of languages, INTEGER, EVEN, factorial, PALINDROME, {anbn}, languages of strings.
1 Chapter 1 Introduction to the Theory of Computation.
Lecture # 3 Regular Expressions 1. Introduction In computing, a regular expression provides a concise and flexible means to "match" (specify and recognize)
Languages, Grammars, and Regular Expressions Chuck Cusack Based partly on Chapter 11 of “Discrete Mathematics and its Applications,” 5 th edition, by Kenneth.
Lecture 05: Theory of Automata:08 Kleene’s Theorem and NFA.
Great Theoretical Ideas in Computer Science.
Module 2 How to design Computer Language Huma Ayub Software Construction Lecture 8.
Lecture-2 Recap Lecture-1
Introduction to Theory of Automata By: Wasim Ahmad Khan.
Recursive Definitions & Regular Expressions (RE)
Regular Expressions and Languages A regular expression is a notation to represent languages, i.e. a set of strings, where the set is either finite or contains.
Lecture 02: Theory of Automata:08 Theory of Automata.
CSC312 Automata Theory Lecture # 3 Languages-II. Formal Language A formal language is a set of words—that is, strings of symbols drawn from a common alphabet.
CS 203: Introduction to Formal Languages and Automata
Recursive Definations Regular Expressions Ch # 4 by Cohen
نظام المحاضرات الالكترونينظام المحاضرات الالكتروني Theory of Automata We will arrive at what we may believe to be the most powerful machine possible. When.
Recognising Languages We will tackle the problem of defining languages by considering how we could recognise them. Problem: Is there a method of recognising.
Lecture 04: Theory of Automata:08 Transition Graphs.
Lecture # Book Introduction to Theory of Computation by Anil Maheshwari Michiel Smid, 2014 “Introduction to computer theory” by Daniel I.A. Cohen.
Theory of computation Introduction theory of computation: It comprises the fundamental mathematical properties of computer hardware, software,
Lecture # 4.
Mathematical Foundations of Computer Science Chapter 3: Regular Languages and Regular Grammars.
Finite Automata Great Theoretical Ideas In Computer Science Victor Adamchik Danny Sleator CS Spring 2010 Lecture 20Mar 30, 2010Carnegie Mellon.
Lecture 02: Theory of Automata:2014 Asif Nawaz Theory of Automata.
Set, Alphabets, Strings, and Languages. The regular languages. Clouser properties of regular sets. Finite State Automata. Types of Finite State Automata.
Lecture 03: Theory of Automata:2014 Asif Nawaz Theory of Automata.
L ANGUAGE C ONCEPTS : F ORMAL M ODEL FOR L ANGUAGES Theory of Computer Akram Salah.
By Dr.Hamed Alrjoub. 1. Introduction to Computer Theory, by Daniel I. Cohen, John Wiley and Sons, Inc., 1991, Second Edition 2. Introduction to Languages.
Lecture 14: Theory of Automata:2014 Finite Automata with Output.
Recap Lecture 3 RE, Recursive definition of RE, defining languages by RE, { x}*, { x}+, {a+b}*, Language of strings having exactly one aa, Language of.
Lecture 17: Theory of Automata:2014 Context Free Grammars.
Chapter 1 INTRODUCTION TO THE THEORY OF COMPUTATION.
Topic 3: Automata Theory 1. OutlineOutline Finite state machine, Regular expressions, DFA, NDFA, and their equivalence, Grammars and Chomsky hierarchy.
Lecture # 2.
BCT 2083 DISCRETE STRUCTURE AND APPLICATIONS
Lecture 1 Theory of Automata
Theory of Automata CS3434 Lecture 01.
Theory of Automata.
Regular Expressions (Examples)
Recap Lecture-2 Kleene Star Closure, Plus operation, recursive definition of languages, INTEGER, EVEN, factorial, PALINDROME, {anbn}, languages of strings.
Chapter 1 Introduction to the Theory of Computation
Recap Lecture-2 Kleene Star Closure, Plus operation, recursive definition of languages, INTEGER, EVEN, factorial, PALINDROME, {anbn}, languages of strings.
CSC312 Automata Theory Lecture # 2 Languages.
CSC312 Automata Theory Lecture # 3 Languages-II.
Welcome to ! Theory Of Automata Irum Feroz
Presentation transcript:

Lecture 01: Theory of Automata:2013 Asif Nawaz Theory of Automata

Lecture 01: Theory of Automata:2013 Asif Nawaz 2 Text and Reference Material 1.Introduction to Computer Theory, by Daniel I. Cohen, John Wiley and Sons, Inc., 1991, Second Edition 2.Introduction to Languages and Theory of Computation, by J. C. Martin, McGraw Hill Book Co., 1997, Second Edition

Lecture 01: Theory of Automata:2013 Asif Nawaz 3 Background We shall form several mathematical models that will describe with varying degrees of accuracy parts of computers, types of computers, and similar machines. In particular, the way we shall be studying about computers is to build mathematical models, called machines, and then to study their limitations by analyzing the types of inputs on which they can operate successfully. The collection of these successful inputs is called the language of the machine.

Lecture 01: Theory of Automata:2013 Asif Nawaz 4 Every time we introduce a new machine, we will learn its language; and every time we develop a new language, we will try to find a machine that corresponds to it. This interplay between languages and machines will be our way of investigating problems and their potential solutions by automatic procedures, which we call algorithms. We will study different types of theoretical machines that are mathematical models for actual physical processes. By considering the possible inputs on which these machines can work, we can analyze their various strengths and weaknesses.

Lecture 01: Theory of Automata:2013 Asif Nawaz 5 We are obliged to prove the truth about whatever we discover. So consider only question of whether certain tasks can be done at all. Conclusion are of the form “this can be done” or “this can never be done”. When reach conclusions of the second type, we mean not just that techniques for performing these tasks are unknown at the present time, but that such techniques will never exist in the future. What is mathematical about the models?

Lecture 01: Theory of Automata:2013 Asif Nawaz 6 We will arrive at what we may believe to be the most powerful machine possible. When we do, we will be surprised to find tasks that even such machine cannot perform. Our ultimate result is that no matter what machine we build, there will always be questions that are simple to state and that the machine can not answer.

Lecture 01: Theory of Automata:2013 Asif Nawaz 7 What does automata mean? It is the plural of automaton, and it means “something that works automatically”

Lecture 01: Theory of Automata:2013 Asif Nawaz Formal Languages A formal language is an abstraction of the general characteristics of programming languages. A formal language consist of a set of symbols and some rules of formation by which these symbols can be combined into entities called sentences

Lecture 01: Theory of Automata:2013 Asif Nawaz Alphabets Definition: A finite non-empty set of symbols (letters), is called an alphabet. It is denoted by Σ ( Greek letter sigma). Example: Σ={a,b} Σ={0,1} //important as this is the language //which the computer understands. Σ={i,j,k}

Lecture 01: Theory of Automata:2013 Asif Nawaz 10 Languages In English, we distinguish 3 different entities: letters, words, and sentences. –Groups of letters make up words and groups of words make up sentences. –However, not all collections of letters form valid words, and not all collections of words form valid sentences. This situation also exists with computer languages. –Certain (but not all) strings of characters are recognizable words (e.g., IF, ELSE, FOR, WHILE …); and certain (but not all) strings of words are recognizable commands.

Lecture 01: Theory of Automata:2013 Asif Nawaz 11 To construct a general theory of formal languages, we need to have a definition of a language structure, in which the decision of whether a given string of units constitutes a valid larger unit is not a matter of guesswork, but is based on explicitly stated rules. In this model, language will be considered as symbols with formal rules, and not as expressions of ideas in the minds of humans. The term “formal” emphasizes that it is the form of the string of symbols that we are interested in, not the meaning.

Lecture 01: Theory of Automata:2013 Asif Nawaz 12 A finite non-empty set of symbols (letters), is called an alphabet. It is denoted by Σ ( Greek letter sigma). Example: Σ={a,b} Σ={0,1} //important as this is the language //which the computer understands. Σ={i,j,k} Basic Definitions

Lecture 01: Theory of Automata:2013 Asif Nawaz 13 Strings Concatenation of finite symbols from the alphabet is called a string. Example: If Σ= {a,b} then a, abab, aaabb, ababababababababab

Lecture 01: Theory of Automata:2013 Asif Nawaz 14 Words Words are strings belonging to some language. Example: If Σ= {x} then a language L can be defined as L={x n : n=1,2,3,…..} or L={x,xx,xxx,….} Here x,xx,… are the words of L All words are strings, but not all strings are words.

Lecture 01: Theory of Automata:2013 Asif Nawaz 15 We shall allow a string to have no letters. We call this empty string or null string, and denote it by the symbol Λ (Capital Greek Lambda). For all languages, the null word, if it is a word in the language, is the word that has no letters. We also denote the null word by Λ. Two words are considered the same if all their letters are the same and in the same order. For clarity, we usually do not allow the symbol Λ to be part of the alphabet of any language. EMPTY STRING or NULL STRING

Lecture 01: Theory of Automata:2013 Asif Nawaz 16 The language that has no words is denoted by the standard symbol for null set, ø. It is not true that Λ is a word in the language ø since this language has no words at all. If a certain language L does not contain the word Λ and we wish to add it to L, we use the operation “+” to form L + {Λ}. This language is not the same as L. However, the language L + ø is the same as L since no new words have been added. Discussion of null

Lecture 01: Theory of Automata:2013 Asif Nawaz 17 Introduction to Defining Languages The rules for defining a language can be of two kinds: –They can tell us how to test if a string of alphabet letters is a valid word, or –They can tell us how to construct all the words in the language by some clear procedures.

Lecture 01: Theory of Automata:2013 Asif Nawaz Defining Languages The languages can be defined in different ways, such as Descriptive definition, Recursive definition, using Regular Expressions(RE) and using Finite Automaton(FA) etc. Descriptive definition of language –The language is defined, describing the conditions imposed on its words. 18

Lecture 01: Theory of Automata:2013 Asif Nawaz 19 Example: Consider this alphabet with only one letter ∑ = { x } We can define a language by saying that any nonempty string of alphabet letters is a word L 1 = { x, xx, xxx, xxxx, … } or L 1 = { x n for n = 1, 2, 3, … } Note that because of the way we have defined it, the language L 1 does not include the null word Λ. Defining Languages

Lecture 01: Theory of Automata:2013 Asif Nawaz 20 Example The language L of strings of odd length, defined over Σ={a}, can be written as L={a, aaa, aaaaa,…..} Example: The language L of strings that does not start with a, defined over Σ={a,b,c}, can be written as L={b, c, ba, bb, bc, ca, cb, cc, …}

Lecture 01: Theory of Automata:2013 Asif Nawaz 21 Example The language L of strings of length 2, defined over Σ={0,1,2}, can be written as L={00, 01, 02,10, 11,12,20,21,22} Example: The language L of strings ending in 0, defined over Σ ={0,1}, can be written as L={0,00,10,000,010,100,110,…}

Lecture 01: Theory of Automata:2013 Asif Nawaz 22 Example The language EQUAL, of strings with number of a’s equal to number of b’s, defined over Σ={a,b}, can be written as { Λ,ab,aabb,abab,baba,abba,…} The language EVEN-EVEN, of strings with even number of a’s and even number of b’s, defined over Σ={a,b}, can be written as {Λ, aa, bb, aaaa,aabb,abab, abba, baab, baba, bbaa, bbbb,…}

Lecture 01: Theory of Automata:2013 Asif Nawaz Example The language {a n b n }, of strings defined over Σ={a,b}, as {an bn : n=1,2,3,…}, can be written as {ab, aabb, aaabbb,aaaabbbb,…} The language {a n b n a n }, of strings defined over Σ={a,b}, as {an bn an: n=1,2,3,…}, can be written as {aba, aabbaa, aaabbbaaa,aaaabbbbaaaa,…} 23

Lecture 01: Theory of Automata:2013 Asif Nawaz Example The language FACTORIAL, of strings defined over Σ= {a}, as {a n ! : n=1,2,3,…}, can be written as {a,aa,aaaaaa,…}. It is to be noted that the language FACTORIAL can be defined over any single letter alphabet. The language DOUBLEFACTORIAL, of strings defined over Σ= {a, b}, as {a n! b n! : n=1,2,3,…}, can be written as {ab, aabb, aaaaaabbbbbb,…} 24

Lecture 01: Theory of Automata:2013 Asif Nawaz 25 Let us define an operation, concatenation, in which two strings are written down side by side to form a new longer string. xxx concatenated with xx is the word xxxxx x n concatenated with x m is the word x n+m For convenience, we may label a word in a given language by a new symbol. For example, xxx is called a, and xx is called b Then to denote the word formed by concatenating a and b, we can write ab = xxxxx It is not true that when two words are concatenated, they produce another word. For example, if the language is L 2 = {x, xxx, xxxxx, …} = {x 2n+1 for n = 0, 1, 2, …} then a = xxx and b = xxxxx are both words in L 2, but their concatenation ab = xxxxxxxx is not in L 2 Concatenation

Lecture 01: Theory of Automata:2013 Asif Nawaz 26 Note that in this simple example, we have: ab = ba But in general, this relationship does NOT hold for all languages (e.g., houseboat and boathouse are two different words in English). Example: Consider another language by beginning with the alphabet ∑ = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 } Define the language L 3 = { any finite string of alphabet letters that does not start with the letter zero } Concatenation makes new Words?

Lecture 01: Theory of Automata:2013 Asif Nawaz 27 This language L 3 looks like the set of positive integers: L 3 = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, … } If we want to define L3 so that it includes the string (word) 0, we could say L 3 = { any finite string of alphabet letters that, if it starts with a 0, has no more letters after the first}

Lecture 01: Theory of Automata:2013 Asif Nawaz 28 Definition: Length We define the function length of a string to be the number of letters in the string. Example: –If a = xxxx in the language L 1, then length(a) = 4 –If c = 428 in the language L 3, then length(c) = 3 –If d = 0 in the language L 3, then length(d) = 1 –In any language that includes the null word Λ, then length(Λ) = 0 For any word w in any language, if length(w) = 0 then w = Λ.

Lecture 01: Theory of Automata:2013 Asif Nawaz 29 Recall that the language L 1 does not contain the null string Λ. Let us define a language like L 1 but that does contain Λ: L 4 = { Λ, x, xx, xxx, xxxx, … } = { x n for n = 0, 1, 2, 3, … } Here we have defined that x 0 = Λ (NOT x 0 = 1 as in algebra) In this way, x n always means the string of n alphabet letters x’s. Remember that even Λ is a word in the language, it is not a letter in the alphabet.

Lecture 01: Theory of Automata:2013 Asif Nawaz 30 Definition: Reverse If a is a word in some language L, then reverse(a) is the same string of letters spelled backward, even if this backward string is not a word in L. Example: –reverse(xxx) = xxx –reverse(145) = 541 –Note that 140 is a word in L 3, but reverse(140) = 041 is NOT a word in L 3

Lecture 01: Theory of Automata:2013 Asif Nawaz Useful Reading First and second chapter of Daniel I. Cohen book. 31