public abstract class SparseShortArray extends Object implements ReadWriteable, Concatenatable<SparseShortArray,SparseShortArray>
Modifier and Type | Class and Description |
---|---|
static class |
SparseShortArray.DualEntry
An entry representing the values in two parallel
SparseShortArray s
at the same index. |
static class |
SparseShortArray.Entry
An entry in a
SparseShortArray , consisting of
an index and value. |
Modifier and Type | Field and Description |
---|---|
protected static int |
DEFAULT_CAPACITY |
int |
length
The length of the array
|
Constructor and Description |
---|
SparseShortArray() |
Modifier and Type | Method and Description |
---|---|
SparseShortArray |
add(SparseShortArray vector)
Add the values in the given vector to a copy of
this array and return the result
|
SparseShortArray |
addInplace(SparseShortArray vector)
Add the values in the given vector to
this vector and return this
|
String |
asciiHeader()
Header for ascii input.
|
byte[] |
binaryHeader()
Header for binary input.
|
abstract void |
compact()
Compact the space being used by the array if possible.
|
SparseShortArray |
concatenate(List<SparseShortArray> ins)
Concatenate all the inputs with this, returning a new object that is the
result of the concatenation.
|
SparseShortArray |
concatenate(SparseShortArray... ins)
Concatenate all the inputs with this, returning a new object that is the
result of the concatenation.
|
static SparseShortArray |
concatenateArrays(SparseShortArray... arrays)
Concatenate multiple arrays into a single new array.
|
abstract SparseShortArray |
copy()
Deep copy the array.
|
float |
density() |
double |
dotProduct(SparseShortArray vector)
Compute the dot product with another vector
|
abstract Iterable<SparseShortArray.Entry> |
entries()
Provide an iterator over the non-zero values.
|
abstract short |
get(int index)
Get the value at the given index.
|
abstract short |
increment(int index,
short value)
Increment the value at the given index.
|
abstract int[] |
indices() |
Iterable<SparseShortArray.DualEntry> |
intersectEntries(SparseShortArray otherArray)
Provide an iterator over the intersection of values present in
both this array and another array.
|
abstract boolean |
isUsed(int index)
Check whether the given index is used (i.e.
|
int |
length() |
int |
maxIndex() |
short |
maxValue() |
int |
minIndex() |
short |
minValue() |
SparseShortArray |
multiply(double value)
Copy this vector and multiply its values by a
scalar
|
SparseShortArray |
multiplyInplace(double value)
Multiply the values inplace by a scalar and return this
|
void |
readASCII(Scanner in)
Read internal state from in.
|
void |
readBinary(DataInput in)
Read internal state from in.
|
abstract SparseShortArray |
reverse()
Reverse the elements, returning this.
|
abstract short |
set(int index,
short value)
Set the value at the given index.
|
void |
setLength(int newLength)
Set the length of the array.
|
int |
size() |
SparseShortArray |
subtract(SparseShortArray vector)
Subtract the values in the given vector from a copy of
this vector and return the result
|
SparseShortArray |
subtractInplace(SparseShortArray vector)
Subtract the values in the given vector from
this array and return this
|
short |
sumValues()
Compute the sum of values
|
short |
sumValuesSquared()
Compute the sum of values squared
|
short[] |
toArray()
Convert this sparse array to a dense array.
|
short[] |
toArray(short[] array)
Convert this sparse array to a dense array.
|
Iterable<SparseShortArray.DualEntry> |
unionEntries(SparseShortArray otherArray)
Provide an iterator over the union of values present in
both this array and another array.
|
abstract int |
used() |
abstract short[] |
values() |
void |
writeASCII(PrintWriter out)
Write the content of this as ascii to out.
|
void |
writeBinary(DataOutput out)
Write the content of this as binary to out.
|
protected static final int DEFAULT_CAPACITY
public int length
public SparseShortArray()
public abstract short increment(int index, short value)
index
- the indexvalue
- the amount to increment by.public abstract int[] indices()
public abstract short[] values()
public abstract Iterable<SparseShortArray.Entry> entries()
Note: the SparseShortArray.Entry
returned by the iterator
is always the same object. In addition, the iterator
cannot affect the value of anything in the array (i.e.
changing anything in the SparseShortArray.Entry
has no effect
on the actual array).
public Iterable<SparseShortArray.DualEntry> unionEntries(SparseShortArray otherArray)
Note: the SparseShortArray.DualEntry
returned by the iterator
is always the same object. In addition, the iterator
cannot affect the value of anything in the array (i.e.
changing anything in the SparseShortArray.DualEntry
has no effect
on the actual array).
otherArray
- the second arraypublic Iterable<SparseShortArray.DualEntry> intersectEntries(SparseShortArray otherArray)
Note: the SparseShortArray.DualEntry
returned by the iterator
is always the same object. In addition, the iterator
cannot affect the value of anything in the array (i.e.
changing anything in the SparseShortArray.DualEntry
has no effect
on the actual array).
otherArray
- the second arraypublic abstract short get(int index)
index
- the indexpublic abstract boolean isUsed(int index)
index
- the indexpublic abstract short set(int index, short value)
index
- the index.value
- the value to set.public void setLength(int newLength)
newLength
- the new array lengthIllegalArgumentException
- if the new length is shorter than
the existing length.public int size()
public int length()
public abstract int used()
public float density()
public abstract void compact()
public void writeASCII(PrintWriter out) throws IOException
WriteableASCII
writeASCII
in interface WriteableASCII
out
- sink to write toIOException
- an error writing to outpublic void readASCII(Scanner in) throws IOException
ReadableASCII
readASCII
in interface ReadableASCII
in
- source to read from.IOException
- an error reading inputpublic String asciiHeader()
ReadableASCII
asciiHeader
in interface ReadableASCII
asciiHeader
in interface WriteableASCII
public void writeBinary(DataOutput out) throws IOException
WriteableBinary
writeBinary
in interface WriteableBinary
out
- sink to write toIOException
- an error writing to outpublic void readBinary(DataInput in) throws IOException
ReadableBinary
readBinary
in interface ReadableBinary
in
- source to read from.IOException
- an error reading inputpublic byte[] binaryHeader()
ReadableBinary
binaryHeader
in interface ReadableBinary
binaryHeader
in interface WriteableBinary
public abstract SparseShortArray copy()
public SparseShortArray add(SparseShortArray vector)
vector
- the vector to addpublic SparseShortArray addInplace(SparseShortArray vector)
vector
- the vector to addpublic SparseShortArray subtract(SparseShortArray vector)
vector
- the array to addpublic SparseShortArray subtractInplace(SparseShortArray vector)
vector
- the vector to addpublic SparseShortArray multiply(double value)
value
- scalar multiplierpublic SparseShortArray multiplyInplace(double value)
value
- scalar multiplierpublic double dotProduct(SparseShortArray vector)
vector
- the other vectorpublic short maxValue()
public short minValue()
public int maxIndex()
public int minIndex()
public abstract SparseShortArray reverse()
public static SparseShortArray concatenateArrays(SparseShortArray... arrays)
arrays
- the arrays to concatenate.public short sumValues()
public short sumValuesSquared()
public short[] toArray()
Be aware that calling this method results in an array of length
being created. This could be very bad for performance.
public short[] toArray(short[] array)
length
, then it will be cleared and populated with the data
held in this sparse array. If the input array is null
or is
smaller than length
, then a new array will be allocated, filled
and returned.
Be aware that calling this method may result in an array of
length
being created. This could be very bad for performance.
array
- The array to fill or null.public SparseShortArray concatenate(SparseShortArray... ins)
Concatenatable
concatenate
in interface Concatenatable<SparseShortArray,SparseShortArray>
ins
- the inputspublic SparseShortArray concatenate(List<SparseShortArray> ins)
Concatenatable
concatenate
in interface Concatenatable<SparseShortArray,SparseShortArray>
ins
- the inputs