R_Language 板


LINE

※ 引述《jackhzt (巴克球)》之铭言: : [问题类型]: : 程式谘询(我想用R 做某件事情,但是我不知道要怎麽用R 写出来) : [软体熟悉度]: : 入门(写过其他程式,只是对语法不熟悉) : [问题叙述]:piecewise linear approximation(PLA) : 目的:使用线性的方式,切割一个序列 ( 时间序列) : 目标方法: 简单来说连结起点和终点, 依时间依序比较点和线的距离 : 太大就将点和终点连线, 以新的线再依序和接下来的点比距离, 重复做 : 以下是原文叙述: : http://imgur.com/eUcKxg6 : http://imgur.com/BLbYeyJ : 问题: : (step1): : Input time series Q(i : j) and threshold value "error". A vector Bp : is used to restore the breakpoints. "k" records the number of : the present breakpoints. "pos" denotes the position of the : newest breakpoint. : Initially, i = 1, j = m, where m is the length of time series. : Since the first point and the last point : are the special breakpoints, let k = 2, Bp(1) = q1 and : Bp(2) = qm. : (step2): : For time series Q(i : j), create line segment L(i : j) according : to the formula (6). Set two variables l = i + 1 and : best_so_far = 0. *公式6在我的程式码中有付 : (step3): : Calculate the distance of point ql to the line segment L(i : j), : that is D(ql,L(i : j)). : (step4): : If D(ql,L(i : j)) > best_so_far, best_so_far = D(ql,L(i : j)) and : pos = l. : (step5): : l = l + 1. If l>=j, go to the step 6; otherwise, go back to step3. : (step6): : If best_so_farPe, k = k + 1, Bp(k) = q_pos, go back to the Step : 2 and let the two subsequences Q(i : pos) and Q(pos : j) : redo the step 2 to step 6, respectively. : (step7): : Sort the element of vector Bp by an ascending time and : output the sorted result. : 出自:http://tinyurl.com/hhosdmk -3.1 : 1.我的程式码看起来有点问题,尤其是step 6这地方不太会表示,有高手可以解惑吗? : 2.有没有比较正常的打法?我的打法好像问题很大 : 3.package方面有试过一些,但是有办法表达和上面叙述一样的package目前好像没找到 : 程式码可贴於以下网站: http://ideone.com/TOEISf : 求高手救援 我不确定我有做对,看图应该是对了 基本上这个要套用递回才能解决 程式如下: 好读版:http://pastebin.com/95ATSHHV q<-c(18, 15, 24, 23, 18, 22, 19, 29, 22, 25, 20, 19, 18, 20, 26, 32, 26, 26, 34, 29, 23, 34, 22, 19, 21, 19, 34, 23, 23, 23, 30, 21, 15, 29, 32, 19, 21, 28, 22, 32, 29, 25, 28, 28, 23, 12, 26, 24, 27, 14, 38, 27, 28, 25, 38, 34, 25, 37, 15, 28, 15, 23, 23, 28, 15, 15, 19, 25, 28, 16, 19, 17, 23, 19, 16, 18, 18, 17, 20, 18, 21, 13, 11, 12, 13, 16, 13, 16, 10, 13, 14, 6, 19, 18, 19, 15, 17, 6, 14, 28, 15, 20, 16, 12) # distance function dis_f <- function(t, q, i, j){ a <- (q[j]-q[i])/(j-i) abs((q[i]*j-q[j]*i)/(j-i) + a * t - q[t]) / sqrt(a^2 + 1) } pla <- function(q, i, j, time, eplison){ if (i > j || j - i <= 1) return(sort(time)) # find the maximum distance (Following two lines represents the Step 3~5) dis_t <- dis_f((i+1):(j-1), q, i, j) # calculate distance of qi~qj loc <- which.max(dis_t) # find the position pos <- i + loc # record the position best_so_far <- dis_t[loc] # print the segment cat(sprintf("segment: %i, %i, %.2f\n", i, j, best_so_far)) # Step 6: find more segments if (best_so_far >= eplison) { # record the time time <- c(time, pos) if (pos < j) { time <- pla(q, i, pos, time, eplison) time <- pla(q, pos, j, time, eplison) } } return(sort(time)) } # calculate eplison eplison <- sd(dis_f(1:length(q), q, 1, length(q))) time <- pla(q, 1, length(q), c(1, length(q)), eplison) plot(1:length(q), q,type="o") lines(time, q[time], col = 2) --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 140.109.74.87
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1458630164.A.3E0.html ※ 编辑: celestialgod (140.109.74.87), 03/22/2016 15:06:07
1F:推 jackhzt: 谢谢c大 我试试看 感恩 03/22 15:25







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

请输入看板名称,例如:BabyMother站内搜寻

TOP