programmable fir and simulation

P

PawelT

Guest
Hello,
I tried to simulate example of generic FIR filter on page 82 from
book Uwe Meyer "Digital Signal Processing with FPGAs".
In book in simulation the first valid output is after 475 ns and zeros
before that.
I tried this example with MAxplus2 Baseline v10.2 and with new
ACF-file. Does anybody compile this?
After compilation and simulation on outputs Y_OUT there is appeared
unexpected new value dec*2046* after 125ns till 325ns,
and after 475 ns there is "correct" value from book.
And my question is: why this *unexpected* value (2046) appeared ?
I tried change options with original ACF-file and *this* value
appeared after changing Assign->Global Project Logic
Synthesis...->Optimize=10 (speed) to Optimize=5 (default value).
After that I tried change number of pipeline stages in lpm_mult, and
this *unexpected* value disappeared when constant Mpipe=1. For
Mpipe=2,3,4 there is bad value....
Any suggestions?
I tried this also with Quartus Web Edition 3.0 and simulation
generates bad Y_OUT....
May I attache this source vhdl code on usenet? I think about
copyrights..
Regards,
PawelT.


Pozdrawiam,
PawelT
 
For discussion I include the code of fir example.


-- This is a generic FIR filter generator
-- It uses W1 signed bit data/coefficients bits
LIBRARY lpm; -- Using predefined packages
USE lpm.lpm_components.ALL;

LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.std_logic_arith.ALL;
USE ieee.std_logic_unsigned.ALL;

ENTITY fir_prog IS ------> Interface
GENERIC (W1 : integer := 9; -- Input bit width
W2 : integer := 18;-- Multiplier bit width 2*W1
W3 : integer := 19;-- Adder width = W2+log2(L)-1
W4 : integer := 11;-- Output bit width
L : integer := 4; -- Filter length
-- for Mpipe = 1 output Y_OUT is OK (PT)
Mpipe : integer := 3-- Pipeline steps of multiplier
);
PORT ( clk : IN STD_LOGIC;
Load_x : IN STD_LOGIC;
x_in : IN STD_LOGIC_VECTOR(W1-1 DOWNTO 0);
-- c_in : IN STD_LOGIC_VECTOR(W1-1 DOWNTO 0); -- (PT)
y_out : OUT STD_LOGIC_VECTOR(W4-1 DOWNTO 0));
END fir_prog;

ARCHITECTURE arch_fir OF fir_prog IS

SUBTYPE N1BIT IS STD_LOGIC_VECTOR(W1-1 DOWNTO 0);
SUBTYPE N2BIT IS STD_LOGIC_VECTOR(W2-1 DOWNTO 0);
SUBTYPE N3BIT IS STD_LOGIC_VECTOR(W3-1 DOWNTO 0);
TYPE ARRAY_N1BIT IS ARRAY (0 TO L-1) OF N1BIT;
TYPE ARRAY_N2BIT IS ARRAY (0 TO L-1) OF N2BIT;
TYPE ARRAY_N3BIT IS ARRAY (0 TO L-1) OF N3BIT;

SIGNAL x : N1BIT;
SIGNAL y : N3BIT;
SIGNAL c : ARRAY_N1BIT; -- Coefficient array
SIGNAL p : ARRAY_N2BIT; -- Product array
SIGNAL a : ARRAY_N3BIT; -- Adder array

BEGIN

Load: PROCESS ------> Load data or coefficient
BEGIN
WAIT UNTIL clk = '1';
IF (Load_x = '0') THEN
-- load coefs from X_IN input (PT)
c(L-1) <= x_in; -- Store coefficient in register
FOR I IN L-2 DOWNTO 0 LOOP -- Coefficients shift one
c(I) <= c(I+1);
END LOOP;
ELSE
x <= x_in; -- Get one data sample at a time

END IF;
END PROCESS Load;


SOP: PROCESS (clk, load_x) ------> Compute sum-of-products
BEGIN
IF clk'event and (clk = '1') THEN
FOR I IN 0 TO L-2 LOOP -- Compute the transposed
a(I) <= (p(I)(W2-1) & p(I)) + a(I+1); -- filter adds
END LOOP;
a(L-1) <= p(L-1)(W2-1) & p(L-1); -- First TAP has
END IF; -- only a register
y <= a(0);
END PROCESS SOP;

-- Instantiate L pipelined multiplier
MulGen: FOR I IN 0 TO L-1 GENERATE
Muls: lpm_mult -- Multiply p(i) = c(i) * x;
GENERIC MAP ( LPM_WIDTHA => W1, LPM_WIDTHB => W1,
LPM_PIPELINE => Mpipe,
LPM_REPRESENTATION => "SIGNED",
LPM_WIDTHP => W2,
LPM_WIDTHS => W2)
PORT MAP ( clock => clk, dataa => x,
-- this line to turn-off pipelining (PT)
-- PORT MAP ( dataa => x,
datab => c(I), result => p(I));
END GENERATE;
y_out <= y(W3-1 DOWNTO W3-W4);
END arch_fir;
 
PawelT wrote:
Hello,
I tried to simulate example of generic FIR filter on page 82 from
book Uwe Meyer "Digital Signal Processing with FPGAs".
In book in simulation the first valid output is after 475 ns and zeros
before that.
I tried this example with MAxplus2 Baseline v10.2 and with new
ACF-file. Does anybody compile this?
After compilation and simulation on outputs Y_OUT there is appeared
unexpected new value dec*2046* after 125ns till 325ns,
and after 475 ns there is "correct" value from book.
And my question is: why this *unexpected* value (2046) appeared ?
I'm guessing that since your flip-flops are not initialized upon reset,
what you are seeing is the time it takes for your filter taps (and
coefficients?) to settle down with valid values. For many designs, this
type of behavior is not a problem. - but you'll have to be the judge of
that for your situation.

After that I tried change number of pipeline stages in lpm_mult, and
this *unexpected* value disappeared when constant Mpipe=1. For
Mpipe=2,3,4 there is bad value....
[...
May I attache this source vhdl code on usenet?
Of course. It often helps in diagnosing problems.

I think about copyrights..
Once posted to usenet, you have little control of the code. You can
place a copyright on it, but enforcement can be near impossible.

Marc
 

Welcome to EDABoard.com

Sponsor

Back
Top