R_Language 板


LINE

[問題類型]: 程式諮詢(我想用R 做某件事情,但是我不知道要怎麼用R 寫出來) [軟體熟悉度]: 入門(寫過其他程式,只是對語法不熟悉) [問題敘述]: 最近在練習單層感知機 用for迴圈寫的版本是OK的 但不知為何while迴圈就不行 初始值: x1 <- c(0, 0) x2 <- c(0, 1) x3 <- c(1, 0) x4 <- c(1, 1) ans0 <- c(1, 1, -1, 1) x0 <- cbind(x1, x2, x3, x4) w0 <- c(0, 1) # 初始weights 目的: 找到一個w0 把x1, x2, x3, x4 分成 1, -1 兩類 ans0為預設答案 行合併之後 逐行檢驗 分類正確則w0不變 反之則迭代新的w0 全部一輪沒錯則停止 [for版本] perceptron <- function(x = x0, w0 = c(0, 1), threshold = -1, rate = 0.8, ans = ans0, n = 1000) { w0 <- c(threshold, w0) x <- rbind(-1, x) for(i in 1:n){ j <- (i + 3) %% 4 + 1 if( all(sign(t(w0) %*% x) == ans) ){ break }else if(sign(t(w0) %*% x[, j]) == ans[j]) { w0 <- w0 }else{w0 <- w0 + sign(ans[j]) * rate * x[, j]} } return(w0) } [while版本] perceptron <- function(x = x0, w0 = c(0, 1), threshold = -1, rate = 0.8, ans = ans0) { w0 <- c(threshold, w0) x <- rbind(-1, x) i <- 1 while(all(sign(t(w0) %*% x) != ans)){ j <- (i + 3) %% 4 + 1 if(sign(t(w0) %*% x[, j]) == ans[j]){ w0 <- w0 }else{w0 <- w0 + sign(ans[j]) * rate * x[, j]} i <- i + 1 } return(w0) } for 版本成功輸出正確的w0 while版本還是輸出初始w0 主要是迴圈寫法的問題 不知道演算法部分是否要寫詳細 若需要我再補充 謝謝 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 49.218.1.235
※ 文章網址: https://webptt.com/m.aspx?n=bbs/R_Language/M.1501643881.A.3E9.html ※ 編輯: linkpon5566 (49.218.1.235), 08/02/2017 11:20:31 ※ 編輯: linkpon5566 (49.218.1.235), 08/02/2017 11:21:27
1F:→ x88776544pc: while 版本的 i 沒有定義初值 08/02 12:53
抱歉是筆誤 已補上 原本的code是有初值的 但依舊不能跑 ※ 編輯: linkpon5566 (49.218.1.235), 08/02/2017 13:20:53
2F:推 x88776544pc: while 後面的條件是全部分錯才做,跟你原先預想的不 08/02 13:53
3F:→ x88776544pc: 一樣 08/02 13:53
感謝!! 已解決 是我誤解 "all" 的用法 把while裡面改成 sum(sign(t(w0) %*% x) == ans) != length(ans) 可以輸出正確結果 ※ 編輯: linkpon5566 (49.218.1.235), 08/02/2017 14:57:44







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