Home » date » 2009 » Dec » 04 »

ws 9: exponential smoothing

*The author of this computation has been verified*
R Software Module: /rwasp_exponentialsmoothing.wasp (opens new window with default values)
Title produced by software: Exponential Smoothing
Date of computation: Fri, 04 Dec 2009 08:35:15 -0700
 
Cite this page as follows:
Statistical Computations at FreeStatistics.org, Office for Research Development and Education, URL http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27.htm/, Retrieved Fri, 04 Dec 2009 16:35:49 +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/2009/Dec/04/t1259940945k20r5bfoclolf27.htm/},
    year = {2009},
}
@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 = {2009},
    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 «
79.8 83.4 113.6 112.9 104 109.9 99 106.3 128.9 111.1 102.9 130 87 87.5 117.6 103.4 110.8 112.6 102.5 112.4 135.6 105.1 127.7 137 91 90.5 122.4 123.3 124.3 120 118.1 119 142.7 123.6 129.6 151.6 110.4 99.2 130.5 136.2 129.7 128 121.6 135.8 143.8 147.5 136.2 156.6 123.3 104.5 139.8 136.5 112.1 118.5 94.4 102.3 111.4 99.2 87.8 115.8
 
Output produced by software:


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


Estimated Parameters of Exponential Smoothing
ParameterValue
alpha0.39496296829087
beta0.183094101313385
gamma0.644958687350449


Interpolation Forecasts of Exponential Smoothing
tObservedFittedResiduals
138786.2410064910560.758993508944016
1487.587.01979041419630.480209585803749
15117.6117.0874142004220.512585799578034
16103.4103.528359905879-0.128359905879265
17110.8110.5395937729980.260406227002349
18112.6111.5682910846041.03170891539605
19102.5102.798455794746-0.298455794746488
20112.4110.2752732604982.12472673950171
21135.6135.1138410677390.48615893226085
22105.1117.588315576490-12.4883155764899
23127.7104.27938131087923.4206186891212
24137144.820228932451-7.82022893245136
259195.8538749386248-4.85387493862478
2690.594.5640330111002-4.06403301110021
27122.4124.620095482164-2.22009548216366
28123.3108.69968078321914.6003192167807
29124.3123.2562551824091.04374481759140
30120125.899247386699-5.89924738669933
31118.1113.2358328737774.86416712622336
32119125.486247188026-6.48624718802567
33142.7148.720876219639-6.02087621963935
34123.6121.2493295721092.35067042789126
35129.6128.6163480440540.983651955945533
36151.6147.9102070438993.6897929561014
37110.4100.9609657060539.43903429394676
3899.2106.547012121165-7.34701212116492
39130.5141.209642796919-10.7096427969186
40136.2127.4400073257038.75999267429725
41129.7134.368655182123-4.66865518212265
42128131.245203197272-3.24520319727154
43121.6122.873339460583-1.27333946058297
44135.8127.5215809025078.27841909749326
45143.8159.071824885082-15.2718248850821
46147.5129.39092268528918.1090773147115
47136.2143.773351668667-7.57335166866687
48156.6162.566569237088-5.96656923708829
49123.3110.60657432178212.6934256782176
50104.5110.280899047444-5.78089904744392
51139.8146.549107503577-6.74910750357657
52136.5141.830251885327-5.33025188532682
53112.1136.981192390721-24.8811923907206
54118.5124.184618141031-5.68461814103101
5594.4113.651172273622-19.2511722736216
56102.3109.882769188564-7.58276918856379
57111.4116.459249243814-5.05924924381364
5899.2101.296471086083-2.09647108608323
5987.892.9228304871463-5.12283048714626
60115.899.295017228643216.5049827713568


Extrapolation Forecasts of Exponential Smoothing
tForecast95% Lower Bound95% Upper Bound
6173.742510212709859.773144095726487.7118763296932
6262.388216202192246.598380608087178.1780517962973
6380.315054429771559.0357735748043101.594335284739
6475.238457854210250.962063617596199.5148520908242
6565.501437444353939.463990621604191.5388842671037
6665.128462486735834.445504100775295.8114208726964
6755.050223569446623.533306190550786.5671409483424
6857.846461633423319.094164472255796.5987587945908
6961.924334854323413.4042716986218110.444398010025
7053.80942649675763.76331594632744103.855537047188
7147.6698718636309-4.86453787945371100.204281606715
7254.9485875501871-14.6951939996628124.592369100037
 
Charts produced by software:
http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/1nvjp1259940913.png (open in new window)
http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/1nvjp1259940913.ps (open in new window)


http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/2jlq21259940913.png (open in new window)
http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/2jlq21259940913.ps (open in new window)


http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/32c001259940913.png (open in new window)
http://www.freestatistics.org/blog/date/2009/Dec/04/t1259940945k20r5bfoclolf27/32c001259940913.ps (open in new window)


 
Parameters (Session):
par1 = 12 ; par2 = Triple ; par3 = multiplicative ;
 
Parameters (R input):
par1 = 12 ; par2 = Triple ; par3 = multiplicative ;
 
R code (references can be found in the software module):
par1 <- as.numeric(par1)
if (par2 == 'Single') K <- 1
if (par2 == 'Double') K <- 2
if (par2 == 'Triple') K <- par1
nx <- length(x)
nxmK <- nx - K
x <- ts(x, frequency = par1)
if (par2 == 'Single') fit <- HoltWinters(x, gamma=0, beta=0)
if (par2 == 'Double') fit <- HoltWinters(x, gamma=0)
if (par2 == 'Triple') fit <- HoltWinters(x, seasonal=par3)
fit
myresid <- x - fit$fitted[,'xhat']
bitmap(file='test1.png')
op <- par(mfrow=c(2,1))
plot(fit,ylab='Observed (black) / Fitted (red)',main='Interpolation Fit of Exponential Smoothing')
plot(myresid,ylab='Residuals',main='Interpolation Prediction Errors')
par(op)
dev.off()
bitmap(file='test2.png')
p <- predict(fit, par1, prediction.interval=TRUE)
np <- length(p[,1])
plot(fit,p,ylab='Observed (black) / Fitted (red)',main='Extrapolation Fit of Exponential Smoothing')
dev.off()
bitmap(file='test3.png')
op <- par(mfrow = c(2,2))
acf(as.numeric(myresid),lag.max = nx/2,main='Residual ACF')
spectrum(myresid,main='Residals Periodogram')
cpgram(myresid,main='Residal Cumulative Periodogram')
qqnorm(myresid,main='Residual Normal QQ Plot')
qqline(myresid)
par(op)
dev.off()
load(file='createtable')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a,'Estimated Parameters of Exponential Smoothing',2,TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'Parameter',header=TRUE)
a<-table.element(a,'Value',header=TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'alpha',header=TRUE)
a<-table.element(a,fit$alpha)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'beta',header=TRUE)
a<-table.element(a,fit$beta)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'gamma',header=TRUE)
a<-table.element(a,fit$gamma)
a<-table.row.end(a)
a<-table.end(a)
table.save(a,file='mytable.tab')
a<-table.start()
a<-table.row.start(a)
a<-table.element(a,'Interpolation Forecasts of Exponential Smoothing',4,TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'t',header=TRUE)
a<-table.element(a,'Observed',header=TRUE)
a<-table.element(a,'Fitted',header=TRUE)
a<-table.element(a,'Residuals',header=TRUE)
a<-table.row.end(a)
for (i in 1:nxmK) {
a<-table.row.start(a)
a<-table.element(a,i+K,header=TRUE)
a<-table.element(a,x[i+K])
a<-table.element(a,fit$fitted[i,'xhat'])
a<-table.element(a,myresid[i])
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,'Extrapolation Forecasts of Exponential Smoothing',4,TRUE)
a<-table.row.end(a)
a<-table.row.start(a)
a<-table.element(a,'t',header=TRUE)
a<-table.element(a,'Forecast',header=TRUE)
a<-table.element(a,'95% Lower Bound',header=TRUE)
a<-table.element(a,'95% Upper Bound',header=TRUE)
a<-table.row.end(a)
for (i in 1:np) {
a<-table.row.start(a)
a<-table.element(a,nx+i,header=TRUE)
a<-table.element(a,p[i,'fit'])
a<-table.element(a,p[i,'lwr'])
a<-table.element(a,p[i,'upr'])
a<-table.row.end(a)
}
a<-table.end(a)
table.save(a,file='mytable2.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