ptolemy.actor.lib.colt
Class ColtBinomialSelector

java.lang.Object
  extended by ptolemy.kernel.util.NamedObj
      extended by ptolemy.kernel.InstantiableNamedObj
          extended by ptolemy.kernel.Entity
              extended by ptolemy.kernel.ComponentEntity
                  extended by ptolemy.actor.AtomicActor
                      extended by ptolemy.actor.TypedAtomicActor
                          extended by ptolemy.actor.lib.Source
                              extended by ptolemy.actor.lib.RandomSource
                                  extended by ptolemy.actor.lib.colt.ColtRandomSource
                                      extended by ptolemy.actor.lib.colt.ColtBinomialSelector
All Implemented Interfaces:
java.io.Serializable, java.lang.Cloneable, Actor, Executable, FiringsRecordable, Initializable, TypedActor, Changeable, Debuggable, DebugListener, Derivable, Instantiable, ModelErrorHandler, MoMLExportable, Moveable, Nameable

public class ColtBinomialSelector
extends ColtRandomSource

Assign trials from several populations using a conditional Binomial selection process. For example, if a vector of P populations are presented (as P input channels) and N trials is specified, then this algorithm will distribute the N trials based on the proportions represented in the P populations. This is done by performing a progressively conditional Binomial selection in which n and p change after each trial assignment step. The Binomial trials (n) is decremented after each assignment step to represent the remaining trials, and the new Binomial probability (p) is calculated based on the populations that remain eligible for selection.

A new set of trial assignments is produced for each iteration and will not change until the next iteration. The values that are generated are independent and the expected values of the assignments will have expected values that are representative of the population proportions.

Since:
Ptolemy II 6.0
Version:
$Id: ColtBinomialSelector.java 59167 2010-09-21 17:08:02Z cxh $
Author:
Raymond A. Cardillo, Matthew J. Robbins, Contributors: Jason Smith and Brian Hudson
See Also:
ColtBinomial, Binomial, Serialized Form
Accepted Rating:
Red (cxh)
Proposed Rating:
Red (cxh)

Nested Class Summary
 
Nested classes/interfaces inherited from class ptolemy.kernel.Entity
Entity.ContainedObjectsIterator
 
Field Summary
private  int[] _current
          The tokens to emit during the current iteration.
private  cern.jet.random.Binomial _generator
          The random number generator.
 TypedIOPort populations
          The populations to select from.
 PortParameter trials
          The total number of trials to assign.
 
Fields inherited from class ptolemy.actor.lib.colt.ColtRandomSource
_randomNumberGenerator, generatorClass
 
Fields inherited from class ptolemy.actor.lib.RandomSource
_generatorSeed, _needNew, _needNewGenerator, _random, resetOnEachRun, seed
 
Fields inherited from class ptolemy.actor.lib.Source
output, trigger
 
Fields inherited from class ptolemy.actor.AtomicActor
_actorFiringListeners, _initializables, _notifyingActorFiring, _stopRequested
 
Fields inherited from class ptolemy.kernel.util.NamedObj
_changeListeners, _changeLock, _changeRequests, _debugging, _debugListeners, _elementName, _isPersistent, _verbose, _workspace, ATTRIBUTES, CLASSNAME, COMPLETE, CONTENTS, DEEP, FULLNAME, LINKS
 
Fields inherited from interface ptolemy.actor.Executable
COMPLETED, NOT_READY, STOP_ITERATING
 
Constructor Summary
ColtBinomialSelector(CompositeEntity container, java.lang.String name)
          Construct an actor with the given container and name.
 
Method Summary
protected  void _createdNewRandomNumberGenerator()
          Create a new random number generator.
protected  void _generateRandomNumber()
          Generate a new random number.
 void fire()
          Send the trial distributions to the output.
 
Methods inherited from class ptolemy.actor.lib.colt.ColtRandomSource
_createGenerator, attributeChanged
 
Methods inherited from class ptolemy.actor.lib.RandomSource
clone, initialize, postfire
 
Methods inherited from class ptolemy.actor.lib.Source
prefire
 
Methods inherited from class ptolemy.actor.TypedAtomicActor
_addPort, _fireAt, _fireAt, attributeTypeChanged, clone, newPort, typeConstraintList, typeConstraints
 
Methods inherited from class ptolemy.actor.AtomicActor
_actorFiring, _actorFiring, addActorFiringListener, addInitializable, connectionsChanged, createReceivers, declareDelayDependency, getCausalityInterface, getDirector, getExecutiveDirector, getManager, inputPortList, isFireFunctional, isStrict, iterate, newReceiver, outputPortList, preinitialize, pruneDependencies, recordFiring, removeActorFiringListener, removeDependency, removeInitializable, setContainer, stop, stopFire, terminate, wrapup
 
Methods inherited from class ptolemy.kernel.ComponentEntity
_adjustDeferrals, _checkContainer, _getContainedObject, _propagateExistence, getContainer, instantiate, isAtomic, isOpaque, moveDown, moveToFirst, moveToIndex, moveToLast, moveUp, propagateExistence, setName
 
Methods inherited from class ptolemy.kernel.Entity
_description, _exportMoMLContents, _removePort, _validateSettables, connectedPortList, connectedPorts, containedObjectsIterator, getAttribute, getPort, getPorts, linkedRelationList, linkedRelations, portList, removeAllPorts, setClassDefinition, uniqueName
 
Methods inherited from class ptolemy.kernel.InstantiableNamedObj
_setParent, exportMoML, getChildren, getElementName, getParent, getPrototypeList, isClassDefinition, isWithinClassDefinition
 
Methods inherited from class ptolemy.kernel.util.NamedObj
_addAttribute, _adjustOverride, _attachText, _cloneFixAttributeFields, _debug, _debug, _debug, _debug, _debug, _getIndentPrefix, _isMoMLSuppressed, _markContentsDerived, _propagateValue, _recordDecoratedAttributes, _removeAttribute, _splitName, _stripNumericSuffix, addChangeListener, addDebugListener, attributeList, attributeList, deepContains, depthInHierarchy, description, description, event, executeChangeRequests, exportMoML, exportMoML, exportMoML, exportMoML, exportMoMLPlain, getAttribute, getAttributes, getChangeListeners, getClassName, getDecoratorAttribute, getDecoratorAttributes, getDerivedLevel, getDerivedList, getDisplayName, getFullName, getModelErrorHandler, getName, getName, getSource, handleModelError, isDeferringChangeRequests, isOverridden, isPersistent, lazyContainedObjectsIterator, message, propagateValue, propagateValues, removeChangeListener, removeDebugListener, requestChange, setClassName, setDeferringChangeRequests, setDerivedLevel, setDisplayName, setModelErrorHandler, setPersistent, setSource, sortContainedObjects, toplevel, toString, validateSettables, workspace
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface ptolemy.actor.Actor
createReceivers, getCausalityInterface, getDirector, getExecutiveDirector, getManager, inputPortList, newReceiver, outputPortList
 
Methods inherited from interface ptolemy.actor.Executable
isFireFunctional, isStrict, iterate, stop, stopFire, terminate
 
Methods inherited from interface ptolemy.actor.Initializable
addInitializable, preinitialize, removeInitializable, wrapup
 
Methods inherited from interface ptolemy.kernel.util.Nameable
description, getContainer, getDisplayName, getFullName, getName, getName, setName
 
Methods inherited from interface ptolemy.kernel.util.Derivable
getDerivedLevel, getDerivedList, propagateValue
 

Field Detail

trials

public PortParameter trials
The total number of trials to assign. This PortParameter is of type Int and has an initial default value of 1.


populations

public TypedIOPort populations
The populations to select from. This multiport is of type Long.


_current

private int[] _current
The tokens to emit during the current iteration.


_generator

private cern.jet.random.Binomial _generator
The random number generator.

Constructor Detail

ColtBinomialSelector

public ColtBinomialSelector(CompositeEntity container,
                            java.lang.String name)
                     throws NameDuplicationException,
                            IllegalActionException
Construct an actor with the given container and name.

Parameters:
container - The container.
name - The name of this actor.
Throws:
IllegalActionException - If the actor cannot be contained by the proposed container.
NameDuplicationException - If the container already has an actor with this name.
Method Detail

fire

public void fire()
          throws IllegalActionException
Send the trial distributions to the output. This set of trial distributions is only changed in the prefire() method, so it will remain constant throughout an iteration.

Specified by:
fire in interface Executable
Overrides:
fire in class RandomSource
Throws:
IllegalActionException - If there is no director.

_createdNewRandomNumberGenerator

protected void _createdNewRandomNumberGenerator()
Create a new random number generator. This method is called after _randomNumberGenerator is changed.

Specified by:
_createdNewRandomNumberGenerator in class ColtRandomSource

_generateRandomNumber

protected void _generateRandomNumber()
                              throws IllegalActionException
Generate a new random number.

Specified by:
_generateRandomNumber in class RandomSource
Throws:
IllegalActionException - If parameter values are incorrect.