MATLAB 板


LINE

小弟的程式如下 A=[0 0 0 0 0 17 17 19 19 19 17 17 17 17 17] B=[0 0 0 0 0 22 22 24 24 24 24 24 24 24 24] C=[A;B] 0,0 出現5次 17,22 出現2次 19,24 出現3次 17,24 出現4次 直向量的個數有15個 在C的一個矩陣下挑出次數最多的直向量,且要最少個數,還要不包含零 所以挑第11組(17,24)的直向量,並取得11這個數值 小弟還有其他矩陣,例如矩陣為11*15(這個範例是2*15) 請問大大這樣的程式要如何寫呢? 謝謝 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.102.186.20
※ 文章網址: https://webptt.com/m.aspx?n=bbs/MATLAB/M.1468513354.A.22C.html ※ 編輯: popo14777 (59.102.186.20), 07/15/2016 00:26:59
1F:→ celestialgod: [N,Xedges,Yedges]= histcounts2(A, B, 0:24, 0:24) 07/15 00:50
2F:→ celestialgod: N就是所求 07/15 00:50
3F:→ celestialgod: N=histcounts2(A, B, 1:17, 1:24); 07/15 00:51
4F:→ celestialgod: 更正,17跟24可以用A跟B的最大值代替 07/15 00:51
5F:→ celestialgod: 對不起 我想錯了 07/15 00:53
6F:→ popo14777: C大這個方法還是不行耶 07/15 09:12
7F:→ popo14777: 喔喔,看到你新發的一封了 07/15 09:15
8F:推 YoursEver: 我會建議設 D = C + random_noise; 然後對D的col vec做 07/15 10:43
9F:→ YoursEver: clustering. 看分群的結果,cluster數就是不同的相量數, 07/15 10:45
10F:→ YoursEver: 每個cluster內的資料點數,就是出現次數. 07/15 10:46
11F:→ YoursEver: 不過當資料不夠大不夠多的時候,不要用這個方法,因為 07/15 10:46
12F:→ YoursEver: 不見得能省計算複雜度. 07/15 10:46
13F:→ popo14777: 謝謝Y大,但我最重要的問題要如何得到11這個數值喔 07/15 13:33
14F:→ popo14777: 已解決,謝謝各位C大與Y大的幫忙 07/17 09:49
15F:推 sunev: CC=C(:,all(C,1)); 07/18 13:35
16F:推 sunev: [N,Xedges,Yedges]=histcounts2(CC(1,:),CC(2,:),... 07/18 13:42
17F:→ sunev: 'BinMethod','integers'); 07/18 13:42
18F:→ sunev: [~,I]=max(N(:));[i,j]=ind2sub(size(N),I); 07/18 13:42
19F:→ sunev: find(C(1,:)==ceil(Xedges(i))&C(2,:)==ceil(Yedges(j))... 07/18 13:43
20F:→ sunev: ,'BinMethod','integers') 07/18 13:43
21F:→ celestialgod: s大你那樣不能用超過2個column的,我有想過XD 07/18 19:16
22F:推 sunev: 啊呀,本來想練習histcounts2的,那還是只能用unique rows 07/18 19:38
23F:→ sunev: [CC,Ia,Ic]=unique(C(:,all(C,1))','rows'); 07/18 19:39
24F:→ sunev: N=histc(Ic,1:size(CC,1));[~,I]=max(N); 07/18 19:39
25F:→ sunev: find(all(bsxfun(@eq,CC(I,:)',C),1),1,'first') 07/18 19:40
26F:推 sunev: 這個版本可能快一點,少一個find及二維@eq,多一個max 07/18 19:54
27F:→ sunev: [CC,Ia,Ic]=unique(C(:,all(C,1))','rows'); 07/18 19:54
28F:→ sunev: N=histc(Ic,1:size(CC,1));[~,I]=max(N); 07/18 19:54
29F:→ sunev: if ~all(CC(I)),N(I)=[];Ia(I)=[];[~,I]=max(N);end 07/18 19:55
30F:→ sunev: Ia(I) 07/18 19:55
31F:推 YoursEver: 這個問題,我考慮的點一直是: 如果是高維向量該怎麼辦? 07/19 11:36
32F:→ YoursEver: 所以才會在一開始想直接在高維空間上做clustering, 07/19 11:37
33F:→ YoursEver: 後來改成採取hashing的概念,把向量換算成某個scalar, 07/19 11:38
34F:→ YoursEver: 接下來就只需要從一串scalar裡面找眾數而已. 07/19 11:39
35F:→ YoursEver: 我比較有興趣知道,如果當輸入的k-by-N矩陣非常大的時候 07/19 11:40
36F:→ YoursEver: 該用什麼觀點看這個問題會比較有效率... 07/19 11:41
37F:→ YoursEver: 例如: 如果 k=256, N=100,000 這種規模. 07/19 11:42
38F:推 sunev: 就偷懶用內建unique rows來處理vector -> scalar的問題 07/19 13:13







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燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP