170 likes | 195 Views
Learn about various models of computation (MOCs) applied in embedded system design, including discrete events, dataflow process networks, Petri nets, and more. Understand the goals, characteristics, and applications of different MOCs for effective system design. Explore the formal representation, semantics, and optimization strategies utilized in the design process.
E N D
Models of Computation for Embedded System Design Alvise Bonivento
Outline • Goals • MOCs • Discrete Events • Dataflow Process Networks • Petri Nets • Synchronous/Reactive • Communicating Synchronous FSM • Labeled Transition Systems • SDL Process Networks • Hybrid Systems • CFSM • Conclusions
Goals • First step in embedded system design: specification process • Formal representation helps • MOCs: efficiency, formal verification, design refinement, optimization and implementation • TSM: framework to compare MOCs
MOCs • A mathematical description that has a syntax and rules for computation of the behavior described by the syntax (semantics). Used to specify the semantics of computation and concurrency. • Characteristics: compact description, fidelity to design style, synthesize and optimize behavior to an implementation. • Language & MOCs: MOC affects expressiveness, trade off.
Discrete Event (DE) • Totally ordered events • Digital Hardware simulators: Verilog, VHDL. • Efficient for large systems, but challenged by simultaneous events t t t t A B C A B C • VHDL: delta step solution t A B C A B C t+Δ t+Δ
Dataflow Process Networks • Directed graph: actors, streams and tokens • Process sequence of firings • Firings organized into a list and scheduled • One cycle through the schedule back to original state • DSP problems A B C D A C D B
Petri Nets • Process control, asynchronous communication and scheduling: avoids state explosion place transition token p0 t1 t2 • The state of a PN is the marking • Transition fire when all the predecessors are marked • When firing occurs, the predecessors decrement their marking and the successors increase it. p2 p1 p3 p4 t3 t5 t4 t6 p5 p6 t0
Petri Nets: example p0 t1 t2 p2 p1 p3 p4 t3 t5 t4 t6 p5 p6 t0
Synchronous/Reactive • All signals have events with identical tags (synchronous) • All signals have events at every clock tick • Cycle based models (clocked-synchronous circuit) • Esterel
Synchronous & Multirate WCDMA cell simulators User 1 Base Station User 2 DSP User N
Communicating Synchronous FSM • FSM consists of: • Set of input symbols • Set of output symbols • Finite set of states with an initial state • Input symbols & states output symbols • Input symbols & states next states • Synchronous • Sequential behavior vs. state explosion • Hierarchy, concurrency, non-determinism
Other models • Labeled Transition Systems (LTS) • CSP, CCS • Communication is based on rendevouz • Single LTS is an interleaved asynchronous model • SDL Process Networks • Specification, simulation and design of TLC protocols • Hybrid Systems • FA where each state is associated with a set of differential equations • When inequalities are satisfied transition may fire • Non-linear dynamic systems
Basic operation: at each clock tick, each module reads inputs, computes and produces outputs simultaneously. Triggering & Ordering: all modules are triggered to compute at every clock tick. System solution: unique solution at each clock tick, makes verification easier. Implementation cost: may be expensive, clock rate not optimized. Basic operation: events with a non-zero amount of time between them, each processmay take an arbitrary time. Triggering & Ordering: triggered to run only when inputs change. System solution: difficult to analyze. Implementation cost: cheaper and more flexible. Synchrony vs. Asynchrony
CFSM • Globally asynchronous, locally synchronous (GALS). • POLIS. • CFSM has: • A finite state machine part: inputs, outputs, states, transition and output relation. • A data computation part: reference in the transition relation to external, combinational functions. • Locally synchronous behavior: each CFSM executes atransition by producing a single output reaction in zero time. • Globally asynchronous behavior: each CFSM reads inputs, executes a transition and produces outputs in an unbounded but finite amount of time. Asynchronous interaction from a system perspective.
CFSM • Timing behavior: • a global scheduler controls the interaction of the CFSMs. • During an execution a CFSM reads its inputs, performs a computation, possibly changes states and writes its outputs. • Each input signal is read at most once,each input event is cleared at every execution. • Input events are read atomically. • Functional behavior: • Determined by the specified transition relation (TR)
CFSM: example i1 A • Inputs arrive at a regular rate of Ni time units. • Each CFSM process at a regular rate of Nr if no errors or 2Nr in case of errors. • No missed event constraint. o i err C B i2
Conclusions • No single agreed upon standard MOC. • CFSM with initially unbounded FIFO buffers: • GALS • Unbounded buffers allows static and quasi static scheduling whenever possible. • Keep buffers lossy in the formal model and give the designer tools to verify a priori if any loss occurs. • Enforce no loss for some buffers in the implementation. • Capture most of the features of the different MOCs. • Multiple languages with semantics in terms of CFSMs: • Multiple scheduling, allocation, partitioning, HW & SW synthesis algorithm can be applied. Formal verification throughout the design process.