Verification of Magnitude and Phase Responses in Fixed-Point Digital
  Filters by de Mello, Daniel P. M. et al.
ar
X
iv
:1
70
6.
05
08
8v
1 
 [c
s.L
O]
  1
6 J
un
 20
17
XXXV SIMPO´SIO BRASILEIRO DE TELECOMUNICAC¸O˜ES E PROCESSAMENTO DE SINAIS - SBRT2017, 3-6 DE SETEMBRO DE 2017, SA˜O PEDRO, SP
Verification of Magnitude and Phase Responses
in Fixed-Point Digital Filters
Daniel P. M. de Mello1, Mauro L. de Freitas2, Lucas C. Cordeiro1, Waldir S. S. Ju´nior1,
Iury V. de Bessa1, Eddie B. L. Filho1,3 and Laurent Clavier2
1Universidade Federal do Amazonas (UFAM), Manaus-AM, Brasil
2Univ. Lille, CNRS, ISEN, Univ. Valenciennes, UMR 8520, IEMN, 59000 Lille, France
3Samsung Instituto de P&D da Amazoˆnia (SIDIA), Manaus-AM, Brasil
Email: dani-dmello@hotmail.com, m.lopesdefreitas@ed.univ-lille1.fr, lucascordeiro@ufam.edu.br,
waldirjr@ufam.edu.br, iurybessa@ufam.edu.br, eddie.l@samsung.com, laurent.clavier@iemn.univ-lille1.fr
Abstract—In the digital signal processing (DSP) area, one of
the most important tasks is digital filter design. Currently, this
procedure is performed with the aid of computational tools, which
generally assume filter coefficients represented with floating-point
arithmetic. Nonetheless, during the implementation phase, which
is often done in digital signal processors or field programmable
gate arrays, the representation of the obtained coefficients can
be carried out through integer or fixed-point arithmetic, which
often results in unexpected behavior or even unstable filters. The
present work addresses this issue and proposes a verification
methodology based on the digital-system verifier (DSVerifier),
with the goal of checking fixed-point digital filters w.r.t. im-
plementation aspects. In particular, DSVerifier checks whether
the number of bits used in coefficient representation will result
in a filter with the same features specified during the design
phase. Experimental results show that errors regarding frequency
response and overflow are likely to be identified with the proposed
methodology, which thus improves overall system’s reliability.
I. INTRODUCTION
Digital Filters with finite impulse response (FIR) or infinite
impulse response (IIR) are used in different areas, such as
digital signal processing (DSP), control systems, telecommu-
nications, medical instrumentation, and consumer electronics.
In general, such applications vary from simple frequency
selection and adaptive filters to equalizers and filter banks,
whose objective is to modify the characteristics of a certain
signal, in accordance with pre-established requisites.
Digital filter design follows an abundant mathematical the-
ory, both in frequency and time domains, and is usually
realized with tools as MATLAB [1], which normally assume
fixed- or floating-point precision. Nonetheless, there can be
a great disparity between a filter design and its practical
implementation. For instance, many projects are implemented
in digital signal processors (DSPS) or field programmable
gate arrays (FPGA), which can employ finite precision, based
on fixed-point arithmetic (with lower cost and complexity),
whereas the associated design usually assume floating-point
precision.
This difference has the potential of generating undesir-
able effects regarding a filter’s frequency response, both in
phase and magnitude, in addition to problems as overflow
and instability. Such behavior is due to quantization errors
caused by finite precision, which result in coefficients that are
different from the ones originally designed. As a result, there
might be questions, in the implementation phase, regarding the
effectiveness of digital filters and the number of bits needed
for their representation, in such a way that design parameters
are also satisfied.
This article presents a verification methodology for digital
filters with fixed-point implementation, based on the Effi-
cient SMT-Based Context-BoundedModel Checker (ESBMC),
which employs Bounded Model Checking (BMC) techniques
and Satisfiability Modulo Theories (SMT) [3], [4]. Such
an approach indicates, according to previously defined filter
parameters, if the chosen number of bits is sufficient and does
not lead to unexpected errors or behaviors. The main advantage
of this approach, over other filter analysis techniques [5], [6],
is that model-checking tools can provide precise information
on how to reproduce errors (for instance, system input values)
through counterexamples.
In order to apply the proposed methodology to digital filter
verification, the Digital System Verifier (DSVerifier) tool was
used, which is a front-end tool for the verification of different
types of digital systems, with the aid of BMC techniques.
An implementation written in C was developed and integrated
into DSVerifier [17], [18], because it was unable to support
the verification of filter-specific properties, such as magnitude
and phase, prior to this work. Various kinds of practical digital
filters were used for verification, with the goal of validating
them against real designs. As a result, such a verifier, together
with traditional design tools, provide a complete digital filter
synthesizing scheme, according to application conditions.
Indeed, the present approach is effective in verifying mag-
nitude and phase responses, which provides an analysis deeply
based on DSP theory and fills gaps presented in the existing
literature. The performed experiments are based on a set of
publicly available benchmarks.2
This work is organized as follows. Section II presents the
verification schemes available in the literature, highlighting
its main characteristics. In section III, the BMC technique
is presented. Then, in section IV, the proposed method is
described, and section V presents the simulations results.
Finally, the conclusions are set out in section VI.
2The benchmarks are available at http://www.esbmc.org/benchmarks/sbrt2017.zip
XXXV SIMPO´SIO BRASILEIRO DE TELECOMUNICAC¸O˜ES E PROCESSAMENTO DE SINAIS - SBRT2017, 3-6 DE SETEMBRO DE 2017, SA˜O PEDRO, SP
II. RELATED WORK
The application of tools that implement the BMC technique,
regarding software verification, is becoming quite popular,
mainly due to the advent of sophisticated SMT solvers,
which are constructed based on efficient satisfiability solvers
(SAT) [7]. Previously published studies related to SMT-based
BMC, for software, handle the problem of verifying ANSI-
C programs that use bit operations, fixed- and floating-point
arithmetic, comparisons and pointers arithmetic [3]; however,
there is little evidence of studies that address the verification of
properties related to digital filters implementation, in ANSI-C,
especially when assuming arbitrary word-length. One of such
studies was previously conducted by Freitas et al. [2], where
digital filter properties, such as overflow, magnitude and stabil-
ity, were verified by employing ESBMC. Those results served
as main inspiration for the present work, whose proposal is
to further extend and reproduce the verified properties, while
creating a support for them on the DSVerifier tool. Now this
new implementation allows passband filters verifications.
Akbarpour and Tahar [8], [9] presented a mechanical ap-
proach for error detection in digital-filter design, which is
based on a high-order logic (HOL) theorems solver. The
authors describe valuation functions that find the real values
of a digital filter’s output, through fixed- and floating-point
representations, aiming to define an error. The latter represents
the difference between the encountered values, through this
valuation function, and the output corresponding to design
specifications.
Recently, Cox, Sankaranarayanan and Chang [10] intro-
duced a new approach that uses precise bit analysis for the
verification of digital filter implementations, in fixed-point.
This approach is based on the BMC technique and employs
SMT solvers for checking verification conditions, which are
generated in the digital-filter design phase. The authors show
that such an approach is more efficient and produces fewer
false alarms, if compared to those that use real arithmetic
solvers; however, the mentioned studies do not address in-
trinsic filters characteristics, such as errors or modifications
related to poles, zeros, or frequency response.
Abreu et al. also proposed a new methodology for the
verification of digital filters, named as DSVerifier, which is
based on state-of-the-art bounded model checkers that support
full C and employ solvers for boolean satisfiability and satisfi-
ability modulo theories [17]. In addition to verifying overflow
and limit-cycle occurrences, DSVerifier can also check output
errors and time constraints, based on discrete-time models
implemented in C.
The findings presented in the previous studies served as
inspiration for the present article, which aims to extend the
approach proposed by Cox, Sankaranarayanan and Chang [10]
and Abreu et al. [17] includes new digital filter properties to
be checked, such as magnitude and phase responses, which
provides an analysis closed related to DSP theory. In addition,
this work applies DSVerifier, which is a model checking
tool to investigate finite word-length (FWL) effects in digital
systems implementations, to the verification of a more diverse
set of benchmarks, including different classes of filters (e.g.,
passband filters).
III. THE BMC TECHNIQUE
With ESBMC, a program under analysis is modeled by a
state transition system, which is generated from the program
control-flow graph (CFG) [11] that is automatically created
during the verification process. A node in a CFG represents an
assignment (deterministic or nondeterministic) or a conditional
expression, while an edge represents a change in a program’s
flow.
A state transition system M = (S, T, S0) is an abstract ma-
chine, which consists in a state set S, where S0 ⊆ S represents
a initial state set and T ⊆ S × S is the transition relation. A
state s ∈ S consists of the value of a program counter pc and
also the values of all variables in an application. An initial state
s0 assigns the program’s initial location γ = (si, si+1) ∈ T , in
the CFG. The transitions are identified as between two states
si and si+1, with a logical formula γ(si, si+1) that contains
the value restrictions of the program counter and the system’s
variables.
Given a transition system M , a property φ and a bound
k, ESBMC unfolds a system x times and transforms the
associated result into a verification condition ψ, in such a
way that ψ is satisfiable if φ contains a counterexample with
length smaller than x [3]. Thus, the BMC technique problem
is formulated as follows
ψx = I(s0) ∧
x∨
i=o
i−1∧
j=0
γ(sj , sj+1) ∧ φ(si), (1)
where φ is a property, I is a set of the initial states in M ,
and γ(sj, sj+1) is the state transition function of M between
steps j and j+1. Thus, I(s0)∧
∧i−1
j=0 γ(sj , sj+1) represents the
execution of M for i times and eq. (1) will only be satisfied
if, and only if, for each i ≤ x, there is a reachable state where
φ is violated. If eq. (1) is satisfiable, then ESBMC shows a
counterexample, defining which variable values are needed to
lead to the related error. The counterexample for a property φ
is a state sequence s0, s1, ..., sx with s0 ∈ S0 and γ(si, si+1)
, for 0 ≤ i < x. If eq. (1) is not satisfied, one can conclude
that no error stateis reachable with x steps or less.
IV. THE NEW VERIFICATION METHODOLOGY
In general, the fixed-point implementation uses standard
registers to store the inputs and outputs along the adders,
multipliers, and delays. However, the results of these elements
might exceed the limits of the allocated variables, or generate
different values than expected, due to the coefficients accuracy
or the associated number of bits. As a result, it is possible that
the result differs from the one specified in the design or even
that a filter becomes unstable without this occurring in the
filter design.
With this in mind, the proposed verification methodology is
split into three main parts: magnitude and phase verification,
poles and zeros stability, and overflow verification.
A. Magnitude and phase verification
Changes in the coefficients, due to the fixed-point quan-
tization, alter the response in magnitude and phase [9]. An
example of this can be seen in Fig. 1.
In this first approach, the input of the proposed verification
system is composed by the filter coefficients in floating-point
XXXV SIMPO´SIO BRASILEIRO DE TELECOMUNICAC¸O˜ES E PROCESSAMENTO DE SINAIS - SBRT2017, 3-6 DE SETEMBRO DE 2017, SA˜O PEDRO, SP
by the design properties, which must be analyzed according to
the adopted conditions, such as passband, cut-off frequency,
rejection band, as well as the gains in each region and the
amount of bits used for the representation in the fixed-point.
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9
−350
−300
−250
−200
−150
−100
−50
0
Normalized Frequency (×pi rad/sample)
M
ag
ni
tu
de
 (d
B)
Magnitude Response (dB)
Fig. 1. Magnitude response of IIR Chebyshev filter with order 12. The
blue curve represents the projected answer and the green curve the response
with fixed-point containing one sign bit, 7 bits for the integer and 6 for the
fractional parts
Given that N is the number of points of the Discrete-Time
Fourier Transform (DTFT) [12], h[n] is the filter impulse
response and Hk is the k-th component of it’s sampled
equivalent in frequency domain, we have that
Hk =
N−1∑
n=0
h(n)e−j(2pi/N)kn. (2)
In addition, suppose that ωp, ωr and ωc are the digital
frequencies of passband, stopband and cutoff, respectively.
In turn, Ap, Ar and Ac are the gains that will be checked.
We assumed the following assertions to verify magnitude and
phase properties for lowpass and highpass filters.
Ilp mag ⇔
[(
|Hk| < Ap
)
∧
(
0 ≤ 2pik
N
≤ ωp
)]
∨[(
|Hk| > Ac
)
∧
(
2pik
N
= ωc
)]
∨[(
|Hk| > Ar
)
∧
(
ωr ≤
2pik
N
≤ pi
)]
, (3)
Ihp mag ⇔
[(
|Hk| > Ar
)
∧
(
0 ≤ 2pik
N
≤ ωr
)]
∨[(
|Hk| < Ac
)
∧
(
2pik
N
= ωc
)]
∨[(
|Hk| < Ap
)
∧
(
ωp ≤
2pik
N
≤ pi
)]
(4)
and
Ilp phase,
Ihp phase
⇔ |∢H(k)− ∢Hfixed(k)| > threshold. (5)
In case of assertion violation, an error is generated to indicate
that the amount of bits is insufficient for the representation,
taking into account the initial design restrictions.
B. Poles and zeros verification
Jury’s algorithm is used to check the stability in the z-
domain for a given characteristic polynomial of the form
S(z) = a0z
N + a1z
N−1 + ...aN−1z + aN = 0, a0 6= 0 (6)
In particular, Jury stability test is already explained in the
control system literature [20]. This study, however, limits itself
to explain the SMT encoding of Jury’s criteria. For the stability
test procedure, the following Jury matrixM = [mij ](2N−2)×N
is built from S(z) coefficients:
M =


V (0)
V (1)
.
.
.
V (N−2)

 , (7)
where V (k) = [v
(k)
ij ]2×N such that
v
(0)
ij =
{
aj−1, if i = 1
v
(0)
(1)(N−j+1)
, if i = 2
, and (8)
v
(k)
ij =


0, if j > n− k
v
(k−1)
1j − v
(k−1)
2j ·
v
(k−1)
11
v
(k−1)
21
, if j ≤ n− k and i = 1
v
(k)
(1)(N−j+1)
, if j ≤ n− k and i = 2
, (9)
where k ∈ Z, such that 0 < k < N − 2. S(z) is the
characteristic polynomial of a stable system if and only if the
following four propositions hold:
• R1: S(1) > 0;
• R2: (−1)NS(−1) > 0;
• R3: |a0| < aN ;
• R4: m11 > 0 ⇐⇒ m31 ∧m51 ∧ · · · ∧m(2N−3)(1) .
The stability property is then encoded by creating a con-
straint using the fixed size bit-vector theory, typically sup-
ported by state-of-the-art SMT solvers [19]:
φstability ⇐⇒ (R1 ∧ R2 ∧ R3 ∧ R4), (10)
where the literal φstability represents the validity of the sta-
bility condition; in particular, the SMT-solver checks whether
Jury criteria hold for the characteristic polynomial coefficients.
C. Overflow verification
The third part concerns the overflow verification after the
coefficients quantization, which would be considered infeasi-
ble without computational tools.
The addition, subtraction, multiplication, and division op-
erations allow the fixed-point representation; however, losing
precision to respect the bits limitation amount. The overflow
happens when the bits representation is violated. In order to
better understand it we will study two overflow types.
Definition 1. The saturation occurs when values outside of the bit
range are represented by the minimum or maximum values.
Despite the easy possibility to find the limits, it would be
difficult to know which input will create the saturations.
Definition 2. The wrapping around occurs when the maximum value
is attributed instead of a minimum value and vice-versa [10].
The input verification has nondeterministic fixed-point num-
bers x˜[n], the h[n] filter coefficients that will be verified and
the number of inputs N . All the overflow check iterations are
given by
Ioverflow ⇔
[(
x˜[n]h[0] > Vmax
)
∨(
x˜[n− 1]h[1] > Vmax
)
∨
. . .(
x˜[n−N − 1]h[N − 1] > Vmax
)]
(11)
XXXV SIMPO´SIO BRASILEIRO DE TELECOMUNICAC¸O˜ES E PROCESSAMENTO DE SINAIS - SBRT2017, 3-6 DE SETEMBRO DE 2017, SA˜O PEDRO, SP
To detect an error, a counterexample is generated. This
counterexample consists of the violated states, providing ac-
cess to the inputs which generated the error, in a specific
order, as well as the output value. This approach gives to the
filter designer information to understand the error conditions
of overflow and underflow, allowing the desginer to come up
with an alternative implementation.
V. EXPERIMENTS
This section consists of two parts. The system configura-
tion is described in Section V-A, while Section V-B sum-
marizes our objectives with the experiments conducted and
Section V-C describes the results obtained with the DSVerifier
tool1 [3], [4], [17], [18], implementing the changes regarding
the filter magnitude and phase, as well as the preexisting
functions for verification of stability and overflow.
A. System configuration and preparation for the experiments
The set of magnitude and phase verification where split into
two main groups: one consisting of IIR filters and another
of FIR filters. Each set is divided into 3 categories: lowpass,
highpass and bandpass, with three filters of small order (2nd
or 4th order), and three filters with high order (12th or 30th
order) in each set for different cut-off frequencies. Three
types of IIR filters were used: Butterworth, Chebyshev, and
Elliptic. For FIR filters, the types Equiripple, Hann Window,
and Maximally Flat.
Altogether, 54 stable filters were created during the design
stage, with 18 FIR and 36 IIR, with sample frequency of
48kHz. All filters transfer functions were obtained with
the Filter Design and Analysis Tool application available in
MATLAB [1] and written in a “.c” file according to the input
specifications for DSVerifier.
Aiming to explore different theories employed on the
SMT [3] solvers, non-integer numbers were encoded in two
different ways: in binary (when bit vector arithmetics is used)
and also in real (when using rational arithmetic). The fixed-
point representation was performed by dividing the number to
be represented between its integer part I , with m bits, and its
fractional part F , with n bits [15]. This approach is represented
within the tuple 〈I, F 〉, which can be encoded both in bit
vectors and rational arithmetic and is interpreted as I+F/2n.
Thus, all the represented values must be between the maximum
and minimum expected values, that is
Vmax = 2
m − 1/2n, (12)
Vmin = −2
m (13)
and
Vmin ≤ vfixed ≤ Vmax. (14)
All experiments were conducted with a Intel Core i7-2600
PC, with 3.40GHz of clock speed and 16GB RAM and
64-bits Ubuntu as operational system. The verification times
presented in the following tables are related to the average
CPU time measured with the times system call (POSIX
system) of 20 consecutive executions for each benchmark,
where the measurement unit is always in seconds.
1http://www.dsverifier.org
B. Experimental Objectives
While creating our benchmark, we aimed for the variety
of filter parameters, such as order, frequency and type, so we
could demonstrate the usefulness of the method in all sorts of
situations. Some filters were defined with an extremely short
interval of passband, so that DSVerifier was taken to the limit
when trying to represent unrealistically challenging situations.
C. Results
Table I summarizes the verification results of phase and
magnitude, with the first letter in the identification name
indicating which filters are FIR and which are IIR. Filters
that contain “hp” are high-pass, while “lp” stands for low-
pass. The filter order is displayed as the number in each
filter identification name. Columns “CF”, “PF” and “SF”
indicate, respectively, the cut-frequency, the pass-frequency
and the stop-frequency in kHz used when synthesizing the
filters. Some of these frequencies are not employed (indicated
by “NE”) in the design specifications of certain filter types.
“VTM” stands for the verification time for magnitude, while
“SM” stands for the magnitude verification status. The status
can be either Successful (S), Passband fail (FP), Stopband fail
(FS) or Cutoff-frequency fail (FC) . SP is the status for phase
verification. The phase status can be either Successful (S) or
Fail (F). FP represents the quantity of bits used for fixed-
point representation. The minimum gain, for the passband,
is fixed in −1dB in Eliptic filters, while the maximum gain
for stopband is fixed in −80dB for Eliptical and Chebychev
filters. These specifications apply for both low-pass and high-
pass filters. Near identical criteria were used for band-pass
filters, except that now a pair of each region frequencies is
needed too the fully specification of the project. All filters in
table I were verified considering a fixed-representation tuple
of〈4, 10〉, except by the second order filters, where 〈1, 5〉 was
used.
The results for magnitude verification of band-pass filters
are included on table II. It’s important noting that instead of
a single frequency as specification, now a frequency pair is
used. The column “FP tuple” indicates the considered FWL
constriction.
The poles and zeros verification occurred in the set of
IIR filters and the result is shown in table III. “VT” stands
for the verification time, in seconds, and “SPZ” represents
the status of the verification. It is worth noting the results
for filters with cutoff-frequency of 100Hz since magnitude
failures were found for all IIR filters. Table IV presents the
results of overflow verifications, which indicates the efficacy
on the detection of this type of error. All the tested filters were
IIR, that were also used in Table I.
VI. CONCLUSION
The present work proposed a methodology for the verifi-
cation of digital filter design parameters through the BMC
technique, which indicates if the amount of bits used in the
representation of the coefficients and samples changes the
previously specified characteristics. During the simulations,
both IIR and FIR filters were addressed, in order to ensure
the outcome of real projects, in different realizations and
applications. The results show that it is possible to detect low
XXXV SIMPO´SIO BRASILEIRO DE TELECOMUNICAC¸O˜ES E PROCESSAMENTO DE SINAIS - SBRT2017, 3-6 DE SETEMBRO DE 2017, SA˜O PEDRO, SP
TABLE I
MAGNITUDE AND PHASE VERIFICATION OF IIR AND FIR FILTERS.
IIR filters CF PF SF TVM SM SP
ilp2 9.6 Na Na 5.25 S S
ihp2 9.6 Na Na 5.39 S S
ilp2EST 0.1 Na Na 207.34 FP F
ilp12 9.6 Na Na 17.07 S F
ihp12 9.6 Na Na 17.15 S F
ilp12EST 0.1 Na Na 423.56 FP F
ilp4C Na 9.6 Na 173.44 FP F
ihp4C Na 9.6 Na 162.24 FS S
ilp4ESTC Na 0.1 Na 163.70 FS F
ilp12C Na 9.6 Na 430.85 FS F
ihp12C Na 9.6 Na 432.66 FS S
ilp12ESTC Na 0.1 Na 523.98 FP F
ilp4E Na Na 9.6 161.44 FP S
ihp4E Na Na 9.6 164.64 FP F
ilp4ESTE Na Na 0.1 164.68 FS F
ilp12E Na Na 9.6 460.18 FP F
ihp12E Na Na 9.6 429.14 FP F
ilp12ESTE Na Na 0.1 455.35 FP F
fhp10 7.2 Na 9.6 14.63 S S
flp10 9.6 Na 9.6 1902.8 FC S
fhp30 9.6 Na 9.6 1164.9 S S
flp30 Na Na 9.6 41.02 S S
flp10EST 0.1 Na 0.1 14.95 S F
flp30EST Na Na 0.1 41.91 S S
fhp10Equi 9.6 Na 9.6 360.9 FS S
flp10Equi 9.6 Na 9.6 70.8 FP S
fhp30Equi 9.6 Na 9.6 1043.2 FP S
flp30Equi Na Na 9.6 1061.3 FS F
flp10ESTEqui 0.1 Na 0.1 363.59 FP F
flp30ESTEqui Na Na 0.1 1052.6 FP S
fhp10Hann 9.6 Na 9.6 361.84 FC F
flp10Hann Na Na 9.6 15.42 S S
fhp30Hann 9.6 Na 9.6 41.91 S S
flp30Hann 9.6 Na 9.6 40.25 S F
flp10ESTHann Na Na 0.1 15.36 S F
flp30ESTHann Na Na 0.1 41.22 S S
TABLE II
MAGNITUDE VERIFICATION OF IIR PASSBAND FILTERS.
IIR filters CF Pairs PF Pairs SF Pairs TVM SM FP tuple
ipb2 7.2, 16.8 Na Na 106.46 FP <1,5>
ipb12 7.2, 16.8 Na Na 17.20 S <4,10>
ipb12EST 7.2, 7.32 Na Na 349.95 FP <4,10>
ipb4E Na 7.2, 16.8 Na 160.24 FP <4,10>
ipb12E Na 7.2, 16.8 Na 447.75 FP <4,10>
ipb12ESTE Na 7.2, 7.32 Na 438.95 FS <4,10>
ipb4C Na Na 7.2, 16.8 140.27 FP <4,10>
ipb12C Na Na 7.2, 16.8 564.95 FS <10,16>
ipb12ESTC Na Na 7.2, 7.92 445.73 FS <10,16>
TABLE III
STABILITY VERIFICATION OF IIR FILTERS.
IIR filters O FC (Hz) Time (s) SPZ FP tuple
hp12 12 9600 1.35 S <4,10>
hp12C 12 9600 1.35 S <4,10>
hp12E 12 9600 79.99 F <4,10>
hp2 2 9600 1.20 S <1,5>
hp4E 4 9600 1.52 S <4,10>
lp12 12 9600 1.35 S <4,10>
lp12C 12 9600 1.30 S <4,10>
lp12E 12 9600 79.83 F <4,10>
lp12ESTC 12 100 1.88 F <4,10>
lp12ESTE 12 100 79.94 F <4,10>
lp2 2 9600 1.16 S <1,5>
lp4E 4 9600 1.22 S <4,10>
TABLE IV
OVERFLOW VERIFICATION OF IIR FILTERS.
Filter Order Time (s) FP tuple Status
lp2 2 77.184 <1,5> S
hp2 2 90.034 <1,5> F
lp4E 4 185.945 <1,5> F
hp4E 4 184.254 <1,5> F
and medium order filters with a moderate verification time.
The main contributions of this work are the incorporations of
parameters related to filter design theories such as magnitude
and phase responses and the location of poles and zeros, which
complements the more computational tests, such as overflow,
as well as adding support for the filter related verifications in
the DSVerifier tool. For future work, it would be of interest
incorporating other parameters and the automatic acquisition
of the minimum number of bits for the successful validation
of the filter design, at fixed-point.
AKNOWLEDGMENTS
The authors would like to thank FAPEAM, CNPq, IRCICA
and CAPES, for the financial aid.
REFERENCES
[1] Mathworks, Inc., “Matlab Getting Started Guide R2011b”, USA, 2011.
[2] M. de Freitas, M. Gadelha, W. da Silva Jr., E. de Lima Filho,
“Verificac¸a˜o de Propriedades de Filtros Digitais Implementados com
Aritme´tica de Ponto Fixo”, XXXI Brazilian Telecommunications Sym-
posium, pp. 1-4, 2013.
[3] L. Cordeiro, B. Fischer e J. M. Silva, “SMT-Based Bounded Model
Checking for Embedded ANSI-C Software”, IEEE Transactions on
Software Engineering (TSE), v. 38, n.4, pp. 957–974, 2012.
[4] L. Cordeiro e B. Fischer, “Verifying Multi-threaded Software using
SMT-based Context-Bounded Model Checking”. in Proc. Int. Conf. on
Software Engineering (ICSE), pp. 331–340, IEEE/ACM, 2011.
[5] A. Oppenheim, R. Schafer e J. Buck, “Discrete-time signal processing”,
Prentice-Hall, Inc., Ed. 2, 1999.
[6] W. T. Padgett and D. V. Anderson, “Fixed-point signal processing”,
Synthesis Lectures on Signal Processing, vol. 4, no. 1, pp. 1–133, 2009.
[7] L. de Moura e N. Bjrner, “Z3: An efficient SMT solver”, in Proc. Int.
Conf. on Tools and Algorithms for the Construction and Analysis of
Systems (TACAS), LNCS 4963, pp. 337–340, 2008.
[8] B. Akbarpour e S. Tahar: “Error Analysis of Digital Filters Using
Theorem Proving”. in Proc. Int. Conf. on Theorem Proving in Higher
Order Logics (TPHOLs), pp. 1–17, 2004.
[9] B. Akbarpour e S. Tahar. “Error analysis of digital filters using HOL
theorem proving”. Journal Applied Logic, v.5, n. 4, pp. 651–666, 2007.
[10] A. Cox, S. Sankaranarayanan, e Bor-Yuh E. Chang, “A bit too precise?
Bounded verification of quantized digital filters”, in Proc. Int. Conf.
on Tools and Algorithms for the Construction and Analysis of Systems
(TACAS), pp. 33–47, 2012.
[11] S. S. Muchnick, “Advanced compiler design and implementation.”,
Morgan Kaufmann Publishers Inc., 1997.
[12] P. Diniz, E. Silva e S. Netto, “Processamento Digital de Sinais - Projeto
e Anlise de Sistemas”, Bookman Editora, 2002.
[13] S. Chandrasekaran, M. Gu, J. Xia e J. Zhu. “A Fast QR Algorithm for
Companion Matrices. Operator Theory: Advances and Applications”,
vol 179, pp. 111–143.
[14] D. C. Lay. Linear Algebra: Case Studies and Applications.
[15] I. Bessa, H. Ismail, L. Cordeiro, J. Chaves Filho, “Verification of
fixed-point digital controllers using direct and delta forms realizations”.
Design Autom. for Emb. Sys. 20(2): 95-126 (2016).
[16] M. Hraschan e M. Viertler, “FIR vs IIR Filter”,
http://secure.spsc.tugraz.at/courses/vwa/papergr6, accessed 10 April
2017.
[17] R. Abreu, M. Gadelha, L. Cordeiro, E. de Lima Filho, W. da Silva Jr.:
Bounded model checking for fixed-point digital filters. Journal of the
Brazilian Computer Society. v. 22, n. 1, pp. 1–20, May 2016.
[18] H. Ismail, I. Bessa, L. Cordeiro, E. de Lima Filho, J. Chaves Filho:
DSVerifier: A Bounded Model Checking Tool for Digital Systems. in
Proc. Int. Conf. on Symposium on Model Checking of Software (SPIN):
pp. 126-131, 2015.
[19] L. Keel and S. Bhattacharyya, Stability margins and digital implemen-
tation of controllers, in Proc. Amer. Control Conf., vol. 5, 1998, pp.
28522856.
[20] I. Bessa, H. Ismail, R. Palhares, L. Cordeiro, and J.Chaves Filho
”Non-Fragile Stability Verification of Digital Control Systems with
Uncertainty, in IEEE TRANSACTIONS ON COMPUTERS, VOL. 66,
NO. 3, 2017.
