ObservationType
- Type of observationParameterType
- Type of parameters to infer@PublicationReference(author="Wikipedia", title="Rejection Sampling", type=WebPage, year=2009, url="http://en.wikipedia.org/wiki/Rejection_sampling") public class RejectionSampling<ObservationType,ParameterType> extends AbstractRandomized implements BayesianEstimator<ObservationType,ParameterType,DataDistribution<ParameterType>>
Modifier and Type | Class and Description |
---|---|
static class |
RejectionSampling.DefaultUpdater<ObservationType,ParameterType>
Default ImportanceSampling Updater that uses a BayesianParameter
to compute the quantities of interest.
|
static class |
RejectionSampling.ScalarEstimator<ObservationType>
Routine for estimating the minimum scalar needed to envelop the
conjunctive distribution.
|
static interface |
RejectionSampling.Updater<ObservationType,ParameterType>
Updater for ImportanceSampling
|
Modifier and Type | Field and Description |
---|---|
static int |
DEFAULT_NUM_SAMPLES
Default number of samples, 1000.
|
protected RejectionSampling.Updater<ObservationType,ParameterType> |
updater
Updater for the ImportanceSampling algorithm.
|
random
Constructor and Description |
---|
RejectionSampling()
Creates a new instance of RejectionSampling
|
Modifier and Type | Method and Description |
---|---|
RejectionSampling<ObservationType,ParameterType> |
clone()
This makes public the clone method on the
Object class and
removes the exception that it throws. |
int |
getNumSamples()
Getter for numSamples
|
RejectionSampling.Updater<ObservationType,ParameterType> |
getUpdater()
Getter for updater
|
DataDistribution<ParameterType> |
learn(java.util.Collection<? extends ObservationType> data)
The
learn method creates an object of ResultType using
data of type DataType , using some form of "learning" algorithm. |
void |
setNumSamples(int numSamples)
Setter for numSamples
|
void |
setUpdater(RejectionSampling.Updater<ObservationType,ParameterType> updater)
Setter for updater
|
getRandom, setRandom
public static final int DEFAULT_NUM_SAMPLES
protected RejectionSampling.Updater<ObservationType,ParameterType> updater
public RejectionSampling()
public RejectionSampling<ObservationType,ParameterType> clone()
AbstractCloneableSerializable
Object
class and
removes the exception that it throws. Its default behavior is to
automatically create a clone of the exact type of object that the
clone is called on and to copy all primitives but to keep all references,
which means it is a shallow copy.
Extensions of this class may want to override this method (but call
super.clone()
to implement a "smart copy". That is, to target
the most common use case for creating a copy of the object. Because of
the default behavior being a shallow copy, extending classes only need
to handle fields that need to have a deeper copy (or those that need to
be reset). Some of the methods in ObjectUtil
may be helpful in
implementing a custom clone method.
Note: The contract of this method is that you must use
super.clone()
as the basis for your implementation.clone
in interface CloneableSerializable
clone
in class AbstractRandomized
public DataDistribution<ParameterType> learn(java.util.Collection<? extends ObservationType> data)
BatchLearner
learn
method creates an object of ResultType
using
data of type DataType
, using some form of "learning" algorithm.learn
in interface BatchLearner<java.util.Collection<? extends ObservationType>,DataDistribution<ParameterType>>
data
- The data that the learning algorithm will use to create an
object of ResultType
.public int getNumSamples()
public void setNumSamples(int numSamples)
numSamples
- Number of samples.public RejectionSampling.Updater<ObservationType,ParameterType> getUpdater()
public void setUpdater(RejectionSampling.Updater<ObservationType,ParameterType> updater)
updater
- Updater for the ImportanceSampling algorithm.