Home » date » 2010 » Nov » 23 »

Workshop 7 - regression model

*The author of this computation has been verified*
R Software Module: /rwasp_multipleregression.wasp (opens new window with default values)
Title produced by software: Multiple Regression
Date of computation: Tue, 23 Nov 2010 11:00:50 +0000
 
Cite this page as follows:
Statistical Computations at FreeStatistics.org, Office for Research Development and Education, URL http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh.htm/, Retrieved Tue, 23 Nov 2010 12:00:21 +0100
 
BibTeX entries for LaTeX users:
@Manual{KEY,
    author = {{YOUR NAME}},
    publisher = {Office for Research Development and Education},
    title = {Statistical Computations at FreeStatistics.org, URL http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh.htm/},
    year = {2010},
}
@Manual{R,
    title = {R: A Language and Environment for Statistical Computing},
    author = {{R Development Core Team}},
    organization = {R Foundation for Statistical Computing},
    address = {Vienna, Austria},
    year = {2010},
    note = {{ISBN} 3-900051-07-0},
    url = {http://www.R-project.org},
}
 
Original text written by user:
 
IsPrivate?
No (this computation is public)
 
User-defined keywords:
 
Dataseries X:
» Textbox « » Textfile « » CSV «
705 4 370 74 67 535 315 6166 53 54 65 4 684 68 62 765 17 449 80 73 70 8 643 72 68 71 56 1551 74 68 605 15 616 61 60 515 503 36660 53 50 78 26 403 82 74 76 26 346 79 73 575 44 2471 58 57 61 24 7427 63 59 645 23 2992 65 64 785 38 233 82 75 79 18 609 82 76 61 96 7615 63 59 70 90 370 73 67 70 49 1066 73 67 72 66 600 76 68 645 21 4873 66 63 545 592 3485 56 53 565 73 2364 57 56 645 14 1016 67 62 645 88 1062 67 62 73 39 480 77 69 72 6 559 75 69 69 32 259 74 64 64 11 1340 67 61 785 26 275 82 75 53 23 12550 54 52 75 32 965 78 72 525 NA 25229 55 50 685 11 4883 71 66 70 5 1189 72 68 705 3 226 75 66 76 3 611 79 73 755 13 404 79 72 745 56 576 78 71 65 29 3096 67 63 54 NA 23193 56 52
 
Output produced by software:

Enter (or paste) a matrix (table) containing all data (time) series. Every column represents a different variable and must be delimited by a space or Tab. Every row represents a period in time (or category) and must be delimited by hard returns. The easiest way to enter data is to copy and paste a block of spreadsheet cells. Please, do not use commas or spaces to seperate groups of digits!


Summary of computational transaction
Raw Inputview raw input (R code)
Raw Outputview raw output of R engine
Computing time6 seconds
R Server'Gwilym Jenkins' @ 72.249.127.135


Multiple Linear Regression - Estimated Regression Equation
Yt[t] = -91.9080275778757 + 0.529691487502998X1t[t] -0.00320282046758429X2t[t] -29.4520792768385X3t[t] + 38.120187685799X4t[t] + e[t]


Multiple Linear Regression - Ordinary Least Squares
VariableParameterS.D.T-STAT
H0: parameter = 0
2-tail p-value1-tail p-value
(Intercept)-91.9080275778757750.240579-0.12250.9032420.451621
X1t0.5296914875029980.5332940.99320.3278190.163909
X2t-0.003202820467584290.011209-0.28570.7768610.38843
X3t-29.452079276838528.448859-1.03530.3080730.154036
X4t38.12018768579937.2460241.02350.313530.156765


Multiple Linear Regression - Regression Statistics
Multiple R0.24378174897495
R-squared0.0594295411332856
Adjusted R-squared-0.0545789993354069
F-TEST (value)0.52127271245618
F-TEST (DF numerator)4
F-TEST (DF denominator)33
p-value0.720694215763594
Multiple Linear Regression - Residual Statistics
Residual Standard Deviation312.156639267537
Sum Squared Residuals3215578.3254805


Multiple Linear Regression - Actuals, Interpolation, and Residuals
Time or IndexActualsInterpolation
Forecast
Residuals
Prediction Error
1705283.624403261612421.375596738388
2535552.72613334315-17.7261333431495
365268.730254866829-203.730254866829
4765342.266020235977422.733979764023
570381.893145463452-311.893145463452
671345.506017325352-274.506017325352
7605404.698832587429200.301167412571
8515402.160574912002112.839425087998
978326.396602497135-248.396602497135
1076376.815213408504-300.815213408504
11575388.114328530766186.885671469234
1261290.627299530763-229.627299530763
13645435.998896692315209.001103307685
14785371.417567512459413.582432487541
1579397.739664952386-318.739664952386
1661328.162956383073-267.162956383073
1770358.629950463710-288.629950463710
1870334.683436430649-264.683436430649
1972294.944655911377-222.944655911377
20645361.342741455145283.657258544855
21545581.561011538759-36.5610115387589
22565395.149975049424169.850024950576
23645302.415912623459342.584087376541
24645341.465752957172303.534247042828
2573289.695432613867-216.695432613867
2672330.866749263006-258.866749263006
2769184.450714926203-115.450714926203
2864261.668936643654-197.668936643654
29785364.926751202785420.073248797215
3053271.916958478780-218.916958478780
3175369.342708055126-294.342708055126
32525163.113965048644361.886034951356
33685993.555331025642-308.555331025642
3470-419.016349041194489.016349041194
35705992.783561772025-287.783561772025
3676-347.376727201954423.376727201954
37755355.181013231290399.81898676871
387451021.81960604923-276.819606049228
3965NANA
4054NANA


Goldfeld-Quandt test for Heteroskedasticity
p-valuesAlternative Hypothesis
breakpoint indexgreater2-sidedless
80.853295510686090.2934089786278210.146704489313910
90.8043077662626070.3913844674747870.195692233737393
100.7463122119893380.5073755760213240.253687788010662
110.6345721414841750.7308557170316510.365427858515825
120.5890607996628320.8218784006743350.410939200337168
130.5047570201616170.9904859596767660.495242979838383
140.5681178359795430.8637643280409140.431882164020457
150.5552267230639980.8895465538720050.444773276936002
160.4994367300527590.9988734601055190.500563269947241
170.4545861250775310.9091722501550630.545413874922469
180.4010157079607320.8020314159214640.598984292039268
190.3342412823027420.6684825646054850.665758717697257
200.3025337556371660.6050675112743320.697466244362834
210.2652087253865300.5304174507730590.73479127461347
220.2024535893194090.4049071786388180.797546410680591
230.2869811853239850.573962370647970.713018814676015
240.3636281666388340.7272563332776670.636371833361166
250.3594816929691890.7189633859383780.640518307030811
260.2968583065946690.5937166131893380.703141693405331
270.5051300161585560.9897399676828880.494869983841444
280.3878146609327270.7756293218654540.612185339067273
290.3456994136885320.6913988273770630.654300586311468
300.3318921308062950.663784261612590.668107869193705
310.3903664056236010.7807328112472030.609633594376399
320.261706267969140.523412535938280.73829373203086


Meta Analysis of Goldfeld-Quandt test for Heteroskedasticity
Description# significant tests% significant testsOK/NOK
1% type I error level00OK
5% type I error level00OK
10% type I error level00OK
 
Charts produced by software:
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/10b3xg1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/10b3xg1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/1n2in1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/1n2in1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/2n2in1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/2n2in1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/3fb081290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/3fb081290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/4fb081290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/4fb081290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/5fb081290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/5fb081290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/6q2ha1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/6q2ha1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/7jbgw1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/7jbgw1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/8jbgw1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/8jbgw1290510042.ps (open in new window)


http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/9jbgw1290510042.png (open in new window)
http://www.freestatistics.org/blog/date/2010/Nov/23/t1290510010a3ri3gyat8ok8bh/9jbgw1290510042.ps (open in new window)


 
Parameters (Session):
par1 = 1 ; par2 = Do not include Seasonal Dummies ; par3 = No Linear Trend ;
 
Parameters (R input):
par1 = 1 ; par2 = Do not include Seasonal Dummies ; par3 = No Linear Trend ;
 
R code (references can be found in the software module):
library(lattice)
library(lmtest)
n25 <- 25 #minimum number of obs. for Goldfeld-Quandt test
par1 <- as.numeric(par1)
x <- t(y)
k <- length(x[1,])
n <- length(x[,1])
x1 <- cbind(x[,par1], x[,1:k!=par1])
mycolnames <- c(colnames(x)[par1], colnames(x)[1:k!=par1])
colnames(x1) <- mycolnames #colnames(x)[par1]
x <- x1
if (par3 == 'First Differences'){
x2 <- array(0, dim=c(n-1,k), dimnames=list(1:(n-1), paste('(1-B)',colnames(x),sep='')))
for (i in 1:n-1) {
for (j in 1:k) {
x2[i,j] <- x[i+1,j] - x[i,j]
}
}
x <- x2
}
if (par2 == 'Include Monthly Dummies'){
x2 <- array(0, dim=c(n,11), dimnames=list(1:n, paste('M', seq(1:11), sep ='')))
for (i in 1:11){
x2[seq(i,n,12),i] <- 1
}
x <- cbind(x, x2)
}
if (par2 == 'Include Quarterly Dummies'){
x2 <- array(0, dim=c(n,3), dimnames=list(1:n, paste('Q', seq(1:3), sep ='')))
for (i in 1:3){
x2[seq(i,n,4),i] <- 1
}
x <- cbind(x, x2)
}
k <- length(x[1,])
if (par3 == 'Linear Trend'){
x <- cbind(x, c(1:n))
colnames(x)[k+1] <- 't'
}
x
k <- length(x[1,])
df <- as.data.frame(x)
(mylm <- lm(df))
(mysum <- summary(mylm))
if (n > n25) {
kp3 <- k + 3
nmkm3 <- n - k - 3
gqarr <- array(NA, dim=c(nmkm3-kp3+1,3))
numgqtests <- 0
numsignificant1 <- 0
numsignificant5 <- 0
numsignificant10 <- 0
for (mypoint in kp3:nmkm3) {
j <- 0
numgqtests <- numgqtests + 1
for (myalt in c('greater', 'two.sided', 'less')) {
j <- j + 1
gqarr[mypoint-kp3+1,j] <- gqtest(mylm, point=mypoint, alternative=myalt)$p.value
}
if (gqarr[mypoint-kp3+1,2] < 0.01) numsignificant1 <- numsignificant1 + 1
if (gqarr[mypoint-kp3+1,2] < 0.05) numsignificant5 <- numsignificant5 + 1
if (gqarr[mypoint-kp3+1,2] < 0.10) numsignificant10 <- numsignificant10 + 1
}
gqarr
}
bitmap(file='test0.png')
plot(x[,1], type='l', main='Actuals and Interpolation', ylab='value of Actuals and Interpolation (dots)', xlab='time or index')
points(x[,1]-mysum$resid)
grid()
dev.off()
bitmap(file='test1.png')
plot(mysum$resid, type='b', pch=19, main='Residuals', ylab='value of Residuals', xlab='time or index')
grid()
dev.off()
bitmap(file='test2.png')
hist(mysum$resid, main='Residual Histogram', xlab='values of Residuals')
grid()
dev.off()
bitmap(file='test3.png')
densityplot(~mysum$resid,col='black',main='Residual Density Plot', xlab='values of Residuals')
dev.off()
bitmap(file='test4.png')
qqnorm(mysum$resid, main='Residual Normal Q-Q Plot')
qqline(mysum$resid)
grid()
dev.off()
(myerror <- as.ts(mysum$resid))
bitmap(file='test5.png')
dum <- cbind(lag(myerror,k=1),myerror)
dum
dum1 <- dum[2:length(myerror),]
dum1
z <- as.data.frame(dum1)
z
plot(z,main=paste('Residual Lag plot, lowess, and regression line'), ylab='values of Residuals', xlab='lagged values of Residuals')
lines(lowess(z))
abline(lm(z))
grid()
dev.off()
bitmap(file='test6.png')
acf(mysum$resid, lag.max=length(mysum$resid)/2, main='Residual Autocorrelation Function')
grid()
dev.off()
bitmap(file='test7.png')
pacf(mysum$resid, lag.max=length(mysum$resid)/2, main='Residual Partial Autocorrelation Function')
grid()
dev.off()
bitmap(file='test8.png')
opar <- par(mfrow = c(2,2), oma = c(0, 0, 1.1, 0))
plot(mylm, las = 1, sub='Residual Diagnostics')
par(opar)
dev.off()
if (n > n25) {
bitmap(file='test9.png')
plot(kp3:nmkm3,gqarr[,2], main='Goldfeld-Quandt test',ylab='2-sided p-value',xlab='breakpoint')
grid()
dev.off()
}
load(file='createtable')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a, 'Multiple Linear Regression - Estimated Regression Equation', 1, TRUE)
a<-table.row.end(a)
myeq <- colnames(x)[1]
myeq <- paste(myeq, '[t] = ', sep='')
for (i in 1:k){
if (mysum$coefficients[i,1] > 0) myeq <- paste(myeq, '+', '')
myeq <- paste(myeq, mysum$coefficients[i,1], sep=' ')
if (rownames(mysum$coefficients)[i] != '(Intercept)') {
myeq <- paste(myeq, rownames(mysum$coefficients)[i], sep='')
if (rownames(mysum$coefficients)[i] != 't') myeq <- paste(myeq, '[t]', sep='')
}
}
myeq <- paste(myeq, ' + e[t]')
a<-table.row.start(a)
a<-table.element(a, myeq)
a<-table.row.end(a)
a<-table.end(a)
table.save(a,file='mytable1.tab')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a,hyperlink('http://www.xycoon.com/ols1.htm','Multiple Linear Regression - Ordinary Least Squares',''), 6, TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'Variable',header=TRUE)
a<-table.element(a,'Parameter',header=TRUE)
a<-table.element(a,'S.D.',header=TRUE)
a<-table.element(a,'T-STAT<br />H0: parameter = 0',header=TRUE)
a<-table.element(a,'2-tail p-value',header=TRUE)
a<-table.element(a,'1-tail p-value',header=TRUE)
a<-table.row.end(a)
for (i in 1:k){
a<-table.row.start(a)
a<-table.element(a,rownames(mysum$coefficients)[i],header=TRUE)
a<-table.element(a,mysum$coefficients[i,1])
a<-table.element(a, round(mysum$coefficients[i,2],6))
a<-table.element(a, round(mysum$coefficients[i,3],4))
a<-table.element(a, round(mysum$coefficients[i,4],6))
a<-table.element(a, round(mysum$coefficients[i,4]/2,6))
a<-table.row.end(a)
}
a<-table.end(a)
table.save(a,file='mytable2.tab')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a, 'Multiple Linear Regression - Regression Statistics', 2, TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Multiple R',1,TRUE)
a<-table.element(a, sqrt(mysum$r.squared))
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'R-squared',1,TRUE)
a<-table.element(a, mysum$r.squared)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Adjusted R-squared',1,TRUE)
a<-table.element(a, mysum$adj.r.squared)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'F-TEST (value)',1,TRUE)
a<-table.element(a, mysum$fstatistic[1])
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'F-TEST (DF numerator)',1,TRUE)
a<-table.element(a, mysum$fstatistic[2])
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'F-TEST (DF denominator)',1,TRUE)
a<-table.element(a, mysum$fstatistic[3])
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'p-value',1,TRUE)
a<-table.element(a, 1-pf(mysum$fstatistic[1],mysum$fstatistic[2],mysum$fstatistic[3]))
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Multiple Linear Regression - Residual Statistics', 2, TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Residual Standard Deviation',1,TRUE)
a<-table.element(a, mysum$sigma)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Sum Squared Residuals',1,TRUE)
a<-table.element(a, sum(myerror*myerror))
a<-table.row.end(a)
a<-table.end(a)
table.save(a,file='mytable3.tab')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a, 'Multiple Linear Regression - Actuals, Interpolation, and Residuals', 4, TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a, 'Time or Index', 1, TRUE)
a<-table.element(a, 'Actuals', 1, TRUE)
a<-table.element(a, 'Interpolation<br />Forecast', 1, TRUE)
a<-table.element(a, 'Residuals<br />Prediction Error', 1, TRUE)
a<-table.row.end(a)
for (i in 1:n) {
a<-table.row.start(a)
a<-table.element(a,i, 1, TRUE)
a<-table.element(a,x[i])
a<-table.element(a,x[i]-mysum$resid[i])
a<-table.element(a,mysum$resid[i])
a<-table.row.end(a)
}
a<-table.end(a)
table.save(a,file='mytable4.tab')
if (n > n25) {
a<-table.start()
a<-table.row.start(a)
a<-table.element(a,'Goldfeld-Quandt test for Heteroskedasticity',4,TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'p-values',header=TRUE)
a<-table.element(a,'Alternative Hypothesis',3,header=TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'breakpoint index',header=TRUE)
a<-table.element(a,'greater',header=TRUE)
a<-table.element(a,'2-sided',header=TRUE)
a<-table.element(a,'less',header=TRUE)
a<-table.row.end(a)
for (mypoint in kp3:nmkm3) {
a<-table.row.start(a)
a<-table.element(a,mypoint,header=TRUE)
a<-table.element(a,gqarr[mypoint-kp3+1,1])
a<-table.element(a,gqarr[mypoint-kp3+1,2])
a<-table.element(a,gqarr[mypoint-kp3+1,3])
a<-table.row.end(a)
}
a<-table.end(a)
table.save(a,file='mytable5.tab')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a,'Meta Analysis of Goldfeld-Quandt test for Heteroskedasticity',4,TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'Description',header=TRUE)
a<-table.element(a,'# significant tests',header=TRUE)
a<-table.element(a,'% significant tests',header=TRUE)
a<-table.element(a,'OK/NOK',header=TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'1% type I error level',header=TRUE)
a<-table.element(a,numsignificant1)
a<-table.element(a,numsignificant1/numgqtests)
if (numsignificant1/numgqtests < 0.01) dum <- 'OK' else dum <- 'NOK'
a<-table.element(a,dum)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'5% type I error level',header=TRUE)
a<-table.element(a,numsignificant5)
a<-table.element(a,numsignificant5/numgqtests)
if (numsignificant5/numgqtests < 0.05) dum <- 'OK' else dum <- 'NOK'
a<-table.element(a,dum)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'10% type I error level',header=TRUE)
a<-table.element(a,numsignificant10)
a<-table.element(a,numsignificant10/numgqtests)
if (numsignificant10/numgqtests < 0.1) dum <- 'OK' else dum <- 'NOK'
a<-table.element(a,dum)
a<-table.row.end(a)
a<-table.end(a)
table.save(a,file='mytable6.tab')
}
 





Copyright

Creative Commons License

This work is licensed under a Creative Commons Attribution-Noncommercial-Share Alike 3.0 License.

Software written by Ed van Stee & Patrick Wessa


Disclaimer

Information provided on this web site is provided "AS IS" without warranty of any kind, either express or implied, including, without limitation, warranties of merchantability, fitness for a particular purpose, and noninfringement. We use reasonable efforts to include accurate and timely information and periodically update the information, and software without notice. However, we make no warranties or representations as to the accuracy or completeness of such information (or software), and we assume no liability or responsibility for errors or omissions in the content of this web site, or any software bugs in online applications. Your use of this web site is AT YOUR OWN RISK. Under no circumstances and under no legal theory shall we be liable to you or any other person for any direct, indirect, special, incidental, exemplary, or consequential damages arising from your access to, or use of, this web site.


Privacy Policy

We may request personal information to be submitted to our servers in order to be able to:

  • personalize online software applications according to your needs
  • enforce strict security rules with respect to the data that you upload (e.g. statistical data)
  • manage user sessions of online applications
  • alert you about important changes or upgrades in resources or applications

We NEVER allow other companies to directly offer registered users information about their products and services. Banner references and hyperlinks of third parties NEVER contain any personal data of the visitor.

We do NOT sell, nor transmit by any means, personal information, nor statistical data series uploaded by you to third parties.

We carefully protect your data from loss, misuse, alteration, and destruction. However, at any time, and under any circumstance you are solely responsible for managing your passwords, and keeping them secret.

We store a unique ANONYMOUS USER ID in the form of a small 'Cookie' on your computer. This allows us to track your progress when using this website which is necessary to create state-dependent features. The cookie is used for NO OTHER PURPOSE. At any time you may opt to disallow cookies from this website - this will not affect other features of this website.

We examine cookies that are used by third-parties (banner and online ads) very closely: abuse from third-parties automatically results in termination of the advertising contract without refund. We have very good reason to believe that the cookies that are produced by third parties (banner ads) do NOT cause any privacy or security risk.

FreeStatistics.org is safe. There is no need to download any software to use the applications and services contained in this website. Hence, your system's security is not compromised by their use, and your personal data - other than data you submit in the account application form, and the user-agent information that is transmitted by your browser - is never transmitted to our servers.

As a general rule, we do not log on-line behavior of individuals (other than normal logging of webserver 'hits'). However, in cases of abuse, hacking, unauthorized access, Denial of Service attacks, illegal copying, hotlinking, non-compliance with international webstandards (such as robots.txt), or any other harmful behavior, our system engineers are empowered to log, track, identify, publish, and ban misbehaving individuals - even if this leads to ban entire blocks of IP addresses, or disclosing user's identity.


FreeStatistics.org is powered by