Class APreAgg
- java.lang.Object
- 
- org.apache.sysds.runtime.compress.colgroup.AColGroup
- 
- org.apache.sysds.runtime.compress.colgroup.AColGroupCompressed
- 
- org.apache.sysds.runtime.compress.colgroup.AColGroupValue
- 
- org.apache.sysds.runtime.compress.colgroup.APreAgg
 
 
 
 
- 
- All Implemented Interfaces:
- Serializable,- Cloneable
 - Direct Known Subclasses:
- ASDCZero,- ColGroupDDC
 
 public abstract class APreAgg extends AColGroupValue Abstract class for all the column groups that use preAggregation for Left matrix multiplications.- See Also:
- Serialized Form
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class org.apache.sysds.runtime.compress.colgroup.AColGroupAColGroup.CompressionType
 
- 
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description intgetPreAggregateSize()voidleftMultByAColGroup(AColGroup lhs, MatrixBlock result)Left side matrix multiplication with a column group that is transposed.voidmmWithDictionary(MatrixBlock preAgg, MatrixBlock tmpRes, MatrixBlock ret, int k, int rl, int ru)voidpreAggregate(MatrixBlock m, double[] preAgg, int rl, int ru)Pre aggregate a matrix block into a pre aggregate target (first step of left matrix multiplication)abstract voidpreAggregateDense(MatrixBlock m, double[] preAgg, int rl, int ru, int cl, int cu)Pre aggregate a dense matrix block into a pre aggregate target (first step of left matrix multiplication)abstract voidpreAggregateSparse(SparseBlock sb, double[] preAgg, int rl, int ru)ADictionarypreAggregateThatIndexStructure(APreAgg that)Pre aggregate into a dictionary.voidtsmmAColGroup(AColGroup other, MatrixBlock result)Matrix multiply with this other column group, but: 1.- 
Methods inherited from class org.apache.sysds.runtime.compress.colgroup.AColGroupValuecentralMoment, computeColSums, containsValue, copy, decompressToDenseBlock, decompressToSparseBlock, estimateInMemorySize, forceMatrixBlockDictionary, getCachedCounts, getCounts, getCounts, getDictionary, getExactSizeOnDisk, getNumberNonZeros, getNumValues, readFields, replace, rexpandCols, rightMultByMatrix, toString, write
 - 
Methods inherited from class org.apache.sysds.runtime.compress.colgroup.AColGroupCompressedgetMax, getMin, preAggRows, tsmm, unaryAggregateOperations, unaryAggregateOperations
 - 
Methods inherited from class org.apache.sysds.runtime.compress.colgroup.AColGroupbinaryRowOpLeft, binaryRowOpRight, colSum, decompressToDenseBlock, decompressToSparseBlock, get, getColIndices, getCompType, getCost, getIdx, getNumCols, leftMultByMatrixNoPreAgg, scalarOperation, shiftColIndices, sliceColumn, sliceColumns, unaryOperation
 
- 
 
- 
- 
- 
Method Detail- 
tsmmAColGrouppublic void tsmmAColGroup(AColGroup other, MatrixBlock result) Description copied from class:AColGroupMatrix multiply with this other column group, but: 1. Only output upper triangle values. 2. Multiply both ways with "this" being on the left and on the right. It should be guaranteed that the input is not the same as the caller of the method. The second step is achievable by treating the initial multiplied matrix, and adding its values to the correct locations in the output.- Specified by:
- tsmmAColGroupin class- AColGroup
- Parameters:
- other- The other Column group to multiply with
- result- The result matrix to put the results into
 
 - 
leftMultByAColGrouppublic final void leftMultByAColGroup(AColGroup lhs, MatrixBlock result) Description copied from class:AColGroupLeft side matrix multiplication with a column group that is transposed.- Specified by:
- leftMultByAColGroupin class- AColGroup
- Parameters:
- lhs- The left hand side Column group to multiply with, the left hand side should be considered transposed.
- result- The result matrix to insert the result of the multiplication into
 
 - 
preAggregateThatIndexStructurepublic final ADictionary preAggregateThatIndexStructure(APreAgg that) Pre aggregate into a dictionary. It is assumed that "that" have more distinct values than, "this".- Parameters:
- that- the other column group whose indexes are used for aggregation.
- Returns:
- A aggregate dictionary
 
 - 
preAggregatepublic void preAggregate(MatrixBlock m, double[] preAgg, int rl, int ru) Pre aggregate a matrix block into a pre aggregate target (first step of left matrix multiplication)- Parameters:
- m- The matrix to preAggregate
- preAgg- The preAggregate target
- rl- Row lower on the left side matrix
- ru- Row upper on the left side matrix
 
 - 
preAggregateDensepublic abstract void preAggregateDense(MatrixBlock m, double[] preAgg, int rl, int ru, int cl, int cu) Pre aggregate a dense matrix block into a pre aggregate target (first step of left matrix multiplication)- Parameters:
- m- The matrix to preAggregate
- preAgg- The preAggregate target
- rl- Row lower on the left side matrix
- ru- Row upper on the left side matrix
- cl- Column lower on the left side matrix (or row lower in the column group)
- cu- Column upper on the left side matrix (or row upper in the column group)
 
 - 
preAggregateSparsepublic abstract void preAggregateSparse(SparseBlock sb, double[] preAgg, int rl, int ru) 
 - 
getPreAggregateSizepublic int getPreAggregateSize() 
 - 
mmWithDictionarypublic void mmWithDictionary(MatrixBlock preAgg, MatrixBlock tmpRes, MatrixBlock ret, int k, int rl, int ru) 
 
- 
 
-