# **The Ptolemy Project**



Shuvra Bhattacharyya Joseph T. Buck Wan-Teh Chang Brian L. Evans Steve X. Gu Sangjin Hong Christopher Hylands Asawaree Kalavade Alan Kamas Allen Lao **Bilung Lee** Edward A. Lee David G. Messerschmitt Praveen K. Murthy Thomas M. Parks José Luis Pino Farhana Shiekh S. Sriram Juergen Teich Warren W. Tsai Patrick J. Warner Michael C. Williamson

UNIVERSITY OF CALIFORNIA AT BERKELEY

| Miniconference Afternoon Program |                                                    |                  |  |
|----------------------------------|----------------------------------------------------|------------------|--|
| 1:00                             | Parallel Implementation                            | S. Sriram        |  |
| 1:20                             | Real-Time Prototyping                              | José Pino        |  |
| 1:40                             | Mixing Dataflow with Control                       | Van-Teh Chang    |  |
| 2:10                             | Break                                              |                  |  |
| 2:30                             | An introduction to a Mathematical Model of Dataflo | w Tom Parks      |  |
| 2:50                             | The Process Networks Domain                        | Tom Parks        |  |
| 3:00                             | Application to the Infopad Project                 | Sam Sheng        |  |
| 3:20                             | NetPlan: A Network Planning Tool on Ptolemy        | Zhigang Qin      |  |
| 3:40                             | Application to Distributed Telecommunications Serv | vices William Li |  |
| 4:00                             | Application to Video Networking                    | Allen Lao        |  |
| 4:20                             | Preview of Ptolemy versions 0.5.2 and 0.6          | Alan Kamas       |  |
| 5:00                             | Adjourn                                            |                  |  |

| Miniconference Morning Program  |  |
|---------------------------------|--|
|                                 |  |
| Overview of the Ptolemy project |  |

9.00

| <ul> <li>10:10 Symbolic Computation in System Simulation and Design<br/>Brian Evan</li> <li>10:30 Break</li> <li>10:50 VHDL Code Generation for Simulation and Synthesis<br/>Mike Williamson</li> <li>11:10 Optimization Issues in Embedded Software Synthesis<br/>Shuvra Bhattacharyys</li> <li>11:40 Combined Code and Data Memory Minimization</li> </ul>                                                                                                                           |       | Edward A. Lee                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------------------------------------------|
| 9:40       Design Methodology Management       Asawaree Kalavade         10:10       Symbolic Computation in System Simulation and Design       Break         10:30       Break       Mike Williamson         10:50       VHDL Code Generation for Simulation and Synthesis       Mike Williamson         11:10       Optimization Issues in Embedded Software Synthesis       Shuvra Bhattacharyy         11:40       Combined Code and Data Memory Minimization       Praveen Murthy | 9:20  |                                                      |
| Asawaree Kalavade<br>10:10 Symbolic Computation in System Simulation and Design<br>Brian Evan<br>10:30 Break<br>10:50 VHDL Code Generation for Simulation and Synthesis<br>Mike Williamson<br>11:10 Optimization Issues in Embedded Software Synthesis<br>Shuvra Bhattacharyyz<br>11:40 Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                                                   |       | Edward A. Lee                                        |
| 10:10       Symbolic Computation in System Simulation and Design<br>Brian Evan         10:30       Break         10:50       VHDL Code Generation for Simulation and Synthesis<br>Mike Williamson         11:10       Optimization Issues in Embedded Software Synthesis<br>Shuvra Bhattacharyys         11:40       Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                      | 9:40  |                                                      |
| Brian Evan         10:30       Break         10:50       VHDL Code Generation for Simulation and Synthesis         Mike Williamson         11:10       Optimization Issues in Embedded Software Synthesis         Shuvra Bhattacharyya         11:40       Combined Code and Data Memory Minimization         Praveen Murthy                                                                                                                                                           |       | Asawaree Kalavade                                    |
| 10:30       Break         10:50       VHDL Code Generation for Simulation and Synthesis<br>Mike Williamson         11:10       Optimization Issues in Embedded Software Synthesis<br>Shuvra Bhattacharyya         11:40       Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                                                                                                             | 10:10 | Symbolic Computation in System Simulation and Design |
| 10:50       VHDL Code Generation for Simulation and Synthesis<br>Mike Williamson         11:10       Optimization Issues in Embedded Software Synthesis<br>Shuvra Bhattacharyya         11:40       Combined Code and Data Memory Minimization         Praveen Murthy                                                                                                                                                                                                                  |       | Brian Evans                                          |
| Mike Williamson<br>11:10 Optimization Issues in Embedded Software Synthesis<br>Shuvra Bhattacharyys<br>11:40 Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                                                                                                                                                                                                                              | 10:30 | Break                                                |
| 11:10       Optimization Issues in Embedded Software Synthesis         Shuvra Bhattacharyy         11:40       Combined Code and Data Memory Minimization         Praveen Murthy                                                                                                                                                                                                                                                                                                       | 10:50 | VHDL Code Generation for Simulation and Synthesis    |
| Shuvra Bhattacharyya<br>11:40 Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                                                                                                                                                                                                                                                                                                             |       | Mike Williamson                                      |
| 11:40 Combined Code and Data Memory Minimization<br>Praveen Murthy                                                                                                                                                                                                                                                                                                                                                                                                                     | 11:10 | Optimization Issues in Embedded Software Synthesis   |
| Praveen Murth                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Shuvra Bhattacharyya                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 11:40 | Combined Code and Data Memory Minimization           |
| 12:00 Lunch                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | Praveen Murthy                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 12:00 | Lunch                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                                                      |

#### UNIVERSITY OF CALIFORNIA AT BERKELEY



This highly multidisciplinary project addresses system-level design and implementation of signal processing systems.



allowing for effective use of specialized design tools within a general system-level design environment.

UNIVERSITY OF CALIFORNIA AT BERKELEY











UNIVERSITY OF CALIFORNIA AT BERKELEY



UNIVERSITY OF CALIFORNIA AT BERKELEY

# **Major Contributions in Dataflow Modeling**

- Compile-time scheduling of *synchronous dataflow* graphs with optimized partitioning and memory utilization.
- Specification of the *Boolean dataflow (BDF) model*, which is Turing complete.
- Proof that the existence of a finite complete cycle and a bounded memory implementation for BDF is *undecidable*.
- *Heuristics* for constructing finite complete cycles and bounded memory schedules most of the time.
- *Multidimensional* generalization to dataflow models.
- **Process network** model generalization to dataflow.
- Visual programming formulation and use of higherorder functions.

# Major Activities • Formal methods • Dataflow (process networks, synchronous, Boolean, multidimensional, ...) • Control (hierarchical FSMs, Esterel, synchronous languages, ...) • Partitioning and scheduling of dataflow graphs (optimize IPC, memory, ...) • Programming languages (higher-order functions, polymorphism, ... ) • Algorithm-level design methodology • Mixing models of computation (discrete-event, FSMs, dataflow, imperative, ...) • Animation and visualization (Tcl/Tk, Matlab, xv, ...) • Mixing domain-specific tools (filter design, Matlab, Mathematica, ...)

- Visual programming (dataflow, FSMs, regularity, recursive, functional, ...)
- System-level design methodology
- Synthesis of embedded software (high-level, assembly, ...)
- Design complexity management (data, tool, flow, methodology, ...)
- Hardware/software codesign (DesignMaker, GCLP partitioning, ...)
- Architecture design and performance modeling (OT principle, VHDL, ...)

UNIVERSITY OF CALIFORNIA AT BERKELEY

# Where to From Here?

- Real-time scalable computing.
- Scalable embedded systems design.
- Design migration from abstract to concrete.
- Formal methods based on partial orders.
- Hybrid systems: combining FSM with dataflow.
- Modeling and analysis of random systems.
- Design of nondeterminate systems.
- Complexity management.
- Design visualization and documentation.
- Partial evaluation and incremental compilation.
- Models for back-end signal interpretation.
- Heterogeneous scheduling.

## Activities during the Next Year

- Software infrastructure
  - · Generalize Wormhole mechanism with dynamic switching.
  - Redesign the code generation mechanism for better retargeting.
  - Improve support for scripted runs.
  - Improve design visualization.
  - Generalize type checking and automatic type conversion.
  - Generalize parameter handling.
  - · Enhance interactive graphics.
  - On-line design documentation.
  - Simulation data management.
- Heterogeneous design
  - Design of a hierarchical finite-state machine controllers
  - Embed controllers designed using Esterel.
  - · System-level performance modeling for heterogeneous hardware.
  - · Complete the design methodology management domain.

UNIVERSITY OF CALIFORNIA AT BERKELEY



# Activities During the Next Year (cont.)

#### • Models of computation

- Explore interacting semantics of synchronous languages and dataflow.
- · Generalize multidimensional dataflow and explore synthesis issues.
- Apply Boolean dataflow technology to VHDL-based synthesis.
- Develop a process network domain that supports nondeterminacy.
- Add enhancements from the Navy's PGM to the dynamic dataflow domain.
- · Implement and understand cyclo-static dataflow.
- Applications
  - InfoPad
  - Radar
  - · Image and video processing
  - Communications
- Algorithm-level design
  - Interface to Mathematica for symbolic computation.
  - Integrate system rewriting in Mathematica with DMM domain.

UNIVERSITY OF CALIFORNIA AT BERKELEY



- Complete distribution of version 0.5.1, including all source code.
- Distribution of Ptiny Ptolemy, a small demonstration version.
- An evolving quick tour of Ptolemy with animations of simple demos.
- The Almagest, a four-volume manual for Ptolemy, in PostScript.
- User's manual in hypertext form. • Publications from the Ptolemy
- Keyword searching for
- Directory of project participants
- Copy of the FAQ and info about mailing lists and newsgroups.

# http://ptolemy.eecs.berkeley.edu

UNIVERSITY OF CALIFORNIA AT BERKELEY