# ECPS 203 Embedded Systems Modeling and Design Lecture 1

#### Rainer Dömer

doemer@uci.edu

Center for Embedded and Cyber-physical Systems University of California, Irvine





## Lecture 1: Overview

- Course Overview
  - Context, description, content
- Course Administration
  - Schedule, assignments, communication
  - Academic honesty
- Introduction to Embedded System Design
  - Embedded computer systems
  - Design challenges
- Project Assignment 1
  - Setup and introduction to application example

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

2

## **Course Context**

- · Professional Master Degree Program
  - Master of Embedded and Cyber-Physical Systems (MECPS)
- Courses
  - Fall quarter
    - ECPS 203: Embedded Systems Modeling and Design
    - · ECPS 205: Sensors, Actuators and Sensor Networks
    - ECPS 206: Real-Time and Distributed Systems
  - Winter quarter
    - ECPS 202: Cyber-Physical Systems Design
    - · ECPS 204: Embedded System Software
    - · ECPS 209: Cyber-Physical Systems Case Studies
  - Spring quarter
    - ECPS 207: Security and Privacy in Cyber-Physical Systems
    - ECPS 208: Control Systems for Cyber-Physical Systems
    - · ECPS 210: Cyber-Physical Systems Project

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

3



## **Course Description**

#### ECPS 203:

Embedded Systems Modeling and Design (4)

- Embedded systems definition, system-level specification, models and languages.
- Concepts, requirements, examples.
- Embedded system models at different levels of abstraction.
- Test benches, design under test, IP components.
- Discrete event simulation, semantics, and algorithms.

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

5

## **Course Content**

- 1. Embedded system concepts, models of computation
- 2. Application introduction, case study example
- IEEE SystemC system-level description language
- 4. Application specification, modeling guidelines
- 5. Validation, discrete event simulation, estimation
- 6. Levels of abstraction, co-design methodology
- 7. Top-down system design methodology
- 8. Embedded system architecture, HW/SW partitioning
- 9. Cycle-accurate, register transfer level models
- 10. Project discussion, completion, report

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

6

## **Course Administration**

- Course web pages at http://newport.eecs.uci.edu/ ~doemer/f19\_ecps203/index.html
  - Instructor information
  - Course syllabus and policies
  - Objectives and outcomes
  - Contents and schedule
  - Resources and communication
  - Assignments

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

7

# **Academic Honesty**

- Honesty and Integrity are Required
  - See UCI Office of Academic Integrity & Student Conduct
  - See course policy on course web site
- Plagiarism
  - Theft of intellectual property
  - Taking someone else's work or ideas and passing them off as one's own
  - > Do not copy code!
- Violations will be reported
  - Academic misconduct report to UCI Office of AISC
    - · Interview, written report, AISC staff meeting, decision, ...
  - Possible sanctions
    - · Warning, probation, suspension, dismissal

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

8



# **Academic Honesty**

- Example (S'16): Automatic text transformation
  - Technical Report 1:

#### 1 INTRODUCTION

With complexities of Systems-on-Chip rising almost daily, the design community has been searching for new methodology that can handle given complexities with increased productivity and less time. The modeling and design of embedded systems can be performed at several abstraction levels. The highest level of abstraction is the System level, where the functionality is described using "system-level specification" (in the case of VLSI design, description languages like VHDL or Verilog) and the architecture is seen as building blocks consisting of processors, memories, etc. . . .

Technical Report 2:

#### INTRODUCTION:

SOC challenges are changing day by day, the plan group has been hunting down new philosophy that can deal with given complexities with expanded efficiency and less time. The displaying and plan of implanted frameworks can be performed at a few reflection levels. The most abnormal amount of reflection is the System level, where the usefulness is portrayed utilizing "framework level determination" (on account of VLSI plan, depiction dialects like VHDL or Verilog) and the design is viewed as building pieces comprising of processors, recollections, and so on...

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

10

## **Embedded System Design**

- · Embedded Computer Systems
  - Examples
  - Design Challenges
  - Design Advantages



- Design Complexity
  - Hardware design gap
  - Software design gap
  - System design gap

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

11

# **Embedded Computer Systems**

· Computers are ubiquitous, omnipresent...



System-on-Chip (SoC) Design:
 Design of complex embedded systems on a single chip



ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

12





## **Embedded System Design**

- Design Advantages
  - Application known at design time
  - Environment known at design time
  - > Allows for customized / optimized solution
    - · Improved performance
    - · More functionality
    - · At lower power
- · Custom Platform, SW and HW components
  - Multi-Processor System-on-Chip (MPSoC),
    - · Complete embedded system integrated on a chip
  - General-purpose and application-specific processors
  - Application Specific Integrated Circuit (ASIC)
  - Field Programmable Gate Array (FPGA)
  - Circuit board with off-the-shelf-components

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

15

Source: simh.trailing-edge.cor



## **Design Complexity Challenge**

- Productivity Gaps
  - Hardware productivity gap
    - · Capacities in chip size outpace capabilities in chip design
    - · Moore's law: chip capacity doubles every 18 months
    - HW design productivity estimated at 1.6x over 18 months
  - Software productivity gap
    - Growth of SW productivity estimated at 2x every 5 years
    - · Needs in embedded SW estimated at 2x over 10 months
  - System productivity gap
    - HW gap + SW gap

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

17

## ECPS 203 Project

- Application Example: Canny Edge Detector
  - Embedded system model for image processing:
     Automatic edge detection in a digital camera





golfcart.pgm

golfcart.pgm\_s\_0.60\_I\_0.30\_h\_0.80.pgm

- Application source and documentation:
- John Canny, "A Computational Approach to Edge Detection", IEEE TPAMI, 1986.
- http://en.wikipedia.org/wiki/Canny\_edge\_detector
- ftp://figment.csee.usf.edu/pub/Edge\_Comparison/source\_code/canny.src

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

18

## Homework Assignment 1

- Setup
  - EECS Department Linux Servers
    - crystalcove.eecs.uci.edu, and other beaches
    - Linux environment (CentOS 6.10)
    - Remote access via secure shell protocol (SSH)
  - Accounts
    - · Login ID is your UCInetID
    - · Password is the same as your EEE password
  - Login and make yourself familiar with
    - Command-line tools and GUI tools (which need X client)
    - Text editing and C/C++ programming
    - · Image processing tools

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

19

# Homework Assignment 1

- Task: Introduction to Application Example
  - Canny Edge Detector
  - Algorithm for edge detection in digital images
- Steps
  - 1. Setup your Linux programming environment
  - Download, adjust, and compile the application C code with the GNU C compiler (gcc)
  - 3. Study the application, determine function-call tree
- Deliverables
  - Source code and text file: canny.c, canny.txt
- Due
  - Wednesday, next week: October 9, 2019, 6pm

ECPS203: Embedded Systems Modeling and Design, Lecture 1

(c) 2019 R. Doemer

20