Prof. Fateman CS 164 Lecture 141 Language definition by interpreter Lecture 14.

Slides:



Advertisements
Similar presentations
1 Programming Languages (CS 550) Mini Language Interpreter Jeremy R. Johnson.
Advertisements

Semantics Static semantics Dynamic semantics attribute grammars
Scheme in Scheme. Why implement Scheme in Scheme  Implementing a language is a good way to learn more about programming languages  Interpreters are.
1 Compiler Construction Intermediate Code Generation.
Prof Fateman CS 164 Lecture 371 Review: Programming Languages and Compilers CS AM MWF 10 Evans.
Fall Semantics Juan Carlos Guzmán CS 3123 Programming Languages Concepts Southern Polytechnic State University.
1 Pass Compiler 1. 1.Introduction 1.1 Types of compilers 2.Stages of 1 Pass Compiler 2.1 Lexical analysis 2.2. syntactical analyzer 2.3. Code generation.
Prof. Fateman CS 164 Lecture 151 Language definition by interpreter, translator, continued Lecture 15.
Python Programming Chapter 1: The way of the program Saad Bani Mohammad Department of Computer Science Al al-Bayt University 1 st 2011/2012.
Functional programming: LISP Originally developed for symbolic computing Main motivation: include recursion (see McCarthy biographical excerpt on web site).
Context-Free Grammars Lecture 7
CS 330 Programming Languages 09 / 18 / 2007 Instructor: Michael Eckmann.
Programming Language Semantics Mooly SagivEran Yahav Schrirber 317Open space html://
Reference Book: Modern Compiler Design by Grune, Bal, Jacobs and Langendoen Wiley 2000.
1 Programming & Programming Languages Overview l Machine operations and machine language. l Example of machine language. l Different types of processor.
Functional programming: LISP Originally developed for symbolic computing First interactive, interpreted language Dynamic typing: values have types, variables.
CS 330 Programming Languages 09 / 16 / 2008 Instructor: Michael Eckmann.
Introduction and Syntax. Course objectives Discuss features of programming languages. Discuss how the features are implemented in a simple computer architecture.
Prof. Fateman CS164 Lecture 211 Local Optimizations Lecture 21.
Direction of analysis Although constraints are not directional, flow functions are All flow functions we have seen so far are in the forward direction.
Building An Interpreter After having done all of the analysis, it’s possible to run the program directly rather than compile it … and it may be worth it.
Prof. Fateman CS 164 Lecture 161 Properly Tail Recursive Interpreter. Some timings of compilation vs interpretation Lecture 16.
1.3 Executing Programs. How is Computer Code Transformed into an Executable? Interpreters Compilers Hybrid systems.
CSC 8310 Programming Languages Meeting 2 September 2/3, 2014.
Precision Going back to constant prop, in what cases would we lose precision?
High-Level Programming Languages: C++
COP4020 Programming Languages
Chapter 1 Introduction Dr. Frank Lee. 1.1 Why Study Compiler? To write more efficient code in a high-level language To provide solid foundation in parsing.
10/1/2015© Hal Perkins & UW CSEG-1 CSE P 501 – Compilers Intermediate Representations Hal Perkins Autumn 2009.
Chapter 10: Compilers and Language Translation Invitation to Computer Science, Java Version, Third Edition.
1 Programming Languages Tevfik Koşar Lecture - II January 19 th, 2006.
CS 326 Programming Languages, Concepts and Implementation Instructor: Mircea Nicolescu Lecture 2.
Interpretation Environments and Evaluation. CS 354 Spring Translation Stages Lexical analysis (scanning) Parsing –Recognizing –Building parse tree.
Prof. Fateman CS 164 Lecture 111 Syntax  Simple Semantics Lecture 11.
CS 153: Concepts of Compiler Design September 16 Class Meeting Department of Computer Science San Jose State University Fall 2015 Instructor: Ron Mak
Semantics In Text: Chapter 3.
1 Compiler Design (40-414)  Main Text Book: Compilers: Principles, Techniques & Tools, 2 nd ed., Aho, Lam, Sethi, and Ullman, 2007  Evaluation:  Midterm.
Programming Languages
1 Compiler Construction (CS-636) Muhammad Bilal Bashir UIIT, Rawalpindi.
Milos Hauskrecht (PDF) Hieu D. Vu (PPT) LISP PROGARMMING LANGUAGE.
1 A Simple Syntax-Directed Translator CS308 Compiler Theory.
CS412/413 Introduction to Compilers Radu Rugina Lecture 13 : Static Semantics 18 Feb 02.
The single most important skill for a computer programmer is problem solving Problem solving means the ability to formulate problems, think creatively.
Prof. Fateman CS 164 Lecture 181 Language definition by interpreter Lecture 18.
Overview of Compilation Prepared by Manuel E. Bermúdez, Ph.D. Associate Professor University of Florida Programming Language Principles Lecture 2.
MiniJava Compiler A multi-back-end JIT compiler of Java.
Introduction to Computer Programming Concepts M. Uyguroğlu R. Uyguroğlu.
Functional Programming
Advanced Computer Systems
Compiler Design (40-414) Main Text Book:
Chapter 1 Introduction.
Introduction to Compiler Construction
Learning to Program D is for Digital.
PROGRAMMING LANGUAGES
Introduction to Parsing
Chapter 1 Introduction.
Compiler Lecture 1 CS510.
Basic Program Analysis: AST
Lecture 15 (Notes by P. N. Hilfinger and R. Bodik)
The Metacircular Evaluator
CSE401 Introduction to Compiler Construction
COP4020 Programming Languages
Representation, Syntax, Paradigms, Types
The Metacircular Evaluator
CS 36 – Chapter 11 Functional programming Features Practice
CMP 131 Introduction to Computer Programming
The Metacircular Evaluator (Continued)
6.001 SICP Variations on a Scheme
Introduction to Intermediate Code, virtual machine implementation
6.001 SICP Interpretation Parts of an interpreter
Presentation transcript:

Prof. Fateman CS 164 Lecture 141 Language definition by interpreter Lecture 14

Prof. Fateman CS 164 Lecture 142 Routes to defining a language Formal mathematics –Context free grammar for syntax –Mathematical semantics (axioms, theorems, proofs) –Rarely used alone (the downfall of Algol 68) –Can be used to verify/prove properties (with difficulty) Informal textual –CFG + natural language (Algol 60, Java Language Spec) –Just natural language (Visual Basic for Dummies) -- examples –Almost universally used Operational –Here’s a program that does the job –Metacircular evaluator for Scheme, Lisp –Evaluator/ interpreter for MiniJava

Prof. Fateman CS 164 Lecture 143 input Typical compiler structure Source program AST Intermediate form output Lex, parse Typecheck, cleanup Assembly lang Object code Machine

Prof. Fateman CS 164 Lecture 144 input “MiniJava run” structure Source program AST Intermediate form output interpreter Lex, parse Typecheck, cleanup What language is interpreter written in? What machine does it run on? Except that MJ has no input…

Prof. Fateman CS 164 Lecture 145 Interpreter structure: advantages interpreter Interpreter is written in a higher level language: source language derives semantics from interpreter program and the semantics of the language of the interpreter (e.g. whatever it is that “+” does in Lisp). What does EACH STATEMENT MEAN? Exhaustive case analysis What are the boundaries of legal semantics? What exactly is the model of scope, etc..

Prof. Fateman CS 164 Lecture 146 Interpreter structure: more advantages interpreter Prototyping / debugging easier (compare to machine level) Portable intermediate form; here AST in Lisp as text; could be byte code intermediate form may be compact Security may be more easily enforced by restricting the interpreter or machine model [e.g. if Lisp were “safe”, so would the interpreter be safe.] In modern scripting applications, most time is spent in library subroutines so speed is not usually an issue.

Prof. Fateman CS 164 Lecture 147 Interpreter structure: disadvantages interpreter Typically unable to reach full machine speed. Repeatedly checking stuff Difficult to transcend the limits of the underlying language implementation (not full access to machine: if interpreter is in Lisp, then “interrupts” are viewed through Lisp’s eyes. If interpreter is in Java, then Java VM presents restrictions.) Code depends on presence of infrastructure (all of Lisp??) so even a tiny program starts out “big”. [Historically, was more of an issue] (if meta-circular) bootstrapping… (digression on first PL)

Prof. Fateman CS 164 Lecture 148 An interpreter compromise (e.g. Java VM) interpreter “Compile” to a hypothetical byte-code stack machine appropriate for Java and maybe some other languages, easily simulated on any real machine. Implement this virtual byte-code stack machine on every machine of interest. When speed is an issue, try Just In Time compiling; convert sections of code to machine language for a specific machine. Or translate Java to C or other target.

Prof. Fateman CS 164 Lecture 149 IMPORTANT OBSERVATION Much of the work that you do interpreting has a corresponding kind of activity that you do in typechecking or compiling. This is why I prefer teaching CS164 by first showing a detailed interpreter for the target language.

Prof. Fateman CS 164 Lecture 1410 Interpreter to TypeChecker / Static Analysis is a small step Modest modification of an interpreter program can result in a new program which is a typechecker. An interpreter has to figure out VALUES and COMPUTE with them. A typechecker has to figure out TYPES and check their validity. For example: Interpreter: To evaluate a sequence {s 1, s 2 }, evaluate s 1 then evaluate s 2, returning the last of these. Typechecker: To TC a sequence {s 1, s 2 }, TC s 1 then TC s 2, returning the type for s 2. Interpreter: To evaluate a sum (+ A B) evaluate A, evaluate B and add. Typechecker: To TC a sum, (+ A B) TC A to an int, TC B to an int, Then, return the type, i.e. Int. Program structure is a walk over the AST.

Prof. Fateman CS 164 Lecture 1411 How large is MJ typechecker / semantics ? Environment setup code for MJ is about 318 lines of code. Simple interpreter, including all environment setup, is additional 290 lines of code, including comments. Add to this file the code needed for type checking and you end up with an extra 326 lines of code. Environment setup would be smaller if we didn’t anticipate type checking.

Prof. Fateman CS 164 Lecture 1412 Interpreter to Compiler is a small step Modest modification of an interpreter program can result in a new program which is a compiler. For example: Interpreter: To evaluate a sequence {s 1, s 2 }, evaluate s 1 then evaluate s 2, returning the last of these. Compiler: To compile a sequence {s 1, s 2 }, compile s 1 then compile s 2, returning the concatenation of the code for s 1 and the code for s 2. Interpreter: To evaluate a sum (+ A B) evaluate A, evaluate B and add. Compiler: To compile a sum, (+ A B) compile A, compile B, concatenate code-sequences. Then, compile + to “add the results of the two previous sections of code”. And concatenate that. Program structure is a walk over the intermediate code AST.

Prof. Fateman CS 164 Lecture 1413 AST for MJ program AST is a data structure presenting the Program and all subparts in a big tree reflecting ALL parsed constructs of the system. Here’s fact.java’s AST with some parts abbreviated with #. (Program (MainClass (id Factorial 1) (id a 2) (Print (Call (NewObject #) (id ComputeFac 3) (ExpList #)))) (ClassDecls (ClassDecl (id Fac 7) (extends nil) (VarDecls) (MethodDecls (MethodDecl IntType # # # # #)))))

Prof. Fateman CS 164 Lecture 1414 Start of the interpreter (defun mj-run (ast) "Interpret a MiniJava program from the AST" (mj-statement (fourth (second ast)) ;; the body (setup-mj-env ast) ;; set up env. )) (Program (MainClass (id Factorial 1) (id a 2) (Print (Call (NewObject #) (id ComputeFac 3) (ExpList #)))) (ClassDecls (ClassDecl (id Fac 7) (extends nil) (VarDecls) (MethodDecls (MethodDecl IntType # # # # #))))); define ComputeFac

Prof. Fateman CS 164 Lecture 1415 MJ statements (defun mj-statement (ast env) "Execute a MiniJava statement" ;; we do a few of these in-line, defer others to subroutines. They could all be subroutines.. (cond ((eq (car ast) 'If) (if (eq (mj-exp-eval (cadr ast)env) 'true) (mj-statement (caddr ast) env) ;;then (mj-statement (cadddr ast) env))) ;;else ((eq (car ast) 'While) (mj-while ast env)) ;; um, do this on another slide ((eq (car ast) 'Print) (format t "~A~%" (mj-exp-eval (cadr ast)))) ((eq (car ast) 'Assign) (mj-set-value (id-name (second ast)) ;; look at this later (mj-exp-eval (caddr ast) env))) ((eq (car ast) 'ArrayAssign) ;; etc ((eq (car ast) 'Block) (dolist (s (cdadr ast)) (mj-statement s env))) ;;;; add other statement types in here, if we extend MJ (t (pprint ast) (error "Unexpected statement")))))

Prof. Fateman CS 164 Lecture 1416 What else is needed? All the functions (mj-while etc etc) [simple] All the supporting data structures (symbol table entries and their organization) [tricky]

Prof. Fateman CS 164 Lecture 1417 if COMPARE…. ((eq (car ast) 'If) (if (eq (mj-exp-eval (cadr ast)env) 'true) (mj-statement (caddr ast) env) ;;then (mj-statement (cadddr ast) env))) ;;else (mj-if (mj-exp-eval (cadr ast)env) (mj-statement (caddr ast) env) ;;then (mj-statement (cadddr ast) env))) ;;else (defun mj-if(a b c)(if a b c)) 2 problems: in Lisp, (if X Y Z) evaluates X. If X is non-nil, returns value of Y. MJ’s false is non-nil. Also, in the call to mj-if, we have evaluated both branches. We lose.

Prof. Fateman CS 164 Lecture 1418 Loops: While is very much like Lisp’s while ((eq (car ast) 'While) (while (eq (mj-exp-eval (cadr ast) env) 'true) (mj-statement (caddr ast) env)))

Prof. Fateman CS 164 Lecture 1419 Also part of the main interpreter: exp-eval (defun mj-exp-eval (ast env) "Evaluate a Mini-Java expression subtree" (labels ((c (v) (eq (car ast) v)) ;; some shorthands (DSB idea!) (e1 () (mj-exp-eval (second ast) env)) (e2 () (mj-exp-eval (third ast) env))) (cond ((eq ast 'this) (mj-this env)) ((atom ast) (error "Unexpected atomic expression")) ((c 'Not) (mj-not (e1))) ((c 'And) (mj-and (second ast) (third ast) env)) ((c 'Plus) (mj-+ (e1) (e2))); also Times, Minus, LessThan ((c 'IntegerLiteral) (second ast)) ;also BooleanLiteral ((c 'ArrayLookup) (elt (e1) (e2))) ((c 'ArrayLength) (length (e1))) ((c 'NewArray) (make-array `(,(e1)) :initial-element 0)) ((c 'NewObject) (mj-new-object (id-name (second (second ast))) env)) ((c 'Call) (mj-call ast env)) ;; REALLY IMPORTANT ((c 'IdentifierExp) (mj-get-value (id-name (second ast)) env)))))

Prof. Fateman CS 164 Lecture 1420 Revisit the statement interpreter (labels ((c (v) (eq (car ast) v)) (e (i) (mj-exp-eval (nth i ast) env)) (s (i) (mj-statement (nth i ast) env))) cond ((c 'Assign) (mj-set-value (id-name (second ast)) (e 2) env)) ((c 'ArrayAssign) (setf (elt (mj-get-value (id-name (second ast)) env) (e 2)) (e 3)))

Prof. Fateman CS 164 Lecture 1421 (looking at code for simple-interp) [no more slides of this]