C H A P T E R TWO - PowerPoint PPT Presentation

1 / 51
About This Presentation
Title:

C H A P T E R TWO

Description:

C H A P T E R T W O Last modified by: TOSHIBA Created Date: 8/1/2003 12:29:19 PM Document presentation format: (4:3) – PowerPoint PPT presentation

Number of Views:62
Avg rating:3.0/5.0
Slides: 52
Provided by: csSuAcTh2
Category:
Tags: two

less

Transcript and Presenter's Notes

Title: C H A P T E R TWO


1
C H A P T E R TWO
  • Syntax and Semantic

2
Chapter 2 Topics
  • Introduction
  • Organization of Language Description
  • Describing Syntax
  • Formal Methods of Describing Syntax
  • The Way of Writing Grammars
  • Formal Semantic
  • Semantic

3
Introduction
  • Who must use language definitions?
  • Other language designers
  • Implementers
  • Programmers (the users of the language)
  • Syntax - the form or structure of the
    expressions, statements, and program units
  • Semantics - the meaning of the expressions,
    statements, and program units

4
Introduction
  • Language description
  • syntax and semantic
  • Syntax
  • how to write program
  • Semantic
  • what does program mean

5
Introduction
  • Dates represented by D (digit) and Symbol (/)
  • DD/DD/DDDD -gt syntax01/02/2001 -gt US
    Jan 2, 2001 Others Feb 1, 2001
  • Same syntax, different semantic

6
Organization of Language Description
  • Tutorials
  • Reference Manuals
  • Formal Definition

7
Tutorials
  • What the main constructs of the language are
  • How they are meant to be used
  • Useful examples for imitating and adapting
  • Introduce syntax and semantics gradually

8
Reference Manuals
  • Describing the syntax and semantics
  • Organized around the syntax
  • Formal syntax and informal semantic
  • Informal semantic English explanations and
    examples to the syntactic rules
  • Began with the Algol60 free of ambiguities

9
Formal Definition
  • Precise description of the syntax and semantics
  • Aimed at specialists
  • Attaches semantic rules to the syntax
  • Conflicting interpretations from English
    explanation
  • Precise formal notation for clarifying subtle
    point

10
Syntactic Elements
  • Character set
  • Identifiers
  • Operator symbols
  • Keywords / Reserved words
  • Comments
  • Separator Brackets
  • Expression
  • Statements

11
Describing Syntax
  • A sentence is a string of characters over some
    alphabet
  • A language is a set of sentences
  • A lexeme is the lowest level syntactic unit of a
    language (e.g., , sum, begin)
  • A token is a category of lexemes (e.g.,
    identifier)

12
A Program Fragment Viewed As a Stream of Tokens
13
Describing Syntax
  • Formal approaches to describing syntax
  • Recognizers - used in compilers
  • Generators generate the sentences of a language
    (focus of this lecture)

14
Formal Methods of Describing Syntax
  • Context-Free Grammars
  • Developed by Noam Chomsky in the mid-1950s
  • Language generators, meant to describe the syntax
    of natural languages
  • Define a class of languages called context-free
    languages

15
CFG for Thai
  • lt??????gt -gt lt??????gtlt?????gtlt????gt
  • lt??????gt -gt ??? ??? ???
  • lt?????gt -gt ??? ??
  • lt????gt -gt ???? ?????
  • lt??????gt -gt lt??????gtlt?????gtlt????gt
  • ??? ??? ????
  • ??? ?? ????

16
Formal Methods of Describing Syntax
  • Backus-Naur Form (1959)
  • Invented by Backus and Naur to describe Algol 58
  • BNF is equivalent to context-free grammars
  • A metalanguage is a language used to describe
    another language.

17
Backus-Naur Form (1959)
  • BNF elements
  • T - terminal symbols
  • N - nonterminal symbols
  • S - start symbol
  • P - set of rules or production

18
BNF grammar
  • Def A grammar production has the form
  • A -gt ? where A is a nonterminal symbol
  • ? is a string of nonterminal and
    terminal symbols
  • This is a rule it describes the structure of a
    while statement
  • ltwhile_stmtgt ? while ( ltlogic_exprgt ) ltstmtgt

19
Formal Methods of Describing Syntax
  • A rule has a left-hand side (LHS) and a
    right-hand side (RHS), and consists of terminal
    and nonterminal symbols
  • A grammar is a finite nonempty set of rules
  • An abstraction (or nonterminal symbol) can have
    more than one RHS
  • ltstmtgt ? ltsingle_stmtgt
  • begin ltstmt_listgt end

20
BNF
  • Nonterminal
  • Identifier
  • Integer
  • Expression
  • Statement
  • Program
  • Terminal
  • The basic alphabet from which programs are
    constructed
  • binaryDigit -gt 0
  • binaryDigit -gt 1
  • binaryDigit -gt 0 1
  • Integer -gt Digit Integer Digit
  • Digit -gt 01234567789
  • Integer -gt Digit
  • Integer -gt Integer Digit
  • Integer -gt Integer Integer Digit
  • Integer -gt Digit Digit

21
Formal Methods of Describing Syntax
  • Syntactic lists are described using recursion
  • ltident_listgt ? ident
  • ident, ltident_listgt
  • A derivation is a repeated application of rules,
    starting with the start symbol and ending with a
    sentence (all terminal symbols)

22
Formal Methods of Describing Syntax
  • An example grammar
  • ltprogramgt ? ltstmtsgt
  • ltstmtsgt ? ltstmtgt ltstmtgt ltstmtsgt
  • ltstmtgt ? ltvargt ltexprgt
  • ltvargt ? a b c d
  • ltexprgt ? lttermgt lttermgt lttermgt - lttermgt
  • lttermgt ? ltvargt const

23
Derivation
  • Grammar
  • Integer -gt Digit Integer Digit
  • Digit -gt 01234567789
  • Is 352 an Integer?
  • Integer gt Integer Digit
  • gt Integer Digit Digit
  • gt Digit Digit Digit
  • gt 3 Digit Digit
  • gt 35 Digit
  • gt 352

24
Derivation
  • Grammar
  • ltassigngt -gt ltidgt ltexprgt
  • ltidgt -gt A B C
  • ltexprgt -gt ltidgt ltexprgt
  • ltidgt ltexprgt
  • ( ltexprgt )
  • ltidgt
  • Statement
  • A B ( A C )
  • Leftmost derivation
  • ltassigngt gt ltidgt ltexprgt
  • gt A ltexprgt
  • gt A ltidgt ltexprgt
  • gt A B ltexprgt
  • gt A B ( ltexprgt )
  • gt A B ( ltidgt ltexprgt)
  • gt A B ( A ltexprgt)
  • gt A B ( A ltidgt)
  • gt A B ( A C )

25
Formal Methods of Describing Syntax
  • An example derivation
  • ltprogramgt gt ltstmtsgt
  • gt ltstmtgt
  • gt ltvargt ltexprgt
  • gt a ltexprgt
  • gt a lttermgt lttermgt
  • gt a ltvargt lttermgt
  • gt a b lttermgt
  • gt a b const

26
Derivation
  • Every string of symbols in the derivation is a
    sentential form
  • A sentence is a sentential form that has only
    terminal symbols
  • A leftmost derivation is one in which the
    leftmost nonterminal in each sentential form is
    the one that is expanded
  • A derivation may be neither leftmost nor rightmost

27
Parse Tree
  • A hierarchical representation of a derivation

ltprogramgt
ltstmtsgt
ltstmtgt
ltvargt

ltexprgt
a
lttermgt

lttermgt
const
ltvargt
b
28
Parse Tree for the Expression x2y
29
Formal Methods of Describing Syntax
  • A grammar is ambiguous if it generates a
    sentential form that has two or more distinct
    parse trees

30
An Ambiguous Grammar
ltAmbExpgt ? ltIntegergt ltAmbExpgt - ltAmbExpgt
Two Different Parse Trees for the AmbExp 2 3
4
31
Is the Grammar Ambiguous?
  • ltexprgt ? ltexprgt ltopgt ltexprgt const
  • ltopgt ? / -

32
Is the Grammar Ambiguous?Yes
  • ltexprgt ? ltexprgt ltopgt ltexprgt const
  • ltopgt ? / -

ltexprgt
ltexprgt
ltexprgt
ltexprgt
ltexprgt
ltexprgt
ltopgt
ltopgt
ltopgt
ltexprgt
ltexprgt
ltexprgt
ltexprgt
ltopgt
ltopgt
const
const
const
const
const
const
-
-
/
/
33
An UnambiguousExpression Grammar
  • If we use the parse tree to indicate precedence
    levels of the operators, we cannot have ambiguity
  • ltexprgt ? ltexprgt - lttermgt lttermgt
  • lttermgt ? lttermgt / const const

ltexprgt
ltexprgt
lttermgt
-
lttermgt
lttermgt
const
/
const
const
34
Formal Methods of Describing Syntax
  • Derivation
  • ltexprgt gt ltexprgt - lttermgt gt lttermgt - lttermgt
  • gt const - lttermgt
  • gt const - lttermgt / const
  • gt const - const / const

35
An Ambiguous If Statement The Dangling Else
Grammatical Ambiguity
36
Formal Methods of Describing Syntax
  • Extended BNF (just abbreviations)
  • Notation used in the course textbook
  • Optional parts
  • ltproc_callgt -gt ident ( ltexpr_listgt)opt
  • Alternative parts
  • lttermgt -gt lttermgt - const
  • Put repetitions (0 or more) in braces ( )
  • ltidentgt -gt letter letter digit

37
Formal Methods of Describing Syntax
  • Extended BNF (just abbreviations)
  • Another frequently used notation
  • Optional parts
  • ltproc_callgt -gt ident ( ltexpr_listgt)
  • Alternative parts
  • lttermgt -gt lttermgt ( -) const
  • Put repetitions (0 or more) in braces ( )
  • ltidentgt -gt letter letter digit

38
BNF and EBNF
  • BNF
  • ltexprgt ? ltexprgt lttermgt
  • ltexprgt - lttermgt
  • lttermgt
  • lttermgt ? lttermgt ltfactorgt
  • lttermgt / ltfactorgt
  • ltfactorgt
  • EBNF
  • ltexprgt ? lttermgt - lttermgt
  • lttermgt ? ltfactorgt / ltfactorgt

39
The Way of Writing Grammars
  • The productions are rules for building string
  • Parse Trees show how a string can be built
  • Notation to write grammar
  • Backus-Naur Form (BNF)
  • Extended BNF (EBNF)
  • Syntax charts graphical notation

40
BNF
  • ltexpression gt ltexpressiongt ltterm gt
  • ltexpressiongt - lttermgt
  • lttermgt
  • ltterm gt lttermgt ltfactorgt
  • lttermgt / ltfactorgt
  • ltfactorgt
  • ltfactor gt number
  • name
  • ( ltexpressiongt )

41
Extended BNF
  • ltexpression gt lttermgt ( - ) lttermgt
  • ltterm gt ltfactorgt ( / ) ltfactorgt
  • ltfactor gt ( ltexpressiongt )
  • name
  • number

42
Syntax Diagram
  • Can be used to visualize rules

expression
term

-
term
factor

/
factor
expression
)
(
name
number
43
Conventions for Writing Regular Expressions
44
Semantics or meaning
  • Semantic any property of a construct
  • The semantic of an expression 23
  • Point of view Semantic
  • An expression evaluator its value 5
  • A type checker type integer
  • An infix-to-postfix translator string 2 3

45
Formal Semantic
  • Static semantic compile-time properties -
    type correctness, translation- determined from
    the static text of a program, without running
    the program on actual data.
  • Dynamic semantic run-time properties
  • - value of expression
  • - the effect of statement
  • - determined by actually doing a computation

46
Semantic Methods
  • Several method for defining semantics
  • The approaches are used for different purposes by
    different communities.
  • The values of variables a and b in ab depend on
    the environment.
  • An environment consists of bindings from variable
    to values.

47
Assignment
  • Draw a parse tree using BNF grammar on slide page
    40
  • 2 3
  • ( 2 3 )
  • 2 3 5
  • ( 2 3 ) 5
  • 2 ( 3 5 )

48
Assignment (cont.)
  • Draw parse trees using the following grammar
  • while expr do id expr
  • begin id expr end
  • if expr then if expr then S else S

S id expr if expr then S if
expr then S else S while expr do
S begin SL end SL S S
SL
49
Assignment (cont.)
  • Write the grammar in any language by using BNF
    or EBNF or syntax diagram
  • Write the keywords in that languages
  • Deadline next class

50
References
  • Books
  • Programming Languages Principles and Paradigms
    Allen B. Tucker Robert E. Noonan
  • Concepts of Programming languages Robert W.
    Sebesta
  • Java BNF
  • http//cui.unige.ch/db-research/Enseignement/analy
    seinfo/JAVA/BNFindex.html

51
Assignment Draw a parse tree
  • using BNF grammar on slide page 35
  • 2 3
  • ( 2 3 )
  • 2 3 5
  • ( 2 3 ) 5
  • 2 ( 3 5 )
  • using the following grammar
  • S id expr if expr then S
    if expr then S else S
  • while expr do s
  • begin SL end
  • SL S
  • S SL
  • while expr do id expr
  • begin id expr end
  • if expr then if expr then S else S
Write a Comment
User Comments (0)
About PowerShow.com