Я хотел бы выполнить регрессию с ломаной палкой, в которой пересечение первого сегмента ограничено, чтобы пройти через начало координат.
В приведенном ниже коде используется «сегментированный» пакет в R для подгонки двух линейных моделей к данным.
Обратите внимание, что регрессия для первого сегмента не проходит через начало координат - насколько я могу судить, сегментированный не позволяет пользователю указать, что перехват для первого сегмента должен проходить через начало координат.
Итак, как можно выполнить такую регрессию с прерывистой линией, ограничивая прохождение первого сегмента через начало координат ..?
## create data with two 'growth' regimes
n <- 100
x <- 1:n
y1 <- x[1:(n/2)] + rnorm(n=n/2, mean = 0, sd=10)
y2 <- rnorm(n=n/2, mean = 0, sd=5) + max(y1)
y <- c(y1,y2)
DF <- data.frame(x,y )
## fit a broken-stick regression model
library(segmented)
LM <- lm(y~x, DF)
Seggie <- segmented(LM, seg.Z=~x, npsi=1, psi=n/2)
## plot the data & the model
plot(Seggie); abline(h=0, lty=2); abline(v=0, lty=2)
points(y ~ x, DF); abline(h=0, lty=2)