看板 Fortran 關於我們 聯絡資訊
※ 引述《kuang01 (我叫小劉)》之銘言: : 想請問各位大大 : 在fortran 一維矩陣裡 : do i=1,5 : A(i)=2 : enddo : 這樣會是 一colum vector 還是 row vector : 因為我在matlab裡 : 如果把 do 換成for : 這樣去寫 會出現 row vector : 想請問 fortran 的一維跟matlab是否不太一樣 底下的人回答大致正確,因為對指標上來說,確實沒差別, 但是你有這種問題,甚至刻意的去區別到底一個一維陣 列是row還是column vector也不是壞事. 因為在記憶體的使用上,fortran確實是by column,而C based的語言,例如C/C++,Matlab,Scilab,Python都是 by row.也就是說,當你往記憶體裡面填入一個二維陣 列時,fortran會讓同一個column的資料作連續的排列. 因此當你在記憶體裡面填值或讀值的時候,在fortran應 該要先作column vector,而Matlab,C/C++,Python等應該要 先做row vector,在記憶體的使用上才是連續的讀寫,不會 一直跳躍. 這個影響還不只是讀寫效率的問題,那還只是其次的,作 不好頂多效率比較低,但是當你要讓by column跟by row 的語言相互傳值時,問題才出現. 例如你想在C-based的語言裡面使用fortran寫成的library, 例如lapack.因為你會把C裡面的一塊記憶體傳到fortran中, 但因為C是將同一個row的資料在記憶體中作連續排列,跟 fortran對記憶體的使用方式剛好相反,所以當你把資料傳入 時,fortran在理解這個陣列時,行列都會顛倒了.所以當你要 把C裡面的值傳到fortran時,往往需要先轉秩才能傳入.反之 亦然. -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 168.150.122.1 ※ 文章網址: http://www.ptt.cc/bbs/Fortran/M.1418933953.A.2EE.html
gilocustom: Matlab是column-major。 12/19 17:57
gilocustom: 話說雖然一般認知都當做Fortran是column-major,但是 12/19 17:58
gilocustom: 在標準書中似乎沒有此規範,會是約定俗成或是取決於 12/19 17:58
gilocustom: 實做嗎? 12/19 17:59
wenni: 是因為Fortran實際存array記憶體是以colume major方式去存 12/19 23:23
wenni: 所以才會特別這樣說 也因此在做do-loop時先column效能較好 12/19 23:24
gilocustom: 請問樓上:你所謂的「實際」是指標準就有明文規定嗎? 12/20 02:18
pipidog: 不是約定成俗,你讓他跟c互傳資料就會發現有問題了。 12/20 02:19
gilocustom: 若既不在標準規範內,且亦非約定俗成(又名:歷史包袱) 12/20 02:51
gilocustom: ,則代表有些編譯器可能是column-major,有些則可能是 12/20 02:52
gilocustom: row-major,意即某些編譯器的Fortran與C溝通時即便不 12/20 02:53
gilocustom: 轉置也不會有資料錯置的狀況(假設C規範是row-major)。 12/20 02:53
gilocustom: 我了解本文的意思,我一直以來也都是這麼被告知的, 12/20 03:05
gilocustom: 我好奇的是這說法究竟是人云亦云,還是明文規定? 12/20 03:05
kkarthur: 判斷是否column-major可以寫隻小程式計算運行的時間 12/24 18:00
kkarthur: 就可以很快地看出差異,不過現在的compiler都有最佳化 12/24 18:00
kkarthur: 直接用預設的選項去編譯程式是看不出來差異的 12/24 18:01
kkarthur: 可以額外加上把最佳化關掉的指令,就可以看出差異來 12/24 18:02