我有一些我想要可视化的序列特征信息.这是一些玩具数据(最后重新生成数据的具体r代码)
type index variable position
...
14 CDS 14 start 31129
15 exon 15 start 32196
16 CDS 16 start 32196
17 stop_codon 17 start 32247
18 exon 1 end 12166
19 CDS 2 end 12166
...
Run Code Online (Sandbox Code Playgroud)
我用来生成以下图的命令是
qplot(position,type,data=m2data,color=type)+xlim(11950,15000)
Run Code Online (Sandbox Code Playgroud)

但是我想在"开始"和"结束"之间添加线段,这些线段与下面共享相同的"索引",这是我用油漆制作的.

如何用R中的ggplot2实现这个目标?
以下是数据
m2data<-structure(list(type = structure(c(2L, 1L, 3L, 2L, 1L, 2L, 1L,
4L, 2L, 2L, 1L, 3L, 2L, 1L, 2L, 1L, 4L, 2L, 1L, 3L, 2L, 1L, 2L,
1L, 4L, 2L, 2L, 1L, 3L, 2L, 1L, 2L, 1L, 4L), class = "factor", .Label = c("CDS",
"exon", "start_codon", "stop_codon")), index = c("1", "2", "3",
"4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15",
"16", "17", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10",
"11", "12", "13", "14", "15", "16", "17"), variable = structure(c(1L,
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L,
2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L,
2L), .Label = c("start", "end"), class = "factor"), position= c(11955L,
12026L, 12026L, 16677L, 16677L, 17745L, 17745L, 17787L, 18309L,
28587L, 28658L, 28658L, 31129L, 31129L, 32196L, 32196L, 32247L,
12166L, 12166L, 12028L, 16841L, 16841L, 17814L, 17786L, 17789L,
18898L, 28798L, 28798L, 28660L, 31299L, 31299L, 32270L, 32246L,
32249L)), .Names = c("type", "index", "variable", "position"), row.names = c(NA,
-34L), class = "data.frame")
Run Code Online (Sandbox Code Playgroud)
这是您的问题的解决方案.虽然您的问题与之前的问题非常相似,但我认为提供特定于您的数据集的答案仍然有用.
library(ggplot2)
library(reshape2)
# Use dcast (in reshape2 package) to create separate columns for start and end.
dat = dcast(m2data, type + index ~ variable, value.var="position")
plot_1 = ggplot(dat, aes(x=start, xend=end, y=type, yend=type, colour=type)) +
geom_segment(size=3) +
geom_point(size=3) +
geom_point(aes(x=end), size=3)
ggsave(filename="plot_1.png", plot_1, width=10, height=2.5)
Run Code Online (Sandbox Code Playgroud)

| 归档时间: |
|
| 查看次数: |
2600 次 |
| 最近记录: |