COSC 6384 Real-Time Systems (M W 2:30pm - 4:00pm) - Spring 2019

Dr. Albert M. K. Cheng
Office: PGH 534
Office hours: M W 4:00pm-5:00pm and by appointment

Required textbook:
Real-Time Systems: Scheduling, Analysis, and Verification by Prof. Albert M. K. Cheng (Publisher: John Wiley & Sons), 2nd printing, 2005.
TA: TBA

Synopsis:
The monitoring and control of physical processes and systems are increasingly performed by computers. These real-time embedded systems must satisfy stringent timing and reliability constraints in addition to functional correctness requirements. Examples of these embedded systems include the new generation of airplane avionics, the planned Space Station control software, high-performance network and telephone switching systems, medical monitoring instruments, multimedia tools, virtual reality systems, robotic controllers, PDAs, wireless phones, and emerging IoT cyber-physical systems. This course introduces a formal framework and powerful techniques for the design and development of this class of systems. These theoretical foundations are followed by hands-on practice in employing these advanced techniques to build, analyze, and verify different modules of actual real-time systems. Scheduling tools and RTOSs (such as VxWorks) are introduced. Tornado development tools are used in projects. Programming in real-time/rule-based languages such as Ada, EQL, MRL, and OPS5 is described. Specification and verification tools such as Statechart, Modechart, and Estella are used to help design experimental real-time systems. Embedded programming techniques are studied. The course also serves as a forum for discussing state-of-the-art research topics in real-time systems design.

Course outline:
Introduction to real-time and Embedded systems
System decomposition and scheduling techniques
In-depth study of Rate-Monotonic Scheduler (RMS), EDF, LLF, and other schedulers
Programming language and operating systems support
Wind River VxWorks RTOS and Tornado Development Tools
Formal specification, analysis, and verification techniques
Embedded programming techniques
Real-time rule-based expert systems
Fault detection, fault recovery, and reliability issues
Time-critical distributed systems and communication networks

Recommended prerequisite:
Operating Systems or equivalent

Course requirements and grading:
several (3 to 4) homework assignments (25%), one open-book exam (no final exam) (35%), one project report (25%), and one project presentation (15%).