비선형회귀분석: 회귀분석에서의 변수 변환

비선형회귀분석: 회귀분석에서의 변수 변환

개요 1

회귀분석은 기본적으로 변수들간의 선형관계를 밝히는 방법이지만, 필요하다면 데이터를 선형으로 ‘펴서’ 분석할 수 있다. 이는 본질적으로 종속변수를 독립변수의 비선형결합으로 설명하는 것이다.

실습

내장데이터 Pressure 데이터를 불러와보자.

20181214\_110640.png 0.png Pressure 데이터는 사실 통계적으로 분석할 필요는 없다.

이는 어디까지나 자연현상이기 때문에 실험만큼이나 수학적인 증명이 필요하고, ‘인과관계’에 관심이 더 많기 때문이다. 그러나 이것을 굳이 회귀분석으로 분석하고 싶을 땐 할 수 있어야 할 것이다. 다만 위 데이터에 대한 회귀식 $$(\text{pressure}) = \beta_{0 } + \beta_{1 } ( \text{temperature} ) + \varepsilon$$ 은 아마 의미가 없을 것이다. 해서, 독립변수에 로그를 취한 $\log ( \text{temperature} )$ 와 종속변수에 로그를 취한 $\log (\text{pressure})$ 를 새로운 변수로 사용해보자. 이렇게 새로이 만들어지는 회귀식을 $$\log (\text{pressure}) = \log {b_{0 }} + {b_{1 }} \log ( \text{temperature} )+ \varepsilon$$ 이라고 하자. 만약 이 분석이 제대로 됐다면, $$\log (\text{pressure}) = \log {b_{0 }} ( \text{temperature} )^{{b_{1 }}}+ \varepsilon$$ 이므로 양변의 로그를 풀면 $$ (\text{pressure}) = b_{0 } ( \text{temperature} )^{{b_{1 }}} + \varepsilon $$ 과 같은 관계식을 유도할 수 있을 것이다. 당연하게도 이러한 식은 실제 물리학에서도 비슷한 모양으로 등장한다. 각각의 회귀분석을 실시하고 회귀직선을 그어보면 아래와 같다.

1.png

로그를 취했다 푸는 수식적인 조작은 사람의 몫이다.

코드

아래는 예제 코드다.

pressure; ?pressure
win.graph(4,4)
plot(pressure,main='Pressure')
 
win.graph(8,4); par(mfrow=c(1,2))
 
out1<-lm(temperature~pressure,data=pressure); summary(out1)
plot(pressure,main='scale'); abline(out1,col='red')
 
y<-pressure[-1,]$pressure; logtemp<-log(y)
x<-pressure[-1,]$temperature; logpress<-log(x)
out2<-lm(logtemp~logpress); summary(out2)
plot(logpress,logtemp,main='log scale'); abline(out2,col='red')

같이보기


  1. Hadi. (2006). Regression Analysis by Example(4th Edition): p152. ↩︎

댓글