Como traçar uma linha de regressão linear em ggplot2 (com exemplos)


Você pode usar a biblioteca de visualização R ggplot2 para traçar um modelo de regressão linear ajustado usando a seguinte sintaxe básica:

 ggplot(data,aes(x, y)) +
  geom_point() +
  geom_smooth(method=' lm ')

O exemplo a seguir mostra como usar essa sintaxe na prática.

Exemplo: traçando uma linha de regressão linear em ggplot2

Suponha que ajustemos um modelo de regressão linear simples ao seguinte conjunto de dados:

 #create dataset
data <- data.frame(y=c(6, 7, 7, 9, 12, 13, 13, 15, 16, 19, 22, 23, 23, 25, 26),
                   x=c(1, 2, 2, 3, 4, 4, 5, 6, 6, 8, 9, 9, 11, 12, 12))

#fit linear regression model to dataset and view model summary
model <- lm(y~x, data=data)
summary(model)

Call:
lm(formula = y ~ x, data = data)

Residuals:
    Min 1Q Median 3Q Max 
-1.4444 -0.8013 -0.2426 0.5978 2.2363 

Coefficients:
            Estimate Std. Error t value Pr(>|t|)    
(Intercept) 4.20041 0.56730 7.404 5.16e-06 ***
x 1.84036 0.07857 23.423 5.13e-12 ***
---
Significant. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1

Residual standard error: 1.091 on 13 degrees of freedom
Multiple R-squared: 0.9769, Adjusted R-squared: 0.9751 
F-statistic: 548.7 on 1 and 13 DF, p-value: 5.13e-12

O código a seguir mostra como visualizar o modelo de regressão linear ajustado:

 library (ggplot2)

#create plot to visualize fitted linear regression model
ggplot(data,aes(x, y)) +
  geom_point() +
  geom_smooth(method=' lm ') 

Gráfico de regressão linear em ggplot2

Por padrão, ggplot2 adiciona linhas de erro padrão ao gráfico. Você pode desativá-los usando o argumento se=FALSE da seguinte forma:

 library (ggplot2)

#create regression plot with no standard error lines
ggplot(data,aes(x, y)) +
  geom_point() +
  geom_smooth(method=' lm ', se= FALSE ) 

linha de regressão ggplot2

Finalmente, podemos personalizar certos aspectos do gráfico para torná-lo mais atraente visualmente:

 library (ggplot2)

#create regression plot with customized style
ggplot(data,aes(x, y)) +
  geom_point() +
  geom_smooth(method=' lm ', se= FALSE , color=' turquoise4 ') +
  theme_minimal() +
  labs(x=' X Values ', y=' Y Values ', title=' Linear Regression Plot ') +
  theme(plot.title = element_text(hjust=0.5, size=20, face=' bold ')) 

Linha de regressão personalizada usando ggplot2 em R

Consulte este artigo para obter um guia completo dos melhores temas ggplot2.

Recursos adicionais

Uma introdução à regressão linear múltipla em R
Como traçar um intervalo de confiança em R

Add a Comment

O seu endereço de email não será publicado. Campos obrigatórios marcados com *