R version 3.2.5 (2016-04-14) -- "Very, Very Secure Dishes" Copyright (C) 2016 The R Foundation for Statistical Computing Platform: x86_64-pc-linux-gnu (64-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(99.13,100.46,101.83,100.82,100.99,99.11,98.99,99.8,100.3,101.56,98.83,101.29,98.24,98.37,99.68,97.8,98.34,98.06,97.19,99.44,99.04,100.81,98.49,101.03,98.59,101.07,99.28,101.65,100.59,101.84,100.27,100.04,97.78,97.59,97.68,100.56,98.9,100.08,101.7,100.9,100.67,100.51,100.01,99.8,97.7,98.14,101.77,99.82,100.03,101.83,98.25,99.88,98.96,98.37,97.52,99.59,97.99,100.68,100.39,99.31,96.93,102.06,97.9,102.29,100.55,100.77,100.68,100.75,100.21,99.85,100.59,101.45) > 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 (Wed, 25 Nov 2015 11:13:57 +0000) > #Author: root > #To cite this work: Wessa P., (2015), Bootstrap Plot for Central Tendency (v1.0.14) 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) + } > x<-na.omit(x) > (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* 99.76903 -0.005333333 0.1718191 t2* 99.94500 -0.025900000 0.2436996 t3* 99.61000 0.023000000 0.1127848 t4* 100.25400 -0.655603333 1.1458403 t5* 100.43598 -0.150580196 0.6575803 Warning message: In .deal.ties(ny, i, tie.action, tie.limit) : encountered a tie, and the difference between minimal and maximal value is > length('x') * 'tie.limit' the distribution could be multimodal > postscript(file="/var/wessaorg/rcomp/tmp/1zz071462298222.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/wessaorg/rcomp/tmp/2zyg81462298222.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/wessaorg/rcomp/tmp/3nwvw1462298222.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/wessaorg/rcomp/tmp/4v64s1462298222.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/wessaorg/rcomp/tmp/5spgc1462298222.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/wessaorg/rcomp/tmp/6np7e1462298222.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/wessaorg/rcomp/tmp/7a6901462298222.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/wessaorg/rcomp/tmp/8lqq91462298222.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/wessaorg/rcomp/tmp/91xw41462298222.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/wessaorg/rcomp/tmp/106uha1462298222.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/wessaorg/rcomp/tmp/11o15a1462298222.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') Warning message: In bxp(list(stats = c(99.3877777777778, 99.6445833333333, 99.7688888888889, : some notches went outside hinges ('box'): maybe set notch=FALSE > grid() > dev.off() null device 1 > > #Note: the /var/wessaorg/rcomp/createtable file can be downloaded at http://www.wessa.net/cretab > load(file="/var/wessaorg/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/wessaorg/rcomp/tmp/12g4je1462298222.tab") > > try(system("convert tmp/1zz071462298222.ps tmp/1zz071462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/2zyg81462298222.ps tmp/2zyg81462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/3nwvw1462298222.ps tmp/3nwvw1462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/4v64s1462298222.ps tmp/4v64s1462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/5spgc1462298222.ps tmp/5spgc1462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/6np7e1462298222.ps tmp/6np7e1462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/7a6901462298222.ps tmp/7a6901462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/8lqq91462298222.ps tmp/8lqq91462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/91xw41462298222.ps tmp/91xw41462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/106uha1462298222.ps tmp/106uha1462298222.png",intern=TRUE)) character(0) > try(system("convert tmp/11o15a1462298222.ps tmp/11o15a1462298222.png",intern=TRUE)) character(0) > > > proc.time() user system elapsed 4.419 0.779 5.237