High dimension matrix algebra

2 Ansichten (letzte 30 Tage)
Pouya Jamali
Pouya Jamali am 16 Nov. 2014
Kommentiert: Matt J am 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.

Akzeptierte Antwort

Jan
Jan am 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 Kommentare
Pouya Jamali
Pouya Jamali am 1 Feb. 2015
But Matlab doesn't even allow me to make a Matrix of zeros of that size!
Matt J
Matt J am 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.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Matt J
Matt J am 16 Nov. 2014
You may have to use pcg() or some other iterative method.
  2 Kommentare
Pouya Jamali
Pouya Jamali am 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 am 16 Nov. 2014
Bearbeitet: Matt J am 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.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Operating on Diagonal Matrices finden Sie in Help Center und File Exchange

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by