High dimension matrix algebra

2 次查看(过去 30 天)
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.

采纳的回答

Jan
Jan 2014-11-16
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 个评论
Pouya Jamali
Pouya Jamali 2015-2-1
But Matlab doesn't even allow me to make a Matrix of zeros of that size!
Matt J
Matt J 2015-2-1
That's what the sparse() command is for...so you don't have to allocate all the zeros occurring in your matrix.

请先登录,再进行评论。

更多回答(1 个)

Matt J
Matt J 2014-11-16
You may have to use pcg() or some other iterative method.
  2 个评论
Pouya Jamali
Pouya Jamali 2014-11-16
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 2014-11-16
编辑:Matt J 2014-11-16
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.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Operating on Diagonal Matrices 的更多信息

产品

Community Treasure Hunt

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

Start Hunting!

Translated by