High dimension matrix algebra

2 views (last 30 days)
Pouya Jamali
Pouya Jamali on 16 Nov 2014
Commented: Matt J on 1 Feb 2015
Hi there,
I'm trying to solve a set of linear equations by using Matlab syntax '\'. This properly works for dimensions less than 100000-by-100000. But for higher orders it starts to produce an error regarding the lack of enough memory and for dimensions greater than one million it says maximum variable size is exceeded.
Please help me to see how can I tackle this problem. I have a 10000000-by-10000000 set of equations to solve.

Accepted Answer

Jan
Jan on 16 Nov 2014
To store a 10000000-by-10000000 matrix you need 800TB Memory - assuming that it is full. As a rule of thumb the double size of free memory is recommended.
Do you see the problem?
  4 Comments
Pouya Jamali
Pouya Jamali on 1 Feb 2015
But Matlab doesn't even allow me to make a Matrix of zeros of that size!
Matt J
Matt J on 1 Feb 2015
That's what the sparse() command is for...so you don't have to allocate all the zeros occurring in your matrix.

Sign in to comment.

More Answers (1)

Matt J
Matt J on 16 Nov 2014
You may have to use pcg() or some other iterative method.
  2 Comments
Pouya Jamali
Pouya Jamali on 16 Nov 2014
I can't workaround your suggestion because Matlab even doesn't allow me to use zeros for pre-allocating this space to the coefficient matrix.
Matt J
Matt J on 16 Nov 2014
Edited: Matt J on 16 Nov 2014
This properly works for dimensions less than 100000-by-100000.
I'm pretty amazed you were able to get this to work on non-sparse matrices of that size. You must have a tonne of RAM.

Sign in to comment.

Categories

Find more on Operating on Diagonal Matrices in Help Center and File Exchange

Products

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!