Class IdentityDictionarySlice
- java.lang.Object
- 
- org.apache.sysds.runtime.compress.colgroup.dictionary.ADictionary
- 
- org.apache.sysds.runtime.compress.colgroup.dictionary.IdentityDictionary
- 
- org.apache.sysds.runtime.compress.colgroup.dictionary.IdentityDictionarySlice
 
 
 
- 
- All Implemented Interfaces:
- Serializable
 
 public class IdentityDictionarySlice extends IdentityDictionary - See Also:
- Serialized Form
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class org.apache.sysds.runtime.compress.colgroup.dictionary.ADictionaryADictionary.DictType
 
- 
 - 
Constructor SummaryConstructors Constructor Description IdentityDictionarySlice(int nRowCol, int l, int u)Create a Identity matrix dictionary slice.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaggregateCols(double[] c, Builtin fn, IColIndex colIndexes)Aggregates the columns into the target double array provided.double[]aggregateRows(Builtin fn, int nCol)Aggregate all entries in the rows.ADictionaryclone()Returns a deep clone of the dictionary.voidcolProduct(double[] res, int[] counts, IColIndex colIndexes)Calculate the column product of the dictionary weighted by counts.voidcolSum(double[] c, int[] counts, IColIndex colIndexes)Get the column sum of the values contained in the dictionaryvoidcolSumSq(double[] c, int[] counts, IColIndex colIndexes)Get the column sum of the values contained in the dictionarybooleancontainsValue(double pattern)Detect if the dictionary contains a specific value.booleanequals(ADictionary o)ADictionary.DictTypegetDictType()Get the dictionary type this dictionary is.longgetExactSizeOnDisk()Calculate the space consumption if the dictionary is stored on disk.longgetInMemorySize()Returns the memory usage of the dictionary.static longgetInMemorySize(int numberColumns)MatrixBlockDictionarygetMBDict()MatrixBlockDictionarygetMBDict(int nCol)Get this dictionary as a MatrixBlock dictionary.longgetNumberNonZeros(int[] counts, int nCol)Calculate the number of non zeros in the dictionary.intgetNumberOfValues(int ncol)Get the number of distinct tuples given that the column group has n columnsdoublegetSparsity()Get the sparsity of the dictionary.StringgetString(int colIndexes)Get a string representation of the dictionary, that considers the layout of the data.doublegetValue(int i)Get Specific value contained in the dictionary at index.doublegetValue(int r, int c, int nCol)Get Specific value contain in dictionary at index.double[]getValues()Get all the values contained in the dictionary as a linearized double array.double[]productAllRowsToDouble(int nCol)Method to product all rows to a column vector.double[]productAllRowsToDoubleWithDefault(double[] defaultTuple)Method to product all rows to a column vector with a default value added in the end.static IdentityDictionaryread(DataInput in)ADictionaryreplace(double pattern, double replace, int nCol)Make a copy of the values, and replace all values that match pattern with replacement value.ADictionaryreplaceWithReference(double pattern, double replace, double[] reference)Make a copy of the values, and replace all values that match pattern with replacement value.ADictionaryscaleTuples(int[] scaling, int nCol)Scale all tuples contained in the dictionary by the scaling factor given in the int list.ADictionarysliceOutColumnRange(int idxStart, int idxEnd, int previousNumberOfColumns)Modify the dictionary by removing columns not within the index range.doublesum(int[] counts, int ncol)Get the sum of the values contained in the dictionarydouble[]sumAllRowsToDouble(int nrColumns)Method used as a pre-aggregate of each tuple in the dictionary, to single double values.double[]sumAllRowsToDoubleSq(int nrColumns)Method used as a pre-aggregate of each tuple in the dictionary, to single double values.double[]sumAllRowsToDoubleWithDefault(double[] defaultTuple)Do exactly the same as the sumAllRowsToDouble but also sum the array given to a extra index in the end of the array.double[]sumAllRowsToDoubleWithReference(double[] reference)Method used as a pre-aggregate of each tuple in the dictionary, to single double values with a reference.doublesumSq(int[] counts, int ncol)Get the square sum of the values contained in the dictionaryStringtoString()voidwrite(DataOutput out)Write the dictionary to a DataOutput.- 
Methods inherited from class org.apache.sysds.runtime.compress.colgroup.dictionary.IdentityDictionaryaddToEntry, addToEntry, addToEntryVectorized, aggregate, aggregateColsWithReference, aggregateRowsWithDefault, aggregateRowsWithReference, aggregateWithReference, applyScalarOp, applyScalarOpAndAppend, applyScalarOpWithReference, applyUnaryOp, applyUnaryOpAndAppend, applyUnaryOpWithReference, binOpLeft, binOpLeftAndAppend, binOpLeftWithReference, binOpRight, binOpRight, binOpRightAndAppend, binOpRightWithReference, centralMoment, centralMomentWithDefault, centralMomentWithReference, colProductWithReference, colSumSqWithReference, containsValueWithReference, getNumberNonZerosWithReference, multiplyScalar, preaggValuesFromDense, product, productAllRowsToDoubleWithReference, productWithDefault, productWithReference, rexpandCols, rexpandColsWithReference, subtractTuple, sumAllRowsToDoubleSqWithDefault, sumAllRowsToDoubleSqWithReference, sumSqWithReference
 - 
Methods inherited from class org.apache.sysds.runtime.compress.colgroup.dictionary.ADictionarycentralMoment, centralMomentWithDefault, centralMomentWithReference, equals
 
- 
 
- 
- 
- 
Constructor Detail- 
IdentityDictionarySlicepublic IdentityDictionarySlice(int nRowCol, int l, int u)Create a Identity matrix dictionary slice. It behaves as if allocated a Sparse Matrix block but exploits that the structure is known to have certain properties.- Parameters:
- nRowCol- the number of rows and columns in this identity matrix.
- l- the index lower to start at
- u- the index upper to end at (not inclusive)
 
 
- 
 - 
Method Detail- 
getValuespublic double[] getValues() Description copied from class:ADictionaryGet all the values contained in the dictionary as a linearized double array.- Overrides:
- getValuesin class- IdentityDictionary
- Returns:
- linearized double array
 
 - 
getValuepublic double getValue(int i) Description copied from class:ADictionaryGet Specific value contained in the dictionary at index.- Overrides:
- getValuein class- IdentityDictionary
- Parameters:
- i- The index to extract the value from
- Returns:
- The value contained at the index
 
 - 
getValuepublic final double getValue(int r, int c, int nCol)Description copied from class:ADictionaryGet Specific value contain in dictionary at index.- Overrides:
- getValuein class- IdentityDictionary
- Parameters:
- r- Row target
- c- Col target
- nCol- nCol in dictionary
- Returns:
- value
 
 - 
getInMemorySizepublic long getInMemorySize() Description copied from class:ADictionaryReturns the memory usage of the dictionary.- Overrides:
- getInMemorySizein class- IdentityDictionary
- Returns:
- a long value in number of bytes for the dictionary.
 
 - 
getInMemorySizepublic static long getInMemorySize(int numberColumns) 
 - 
aggregateRowspublic double[] aggregateRows(Builtin fn, int nCol) Description copied from class:ADictionaryAggregate all entries in the rows.- Overrides:
- aggregateRowsin class- IdentityDictionary
- Parameters:
- fn- The aggregate function
- nCol- The number of columns contained in the dictionary.
- Returns:
- Aggregates for this dictionary tuples.
 
 - 
aggregateColspublic void aggregateCols(double[] c, Builtin fn, IColIndex colIndexes)Description copied from class:ADictionaryAggregates the columns into the target double array provided.- Overrides:
- aggregateColsin class- IdentityDictionary
- Parameters:
- c- The target double array, this contains the full number of columns, therefore the colIndexes for this specific dictionary is needed.
- fn- The function to apply to individual columns
- colIndexes- The mapping to the target columns from the individual columns
 
 - 
clonepublic ADictionary clone() Description copied from class:ADictionaryReturns a deep clone of the dictionary.- Overrides:
- clonein class- IdentityDictionary
 
 - 
getDictTypepublic ADictionary.DictType getDictType() Description copied from class:ADictionaryGet the dictionary type this dictionary is.- Overrides:
- getDictTypein class- IdentityDictionary
- Returns:
- The Dictionary type this is.
 
 - 
getNumberOfValuespublic int getNumberOfValues(int ncol) Description copied from class:ADictionaryGet the number of distinct tuples given that the column group has n columns- Overrides:
- getNumberOfValuesin class- IdentityDictionary
- Parameters:
- ncol- The number of Columns in the ColumnGroup.
- Returns:
- the number of value tuples contained in the dictionary.
 
 - 
sumAllRowsToDoublepublic double[] sumAllRowsToDouble(int nrColumns) Description copied from class:ADictionaryMethod used as a pre-aggregate of each tuple in the dictionary, to single double values. Note if the number of columns is one the actual dictionaries values are simply returned.- Overrides:
- sumAllRowsToDoublein class- IdentityDictionary
- Parameters:
- nrColumns- The number of columns in the ColGroup to know how to get the values from the dictionary.
- Returns:
- a double array containing the row sums from this dictionary.
 
 - 
sumAllRowsToDoubleWithDefaultpublic double[] sumAllRowsToDoubleWithDefault(double[] defaultTuple) Description copied from class:ADictionaryDo exactly the same as the sumAllRowsToDouble but also sum the array given to a extra index in the end of the array.- Overrides:
- sumAllRowsToDoubleWithDefaultin class- IdentityDictionary
- Parameters:
- defaultTuple- The default row to sum in the end index returned.
- Returns:
- a double array containing the row sums from this dictionary.
 
 - 
sumAllRowsToDoubleWithReferencepublic double[] sumAllRowsToDoubleWithReference(double[] reference) Description copied from class:ADictionaryMethod used as a pre-aggregate of each tuple in the dictionary, to single double values with a reference.- Overrides:
- sumAllRowsToDoubleWithReferencein class- IdentityDictionary
- Parameters:
- reference- The reference values to add to each cell.
- Returns:
- a double array containing the row sums from this dictionary.
 
 - 
sumAllRowsToDoubleSqpublic double[] sumAllRowsToDoubleSq(int nrColumns) Description copied from class:ADictionaryMethod used as a pre-aggregate of each tuple in the dictionary, to single double values. Note if the number of columns is one the actual dictionaries values are simply returned.- Overrides:
- sumAllRowsToDoubleSqin class- IdentityDictionary
- Parameters:
- nrColumns- The number of columns in the ColGroup to know how to get the values from the dictionary.
- Returns:
- a double array containing the row sums from this dictionary.
 
 - 
productAllRowsToDoublepublic double[] productAllRowsToDouble(int nCol) Description copied from class:ADictionaryMethod to product all rows to a column vector.- Overrides:
- productAllRowsToDoublein class- IdentityDictionary
- Parameters:
- nCol- The number of columns in the ColGroup to know how to get the values from the dictionary.
- Returns:
- A row product
 
 - 
productAllRowsToDoubleWithDefaultpublic double[] productAllRowsToDoubleWithDefault(double[] defaultTuple) Description copied from class:ADictionaryMethod to product all rows to a column vector with a default value added in the end.- Overrides:
- productAllRowsToDoubleWithDefaultin class- IdentityDictionary
- Parameters:
- defaultTuple- The default row that aggregate to last cell
- Returns:
- A row product
 
 - 
colSumpublic void colSum(double[] c, int[] counts, IColIndex colIndexes)Description copied from class:ADictionaryGet the column sum of the values contained in the dictionary- Overrides:
- colSumin class- IdentityDictionary
- Parameters:
- c- The output array allocated to contain all column groups output.
- counts- The counts of the individual tuples.
- colIndexes- The columns indexes of the parent column group, this indicate where to put the column sum into the c output.
 
 - 
colSumSqpublic void colSumSq(double[] c, int[] counts, IColIndex colIndexes)Description copied from class:ADictionaryGet the column sum of the values contained in the dictionary- Overrides:
- colSumSqin class- IdentityDictionary
- Parameters:
- c- The output array allocated to contain all column groups output.
- counts- The counts of the individual tuples.
- colIndexes- The columns indexes of the parent column group, this indicate where to put the column sum into the c output.
 
 - 
colProductpublic void colProduct(double[] res, int[] counts, IColIndex colIndexes)Description copied from class:ADictionaryCalculate the column product of the dictionary weighted by counts.- Overrides:
- colProductin class- IdentityDictionary
- Parameters:
- res- The result vector to put the result into
- counts- The weighted count of individual tuples
- colIndexes- The column indexes.
 
 - 
sumpublic double sum(int[] counts, int ncol)Description copied from class:ADictionaryGet the sum of the values contained in the dictionary- Overrides:
- sumin class- IdentityDictionary
- Parameters:
- counts- The counts of the individual tuples
- ncol- The number of columns contained
- Returns:
- The sum scaled by the counts provided.
 
 - 
sumSqpublic double sumSq(int[] counts, int ncol)Description copied from class:ADictionaryGet the square sum of the values contained in the dictionary- Overrides:
- sumSqin class- IdentityDictionary
- Parameters:
- counts- The counts of the individual tuples
- ncol- The number of columns contained
- Returns:
- The square sum scaled by the counts provided.
 
 - 
sliceOutColumnRangepublic ADictionary sliceOutColumnRange(int idxStart, int idxEnd, int previousNumberOfColumns) Description copied from class:ADictionaryModify the dictionary by removing columns not within the index range.- Overrides:
- sliceOutColumnRangein class- IdentityDictionary
- Parameters:
- idxStart- The column index to start at.
- idxEnd- The column index to end at (not inclusive)
- previousNumberOfColumns- The number of columns contained in the dictionary.
- Returns:
- A dictionary containing the sliced out columns values only.
 
 - 
containsValuepublic boolean containsValue(double pattern) Description copied from class:ADictionaryDetect if the dictionary contains a specific value.- Overrides:
- containsValuein class- IdentityDictionary
- Parameters:
- pattern- The value to search for
- Returns:
- true if the value is contained else false.
 
 - 
getNumberNonZerospublic long getNumberNonZeros(int[] counts, int nCol)Description copied from class:ADictionaryCalculate the number of non zeros in the dictionary. The number of non zeros should be scaled with the counts given. This gives the exact number of non zero values in the parent column group.- Overrides:
- getNumberNonZerosin class- IdentityDictionary
- Parameters:
- counts- The counts of each dictionary entry
- nCol- The number of columns in this dictionary
- Returns:
- The nonZero count
 
 - 
getMBDictpublic MatrixBlockDictionary getMBDict() - Overrides:
- getMBDictin class- IdentityDictionary
 
 - 
getMBDictpublic MatrixBlockDictionary getMBDict(int nCol) Description copied from class:ADictionaryGet this dictionary as a MatrixBlock dictionary. This allows us to use optimized kernels coded elsewhere in the system, such as matrix multiplication. Return null if the matrix is empty.- Overrides:
- getMBDictin class- IdentityDictionary
- Parameters:
- nCol- The number of columns contained in this column group.
- Returns:
- A Dictionary containing a MatrixBlock.
 
 - 
getStringpublic String getString(int colIndexes) Description copied from class:ADictionaryGet a string representation of the dictionary, that considers the layout of the data.- Overrides:
- getStringin class- IdentityDictionary
- Parameters:
- colIndexes- The number of columns in the dictionary.
- Returns:
- A string that is nicer to print.
 
 - 
toStringpublic String toString() - Overrides:
- toStringin class- IdentityDictionary
 
 - 
scaleTuplespublic ADictionary scaleTuples(int[] scaling, int nCol) Description copied from class:ADictionaryScale all tuples contained in the dictionary by the scaling factor given in the int list.- Overrides:
- scaleTuplesin class- IdentityDictionary
- Parameters:
- scaling- The amount to multiply the given tuples with
- nCol- The number of columns contained in this column group.
- Returns:
- A New dictionary (since we don't want to modify the underlying dictionary)
 
 - 
writepublic void write(DataOutput out) throws IOException Description copied from class:ADictionaryWrite the dictionary to a DataOutput.- Overrides:
- writein class- IdentityDictionary
- Parameters:
- out- the output sink to write the dictionary to.
- Throws:
- IOException- if the sink fails.
 
 - 
readpublic static IdentityDictionary read(DataInput in) throws IOException - Throws:
- IOException
 
 - 
getExactSizeOnDiskpublic long getExactSizeOnDisk() Description copied from class:ADictionaryCalculate the space consumption if the dictionary is stored on disk.- Overrides:
- getExactSizeOnDiskin class- IdentityDictionary
- Returns:
- the long count of bytes to store the dictionary.
 
 - 
replacepublic ADictionary replace(double pattern, double replace, int nCol) Description copied from class:ADictionaryMake a copy of the values, and replace all values that match pattern with replacement value. If needed add a new column index.- Overrides:
- replacein class- IdentityDictionary
- Parameters:
- pattern- The value to look for
- replace- The value to replace the other value with
- nCol- The number of columns contained in the dictionary.
- Returns:
- A new Column Group, reusing the index structure but with new values.
 
 - 
replaceWithReferencepublic ADictionary replaceWithReference(double pattern, double replace, double[] reference) Description copied from class:ADictionaryMake a copy of the values, and replace all values that match pattern with replacement value. If needed add a new column index. With reference such that each value in the dict is considered offset by the values contained in the reference.- Overrides:
- replaceWithReferencein class- IdentityDictionary
- Parameters:
- pattern- The value to look for
- replace- The value to replace the other value with
- reference- The reference tuple to add to all entries when replacing
- Returns:
- A new Column Group, reusing the index structure but with new values.
 
 - 
getSparsitypublic double getSparsity() Description copied from class:ADictionaryGet the sparsity of the dictionary.- Overrides:
- getSparsityin class- IdentityDictionary
- Returns:
- a sparsity between 0 and 1
 
 - 
equalspublic boolean equals(ADictionary o) - Overrides:
- equalsin class- IdentityDictionary
 
 
- 
 
-