大家好
小弟目前正在跑一個計算
流程大致上是這樣
先產生一個empty matrix
用for迴圈跑不同的參數 ex. for x = 0 : 0.01 : 0.12
每次都解一個大型矩陣
大概10000x10000
每次會解出10000個eigenvalue
接著把這個10000個eigenvalue用column方式儲存到empty matrix中
所以跑完之後那個empty矩陣就會變成
[[v_0] [v_0.01] [v_0.02] ... [v_0.12] ]
每個v都代表一個 10000x1 的column
接下來再把這個矩陣的"每一個row"依次對x = 0 : 0.01 : 0.12 作圖
所以會畫出10000條線
原本10000x10000的case我的電腦還是可以跑
但再變大幾倍後就會出現out of memory
我想了幾種解決方法,但不清楚怎麼執行,請各位大大幫幫我
(1)
我想說out of memory應該是因為最後那個empty matrix會變超大
所以想說能不能自行產生10000個empty matrix
每次解完一次10000x10000矩陣的eigenvalue後 把column中每個元素依次存在
那10000個empty matrix中
這樣的話最後就會有10000個矩陣
但是每個矩陣都是小小的row (ex. 0:0.01:0.12 大概才1*13的 row array而已)
我希望程式碼大概長這樣
for i = 1 : 1 : 10000 ;
造出"名字是 Ai "的empty matrix ; ←這邊不會用orz
end
for x = 參數 ;
解10000x10000的矩陣
解出10000x1的eigenvalue column vector(假設叫他v)
把每個元素依次存在對應的Ai empty matrix中
for j = 1 : 1 : 10000 ;
Aj = [Aj v(j)] ; ←這邊不會用orz
end
end
不知道這樣把矩陣拆成10000個小矩陣的方法能不能解決
(2)
研究室好像有大型電腦 但我的project以理論推導為主 幾乎沒碰過
如果用大型電腦幫我跑的話 能不能用我最一開始的流程呢?
就是直接存一個超大容量的矩陣 再一次對個別row作圖
我是希望最後最上面那個流程可以處理70000x70000的矩陣
不知道大型電腦有沒有辦法解決out of memory的問題
小弟仍在學習matlab
關於以上幾點問題希望各位指教
謝謝