R_Language 板


LINE

試試看這是不是你要的,沒有再試其他方法,可能有更快的解法.. 如果不要那個 偵測 > 5 的criteria, 可以不要那些if else 直接回傳which.min library(data.table) library(Imap) data <- fread('Lon Lat 100.7200 13.61500 100.6683 13.52000 100.5717 13.54500 100.5750 13.69333 100.5783 13.82333 100.3983 13.90833') mindst <- function(i,x,y,criteria=NA) { y$id <- seq_len(nrow(y)) if(!is.na(criteria)) { idx <- which(y$Lon<=x$Lon[i]+criteria & y$Lat<=x$Lat[i]+criteria) if (!any(idx)) { return(0L) } y <- y[idx,] } y$id[which.min(sapply(1:nrow(y),function(j) { gdist(x$Lon[i],x$Lat[i], y$Lon[j],y$Lat[j], units = "nm",verbose = FALSE)} ))] } set.seed(123L) temp <- data.table(Lon=100.0+sample.int(1000,size=1000, replace=T)/100, Lat=10.0+sample.int(100,size=1000, replace=T)/10) system.time(out1 <- sapply(1:nrow(data),mindst, x=data, y=temp)) system.time(out2 <- sapply(1:nrow(data),mindst, x=data, y=temp, criteria=5)) #> system.time(out1 <- sapply(1:nrow(data),mindst, x=data, y=temp)) # user system elapsed # 0.86 0.00 0.86 #> #> system.time(out2 <- sapply(1:nrow(data),mindst, x=data, y=temp, criteria=5)) # user system elapsed # 0.41 0.00 0.40 #> out1 #[1] 289 289 289 289 326 326 #> out2 #[1] 289 289 289 289 326 326 ※ 引述《giock18 (小武)》之銘言: : [問題類型]: : 程式諮詢(我想用R 做某件事情,但是我不知道要怎麼用R 寫出來) : [軟體熟悉度]: : 入門(寫過其他程式,只是對語法不熟悉) : [問題敘述]: : 我有兩組經緯度座標,每組資料長得像這樣 : data$Lon data$Lat : 100.7200 13.61500 : 100.6683 13.52000 : 100.5717 13.54500 : 100.5750 13.69333 : 100.5783 13.82333 : 100.3983 13.90833 : 另一組稱為temp : temp$Lon & temp$Lat : 其中一組是參考地標的經緯度,另外一組是實際的軌跡 : 我使用gdist來算出點和點之間的距離,並找最小值, : 也就是最靠近這個地標的點。 : 因此我的程式碼這樣寫 : for (i in nrow(data)){ : closest<-which.min(gdist(data$Lon[i], : OFPdata$Lat[i],temp$LONGITUDE,temp$LATITUDE,units = "nm",verbose = FALSE) )} : 用迴圈的方式去找每個地標對應到的最靠近軌跡 : which.min雖然有用,但是應該是因為原本lmap::gdist的設計是輸入單值, : 但我卻給他一欄資料,所以他會跳出警告如下,雖然程式還是可以work, : 但想知道有沒有更正確的寫法? : Warning messages: : 1: In while (abs(lamda - lamda.old) > 1e-11) { : : the condition has length > 1 and only the first element will be used : 2: In while (abs(lamda - lamda.old) > 1e-11) { : : the condition has length > 1 and only the first element will be used : 另外,為了提升程式的效率,想要將軌跡與地標的計算迭代縮小成 : 經度或緯度差5度以內的才計算,不知道有甚麼方法可以達成呢? : 我有在stackoverflow發問,原文網址如下: : https://stackoverflow.com/questions/46843802/find-the-nearest-point-using-lmapgdist-function : 先謝謝了 : [環境敘述]: : R version 3.4.1 (2017-06-30) : Platform: x86_64-w64-mingw32/x64 (64-bit) : Running under: Windows >= 8 x64 (build 9200) : [關鍵字]: : lmap,gdsit,nearest point,closer point,經緯度距離 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 36.226.211.224
※ 文章網址: https://webptt.com/m.aspx?n=bbs/R_Language/M.1509032811.A.7DA.html
1F:推 giock18: 太感謝了 !!! 10/28 15:47







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

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

TOP