R_Language 板


LINE

一部分原始資料 ## Distance matrix #實際上有十幾個站位 COM01 AR01 PA01 PA02 COM01 0 8 112 110 AR01 8 0 118 116 PA01 112 118 0 4 PA02 110 116 4 0 ## spp matrix #實際上有十萬多個物種 COM01 AR01 PA01 PA02 OTU1 7774 4 310 12 OTU2 5 0 81 9 OTU3 0 0 71 1 OTU4 1 0 0 0 把error的資訊跟traceback留在下面: Error in dist.mat[pair[1], pair[2]] : subscript out of bounds 19. FUN(newX[, i], ...) 18. apply(., 2, function(pair) { dist.mat[pair[1], pair[2]] }) 17. function_list[[i]](value) 16. freduce(value, `_function_list`) 15. `_fseq`(`_lhs`) 14. eval(expr, envir, enclos) 13. eval(quote(`_fseq`(`_lhs`)), env, env) 12. withVisible(eval(quote(`_fseq`(`_lhs`)), env, env)) 11. y[y != 0] %>% names(.) %>% combn(., 2) %>% apply(., 2, function(pair) { dist.mat[pair[1], pair[2]] }) %>% max(.) 10. FUN(newX[, i], ...) 9. apply(., 1, function(y) { if (sum(y >= 2)) { y[y != 0] %>% names(.) %>% combn(., 2) %>% apply(., 2, function(pair) { ... 8. function_list[[k]](value) 7. withVisible(function_list[[k]](value)) 6. freduce(value, `_function_list`) 5. `_fseq`(`_lhs`) 4. eval(expr, envir, enclos) 3. eval(quote(`_fseq`(`_lhs`)), env, env) 2. withVisible(eval(quote(`_fseq`(`_lhs`)), env, env)) 1. OTU_location[, c("COM01", "AR01", "PA01", "PA02", "GJ01", "QK01", "AK03", "SH01", "SI02", "TA01", "GG01", "DSZ01", "SM22", "LGH03")] %>% as.matrix %>% apply(., 1, function(y) { if (sum(y >= 2)) { ... ※ 引述《andrew43 (討厭有好心推文後刪文者)》之銘言: : 大致上這樣做。 : ## site 座標 : location <- : data.frame( : site.name = c("site1", "site2", "site3"), : x = c(3,1,16), : row.names = 1 : ) : ## site 距離矩陣 : dist.mat <- : dist(as.matrix(location)) %>% : as.matrix : dist.mat : ## 各site物種出現豐度 : spp.dt <- : data.frame( : spp = c("A", "B"), : site1 = c(5,4), : site2 = c(0,7), : site3 = c(20,2) : ) : library(magrittr) : spp.dt[, c("site1", "site2", "site3")] %>% : as.matrix %>% : apply(., 1, function(y) { : y[y != 0] %>% : names(.) %>% : combn(., 2) %>% : apply(., 2, function(pair) { : dist.mat[pair[1], pair[2]] : }) %>% : max(.) : }) : ※ 引述《lilian0330 (俐俐)》之銘言: : : 大家好,剛開始統計軟體入門,寫過Matlab跟R : : 但最近在處理資料常常不知道怎麼解決error... : : [問題] : : 要做物種出現的「最大距離」,例如有三個地點,在三個點之間有三個不相等的距離。 : : 而物種A出現在site1跟site3,所以距離就是distance(1-3) : : 物種B出現在site1,2,3,但因為2跟3比較遠,最大距離是distance(2-3) : : 我目前已經做出來兩兩site之間的distance matrix : : 但是我不知道用while迴圈怎麼讓R自動判斷這個物種的「最大距離」 : : 資料形式 : : Species| site1 | site2 | site3 | max_distance : : ------------------------------------------------------- : : A | 5 | 0 | 20 | distance(1-3) : : B | 4 | 7 | 2 | distance(2-3) : : 我目前想到的邏輯是 : : table[1,2]-table[1,3]!=table[1,2]|table[1,3] : : 依序做成這個物種的「所有距離」,最後再用max()選擇「最大距離」 : : 想問問大家如果寫成while loop怎麼寫比較好呢? : : [環境敘述]: : : R version 3.3.2 (2016-10-31) : : Platform: x86_64-w64-mingw32/x64 (64-bit) : : Running under: Windows >= 8 x64 (build 9200) : : locale: : : [1] LC_COLLATE=Chinese (Traditional)_Taiwan.950 LC_CTYPE=Chinese : : (Traditional)_Taiwan.950 : : [3] LC_MONETARY=Chinese (Traditional)_Taiwan.950 LC_NUMERIC=C : : [5] LC_TIME=Chinese (Traditional)_Taiwan.950 : : attached base packages: : : [1] stats graphics grDevices utils datasets methods base : : other attached packages: : : [1] sp_1.2-4 phyloseq_1.19.1 BiocInstaller_1.24.0 : : readxl_0.1.1 ggplot2_2.2.1 : : [6] vegan3d_1.0-1 vegan_2.4-2 lattice_0.20-34 : : permute_0.9-4 : : loaded via a namespace (and not attached): : : Error in x[["Version"]] : subscript out of bounds : : In addition: Warning messages: : : 1: In FUN(X[[i]], ...) : : : DESCRIPTION file of package 'Rcpp' is missing or broken : : 2: In FUN(X[[i]], ...) : : : DESCRIPTION file of package 'jsonlite' is missing or broken --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.112.69.189
※ 文章網址: https://webptt.com/m.aspx?n=bbs/R_Language/M.1491327979.A.06C.html
1F:→ andrew43: 資料和你差不多大的例子 http://tinyurl.com/luhs2hs 04/05 05:35
2F:→ andrew43: 改用for loop寫,慢很多但夠應付了。 04/05 05:37
3F:→ andrew43: 會額外回傳最遠的二個site名 04/05 05:38
4F:→ andrew43: 建議你還是提何「可重覆錯誤的確實資料與R code」不然 04/05 05:40
5F:→ andrew43: 一直隔空抓藥會浪費彼此時間。 04/05 05:40
6F:→ andrew43: s/提何/提供/ 04/05 05:41







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

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

TOP