This forum has been archived. All content is frozen. Please use KDE Discuss instead.

SVD and temporaries

Tags: None
(comma "," separated)
Adolfo Rodriguez
Registered Member
Posts
5
Karma
0

SVD and temporaries

Tue Jul 14, 2009 4:06 pm
Hi all,

I've been checking out eigen's SVD implementations, the JAMA-based of 2.03 and the very recent quick-and-dirty (non-Eigenized) port from numerical recipes.

I've noticed that in both cases temporary matrices/vectors are created

Our application is such that in certain parts (real-time code) no dynamic memory allocations should be made, and we require computing SVDs. The ideal scenario for us would be to create an instance of SVD in the non-real-time part of the code, and perform all allocations there, and call SVD.compute in the real-time part.

The question is then, what are your thoughts on differing all memory allocation to the object construction phase? are there any important cons to this besides having additional class members?

...and just out of curiosity, will the numeric recipes algorithm stay in eigen (with the adequate modifications), or no decision has been made yet on the subject?

Thanks in advance,

Adolfo.
User avatar
ggael
Moderator
Posts
3447
Karma
19
OS

Re: SVD and temporaries

Thu Jul 16, 2009 7:13 am
Actually the SVD is going to be rewritten, and don't worry we'll take care of preallocating everything that can be: this is the main reason in having a compute() method.
Adolfo Rodriguez
Registered Member
Posts
5
Karma
0

Re: SVD and temporaries

Fri Jul 17, 2009 10:12 am
Cool :)

Indeed, that's the nice thing of having the compute() method!

Cheers,

Adolfo
myguel
Registered Member
Posts
14
Karma
0

Re: SVD and temporaries

Thu Jul 23, 2009 5:17 pm
I need a pseudo-inverse calculation and as I did not find one in the SVD module, I was planning to submit a patch for it.
I think even with a rewritting of the SVD, such a patch will be usefull in the meantime.
Do you have a schedule for the rewritting of the SVD?
Do you think a pseudoinverse method should be part of the API of matrixBase, as for the inverse method?

P.S. I noticed that the method matrixU, matrixV, etc are not declared inlined, is there some particular reason for that?

P.P.S. I also noticed that the types Scalar, RealScalar, MatrixUType, MatrixVType and SingularValuesType are private even if some are the return type of public methods. I have the same interrogation: what is the reason for that design choice?
myguel
Registered Member
Posts
14
Karma
0

Re: SVD and temporaries

Thu Jul 23, 2009 10:03 pm
I have almost finished to write the patch.
However I notice a strange thing. I don't know if you plan to change it in the rewritten version.
It happens if the numbers of rows and columns are different.

The API choose to represent the rectangular diagonal matrix, D, of U * D * V^*, as a vector of singular values which has the same size than the number of columns.

It is fine if the number of columns is smaller than the number of rows but otherwise it introduces zeros at random places in the vector.
The consequence is that it is not possible to easily construct the rectangular diagonal matrix.

In this case I choose to sort the vector and take the first entries to construct the rectangular diagonal matrix.
However it makes the calculi awkward.
I wonder if it could not be possible in the compute() method to transpose the input matrix, take its svd and copy the transpose of the resulting matrices back instead.

Ok, again this workaround is not very interesting since you are rewritting the module...
However I wanted to point out this problem.
User avatar
bjacob
Registered Member
Posts
658
Karma
3

Re: SVD and temporaries

Sun Jul 26, 2009 8:53 am
OK, i'm really starting the SVD rewrite now.

Yes, pseudoinverse is always useful, it's independent of the SVD rewrite!

According to this:
http://en.wikipedia.org/wiki/Moore%E2%8 ... SVD_method

the pseudoinverse is quite trivial to compute from the SVD.


Join us on Eigen's IRC channel: #eigen on irc.freenode.net
Have a serious interest in Eigen? Then join the mailing list!


Bookmarks



Who is online

Registered users: Bing [Bot], blue_bullet, Google [Bot], Sogou [Bot]