CIS 540: Principles of Embedded Computation, Spring 2014
- Instructor: Rajeev Alur
- Lectures: Monday, Wednesday, 10.30 -- Noon, Moore 212
- Recitation: Friday, Noon -- 1pm, Moore 212
- Teaching Assistant: Rahul Vasist (
- Office Hours: Rajeev Alur: Tuesday, 4-5pm (Levine 609)
This course is focused on the principles underlying design and analysis of
computational elements that interact with the physical environment.
Increasingly, such embedded computers are everywhere, from
smart cameras to medical devices to automobiles.
While the classical
theory of computation focuses on the function that a program computes,
to understand embedded computation, we need to focus on the
reactive nature of the interaction of a component with its
environement via inputs and outputs, the continuous dynamics of the physical
world, different ways of communication among components, and
requirements concerning safety, timeliness, stability, and performance.
Developing tools for approaching design, analysis, and implementation of
embedded systems in a principled manner is an active research area.
This course will attempt to give students a coherent introduction to
this emerging area.
This course assumes mathematical maturity, commensurate with
either ESE 210 (Introduction to Dynamical Systems) or
CIS 262 (Introduction to Theory of Computation).
It is suitable for students who have undergraduate degree in computer science,
or computer engineering, or electrical engineering. It is also suitable for
Penn undergraduates in CSCI and CMPE as an upper-level elective.
Principles of Cyber-Physical Systems; R. Alur, 2014, MIT Press (To appear).
Draft will be made available to registered students.
Comments on the textbook draft are most welcome (typos, errors, suggestions for improving the explanation/presentation). Email your comments to alur@cis.
- Six Homeworks (30%): Each such homework will consist of theoretical problems.
- Three Modeling Projects (15%): Each such project will involve modeling and analysis.
First project involves the model checker SPIN, the second involves Matlab, and the third will use
- Midterm (20%): In-class exam (March 5)
- Final Exam (35%) (May 9)
- Chapter 2: Synchronous Models; Jan 15, 22, 27, 29
- Chapter 3: Safety Requirements; Feb 3, 5, 10, 12, 17
- Chapter 4: Asynchronous Models; Feb 19, 24, 26, March 3
- Midterm: March 5
- Chapter 5: Model Checking; March 17, 19, 24, 26
- Chapter 6: Dynamical Systems; March 31, April 2, 7, 9
- Chapter 7: Timed Models; April 14, 16, 21
- Chapter 9: Hybrid Systems; April 23, 28, 30
- Final Exam: Friday, May 9, 12-2.
The closest match is
Introduction to Embedded Systems -- A Cyber-Physical Systems Approach
by E.A. Lee and S.A. Seshia. (see online version)
Our course/notes cover fewer topics in greater theoretical depth.
Following books are also relevant for supplementary reading for different chapters:
Relevant Modeling and Analysis Software
- Recitation: Recitation will not cover new material, and will be used
to solve exercises, answer questions, and review background material.
- Grades will posted on canvas.
- Plagiarism policy: For homeworks, projects, and exams, you can use your
personal class notes, lecture notes, and reference books.
Do not copy material from friends or from the web.
For violations of this rule, you will be reported to the Office of the Student Conduct at Penn, which may result in expulsion.
Please take the plagiarism rules serioiusly.
Start working on the homeworks and projects early, and if you get stuck, contact the instructor or the TA.
Maintained by Rajeev Alur