R version 3.0.2 (2013-09-25) -- "Frisbee Sailing" Copyright (C) 2013 The R Foundation for Statistical Computing Platform: i686-pc-linux-gnu (32-bit) R is free software and comes with ABSOLUTELY NO WARRANTY. You are welcome to redistribute it under certain conditions. Type 'license()' or 'licence()' for distribution details. R is a collaborative project with many contributors. Type 'contributors()' for more information and 'citation()' on how to cite R or R packages in publications. Type 'demo()' for some demos, 'help()' for on-line help, or 'help.start()' for an HTML browser interface to help. Type 'q()' to quit R. > x <- c(78.7,75.7,77.1,86.1,86.8,86.3,91.5,90.7,78.2,73,73.7,77.3,67.5,72.7,76.6,82.4,82.3,86.3,93,88.8,96.9,103.9,115.7,112.8,114.7,118,129.3,137,156,166.2,167.8,144.3,126,90.4,67.5,52.4,54.6,52.9,59.1,63.3,73.8,87.6,81.8,90.7,86.3,93.6,98,94.3,97.6,94.2,100.2,106.7,95.7,94.6,94.7,96.2,96.3,103.3,106.8,113.7,117.4,123.6,137.6,147.4,137.2,133.8,136.7,127.3,128.7,127,133.7,132,135.1,142.6,149.3,143.5,131.4,114.7,122.3,133.4,134.6,130.9,127.9,128) > par4 = 'P1 P5 Q1 Q3 P95 P99' > par3 = '0' > par2 = '5' > par1 = '50' > par4 <- 'P1 P5 Q1 Q3 P95 P99' > par3 <- '0' > par2 <- '5' > par1 <- '50' > #'GNU S' R Code compiled by R2WASP v. 1.2.327 () > #Author: root > #To cite this work: Wessa P., (2013), Bootstrap Plot for Central Tendency (v1.0.13) in Free Statistics Software (v$_version), Office for Research Development and Education, URL http://www.wessa.net/rwasp_bootstrapplot1.wasp/ > #Source of accompanying publication: Office for Research, Development, and Education > # > par1 <- as.numeric(par1) > par2 <- as.numeric(par2) > if (par3 == '0') bw <- NULL > if (par3 != '0') bw <- as.numeric(par3) > if (par1 < 10) par1 = 10 > if (par1 > 5000) par1 = 5000 > library(modeest) This is package 'modeest' written by P. PONCET. For a complete list of functions, use 'library(help = "modeest")' or 'help.start()'. > library(lattice) > library(boot) Attaching package: 'boot' The following object is masked from 'package:lattice': melanoma > boot.stat <- function(s,i) + { + s.mean <- mean(s[i]) + s.median <- median(s[i]) + s.midrange <- (max(s[i]) + min(s[i])) / 2 + s.mode <- mlv(s[i], method='mfv')$M + s.kernelmode <- mlv(s[i], method='kernel', bw=bw)$M + c(s.mean, s.median, s.midrange, s.mode, s.kernelmode) + } > (r <- boot(x,boot.stat, R=par1, stype='i')) ORDINARY NONPARAMETRIC BOOTSTRAP Call: boot(data = x, statistic = boot.stat, R = par1, stype = "i") Bootstrap Statistics : original bias std. error t1* 105.18690 0.6241667 2.773429 t2* 97.80000 3.9620000 6.282894 t3* 110.10000 -0.5200000 2.521742 t4* 86.30000 13.6431500 18.562923 t5* 90.97479 9.8592370 16.976864 > postscript(file="/var/fisher/rcomp/tmp/1bnt01385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > plot(r$t[,1],type='p',ylab='simulated values',main='Simulation of Mean') > grid() > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/2o9dq1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > plot(r$t[,2],type='p',ylab='simulated values',main='Simulation of Median') > grid() > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/3jme61385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > plot(r$t[,3],type='p',ylab='simulated values',main='Simulation of Midrange') > grid() > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/4rupw1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > plot(r$t[,4],type='p',ylab='simulated values',main='Simulation of Mode') > grid() > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/5h27e1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > plot(r$t[,5],type='p',ylab='simulated values',main='Simulation of Mode of Kernel Density') > grid() > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/6v3qt1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > densityplot(~r$t[,1],col='black',main='Density Plot',xlab='mean') > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/7o7mx1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > densityplot(~r$t[,2],col='black',main='Density Plot',xlab='median') > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/8n7h21385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > densityplot(~r$t[,3],col='black',main='Density Plot',xlab='midrange') > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/9m10k1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > densityplot(~r$t[,4],col='black',main='Density Plot',xlab='mode') > dev.off() null device 1 > postscript(file="/var/fisher/rcomp/tmp/10jc051385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > densityplot(~r$t[,5],col='black',main='Density Plot',xlab='mode of kernel dens.') > dev.off() null device 1 > z <- data.frame(cbind(r$t[,1],r$t[,2],r$t[,3],r$t[,4],r$t[,5])) > colnames(z) <- list('mean','median','midrange','mode','mode k.dens') > postscript(file="/var/fisher/rcomp/tmp/11z27w1385488866.ps",horizontal=F,onefile=F,pagecentre=F,paper="special",width=8.3333333333333,height=5.5555555555556) > boxplot(z,notch=TRUE,ylab='simulated values',main='Bootstrap Simulation - Central Tendency') > grid() > dev.off() null device 1 > > #Note: the /var/fisher/rcomp/createtable file can be downloaded at http://www.wessa.net/cretab > load(file="/var/fisher/rcomp/createtable") > > a<-table.start() > a<-table.row.start(a) > a<-table.element(a,'Estimation Results of Bootstrap',10,TRUE) > a<-table.row.end(a) > if (par4 == 'P1 P5 Q1 Q3 P95 P99') { + myq.1 <- 0.01 + myq.2 <- 0.05 + myq.3 <- 0.95 + myq.4 <- 0.99 + myl.1 <- 'P1' + myl.2 <- 'P5' + myl.3 <- 'P95' + myl.4 <- 'P99' + } > if (par4 == 'P0.5 P2.5 Q1 Q3 P97.5 P99.5') { + myq.1 <- 0.005 + myq.2 <- 0.025 + myq.3 <- 0.975 + myq.4 <- 0.995 + myl.1 <- 'P0.5' + myl.2 <- 'P2.5' + myl.3 <- 'P97.5' + myl.4 <- 'P99.5' + } > if (par4 == 'P10 P20 Q1 Q3 P80 P90') { + myq.1 <- 0.10 + myq.2 <- 0.20 + myq.3 <- 0.80 + myq.4 <- 0.90 + myl.1 <- 'P10' + myl.2 <- 'P20' + myl.3 <- 'P80' + myl.4 <- 'P90' + } > a<-table.row.start(a) > a<-table.element(a,'statistic',header=TRUE) > a<-table.element(a,myl.1,header=TRUE) > a<-table.element(a,myl.2,header=TRUE) > a<-table.element(a,'Q1',header=TRUE) > a<-table.element(a,'Estimate',header=TRUE) > a<-table.element(a,'Q3',header=TRUE) > a<-table.element(a,myl.3,header=TRUE) > a<-table.element(a,myl.4,header=TRUE) > a<-table.element(a,'S.D.',header=TRUE) > a<-table.element(a,'IQR',header=TRUE) > a<-table.row.end(a) > a<-table.row.start(a) > a<-table.element(a,'mean',header=TRUE) > q1 <- quantile(r$t[,1],0.25)[[1]] > q3 <- quantile(r$t[,1],0.75)[[1]] > p01 <- quantile(r$t[,1],myq.1)[[1]] > p05 <- quantile(r$t[,1],myq.2)[[1]] > p95 <- quantile(r$t[,1],myq.3)[[1]] > p99 <- quantile(r$t[,1],myq.4)[[1]] > a<-table.element(a,signif(p01,par2)) > a<-table.element(a,signif(p05,par2)) > a<-table.element(a,signif(q1,par2)) > a<-table.element(a,signif(r$t0[1],par2)) > a<-table.element(a,signif(q3,par2)) > a<-table.element(a,signif(p95,par2)) > a<-table.element(a,signif(p99,par2)) > a<-table.element( a,signif( sqrt(var(r$t[,1])),par2 ) ) > a<-table.element(a,signif(q3-q1,par2)) > a<-table.row.end(a) > a<-table.row.start(a) > a<-table.element(a,'median',header=TRUE) > q1 <- quantile(r$t[,2],0.25)[[1]] > q3 <- quantile(r$t[,2],0.75)[[1]] > p01 <- quantile(r$t[,2],myq.1)[[1]] > p05 <- quantile(r$t[,2],myq.2)[[1]] > p95 <- quantile(r$t[,2],myq.3)[[1]] > p99 <- quantile(r$t[,2],myq.4)[[1]] > a<-table.element(a,signif(p01,par2)) > a<-table.element(a,signif(p05,par2)) > a<-table.element(a,signif(q1,par2)) > a<-table.element(a,signif(r$t0[2],par2)) > a<-table.element(a,signif(q3,par2)) > a<-table.element(a,signif(p95,par2)) > a<-table.element(a,signif(p99,par2)) > a<-table.element(a,signif(sqrt(var(r$t[,2])),par2)) > a<-table.element(a,signif(q3-q1,par2)) > a<-table.row.end(a) > a<-table.row.start(a) > a<-table.element(a,'midrange',header=TRUE) > q1 <- quantile(r$t[,3],0.25)[[1]] > q3 <- quantile(r$t[,3],0.75)[[1]] > p01 <- quantile(r$t[,3],myq.1)[[1]] > p05 <- quantile(r$t[,3],myq.2)[[1]] > p95 <- quantile(r$t[,3],myq.3)[[1]] > p99 <- quantile(r$t[,3],myq.4)[[1]] > a<-table.element(a,signif(p01,par2)) > a<-table.element(a,signif(p05,par2)) > a<-table.element(a,signif(q1,par2)) > a<-table.element(a,signif(r$t0[3],par2)) > a<-table.element(a,signif(q3,par2)) > a<-table.element(a,signif(p95,par2)) > a<-table.element(a,signif(p99,par2)) > a<-table.element(a,signif(sqrt(var(r$t[,3])),par2)) > a<-table.element(a,signif(q3-q1,par2)) > a<-table.row.end(a) > a<-table.row.start(a) > a<-table.element(a,'mode',header=TRUE) > q1 <- quantile(r$t[,4],0.25)[[1]] > q3 <- quantile(r$t[,4],0.75)[[1]] > p01 <- quantile(r$t[,4],myq.1)[[1]] > p05 <- quantile(r$t[,4],myq.2)[[1]] > p95 <- quantile(r$t[,4],myq.3)[[1]] > p99 <- quantile(r$t[,4],myq.4)[[1]] > a<-table.element(a,signif(p01,par2)) > a<-table.element(a,signif(p05,par2)) > a<-table.element(a,signif(q1,par2)) > a<-table.element(a,signif(r$t0[4],par2)) > a<-table.element(a,signif(q3,par2)) > a<-table.element(a,signif(p95,par2)) > a<-table.element(a,signif(p99,par2)) > a<-table.element(a,signif(sqrt(var(r$t[,4])),par2)) > a<-table.element(a,signif(q3-q1,par2)) > a<-table.row.end(a) > a<-table.row.start(a) > a<-table.element(a,'mode k.dens',header=TRUE) > q1 <- quantile(r$t[,5],0.25)[[1]] > q3 <- quantile(r$t[,5],0.75)[[1]] > p01 <- quantile(r$t[,5],myq.1)[[1]] > p05 <- quantile(r$t[,5],myq.2)[[1]] > p95 <- quantile(r$t[,5],myq.3)[[1]] > p99 <- quantile(r$t[,5],myq.4)[[1]] > a<-table.element(a,signif(p01,par2)) > a<-table.element(a,signif(p05,par2)) > a<-table.element(a,signif(q1,par2)) > a<-table.element(a,signif(r$t0[5],par2)) > a<-table.element(a,signif(q3,par2)) > a<-table.element(a,signif(p95,par2)) > a<-table.element(a,signif(p99,par2)) > a<-table.element(a,signif(sqrt(var(r$t[,5])),par2)) > a<-table.element(a,signif(q3-q1,par2)) > a<-table.row.end(a) > a<-table.end(a) > table.save(a,file="/var/fisher/rcomp/tmp/12c6a71385488866.tab") > > try(system("convert tmp/1bnt01385488866.ps tmp/1bnt01385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/2o9dq1385488866.ps tmp/2o9dq1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/3jme61385488866.ps tmp/3jme61385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/4rupw1385488866.ps tmp/4rupw1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/5h27e1385488866.ps tmp/5h27e1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/6v3qt1385488866.ps tmp/6v3qt1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/7o7mx1385488866.ps tmp/7o7mx1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/8n7h21385488866.ps tmp/8n7h21385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/9m10k1385488866.ps tmp/9m10k1385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/10jc051385488866.ps tmp/10jc051385488866.png",intern=TRUE)) character(0) > try(system("convert tmp/11z27w1385488866.ps tmp/11z27w1385488866.png",intern=TRUE)) character(0) > > > proc.time() user system elapsed 6.720 1.350 8.053