Generalized Graph Connections for Dataflow Modeling of DSP Applications by Liu, Yanzhou et al.
Generalized Graph Connections for Dataflow
Modeling of DSP Applications
Yanzhou Liu∗, Lee Barford†, Shuvra S. Bhattacharyya∗‡
∗Department of Electrical and Computer Engineering, University of Maryland, College Park, MD 20742, USA
†Keysight Laboratories, Keysight Technologies, Reno, NV, USA
‡Department of Pervasive Computing Tampere University of Technology, Tampere, Finland
Abstract—In dataflow representations for signal processing
systems, applications are represented as directed graphs in
which vertices represent computations and edges correspond to
buffers that store data as it passes between computations. The
buffers are single-input, single-output components that manage
data in a first-in, first-out (FIFO) fashion. In this paper, we
generalize the concept of dataflow buffers with a concept called
“passive blocks”. Like dataflow buffers, passive blocks are used
to store data during the intervals between its generation by
producing actors, and its use by consuming actors. However,
passive blocks can have multiple inputs and multiple outputs,
and can incorporate operations on and rearrangements of the
stored data subject to certain constraints. We define a form
of flowgraph representation that is based on replacing dataflow
edges with the proposed concept of passive blocks. We present
a structured design methodology for utilizing this new form
of signal processing flowgraph, and demonstrate its utility in
improving memory management efficiency, and execution time
performance.
I. INTRODUCTION
Dataflow modeling is widely used in design processes and
tools for signal processing systems. In this form of modeling,
applications are represented as directed graphs, called dataflow
graphs, in which vertices (actors) represent discrete computa-
tions that are executed iteratively (fire) to process semi-infinite
streams of input data. Each edge e = (x, y) in a dataflow graph
represents a logical communication channel between actors x
and y. More specifically, each e = (x, y) represents a first-
in, first-out (FIFO) buffer that stores data during the period
between its production by actor x and its consumption by
actor y. Actors can be fired when certain conditions, referred
to as firing rules, are satisfied [1].
Dataflow modeling has proven to be of great utility in
the design and implementation of signal processing systems
for various reasons, including its provisions for ensuring
determinacy, support for exploiting parallelism, and capability
for exposing high-level application structure that is useful for
many kinds of design optimization beyond those associated
with exploiting parallelism [2].
A limitation of signal processing dataflow representations,
however, is that they are inefficient in describing inter-actor
communication patterns that depart from the simple single-
input, single-output (SISO) interface and FIFO behavior that
This is a pre-publication version of a paper that has been accepted for
publication in the 2018 IEEE International Workshop on Signal Processing
Systems. The official/final version of the paper will be posted on IEEE Xplore.
(a) (b)
(c) (d)
Fig. 1. (a) Fork actor. (b) Pseudocode fragment for the fork actor. (c) Passive
version of fork actor; wptr, rptr1, and rptr2 show possible positions of the
write pointer and the two read pointers. (d) Cascade of gain and fork actors.
are defined for dataflow edges. As a canonical example of
this kind of inefficiency, consider the fork actor illustrated in
Figure 1a. This is a synchronous dataflow (SDF) [3] actor that
consumes a single token t and produces two tokens — one on
each output edge — on each firing. The values of the two
tokens that are produced are identical to the value of the input
token t. Thus, this actor can be viewed as providing a kind of
broadcast functionality.
Figure 1b shows a pseudocode fragment for the fork actor.
From this pseudocode, we can see that there is overhead of
copying the value of the input token to each of the outputs.
This overhead in general includes a run-time cost as well as a
cost in terms of increased memory requirements. The overhead
is required under a pure dataflow interpretation since the input
token must be replicated on each of the two output edges
(FIFOs).
The functionality of the fork actor can be realized more
efficiently if we abandon this pure dataflow interpretation, and
implement the actor instead using the one-input, two-output
component illustrated in Figure 1c. This component, which
we refer to here as a passive fork, is not fired as a dataflow
actor is. Instead, the component operates in a manner similar
to a typical FIFO implementation, where a buffer is associated
with the component, and tokens are written to and read from
the buffer using write and read pointers, respectively. However,
the passive fork has two read pointers — one corresponding
to each output edge of the fork actor — instead of the single
read pointer that would be used in a FIFO. In effect, we
ar
X
iv
:1
80
7.
05
72
1v
1 
 [e
es
s.S
P]
  1
6 J
ul 
20
18
have transformed the fork actor, which operates in an “active”
manner (by firing) into an passive component, which is used
by writing to and reading from the component’s ports.
A more powerful form of this “active-to-passive” conversion
is illustrated on Figure 1d, which shows a gain actor that is
connected at the input of the fork actor. This gain actor corre-
sponds to a constant multiplication, where the constant factor k
is a parameter of the actor. The gain together with the fork can
be replaced by a single passive component. This component
is similar to the passive fork actor, except that when a value
is written into the buffer, it is multiplied by k before being
stored. In this paper, we generalize this process of converting
certain kinds of actors into passive components, which achieve
equivalent functionality through read/write interfaces rather
than through the mechanism of being fired. This generalization
leads to a powerful new design methodology in which passive
components of arbitrary complexity can be designed to provide
streamlined functionality for actors or subgraphs that are more
efficiently realized with internal buffers and read/write inter-
faces. When dataflow graphs are transformed to incorporate
such passive components, we refer to the resulting graphs as
Passive-Active Flow Graphs (PAFGs). A central objective of
this paper is to introduce PAFGs as a useful new representation
for model-based design of signal processing systems.
II. RELATED WORK
Many researchers have investigated efficient buffer memory
management in dataflow graphs (e.g., see [2], [4]–[6]). Bhat-
tacharyya and Lee discussed the concept that certain actors,
such as the fork actor described above, can be implemented
more efficiently by deviating from pure dataflow semantics [7].
However, this earlier work did not propose any approach for
integrating such deviations systematically into the modeling
framework. In this new work, we develop such a systematic
approach based on the novel abstraction of PAFGs.
Perhaps the most closely related form of dataflow memory
management optimization to what we develop in this paper
is buffer merging, which involves mapping subsets of input
and output buffers of a given actor to a common memory
space (e.g., see [8], [9]). Like the method of [9], the PAFG
approach allows for memory sharing across arbitrary numbers
of input and output buffers for a given actor. Similarly, like the
method of [8], the PAFG approach does not involve expansion
to a single rate rate graph, which can be costly in terms of
compiler memory requirements and time complexity for highly
multirate applications (e.g., see [10]). In this sense, the PAFG
approach provides a novel combination of useful features
in the two previously developed buffer merging approaches
described above. Additionally, while the methods of [8], [9]
are limited to SDF graphs, the PAFG approach is not re-
stricted to any specific form of dataflow. For example, Boolean
dataflow switch and select actors [11] can be formulated as
optimized PAFG components using the same methodology
that is presented in this paper. Applicability beyond SDF is
also a distinguishing point compared to the abstraction of
deterministic SDF with shared FIFOs (DSSF) [12].
While there are significant differences between buffer merg-
ing, DSSF, and PAFG-based memory management, investi-
gating and exploiting complementary relationships among the
different approaches is an interesting direction for future work.
III. PAFG REPRESENTATIONS
In this section, we develop in detail the PAFG model of
computation. In this work, PAFGs are derived from dataflow
graphs, and are intended as intermediate representations or
implementation architectures for dataflow application graphs
(dataflow models of signal processing applications). For con-
creteness, we develop the concepts of PAFGs here in the
context of core functional dataflow (CFDF) as the application
graph model; however, the concepts are not specific to CFDF
and can be adapted to other forms of dataflow. CFDF is
a highly expressive model that can be used to represent
other well-known dataflow models, including synchronous,
cyclo-static, and Boolean dataflow [13]. CFDF is the model
that underlies the lightweight dataflow environment (LIDE)
tool [14], which we use for our experiments in Section V.
We first define some notation that will be useful throughout
the remainder of this paper. Given an edge e in a directed
graph, we denote the source and sink vertices of e by src(e)
and snk(e), respectively. A self-loop is an edge whose source
and sink vertices are identical. In the remainder of this paper,
we consider only directed graphs that do not contain self-
loops. Self-loops can be incorporated easily into the methods
developed in this paper; we omit the details due to space
limitations.
Given an edge e, we say that src(e) is a predecessor
of snk(e), snk(e) is a successor of src(e), and src(e) and
snk(e) are adjacent vertices. The sets of all predecessors
and successors of a vertex v in a given graph are denoted
by pred(v) and succ(v), respectively. The sets of all input
edges and output edges of v are denoted by in(v) and out(v),
respectively.
We refer to PAFG vertices as blocks. In a dataflow graph,
vertices correspond to computational modules, and edges
correspond to SISO buffers between the modules. In con-
trast, in a PAFG, both computational modules and buffers
are represented as vertices, and edges represent connections
between computational modules and buffers. Additionally,
PAFG buffers are not restricted to SISO interfaces — they
can have multiple inputs, multiple outputs, or both. A third
distinguishing characteristic of the PAFGs that we are inter-
ested in this paper is that they are bipartite graphs. We define
this bipartite characteristic precisely in Section III-C.
For conciseness and clarity, we assume that dataflow graphs
and PAFGs are directed graphs rather than multigraphs (which
can contain multiple edges directed in the same direction and
between the same pair of vertices). The adaptation of the
PAFG model to multigraphs can be readily achieved when
implementing the model.
We refer to an ordered pair of actors (xd, yd) as a dataflow
pair and an ordered pair of PAFG blocks (xb, yb) as a PAFG
pair.
The PAFGs that we are concerned with in this paper
are derived from corresponding dataflow graphs (application
graphs). We elaborate on the process of deriving a PAFG from
a dataflow graph in Section III-D. This derivation process
places blocks in a PAFG F in correspondence with actors
or edges in the dataflow graph from which F was derived. A
simple passive buffer is a PAFG block that corresponds in this
way to an edge in some dataflow graph. A PAFG block that is
not a simple passive buffer is referred to as a non-simple block.
We often refer to simple passive buffers as simple blocks.
A. PAFG Blocks
A PAFG block is either a passive block or an active
block. The distinction between these two types was motivated
intuitively in Section I. More precisely, an active block cor-
responds to an application graph actor that is used in the
usual way — that is, through interfaces that are associated
with firing the actor and (if available) for testing fireability. In
CFDF, these are referred to as invoke and enable interfaces,
respectively [13]. In contrast, a passive block is used through
read/write interfaces, as illustrated by the passive fork example
in Section I.
Given an application graph G, we assume that implementa-
tions of the actors in G are available in an actor library. We
assume that each actor in G has one active implementation
(with enable/invoke interfaces) in the library, and that it may
or may not have a passive implementation (with read/write
interfaces). We refer to an actor A as a buffer actor if it
has a passive implementation; otherwise, we refer to A as
a computational actor. Thus, only buffer actors can be placed
in correspondence with passive blocks.
Like active blocks, non-simple passive blocks correspond
to actors. However, they are used (executed) in a different
way — again, as illustrated by the difference between the
active (“standard”) and passive versions of the fork actor in
Section I. A non-simple passive block should implement the
same input/output behavior as its corresponding actor — that
is, it should perform the same mapping from input streams into
output streams. For background on the interpretation of actors
as mappings from input streams to output streams, we refer
the reader to [1]. In this work, we assume that unit testing
processes are used to validate such “mapping equivalence”
between passive blocks and their corresponding actors. For
background on synergies between unit testing and dataflow-
based design processes, we refer the reader to [14]. We envi-
sion as an interesting area for future work the automation of
the equivalence checking process between active and passive
implementations of the same buffer actor.
A block in a PAFG is either a computational block or a
buffer block. The computational/buffer dichotomy is another
relevant way to distinguish between blocks in addition to
the active/passive and simple/non-simple dichotomies. All
computational blocks are active blocks. However, buffer blocks
can in general be either passive or active.
B. Coordination Functions and Alternating PAFGs
When deriving a PAFG, each buffer block needs to be
designated as being an active or passive buffer. An active
buffer is executed like any other actor (using enable/invoke
interfaces), while passive buffers are read from and written
to directly by computational blocks and active buffers (using
read/write interfaces). Coordination functions are used to spec-
ify whether a given block is executed in a passive or active
fashion. Thus, coordination functions specify how schedulers
should manipulate the blocks when executing the associated
application graph.
Given a PAFG F , we represent the set of blocks (vertices)
in F by blks(F ), and we define a coordination function of
F as one that specifies for each b ∈ blks(F ) whether or
not b is to be executed in an active or passive fashion. More
precisely, a coordination function is a mapping C : blks(F )→
{pssv , actv}, where C(bc) = actv for every computational
block bc ∈ blks(F ), and C(bs) = pssv for every simple block
bs ∈ blks(F ). We refer to C(b) as the coordination type of
block b with respect to C. Computational blocks and simple
blocks must be coordinated in an active and passive fashion,
respectively, and a coordination function just “reminds us” of
this. On the other hand, a coordination function C specifies
for each non-simple buffer block whether or not the block is
to be executed in a passive or active fashion (if we execute
the PAFG based on C).
A coordinated PAFG is an ordered pair Z = (F,C), where
F is a PAFG and C is a coordination function for F .
C. Alternating PAFGs
In this work, we are interested in a specific form of coor-
dinated PAFG, which we refer to as an alternating PAFG. An
alternating PAFG is defined to be a coordinated PAFG that is
bipartite in terms of the active blocks and passive blocks. More
precisely, an alternating PAFG Z = (F,C) with F = (Vf , Ef )
is one that satisfies C(src(e)) 6= C(snk(e))for all e ∈ Ef .
A block in a PAFG is an interface block if it has no output
edges or it has no input edges. The concept of coordinated
PAFGs allows for the possibility of interface blocks that
are passive. However, we have not yet experimented with
the design of passive interface blocks. Exploration into the
utility of passive interface blocks appears to be an interesting
direction for future work.
In our context, direct communication between pairs of active
blocks or pairs of passive blocks is ambiguous. Intuitively,
some form of buffer is needed to manage the flow of data
between active blocks (just as dataflow edges connect pairs of
communicating actors in dataflow graphs). Generalization of
the developments of this paper beyond alternating PAFGs is
potentially another interesting direction for future work.
D. Direct PAFGs
We propose a design methodology in which dataflow graphs
are converted into a kind of equivalent PAFG representation,
and then transformed so that some subset of the active buffers
is converted into passive coordination form. In this section, we
Fig. 2. A dataflow graph (application graph).
define the equivalent PAFG representation, which we refer to
as direct PAFG form, and in Section IV, we define the process
of transforming active buffers into passive form.
Suppose that we are given a dataflow graph G = (V,E).
For each edge e ∈ E, we define a corresponding passive buffer
ρ(e). We denote the set of passive buffers defined in this way
as P (G). Thus, P (G) = {ρ(e) | e ∈ E}. Each ρ(e) ∈ P (G)
is a simple block (see Section III-A) since it is defined in
correspondence with a distinct dataflow graph edge e.
Similarly, for each v ∈ V , we define a corresponding
block α(v). Each α(v) is referred to as an actor block with
corresponding actor v. If v is a computational actor, then
α(v) is defined as a computational block. Otherwise, α(v)
is defined as a non-simple buffer block. For a given dataflow
graph G = (V,E), we define the set of all actor blocks by
A(G) = {α(v) | v ∈ V }
For each z = ρ(e) ∈ P (G), we define the PAFG pairs
κi(z) = (α(src(e)), z) and κo(z) = (z, α(snk(e)). Recall
that PAFG pairs are ordered pairs of blocks, and actor blocks
and passive buffers both represent different types of blocks.
Thus, κi(z) and κo(z) can correctly be referred to as PAFG
pairs. The sets of all pairs defined in this way are represented
by Ki = {κi(z) | z ∈ P (G)}, and Ko = {κo(z) | z ∈ P (G)}.
The direct PAFG representation of G is a coordinated PAFG
Zd = (Fd, Cd). The PAFG Fd = (Vd, Ed) is defined by Vd =
(A(G) ∪ P (G)), and Ed = (Ki ∪ Ko), and the coordination
function is defined by Cd(b) = actv for every non-simple
block b.
By construction, each edge in Zd connects a simple block
to a computational block or an active buffer block. Thus, a
direct PAFG is always an alternating PAFG.
To illustrate key concepts introduced in this section, Fig-
ure 2 shows an example of a dataflow graph (application
graph), Figure 3 shows the direct PAFG that results from
this application graph, and Table I shows the coordination
function for the direct PAFG. In Figure 2 and Figure 3, each
Hi is a computational actor, each Ji is a buffer actor, each Yi
corresponds to Hi, each Zi corresponds to Ji, and each Li is
a simple passive buffer.
As illustrated in Figure 2 and Figure 3, we use the conven-
tion that dataflow graph actors are drawn with circles, PAFG
blocks are drawn with rectangles, and the borders of PAFG
blocks are solid or dashed based on whether the blocks are
active or passive, respectively.
Fig. 3. The direct PAFG that is derived from the application graph of Figure 2.
TABLE I
COORDINATION FUNCTION FOR THE DIRECT PAFG OF FIGURE 3.
Block (B) Coordination type C(B)
Yi, i = 1, 2, . . . , 10 actv
Zj , j = 1, 2, . . . , 4 actv
Lk, k = 1, 2, . . . , 15 pssv
E. Association between Dataflow Graphs and PAFGs
Given a dataflow graph G = (V,E) and a PAFG F =
(Vf , Ef ), we say that G and F are associated (each is associ-
ated with the other) if each simple block p in F corresponds
to an edge e in G (p = ρ(e)), and each non-simple block q in
F corresponds to an actor a in G (q = α(a)). By construction,
the direct PAFG representation of a dataflow graph G is always
associated with G.
IV. PASSIVIZATION TRANSFORMATION
In the direct PAFG representation of a dataflow graph, all
non-simple buffer blocks are coordinated as active buffers. In
this section, we define the process of converting an active
buffer to passive form. This conversion process is defined as
a transformation process for alternating PAFGs — that is, a
process that takes as input an alternating PAFG and produces
as output another alternating PAFG.
If b and c are adjacent blocks in a PAFG, then we disallow
coordination functions that assign a passive form to both b
and c. We refer to this as the adjacent buffer coordination
(ABC) restriction. We impose the ABC restriction because we
do not have any mechanism defined for direct communication
between two passive blocks. Intuitively, communication be-
tween passive buffer blocks “stalls” because each is “waiting”
for a read or write operation to be initiated by the other. It may
be interesting as future work to investigate communication
mechanisms that allow one to relax the ABC restriction.
Given an alternating PAFG (F,C) and a block b in F , we
say that b is simply surrounded if all of its predecessors and
successors are simple passive buffers. Formally, this means
that x is a simple passive buffer for all x ∈ (pred(b)∪succ(b)).
For example, in Figure 3, blocks Z1 and Z2 are simply
surrounded, while blocks L1 and L2 are not.
Suppose that we have an alternating PAFG Za = (Fa, Ca),
where Fa = (Va, Ea), and suppose we have an active buffer
β ∈ Va that is simply surrounded. Then we can perform the
passivization transformation of Za with respect to β. This
transformation, which is the primary contribution of this sec-
tion, produces a new PAFG Zb = (Fb, Cb), Fb = (Vb, Eb). The
Fig. 4. Resulting PAFG after applying the passivization transformation.
vertex set of Fb is defined by the set difference Vb = Va−Vz ,
where Vz = pred(β) ∪ succ(β).
To define the edge set Eb, we first define the sets Yp =
{y ∈ pred(x) | x ∈ pred(β)}, and Ys = {y ∈ succ(x) |
x ∈ succ(β)}. Since β is simply surrounded, we have from
the ABC restriction that all elements of Yp and Ys are active
blocks. Next, we construct the set Eβ of PAFG pairs that are
directed from members of Yp to β, or from β to members of
Ys: Eβ = ({(x, β) | x ∈ Yp} ∪ {(β, y) | y ∈ Ys}). We also
define the set of all input and output edges of blocks that are
adjacent to β: Er = {e ∈ out(x) | x ∈ Vz} ∪ {e ∈ in(x) |
x ∈ Vz}. We can then define Eb by Eb = ((Ea −Er) ∪Eβ).
The coordination function Cb : Vb → {pssv , actv} is
derived by changing the form of β, while “copying” the values
from Ca for all other blocks in Vb: Cb(β) = pssv , and
Cb(x) = Ca(x) for all x ∈ (Vb − {β}).
To summarize, the passivization transformation with respect
to a simply surrounded active buffer β involves the following
steps: (1) changing the form of β from actv to pssv ; (2)
removing all of the predecessor and successor blocks of β
along with their input and output edges; (3) adding edges that
are directed to β from each member of Yp; and (4) adding
edges that are directed from β to each member of Ys.
The passivization transformation can be applied multiple
times, where in each application (transformation step) after
the first, the transformation is applied on the graph that results
from the previous step.
For example, Figure 4 illustrates the PAFG that results after
applying the passivization transformation three times on the
direct PAFG of Figure 3. The transformation is applied with
respect to Z1, Z2, and then Z3.
V. APPLICATION EXAMPLES AND EXPERIMENTS
In this section, we present experiments on two relevant
applications. These experiments demonstrate the utility of de-
sign optimization using PAFGs. In both of these experiments,
we carried out a sequence of passivization transformations
by hand, and implemented the original dataflow graph and
the optimized PAFG (derived through the transformations)
using the lightweight dataflow environment (LIDE) [14]. In
this work, we have developed extensions in LIDE to provide
complete support for design and implementation using PAFGs,
including features that allow implementation and interfacing
of non-simple passive blocks. The experiments for both appli-
cations are conducted on an Intel Core i7-2600K Quad-core
Fig. 5. Dataflow graph for EVM measurement.
CPU running Ubuntu Linux 16.04 LTS, and using GCC 5.4.0
for code compilation.
A. Error Vector Magnitude Computation
The error vector magnitude (EVM) is a figure of merit for
signal quality in communication systems. EVM computation is
an important application in measurement and test equipment
for communications. For background on EVM computation,
we refer the reader to [15].
A dataflow graph for measuring the EVM for a given
reference signal and received signal is shown in Figure 5. This
is a dynamic dataflow graph modeled using CFDF semantics,
as supported in LIDE. Here, SRC1 provides on each ith
firing the input data length for the ith EVM computation. The
actors SRC2 and SRC3 provide the real and imaginary parts,
respectively, of the reference signal; and similarly, SRC4 and
SRC5 provide the real and imaginary parts of the received
signal. The actor FA is a fork actor (see Section I), which
broadcasts data to multiple output ports. The actors RFC and
RCC are interleavers that interleave corresponding pairs of
input tokens so that the real and imaginary parts of each signal
sample are arranged in successive elements of the actors’
output streams. The actors E and RFM compute the error
vector and reference signal magnitude, respectively. The actor
RMS computes the root mean square (RMS) ke of the error
signal and the RMS kr of the reference signal, and derives
the EVM result as the ratio ke/kr. The actors RFA and EA
compute the average magnitudes of the reference and error
signals, respectively. The SNK actor represents the output
interface of the graph; in our experiments, we use a file writing
interface.
We first derive a direct PAFG, which represents the im-
plementation of the application graph (Figure 5) using pure
dataflow semantics. To the direct PAFG, we apply the pas-
sivization transformation three times with respect to the actors
FA, RFC and RCC. All three of these actors are simply-
surrounded, and can be implemented efficiently in passive
form.
The resulting optimized PAFG is illustrated in Figure 6.
We use a minor abuse of notation where non-simple blocks
in the PAFG are labeled with the same names as their
corresponding actors in the application graph. Blocks labeled
as SPB represent simple passive buffers.
Table II compares the performance of the direct and trans-
formed PAFGs. Through passivization, the throughput is im-
Fig. 6. Optimized PAFG for EVM measurement.
65&
63%
'9/
675
)60
757
5(55(/)73+6
'$6
'%6
)
63%
)
)
)
63%
)
)
63%
63%
63%)
63%
Fig. 7. Optimized PAFG for jitter measurement application.
proved by about 31.88%, and the buffer memory requirement
(BMR) is reduced by about 25%. We define the BMR of
a PAFG G as the total memory requirement for all passive
blocks in G.
TABLE II
RESULTS FOR THE EVM APPLICATION.
Throughput
(samples/sec)
BMR (MB)
Direct PAFG 7.93× 105 29.30
Optimized PAFG 1.05× 106 21.97
B. Jitter Measurement Application
Jitter measurement is another important application for real-
time signal processing in communication systems. In this
section, we apply PAFG-based modeling and optimization for
a jitter measurement system design that is presented in [16].
For details on this system design, including the dataflow model
and the constituent actors, we refer the reader to [16].
An important parameter in the jitter measurement system
is the window size, which determines the number of samples
that are processed in a given dataflow graph iteration. Larger
window sizes in general improve the throughput at the expense
of a larger BMR [16].
Again, we first derive the direct PAFG and then transform
this into an optimized PAFG through a sequence of pas-
sivization transformations. In this transformation process, we
convert the six fork actors in the design, from active to passive
buffer form. The resulting optimized PAFG is illustrated
in Figure 7. In this figure, the non-simple passive blocks
corresponding to the fork actors are denoted F1, F2, . . . , F6.
Table III shows the improvement measured from the opti-
mized PAFG compared to the direct PAFG for different win-
dow sizes. From these results, we see significant improvements
delivered by the optimized PAFG in terms of the trade-off
between throughput and BMR. For the optimized PAFG, the
BMR ranges from 0.38MB to 6.0MB for increasing window
sizes, and the throughput ranges from 1.9 × 106 samples/sec
to 3.1× 106 samples/sec.
TABLE III
RESULTS FOR THE JITTER MEASUREMENT APPLICATION.
Window size 16,384 32,768 65,536 131,072 262,144
Throughput 11% 7.0% 7.7% 6.5% 7.0%
BMR 60% 60% 60% 60% 60%
VI. CONCLUSION AND FUTURE WORK
In this paper, we have introduced passive-active flow-
graphs (PAFGs) as a model of computation that complements
dataflow models for design and implementation of signal
processing systems. PAFGs generalize the concept of dataflow
edges into multi-input, multi-output components that are called
“passive blocks”. PAFGs provide a new approach to integrat-
ing designer-specified memory management optimization sys-
tematically into the framework of dataflow-based design and
implementation. In addition to presenting details of the PAFG
model of computation, we have introduced the passiviza-
tion transformation, which can be used iteratively to derive
progressively more efficient PAFGs. We have demonstrated
the utility of PAFGs and the passivization transformation on
two important signal processing applications. Useful directions
for future work include automating the equivalence checking
between active and passive versions of a given actor, and
the generalization of relevant methods in this paper beyond
alternating PAFGs.
VII. ACKNOWLEDGMENTS
This research was supported in part by the U.S. National
Science Foundation.
REFERENCES
[1] E. A. Lee and T. M. Parks, “Dataflow process networks,” Proceedings
of the IEEE, pp. 773–799, May 1995.
[2] S. S. Bhattacharyya, E. Deprettere, R. Leupers, and J. Takala, Eds.,
Handbook of Signal Processing Systems, 2nd ed. Springer, 2013.
[3] E. A. Lee and D. G. Messerschmitt, “Synchronous dataflow,” Proceed-
ings of the IEEE, vol. 75, no. 9, pp. 1235–1245, September 1987.
[4] S. Fischaber, R. Woods, and J. McAllister, “SoC memory hierarchy
derivation from dataflow graphs,” in Proceedings of the IEEE Workshop
on Signal Processing Systems, October 2007.
[5] H. Oh and S. Ha, “Fractional rate dataflow model and efficient code
synthesis for multimedia applications,” ACM SIGPLAN Notices, vol. 37,
July 2002.
[6] S. Stuijk, M. Geilen, and T. Basten, “Exploring tradeoffs in buffer re-
quirements and throughput constraints for synchronous dataflow graphs,”
in Proceedings of the Design Automation Conference, July 2006.
[7] S. S. Bhattacharyya and E. A. Lee, “Memory management for syn-
chronous dataflow programs,” Electronics Research Laboratory, Univer-
sity of California at Berkeley, Tech. Rep. UCB/ERL M92/128, 1992.
[8] P. K. Murthy and S. S. Bhattacharyya, “Buffer merging — a powerful
technique for reducing memory requirements of synchronous dataflow
specifications,” ACM Transactions on Design Automation of Electronic
Systems, vol. 9, no. 2, pp. 212–237, April 2004.
[9] K. Desnos, M. Pelcat, J.-F. Nezan, and S. Aridhi, “Buffer merging
technique for minimizing memory footprints of synchronous dataflow
specifications,” in Proceedings of the International Conference on
Acoustics, Speech, and Signal Processing, 2015, pp. 1111–1115.
[10] C. Hsu, M. Ko, S. S. Bhattacharyya, S. Ramasubbu, and J. L. Pino,
“Efficient simulation of critical synchronous dataflow graphs,” ACM
Transactions on Design Automation of Electronic Systems, vol. 12, no. 3,
p. 21, 2007, 28 pages.
[11] J. T. Buck and E. A. Lee, “Scheduling dynamic dataflow graphs using
the token flow model,” in Proceedings of the International Conference
on Acoustics, Speech, and Signal Processing, April 1993.
[12] S. Tripakis, D. Bui, M. Geilen, B. Rodiers, and E. A. Lee, “Compo-
sitionality in synchronous data flow: Modular code generation from
hierarchical SDF graphs,” ACM Transactions on Embedded Computing
Systems, vol. 12, no. 3, 2013.
[13] W. Plishker, N. Sane, M. Kiemb, and S. S. Bhattacharyya, “Heteroge-
neous design in functional DIF,” in Proceedings of the International
Workshop on Systems, Architectures, Modeling, and Simulation, 2008,
pp. 157–166.
[14] S. Lin, Y. Liu, K. Lee, L. Li, W. Plishker, and S. S. Bhattacharyya, “The
DSPCAD framework for modeling and synthesis of signal processing
systems,” in Handbook of Hardware/Software Codesign, S. Ha and
J. Teich, Eds. Springer, 2017, pp. 1–35.
[15] R. Schmogrow et al., “Error vector magnitude as a performance measure
for advanced modulation formats,” IEEE Photonics Technology Letters,
vol. 24, no. 1, pp. 61–63, 2012.
[16] Y. Liu, L. Barford, and S. S. Bhattacharyya, “Constant-rate clock
recovery and jitter measurement on deep memory waveforms using
dataflow,” in Proceedings of the IEEE International Instrumentation and
Measurement Technology Conference, 2015, pp. 1590–1595.
