- java.lang.Object
-
- com.pervasive.datarush.sequences.scalar.AbstractScalarTokenSequence
-
- com.pervasive.datarush.sequences.scalar.DoubleTokenList
-
- All Implemented Interfaces:
MutableTokenSequence,DoubleTokenSequence,MutableDoubleTokenSequence,MutableScalarTokenSequence,NumericTokenSequence,ScalarTokenAppendable,ScalarTokenSequence,TokenAppendable,TokenSequence,ScalarTyped,TokenTyped
public final class DoubleTokenList extends AbstractScalarTokenSequence implements MutableDoubleTokenSequence
Primary implementation ofMutableDoubleTokenSequence.- See Also:
TokenTypeConstant.DOUBLE
-
-
Constructor Summary
Constructors Constructor Description DoubleTokenList(int capacity)Create an empty array
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidappend(double value)Appends the specified double to this sequence.voidappend(double value, int count)Appends the specified double to this sequence multiple times.voidfill(int start, int length, double value)Sets the tokens in the specified subsequence to the given double value.voidfillValue(int start, int length, TokenValued value)Sets the tokens in the specified subsequence to the given value.BigDecimalgetBigDecimal(int i)Gets the value of the specified token as aBigDecimal.doublegetDouble(int i)Gets the value of the specified token as adouble.DoubleValuedgetToken(int index)Gets the value at the specified position.DoubleSettablegetTokenSetter(int index)Returns a mutator for the given index.ScalarTokenTypegetType()Gets the data type of the tokens in the sequence.voidgetValues(int index, double[] values, boolean[] nullFlags, int offset, int length)Gets the values and null indicators for a range of tokens asdoubles.voidgetValues(int index, BigDecimal[] values, boolean[] nullFlags, int offset, int length)Gets the values and null indicators for a range of tokens asBigDecimalobjects.booleanisZero(int index)Indicates whether the specified token has a zero value.DoubleValuedIteratornewValueIterator()Creates an iterator over the non-null values of this sequence.voidsetDouble(int index, double value)Sets the token at the specified position to the given double value.voidsetNull(int index)Sets the token at the specified position to be null valued.voidsetNull(int start, int length)Sets the tokens in the specified subsequence to be null valued.voidsetValue(int index, TokenValued value)Sets the token at the specified position to the given value.voidsetValues(int start, TokenSequence values, int offset, int length)Sets the tokens in the specified subsequence of the array to the corresponding values from a subsequence of the given source sequence.voidsetZero(int index)Sets the token at the specified position to be zero valued.voidsetZero(int start, int length)Sets the tokens in the specified subsequence to be zero valued.-
Methods inherited from class com.pervasive.datarush.sequences.scalar.AbstractScalarTokenSequence
append, append, append, append, appendNull, appendNull, appendZero, appendZero, capacity, compareElement, compareElements, ensureCanonical, getElementComparator, getModificationCount, hashCode, isNull, isNull, map, remaining, reset, size, toString, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface com.pervasive.datarush.sequences.scalar.MutableScalarTokenSequence
ensureCanonical, getModificationCount
-
Methods inherited from interface com.pervasive.datarush.sequences.MutableTokenSequence
appendNull, appendNull, appendZero, appendZero, reset
-
Methods inherited from interface com.pervasive.datarush.sequences.scalar.ScalarTokenSequence
isNull
-
Methods inherited from interface com.pervasive.datarush.sequences.TokenAppendable
append, append, append, append
-
Methods inherited from interface com.pervasive.datarush.sequences.TokenSequence
compareElement, compareElements, getElementComparator, hashCode, isNull, size, toString
-
-
-
-
Method Detail
-
getType
public ScalarTokenType getType()
Description copied from interface:ScalarTokenSequenceGets the data type of the tokens in the sequence.- Specified by:
getTypein interfaceScalarTokenSequence- Specified by:
getTypein interfaceScalarTyped- Specified by:
getTypein interfaceTokenTyped- Returns:
- the token data type
-
getBigDecimal
public BigDecimal getBigDecimal(int i)
Description copied from interface:NumericTokenSequenceGets the value of the specified token as aBigDecimal.- Specified by:
getBigDecimalin interfaceNumericTokenSequence- Parameters:
i- the position of the token in the sequence- Returns:
- the value of the token. If the
token is null valued,
nullis returned.
-
getDouble
public double getDouble(int i)
Description copied from interface:DoubleTokenSequenceGets the value of the specified token as adouble.- Specified by:
getDoublein interfaceDoubleTokenSequence- Parameters:
i- the position of the token in the sequence- Returns:
- the value of the token. If the
token is null valued,
Double.NaNis returned.
-
getToken
public DoubleValued getToken(int index)
Description copied from interface:TokenSequenceGets the value at the specified position.- Specified by:
getTokenin interfaceDoubleTokenSequence- Specified by:
getTokenin interfaceNumericTokenSequence- Specified by:
getTokenin interfaceScalarTokenSequence- Specified by:
getTokenin interfaceTokenSequence- Parameters:
index- the index of the token- Returns:
- the value
-
getTokenSetter
public DoubleSettable getTokenSetter(int index)
Description copied from interface:MutableTokenSequenceReturns a mutator for the given index.- Specified by:
getTokenSetterin interfaceMutableDoubleTokenSequence- Specified by:
getTokenSetterin interfaceMutableScalarTokenSequence- Specified by:
getTokenSetterin interfaceMutableTokenSequence- Parameters:
index- the position- Returns:
- a mutator for the given index.
-
getValues
public void getValues(int index, double[] values, boolean[] nullFlags, int offset, int length)Description copied from interface:DoubleTokenSequenceGets the values and null indicators for a range of tokens asdoubles.- Specified by:
getValuesin interfaceDoubleTokenSequence- Parameters:
index- the starting index of the rangevalues- an array into which to place element valuesnullFlags- an array into which to place null indicator valuesoffset- the starting offset into the target arrays. That is,elements[offset]andnulls[offset]will get the value and null indicator respectively of the token at positionstart, and so on.length- number of tokens to get
-
getValues
public void getValues(int index, BigDecimal[] values, boolean[] nullFlags, int offset, int length)Description copied from interface:NumericTokenSequenceGets the values and null indicators for a range of tokens asBigDecimalobjects.- Specified by:
getValuesin interfaceNumericTokenSequence- Parameters:
index- the starting index of the rangevalues- an array into which to place element valuesnullFlags- an array into which to place null indicator valuesoffset- the starting offset into the target arrays. That is,elements[offset]andnulls[offset]will get the value and null indicator respectively of the token at positionstart, and so on.length- number of tokens to get
-
setNull
public void setNull(int index)
Description copied from interface:MutableTokenSequenceSets the token at the specified position to be null valued.- Specified by:
setNullin interfaceMutableTokenSequence- Parameters:
index- the position of the token in the array
-
setNull
public void setNull(int start, int length)Description copied from interface:MutableTokenSequenceSets the tokens in the specified subsequence to be null valued.- Specified by:
setNullin interfaceMutableTokenSequence- Parameters:
start- the starting index of the subsequence in the arraylength- the length of the subsequence
-
setDouble
public void setDouble(int index, double value)Sets the token at the specified position to the given double value.- Specified by:
setDoublein interfaceMutableDoubleTokenSequence- Parameters:
index- the position of the token in the arrayvalue- the double value to which to set the token. PassingDouble.NaNis equivalent to callingsetNull(index).
-
fill
public void fill(int start, int length, double value)Sets the tokens in the specified subsequence to the given double value.- Parameters:
start- the starting index of the subsequence in the arraylength- the length of the subsequencevalue- the double value to which to set the tokens. PassingDouble.NaNis equivalent to callingsetNull(start, length).
-
setZero
public void setZero(int index)
Description copied from interface:MutableTokenSequenceSets the token at the specified position to be zero valued.- Specified by:
setZeroin interfaceMutableTokenSequence- Parameters:
index- the position of the token in the array
-
setZero
public void setZero(int start, int length)Description copied from interface:MutableTokenSequenceSets the tokens in the specified subsequence to be zero valued.- Specified by:
setZeroin interfaceMutableTokenSequence- Parameters:
start- the starting index of the subsequence in the arraylength- the length of the subsequence
-
isZero
public final boolean isZero(int index)
Description copied from interface:ScalarTokenSequenceIndicates whether the specified token has a zero value.- Specified by:
isZeroin interfaceScalarTokenSequence- Parameters:
index- the index of the token- Returns:
trueif the element is zero,falseotherwise
-
setValue
public void setValue(int index, TokenValued value)Description copied from interface:MutableTokenSequenceSets the token at the specified position to the given value.- Specified by:
setValuein interfaceMutableTokenSequence- Parameters:
index- the position of the token in the arrayvalue- the value to which to set the token. This value must be of an appropriate type for the array.
-
fillValue
public void fillValue(int start, int length, TokenValued value)Description copied from interface:MutableTokenSequenceSets the tokens in the specified subsequence to the given value.- Specified by:
fillValuein interfaceMutableTokenSequence- Parameters:
start- the starting index of the subsequence in the arraylength- the length of the subsequencevalue- the value to which to set the tokens. This value must be of an appropriate type for the array
-
setValues
public void setValues(int start, TokenSequence values, int offset, int length)Description copied from interface:MutableTokenSequenceSets the tokens in the specified subsequence of the array to the corresponding values from a subsequence of the given source sequence.- Specified by:
setValuesin interfaceMutableTokenSequence- Parameters:
start- the starting index of the subsequence in the arrayvalues- the source sequence. This sequence must be of an appropriate type for the array.offset- the starting index in the source sequence. Corresponding values will be taken relative to this position. That is, the value of the token at positionoffsetinvalueswill be assigned to the token at positionstart, and so on.length- the number of tokens to copy
-
append
public void append(double value)
Description copied from interface:MutableDoubleTokenSequenceAppends the specified double to this sequence.- Specified by:
appendin interfaceMutableDoubleTokenSequence- Parameters:
value- the value to append. IfNaN, this is equivalent toappendNull().
-
append
public void append(double value, int count)Description copied from interface:MutableDoubleTokenSequenceAppends the specified double to this sequence multiple times.- Specified by:
appendin interfaceMutableDoubleTokenSequence- Parameters:
value- the value to append. IfNaN, this is equivalent toappendNull(count).count- the number of copies to append.
-
newValueIterator
public DoubleValuedIterator newValueIterator()
Description copied from interface:TokenSequenceCreates an iterator over the non-null values of this sequence. The iterator will automatically be reset as modifications are made to the sequence.- Specified by:
newValueIteratorin interfaceDoubleTokenSequence- Specified by:
newValueIteratorin interfaceNumericTokenSequence- Specified by:
newValueIteratorin interfaceScalarTokenSequence- Specified by:
newValueIteratorin interfaceTokenSequence- Returns:
- an newly-created iterator over the non-null values of this sequence.
-
-