module Statistics.LinearRegression (
linearRegression,
linearRegressionRSqr,
linearRegressionTLS,
correl,
covar,
) where
import qualified Data.Vector.Unboxed as U
import qualified Statistics.Sample as S
covar :: S.Sample -> S.Sample -> Double
covar xs ys = U.sum (U.zipWith (*) (U.map (subtract m1) xs) (U.map (subtract m2) ys)) / (n1)
where
!n = fromIntegral $ U.length xs
!m1 = S.mean xs
!m2 = S.mean ys
correl :: S.Sample -> S.Sample -> Double
correl xs ys = let !c = covar xs ys
!sx = S.stdDev xs
!sy = S.stdDev ys
in c / (sx * sy)
linearRegressionRSqr :: S.Sample -> S.Sample -> (Double, Double, Double)
linearRegressionRSqr xs ys = (alpha, beta, r*r)
where
!c = covar xs ys
!r = c / (sx * sy)
!m1 = S.mean xs
!m2 = S.mean ys
!sx = S.stdDev xs
!sy = S.stdDev ys
!n = fromIntegral $ U.length xs
!beta = r * sy / sx
!alpha = m2 beta * m1
linearRegression :: S.Sample -> S.Sample -> (Double, Double)
linearRegression xs ys = (alpha, beta)
where
(alpha, beta, _) = linearRegressionRSqr xs ys
linearRegressionTLS :: S.Sample -> S.Sample -> (Double,Double)
linearRegressionTLS xs ys = (alpha, beta)
where
!c = covar xs ys
!b = (S.varianceUnbiased xs (S.varianceUnbiased ys)) / c
!m1 = S.mean xs
!m2 = S.mean ys
!betas = [(b sqrt(b^2+4))/2,(b + sqrt(b^2+4)) /2]
!beta = if c > 0 then maximum betas else minimum betas
!alpha = m2 beta * m1