Package jslx.statistics
Class MultiBootstrap
- java.lang.Object
- 
- jslx.statistics.MultiBootstrap
 
- 
- All Implemented Interfaces:
- RNStreamControlIfc
 
 public class MultiBootstrap extends java.lang.Object implements RNStreamControlIfc A collection of Bootstrap instances to permit multi-dimensional bootstrapping. Construction depends on a named mapping of double[] arrays that represent the original samples. A static create method also allows creation based on a mapping to implementations of the SampleIfc. The name provided for each dataset (or sampler) should be unique and will be used to identify the associated bootstrap results. We call this name a addFactor.
- 
- 
Field SummaryFields Modifier and Type Field Description protected java.util.Map<java.lang.String,Bootstrap>myBootstrapsprotected longmyIdThe id of this objectprotected java.lang.StringmyName
 - 
Constructor SummaryConstructors Constructor Description MultiBootstrap(java.lang.String name, java.util.Map<java.lang.String,double[]> dataMap)MultiBootstrap(java.util.Map<java.lang.String,double[]> dataMap)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadvanceToNextSubstream()Positions the RNG at the beginning of its next substream for all bootstrapsjava.lang.StringasString()static MultiBootstrapcreate(int sampleSize, java.util.Map<java.lang.String,SampleIfc> samplerMap)static MultiBootstrapcreate(java.lang.String name, int sampleSize, java.util.Map<java.lang.String,SampleIfc> samplerMap)static MultiBootstrapcreate(java.lang.String name, java.util.Map<java.lang.String,java.util.Map.Entry<java.lang.Integer,SampleIfc>> samplerMap)static MultiBootstrapcreate(java.util.Map<java.lang.String,java.util.Map.Entry<java.lang.Integer,SampleIfc>> samplerMap)voidgenerateSamples(int numBootstrapSamples)The individual bootstrapped samples are not saved.voidgenerateSamples(int numBootstrapSamples, boolean saveBootstrapSamples)The estimator is EstimatorIfc.Average()voidgenerateSamples(int numBootstrapSamples, EstimatorIfc estimator)The individual bootstrapped samples are not saved.voidgenerateSamples(int numBootstrapSamples, EstimatorIfc estimator, boolean saveBootstrapSamples)This method changes the underlying state of the Bootstrap instance by performing the bootstrap sampling.voidgenerateSamples(java.util.Map<java.lang.String,java.lang.Integer> numBootstrapSamples, EstimatorIfc estimator, boolean saveBootstrapSamples)This method changes the underlying state of the Bootstrap instance by performing the bootstrap sampling.booleangetAntitheticOption()False means at least one is false.BootstrapgetBootstrap(java.lang.String name)java.util.List<Bootstrap>getBootstrapList()java.util.Map<java.lang.String,java.util.List<RVariableIfc>>getBootstrapRandomVariables()Gets a map with key = name, where name is the associated bootstrap name and the value is List holding a RVariableIfc representation for each bootstrap generate within the bootstrap.java.util.Map<java.lang.String,java.util.List<RVariableIfc>>getBootstrapRandomVariables(boolean useCRN)Gets a map with key = name, where name is the associated bootstrap name and the value is List holding a RVariableIfc representation for each bootstrap generate within the bootstrap.java.util.Map<java.lang.String,double[]>getBootstrapSampleAverages()Gets a map with key = name, where name is the associated bootstrap name and the value is the an array holding the generate averages for each bootstrap samples within the bootstrapjava.util.Map<java.lang.String,java.util.List<double[]>>getBootstrapSampleData()Gets a map with key = name, where name is the associated bootstrap name and the value is List holding the generate data for each bootstrap generate within the bootstrap.java.util.Map<java.lang.String,double[]>getBootstrapSampleData(int b)Gets a map with key = name, where name is the associated bootstrap name and the value is the generate data for the bth bootstrap generate.double[]getBootstrapSampleData(java.lang.String name, int b)java.util.Map<java.lang.String,double[]>getBootstrapSampleVariances()Gets a map with key = name, where name is the associated bootstrap name and the value is the an array holding the generate variances for each bootstrap samples within the bootstrapjava.util.List<java.lang.String>getFactorNames()longgetId()java.lang.StringgetName()intgetNumberFactors()voidresetStartStream()The resetStartStream method will position the RNG at the beginning of its stream.voidresetStartSubstream()Resets the position of the RNG at the start of the current substream for all bootstrapsvoidsetAntitheticOption(boolean flag)Tells all the streams to change their antithetic optionjava.lang.StringtoString()
 
- 
- 
- 
Field Detail- 
myIdprotected final long myId The id of this object
 - 
myNameprotected final java.lang.String myName 
 - 
myBootstrapsprotected java.util.Map<java.lang.String,Bootstrap> myBootstraps 
 
- 
 - 
Constructor Detail- 
MultiBootstrappublic MultiBootstrap(java.util.Map<java.lang.String,double[]> dataMap) - Parameters:
- dataMap- a map holding the name for each data set
 
 - 
MultiBootstrappublic MultiBootstrap(java.lang.String name, java.util.Map<java.lang.String,double[]> dataMap)- Parameters:
- name- the name of the instance
- dataMap- a map holding the name for each data set, names cannot be null and the arrays cannot be null
 
 
- 
 - 
Method Detail- 
getIdpublic final long getId() - Returns:
- the identity is unique to this execution/construction
 
 - 
getNamepublic final java.lang.String getName() - Returns:
- the name of the bootstrap
 
 - 
getNumberFactorspublic final int getNumberFactors() - Returns:
- the number of factors in the multibootstrap
 
 - 
getFactorNamespublic final java.util.List<java.lang.String> getFactorNames() - Returns:
- the names of the factors as a list
 
 - 
createpublic static final MultiBootstrap create(int sampleSize, java.util.Map<java.lang.String,SampleIfc> samplerMap) - Parameters:
- sampleSize- the size of the original generate
- samplerMap- something to generate the original generate of the provided size
- Returns:
- an instance of MultiBootstrap based on data generated from each generate
 
 - 
createpublic static final MultiBootstrap create(java.lang.String name, int sampleSize, java.util.Map<java.lang.String,SampleIfc> samplerMap) - Parameters:
- name- the name of the instance
- sampleSize- the generate size, all samplers have the same amount sampled
- samplerMap- something to generate the original generate of the provided size
- Returns:
- an instance of MultiBootstrap based on data generated from each generate
 
 - 
createpublic static final MultiBootstrap create(java.util.Map<java.lang.String,java.util.Map.Entry<java.lang.Integer,SampleIfc>> samplerMap) - Parameters:
- samplerMap- the String of the map is the named identifier for the bootstrap, the entry of the map is a pair (Integer, SamplerIfc) which represents the number to generate and the sampler
- Returns:
- an instance of MultiBootstrap based on data generated from each generate
 
 - 
createpublic static final MultiBootstrap create(java.lang.String name, java.util.Map<java.lang.String,java.util.Map.Entry<java.lang.Integer,SampleIfc>> samplerMap) - Parameters:
- name- the name of the instance
- samplerMap- the String of the map is the named identifier for the bootstrap, the entry of the map is a pair (Integer, SamplerIfc) which represents the number to generate and the sampler
- Returns:
- an instance of MultiBootstrap based on data generated from each generate
 
 - 
generateSamplespublic final void generateSamples(int numBootstrapSamples) The individual bootstrapped samples are not saved. The estimator is EstimatorIfc.Average()- Parameters:
- numBootstrapSamples- the number of bootstrap samples to generate
 
 - 
generateSamplespublic final void generateSamples(int numBootstrapSamples, boolean saveBootstrapSamples)The estimator is EstimatorIfc.Average()- Parameters:
- numBootstrapSamples- the number of bootstrap samples to generate
- saveBootstrapSamples- indicates that the statistics and data of each bootstrap generate should be saved
 
 - 
generateSamplespublic final void generateSamples(int numBootstrapSamples, EstimatorIfc estimator)The individual bootstrapped samples are not saved.- Parameters:
- numBootstrapSamples- the number of bootstrap samples to generate
- estimator- a function of the data
 
 - 
generateSamplespublic void generateSamples(int numBootstrapSamples, EstimatorIfc estimator, boolean saveBootstrapSamples)This method changes the underlying state of the Bootstrap instance by performing the bootstrap sampling.- Parameters:
- numBootstrapSamples- the number of bootstrap samples to generate, assumes all are the same.
- estimator- a function of the data
- saveBootstrapSamples- indicates that the statistics and data of each bootstrap generate should be saved
 
 - 
generateSamplespublic void generateSamples(java.util.Map<java.lang.String,java.lang.Integer> numBootstrapSamples, EstimatorIfc estimator, boolean saveBootstrapSamples)This method changes the underlying state of the Bootstrap instance by performing the bootstrap sampling.- Parameters:
- numBootstrapSamples- the number of bootstrap samples to generate for each of the bootstraps, the keys must match the keys in the original data map. If the names do not match then the bootstraps are not generated.
- estimator- a function of the data
- saveBootstrapSamples- indicates that the statistics and data of each bootstrap generate should be saved
 
 - 
getBootstrapSampleAveragespublic java.util.Map<java.lang.String,double[]> getBootstrapSampleAverages() Gets a map with key = name, where name is the associated bootstrap name and the value is the an array holding the generate averages for each bootstrap samples within the bootstrap- Returns:
- a map of the generate averages
 
 - 
getBootstrapSampleVariancespublic java.util.Map<java.lang.String,double[]> getBootstrapSampleVariances() Gets a map with key = name, where name is the associated bootstrap name and the value is the an array holding the generate variances for each bootstrap samples within the bootstrap- Returns:
- a map of the generate averages
 
 - 
getBootstrapSampleDatapublic java.util.Map<java.lang.String,java.util.List<double[]>> getBootstrapSampleData() Gets a map with key = name, where name is the associated bootstrap name and the value is List holding the generate data for each bootstrap generate within the bootstrap. The size of the list is the number of bootstrap samples generated. Each element of the list is the data associated with each generate.- Returns:
- a map of the list of bootstrap data
 
 - 
getBootstrapRandomVariablespublic java.util.Map<java.lang.String,java.util.List<RVariableIfc>> getBootstrapRandomVariables() Gets a map with key = name, where name is the associated bootstrap name and the value is List holding a RVariableIfc representation for each bootstrap generate within the bootstrap. The size of the list is the number of bootstrap samples generated. Each element of the list is a RVariableIfc representation of the data with the bootstrap generate. The stream for every random variable is the same across the bootstraps (but different across factors) to facilitate common random number generation (CRN).- Returns:
- a map of the list of bootstrap random variable representations
 
 - 
getBootstrapRandomVariablespublic java.util.Map<java.lang.String,java.util.List<RVariableIfc>> getBootstrapRandomVariables(boolean useCRN) Gets a map with key = name, where name is the associated bootstrap name and the value is List holding a RVariableIfc representation for each bootstrap generate within the bootstrap. The size of the list is the number of bootstrap samples generated. Each element of the list is a RVariableIfc representation of the data with the bootstrap generate.- Parameters:
- useCRN- , if true the stream for every random variable is the same across the bootstraps to facilitate common random number generation (CRN). If false different streams are used for each created random variable
- Returns:
- a map of the list of bootstrap random variable representations
 
 - 
getBootstrapSampleDatapublic double[] getBootstrapSampleData(java.lang.String name, int b)- Parameters:
- name- the name of the bootstrap
- b- the bootstrap generate number, b = 1, 2, ... to getNumBootstrapSamples()
- Returns:
- the generate generated for the bth bootstrap, if no samples are saved then the array returned is of zero length
 
 - 
getBootstrapSampleDatapublic java.util.Map<java.lang.String,double[]> getBootstrapSampleData(int b) Gets a map with key = name, where name is the associated bootstrap name and the value is the generate data for the bth bootstrap generate. The size of the array is the size of the generated bootstrap generate, the array may be of zero length if the samples were not saved- Parameters:
- b- the bootstrap generate number, b = 1, 2, ... to getNumBootstrapSamples()
- Returns:
- a map holding the bth bootstrap data for each bootstrap
 
 - 
getBootstrappublic final Bootstrap getBootstrap(java.lang.String name) - Parameters:
- name- the name of the Bootstrap to get
- Returns:
- the Bootstrap associated with the name
 
 - 
getBootstrapListpublic java.util.List<Bootstrap> getBootstrapList() - Returns:
- a list of all the bootstraps
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 - 
asStringpublic java.lang.String asString() - Returns:
- the bootstrap results as a string
 
 - 
resetStartStreampublic void resetStartStream() The resetStartStream method will position the RNG at the beginning of its stream. This is the same location in the stream as assigned when the RNG was created and initialized for all bootstraps- Specified by:
- resetStartStreamin interface- RNStreamControlIfc
 
 - 
resetStartSubstreampublic void resetStartSubstream() Resets the position of the RNG at the start of the current substream for all bootstraps- Specified by:
- resetStartSubstreamin interface- RNStreamControlIfc
 
 - 
advanceToNextSubstreampublic void advanceToNextSubstream() Positions the RNG at the beginning of its next substream for all bootstraps- Specified by:
- advanceToNextSubstreamin interface- RNStreamControlIfc
 
 - 
setAntitheticOptionpublic void setAntitheticOption(boolean flag) Tells all the streams to change their antithetic option- Specified by:
- setAntitheticOptionin interface- RNStreamControlIfc
- Parameters:
- flag- true means that it produces antithetic variates.
 
 - 
getAntitheticOptionpublic boolean getAntitheticOption() False means at least one is false.- Specified by:
- getAntitheticOptionin interface- RNStreamControlIfc
- Returns:
- true means on all bootstraps have antithetic option on
 
 
- 
 
-