ggplot2中两个美学和geom_abline的传说

Aug*_*bas 2 r ggplot2

我正在尝试为下面的情节准备一个图例,点缀后跟A和虚线后跟B.它没有正确显示.由于我有2种美学,它有时只显示一种线型,有时甚至没有.我用scale_linetype_manual()guides(),但它无法产生预期的效果.但

我创建的代码,我删除了显示我尝试制作图例的代码.

exemplo<-data.frame(Location = c("Tiburon Peninsula", "San Francisco","Santa Barbara area", "Santa Monica Mountains", "Marin County", 
                             "Santa Cruz Mountains", "Monterey County", "San Diego County","California Coast"),
                Area = c(5.9, 45, 110, 320, 529, 1386, 3324,4260, 24520),
                Species = c(370L, 640L, 680L, 640L, 1060L, 1200L,1400L, 1450L, 2525L))
modelo<-lm(log(Species,10)~log(Area,10),data=exemplo)

modelo_nls<-nls(Species~a*Area^z,start=list(a=1,z=0.25),data=exemplo)
linha<-data.frame(x=log10(seq(1,25000,100)),y=log10(predict(modelo_nls,newdata=data.frame(Area=seq(1,25000,100)))))
ggplot(data=exemplo,aes(x=log10(Area),y=log10(Species)) )  + geom_point() +
geom_abline(intercept = modelo$coefficients[1], slope = modelo$coefficients[2],linetype="dotted") +
geom_line(data=linha,aes(x=x,y=y),linetype="dashed")+        
xlab(label="Área(ha)") + ylab(label="Número de espécies")
Run Code Online (Sandbox Code Playgroud)

tim*_*cas 5

一种方法是将两个预测的行组合成一个数据帧,其中一个额外的列指示每行属于哪个模型.

# Add model = 'A' to this data frame (I may have got A and B the wrong way round)
   linha <- data.frame(x = log10(seq(1,25000,100)),
                       y = log10(predict(modelo_nls,newdata=data.frame(Area=seq(1,25000,100)))),
                       model = 'A')

# Make data frame of line from modelo
lin2 <- data.frame(x = log10(seq(1,25000,100)), 
                   y = predict(modelo, newdata = list(Area = seq(1,25000,100))), 
                   model = 'B')

# Combine two models
combinedLines <- rbind(linha, lin2)
Run Code Online (Sandbox Code Playgroud)

然后用模型作为审美情节

ggplot(data=exemplo,aes(x=log10(Area),y=log10(Species)) )  + geom_point() +
geom_line(data=combinedLines, aes(x=x,y=y, linetype = model))+        
xlab(label="Área(ha)") + ylab(label="Número de espécies")
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述