除非将另一个r ^ 2列添加到数据中,否则不能将不同的标签应用于不同的方面。一种方法是使用geom_text,但需要首先计算所需的统计信息。下面我以虹膜为例,对于您的情况,只需更改Species for Variety等,
library(tidyverse)
# simulate data for 2 treatments
# d2 is just shifted up from d1
d1 <- data.frame(iris,Treatment="A")
d2 <- data.frame(iris,Treatment="B") %>%
mutate(Sepal.Length=Sepal.Length+rnorm(nrow(iris),1,0.5))
# combine datasets
DF <- rbind(d1,d2) %>% rename(Variety = Species)
# plot like you did
# note I use "free" scales,if scales very different between Species
# your facet plots will be squished
g <- ggplot(DF,aes(x=Sepal.Width,y=Sepal.Length,col=Treatment))+
geom_point(shape=1,size=1)+
geom_smooth(method=lm)+
scale_color_brewer(palette = "Set1")+
facet_wrap(.~Variety,scales="free")
# rsq function
RSQ = function(y,x){signif(summary(lm(y ~ x))$adj.r.squared,3)}
#calculate rsq for variety + treatment
STATS <- DF %>%
group_by(Variety,Treatment) %>%
summarise(Rsq=RSQ(Sepal.Length,Sepal.Width)) %>%
# make a label
# one other option is to use stringr::str_wrap in geom_text
mutate(Label=paste("Treat",Treatment,",Rsq=",Rsq))
# set vertical position of rsq
VJUST = ifelse(STATS$Treatment=="A",1.5,3)
# finally the plot function
g + geom_text(data=STATS,aes(x=-Inf,y=+Inf,label=Label),hjust = -0.1,vjust = VJUST,size=3)
对于最后一个geom_text()调用,我通过乘以“处理”来允许文本的y坐标不同。.您可能需要根据您的图进行调整。.
,
以下是import numpy as np
from matplotlib import pyplot as plt
def plot_polynomials(solutions,train_x,train_y):
x = np.arange(-5,6)
plt.plot(x,genPoly(x,solutions))
plt.show()
data = read_coords("data.csv")
data = np.asarray(data)
system,solution = pol_regression(data[:,0],data[:,1],2)
plot_polynomials(solution,1])
#I want to do something like this but im not sure what plot_polynomials() should contain
#to be able to "hold onto" the constructed graph before showing.
#I need all polynomials on the same graph
for i in range(11):
system,i)
plot_polynomials(solution,1])
包的示例:
ggpmisc
本文链接:https://www.f2er.com/3110816.html