calculate Y Y = A * X * At

V

VHDL_HELP

hi every body ,
my problem is how to calculate Y = A * X * At , Y,A,At are matrix of
N*N dimension At is the transpose of A
please help me
 
J

Jonathan Bromley

hi every body ,
my problem is how to calculate Y = A * X * At , Y,A,At are matrix of
N*N dimension At is the transpose of A
please help me

With which part of this? Matrix multiplication? The transpose
operation? Coding arithmetic in VHDL?

My suggestions to you:

(1) To clarify your own thinking, take a rather small value of N
such as N=3, and then write out the calculations long-hand.
The result Y then has only 9 elements, so you should be able
to see how each element of Y is calculated as a function of the
elements of A and X. Once you have seen the way this works
for small N, you should be able to generalise it for any N
in the form of sums of products that will then map on to
"for" loops in any reasonable programming language.

(2) Now, decide what your VHDL module is expected to do.
Will you see all N^2 elements of A, and all N elements of X,
simultaneously on a large set of inputs? Or must you fetch
these values from some memory where they have previously
been saved? Or, perhaps, A is a constant matrix and it's only
the values of X that change. All these questions dramatically
affect the overall shape of your design, and the techniques
you must use to implement it. No VHDL coding yet!

(3) Next, think about speed/area trade-offs. For any of these
matrix-manipulation tasks, you have a choice: do all the
calculations simultaneously using a large number of arithmetic
units (adders and multipliers), or use a smaller number of
arithmetic units - possibly as few as one - and perform the
calculation iteratively over many clock cycles, using some
memory element to store the intermediate results.

(4) Finally, when you know what you are trying to achieve,
you should be able to start writing the VHDL without too
much trouble.

It would have been a courtesy to this newsgroup if you had
taken the trouble to do (1), and at least some of (2), and
think about (3), before asking for help on VHDL which
affects only part (4). I do not intend to do your algebra
homework for you, and I doubt anyone else does either.
--
Jonathan Bromley, Consultant

DOULOS - Developing Design Know-how
VHDL * Verilog * SystemC * e * Perl * Tcl/Tk * Project Services

Doulos Ltd., 22 Market Place, Ringwood, BH24 1AW, UK
(e-mail address removed)
http://www.MYCOMPANY.com

The contents of this message may contain personal views which
are not the views of Doulos Ltd., unless specifically stated.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
474,172
Messages
2,570,933
Members
47,472
Latest member
blackwatermelon

Latest Threads

Top