Re: [问题] 特制Boxplot盒须图

楼主: andrew43 (讨厌有好心推文后删文者)   2015-03-05 20:56:15
首先,boxplot() 其实会回传一个物件,我叫 z 物件好了。
这个 z 物件本身是一个 list,里头就是 boxplot 的各种资讯。
像是 z$stat 就是各变量的 quantiles,z$name 是各变量的名称。
你可以观察看看 bx.p <- boxplot(split(rt(100, 4), gl(5, 20))) 的
bx.p 实际上是回传了什么给你。
这个 z 物件可以自己建,就像建一个 list 一样。
然后再以 bxp(z物件) 画出一个 boxplot。
请看以下按你的需求设计的例子。
# 二组虚假资料
a <- c(1:100)
b <- c(50:1000)
# 建立 z 物件(本身是一个 list)
bxpObj <- list()
# 一定要有 bxpObj$stats 这项,里头是一个 matrix,
# 其中栏是变量,列是各 quantile,要有5列。
# 各 quantile 分别会被画成下底线、下盒线、中位线、上盒线和上底线。
bxpObj$stats <- rbind(
cbind(
quantile(a, c(0.1, 0.25, 0.5, 0.75, 0.9)),
quantile(b, c(0.1, 0.25, 0.5, 0.75, 0.9))
)
)
# bxpObj$name 这项就是变量名称
bxpObj$name <- c("a", "b")
# 重点来了:用 bxp() 画
bxp(bxpObj)
# 直接用 points() 补画你要求的 20% 和 80% quantile。
points(1, quantile(a, 0.2), pch=1) # a的20% quantile
points(1, quantile(a, 0.8), pch=2) # a的80% quantile
points(2, quantile(b, 0.2), pch=3) # b的20% quantile
points(2, quantile(b, 0.8), pch=4) # b的80% quantile
最后,如果你想自行改写成一个新的 function,也要视你的资料而定。
例如是 myboxplot(变量,组别) 还是 myboxplot(matrix) 的写法会不太一样。
但重点就是我前面写的:建一个 z 物件再喂 bxp() 吃下去就对了。
※ 引述《ming790925 (MING)》之铭言:
: [问题类型]:
: 程式咨询
: [软件熟悉度]:
: 使用者(已经有用R 做过不少作品)
: [问题叙述]:
: 我想画一个 boxplot 但不要内建那种,
: 因为我在意的是某几格特定的百分位数,
: 还有我不希望画出outliers
: 因为找了满久的 都没有找到能达到这样的套件
: 想请问各位是否有印象有什么套件已经能完成?
: 举例来说:
: 除了中间的盒子外,我想要延伸出去到90% 10% quantile的值
: 并在80% 20%也加上标记
: 感激!!!!!
: [关键字]:
: boxplot quntile
作者: ming790925 (MING)   2015-03-05 22:18:00
请问如果在80%画跟盒宽一样长的线,只能用segments吗?
楼主: andrew43 (讨厌有好心推文后删文者)   2015-03-05 22:35:00
宽度是可以算的。请看看 ?bxp 里的 pars 参数里 *wex 这几项。但怎么直接取得这个宽度,我就不知道了。例如 bxp(..., pars=list(boxwex = 1)) 可使盒子靠紧。此时,上例中,横轴的0.5--1.5就是宽度之范围。boxwex默认是0.8,所以你应该能够算得默认的宽度范围。
作者: ming790925 (MING)   2015-03-05 22:50:00
感恩!

Links booklink

Contact Us: admin [ a t ] ucptt.com