- Instructor: Deniz Pehlivanoglu
- Lectures: 40
- Students: 12673
- Duration: 10 weeks
Motivation for doing this course
Why at all does one need to study compilers? What is its use? Why should one do this course ? Well these are some of the reasons why you should go for it.
. Language processing is an important component of programming
. A large number of systems software and application programs require structured input
. Operating Systems (command line processing)
. Databases (Query language processing)
. Type setting systems like Latex, Nroff, Troff, Equation editors, M4
. VLSI design and testing
, . Software quality assurance and software testing
. XML, html based systems, Awk, Sed, Emacs, vi ..
. Form processing, extracting information automatically from forms
. Compilers, assemblers and linkers
. High level language to language translators
. Natural language processing
. Where ever input has a structure one can think of language processing
. Why study compilers? Compilers use the whole spectrum of language processing technology
An example of the banner program of Unix which, as the name suggests is used specifically to design banners. Here we are trying to print the alphabet “I”. One’s task gets much simplified when using the representation on the right. And in order to do all this one needs is a compiler to process the high level representation on the right. A compiler hence makes life easy for the coder.
Many common applications require structured input during development phase (design of banner programme of Unix)
xxxxxxxxx
|
9x
|
|
---|---|---|
xxxxxxxxx
|
9x
|
|
xxxxxxxxx
|
9x
|
|
xxx
|
3b 3x
|
3 9x
|
xxx
|
3b 3x
|
6 3b 3x
|
xxx
|
3b 3x
|
3 9x
|
xxx
|
3b 3x
|
|
xxx
|
3b 3x
|
|
xxx
|
3b 3x
|
|
xxxxxxxxx
|
9x
|
|
xxxxxxxxx
|
9x
|
|
xxxxxxxxx
|
9x
|
|
What will we learn in the course? . So. here comes the big question finally. What is it that you are going to learn in this course. Any guess ? . How high level languages are implemented to generate machine code. Complete structure of compilers and how various parts are composed together to get a compiler . Course has theoretical and practical components. Both are needed in implementing programming languages. The focus will be on practical application of the theory. . Emphasis will be on algorithms and data structures rather than proofs of correctness of algorithms. . Theory of lexical analysis, parsing, type checking, runtime system, code generation, optimization (without going too deep into the proofs etc.) . Techniques for developing lexical analyzers, parsers, type checkers, run time systems, code generator, optimization. Use of tools and specifications for developing various parts of compilers What do we expect to achieve by the end of the course?
|
Required Background and self reading
. Courses in data structures, computer organization, operating systems
. Proficiency in C/C++/Java programming languages
. Knowledge of at least one assembly language, assembler, linker & loader, symbolic debugger
. You are expected to read the complete book (except the chapter on code optimization) on Compiler Design by Aho, Sethi and Ullman.
All the material will not be covered in the lectures
Free Certification
Academy Europe presents high-quality formal diplomas, certificates and e-certificates which are formal proof and recognition of accredited online courses. It shows all student’s abilities to learn and achieve high results and is very useful to promote personal career including with CVs, job applications and self improvements.
How can you get your certificate at Academy Europe?
- You must click “complete” link at the end of every lesson of your course after you finish them.
- When you finish all lessons of course, the “finish course” link is going to be active at the end of last lesson.
- When you click the “finish course” link, you will finish your course on Academy Europe officially. Then, “certificate” page of you completed course will be automatically active.
- You can see and download your certificate online after you click on your “certificate” link.
Samples: Horizantal Diploma – Horizantal Certificate – Vertical E-Certificate
Prerequisites
The basic knowledge of Graphical User Interface, Object Oriented Programming and software tools and menus are the only prerequisite for this tutorial.
Before you start proceeding with this course on Academy Europe, we are assuming that you have a good aptitude and can think logically. You should want to try something different.
Ideal candidates for the course would typically possess:
– Discipline and attentiveness
– Ability to conduct research
– Ability to perform tasks with speed, efficiency, and accuracy
– Analytical judgment
– Patience to interpret technical/scientific data
– A willingness to learn, roll up your sleeves and work toward your dream!
– A computer, tablet or smartphone and an internet connection
– Basic computer skills
Audience
This tutorial has been intended for the users willing to take the human computer interactions as a next level of study in their career.
This course by Academy Europe aims at imparting quality education and training to students.
Academy Europe is dedicated to its students, their specific learning requirements, and their overall learning success.
This course is directed toward a student-centered, independent study, asynchronous learning approach.
After completing this course on Academy Europe, students will get self improvement and promotion in their careers.
This course is based on at least two learning skills which are provided to the users through audio & visuals, videos, verbal presentations and articles, all of which are asynchronized with distance education approach.