MATLAB 板


LINE

各位版友好: 最近在實作演算法 sub routine 時遇到了效能問題,sub routine 的目標是在給 定Z矩陣的情況下,找到最好的W來使得 L(ZW) + C*Tr(W'W)最小,其中Loss function 的 長相是 \sum_{(i,j) sample} -R_{ij}log(sigmoid(ZW_{ij}))-(1-R_{ij})log(1-sigmo id(ZW_{ij})), R 是觀察到的資料,取值在{0,1}。C 是 regularization constant. 然後 minimize function 的gradient 會是 ▼W = Z'▼L(ZW)+2CW 資料型態 : Z 會是一個 N*K 的sparse 矩陣, W 會是 K*N 的 dense 矩陣 , R 會是 N*N 的 sparse 矩陣 (只考慮有被抽樣的點), N >>> K, N/K = 10^2~10^3 。 當前解法 : 之前已經實作了一個 Z 是 dense 的版本,由 matlab 經由 mex 把資料傳到 C裡,然後我再在C裡使用 liblbfgs library 求解傳回。而我需要做的事就是給定w 求 gradient給liblbfgs,目前的複雜度是 nnz(R)*K (算ZW) + nnz(R)*K (算Z'▼L) + K^2 (算+CW) 現在我有問題的點是我有很多可能的改進方向,不知道該選擇什麼比較好。 (1) 沿用原本的架構,只是將Z是sparse 也考慮進去,再自己利用迴圈實作sparse 矩陣乘 法,複雜度應該是 nnz(R)*K*r (evaluate ZW, 其中因為Z的row sparse,在算ZW_ij可能 平均起來只要做 rK 次) + nnz(R)*K*r (同理) + K^2 結果 : 速度大概會變快1/r 倍 優 : 我只要改改code就好,也不用學新東西 缺 : 因為自己實作,不會平行處理,沒有利用到 multi core (2) 在做稀疏矩陣乘法時直接使用類似Intel-MKL 的library 來加速 優 : 簡單,之前有修過數值方法,還記得怎麼call API 缺 : 我不太清楚要怎麼使用ICC 來編譯mex file,不知是否相容,可以 mex -setup ICC? 不清楚實際怎麼implement,無法細緻的分析 (3) 交由GPU來計算,不管是在C裡自己寫還是就直接在matlab 裡做,用matlab提供的GPU API 優: 可以很平行的處理?學習GPU運算增強自己的能力XD 缺: 沒有寫過這樣利用GPU去做事的程式,learning curve有點抖,可能需要花很多時間找 資料或實作,一樣可能很難分析。 (4) 可能還有其他方法? 或者要進一步考慮Block Algorithm 或 catch affinity 版友覺得應該朝哪個方向努力呢?這個subroutine會很常被call到,效能是非常重要的考量 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.112.218.160
※ 文章網址: https://webptt.com/m.aspx?n=bbs/MATLAB/M.1507742158.A.5F3.html
1F:推 sunev: 你哪部份是用matlab script,哪部份是用mex,哪部份是用C? 10/12 01:27
抱歉沒有講清楚,由於演算法還在早期研究正確性,目前主要是使用matlab,但為了加快 W求解,所以寫了一個mex function 從 matlab 讀入 Z,W,R 等資料,在這個mex function 處理好變數的傳遞後,會call一個普通的C++ function,然後計算都在上面。 ※ 編輯: InnocentMage (140.112.218.160), 10/12/2017 01:33:06
2F:推 sunev: matlab內建sparse,要刻一個BFGS也不是很難。你的瓶頸在哪 10/12 01:29
我原本是覺得matlab不夠快,而手邊又有C++的lbfgs solver http://www.chokkan.org/software/liblbfgs/ 所以想把它用mex file 接起來,目前的瓶緊是 lbfgs 每個iteration 算得不夠快,而這個library 需要自己實作evaluate 就是在給定W下gradient 會是啥,所以才想優化這部分。 ※ 編輯: InnocentMage (140.112.218.160), 10/12/2017 01:38:20
3F:推 sunev: BFGS的哪個部份不夠快,現在gradient是用matlab還是用C算? 10/12 01:57
4F:→ sunev: 所以你有用過matlab的BFGS然後嫌不夠快,改用C確實變快? 10/12 02:03







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP