Chapter 1 - William Stallings, Data and Computer Communications

Download Report

Transcript Chapter 1 - William Stallings, Data and Computer Communications

Theory of Automata
• 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.
By
Enas Ajil
‫نظام المحاضرات االلكتروني‬
• 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.
‫نظام المحاضرات االلكتروني‬
A finite non-empty set of symbols (letters), is called
an alphabet. It is denoted by Σ ( Greek letter sigma).
*Words are strings belonging to some language.
*We shall allow a string to have no letters. We call
this empty string or null string, and denote it by the
symbol Λ.
‫نظام المحاضرات االلكتروني‬
• 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
xn concatenated with xm is the word xn+m
• We define the function length of a string to be the number of
letters in the string.
• Example:
• If a = xxxx in the language L1, then length(a) = 4
‫نظام المحاضرات االلكتروني‬
• 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
• Definition: Given an alphabet ∑, we define a language in
which any string of letters from ∑ is a word, even the null
string Λ. We call this language the closure of the alphabet ∑,
and denote this language by ∑*.
• Examples:
If ∑ = { x } then ∑* = { Λ, x, xx, xxx, … }
‫نظام المحاضرات االلكتروني‬
Regular expressions
The language-defining symbols we are about to create are
called regular expressions
.
The language that are associated with those regular
expression are called regular languages.
‫نظام المحاضرات االلكتروني‬
Recursive Definitions
*Even numbers
*Odd numbers
‫نظام المحاضرات االلكتروني‬
Graphs
Transition graph
Deterministic Finite Automata
Nondeterministic Finite Automata
‫نظام المحاضرات االلكتروني‬
Equivalence Regular
Expression & NFA-^
moves
‫نظام المحاضرات االلكتروني‬
Classification of
Languages
‫نظام المحاضرات االلكتروني‬
Context Free Grammars
Trees
Regular Grammars
‫نظام المحاضرات االلكتروني‬