Class CompressedBitMatrix<R,C> 
java.lang.Object
ubic.basecode.dataStructure.matrix.AbstractMatrix<R,C,double[]>
  
ubic.basecode.dataStructure.matrix.CompressedBitMatrix<R,C> 
- All Implemented Interfaces:
- Serializable,- Matrix2D<R,,- C, - double[]> - ObjectMatrix<R,- C, - double[]> 
public class CompressedBitMatrix<R,C> 
extends AbstractMatrix<R,C,double[]>
implements ObjectMatrix<R,C,double[]>    
Named compressed sparse bit matrix.
- Author:
- xwan
- See Also:
- 
Field SummaryFieldsFields inherited from class ubic.basecode.dataStructure.matrix.AbstractMatrixMAX_ROWS_TO_PRINT
- 
Constructor SummaryConstructorsConstructorDescriptionCompressedBitMatrix(int rows, int cols, int totalBitsPerItem) Constructs a matrix with specified rows, columns, and total bits per cell
- 
Method SummaryModifier and TypeMethodDescriptionintbitCount(int r, int c) Count the number of one-bits at the specified cell positionintcolumns()Get the number of columns the matrix has.double[]get(int row, int col) booleanget(int row, int col, int index) Checks the bit of the specified cell at the specified index.long[]getAllBits(int row, int col) Returns all of the bits for a cellintReturns the total number of bits in a matrix celldouble[]double[][]getColumn(int i) double[]getEntry(int row, int column) double[][]getRow(int i) int[]getRowBitCount(int row) booleanisMissing(int i, int j) Check if the value at a given index is missing.intoverlap(int row1, int col1, int row2, int col2) Counts the number of one-bits that are in common between the two specified cells; i.e. performs an AND operation on the two bit vectors and counts the remaining 1 bits.voidreset(int r, int c) introws()Get the number of rows the matrix hasvoidset(int row, int col, double[] val) Set the matrix cell to the specified bit vectorvoidset(int row, int col, int index) Sets the bit of the specified cell at the specified index to 1.voidintsize()ObjectMatrix<R, C, double[]> subset(int startRow, int startCol, int numRow, int numCol) ObjectMatrix<R, C, double[]> subsetColumns(List<C> columns) voidSave the matrix to the specified filelongNumber of ones in the entire matrix.voidunset(int row, int col, int index) Methods inherited from class ubic.basecode.dataStructure.matrix.AbstractMatrixaddColumnName, addRowName, asDoubles, assign, checkColRange, checkRowRange, containsColumnName, containsRowName, getColIndexByName, getColName, getColNames, getRowIndexByName, getRowName, getRowNameMapIterator, getRowNames, hasColNames, hasMissingValues, hasRow, hasRowNames, numMissing, setColumnName, setColumnNames, setRowName, setRowNamesMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ubic.basecode.dataStructure.matrix.Matrix2DaddColumnName, asDoubles, assign, containsColumnName, containsRowName, getColIndexByName, getColName, getColNames, getRowIndexByName, getRowName, getRowNameMapIterator, getRowNames, hasColNames, hasRow, hasRowNames, numMissing, setColumnName, setColumnNames, setRowName, setRowNames
- 
Field Details- 
BIT1public static long BIT1
- 
BITS_PER_ELEMENTpublic static int BITS_PER_ELEMENT
 
- 
- 
Constructor Details- 
CompressedBitMatrixpublic CompressedBitMatrix(int rows, int cols, int totalBitsPerItem) Constructs a matrix with specified rows, columns, and total bits per cellImplementation note: this is created by maintaining one or more Double matrices; the Doubles are used as bit fields. - Parameters:
- rows- - number of rows in the matrix
- cols- - number of columns in the matrix
- totalBitsPerItem- - the number of bits for each cell
 
 
- 
- 
Method Details- 
bitCountpublic int bitCount(int r, int c) Count the number of one-bits at the specified cell position- Parameters:
- r-
- c-
- Returns:
 
- 
columnspublic int columns()Description copied from interface:Matrix2DGet the number of columns the matrix has.
- 
getpublic double[] get(int row, int col) - Specified by:
- getin interface- ObjectMatrix<R,- C, - double[]> 
 
- 
getpublic boolean get(int row, int col, int index) Checks the bit of the specified cell at the specified index.- Parameters:
- row- - matrix row
- col- - matrix column
- index- - bit vector index
- Returns:
- true if bit is 1, false if 0.
 
- 
getAllBitspublic long[] getAllBits(int row, int col) Returns all of the bits for a cell- Parameters:
- row- - the cell row
- col- - the cell column
- Returns:
- all the bits encoded as an array of longs
 
- 
getBitNumpublic int getBitNum()Returns the total number of bits in a matrix cell- Returns:
- the number of bits per cell
 
- 
getByKeys
- 
getColumnpublic double[][] getColumn(int i) - Specified by:
- getColumnin interface- ObjectMatrix<R,- C, - double[]> 
 
- 
getEntrypublic double[] getEntry(int row, int column) 
- 
getRowpublic double[][] getRow(int i) - Specified by:
- getRowin interface- ObjectMatrix<R,- C, - double[]> 
 
- 
getRowBitCountpublic int[] getRowBitCount(int row) - Parameters:
- row-
- Returns:
- - array of counts of one-bits for each cell in the row.
 
- 
isMissingpublic boolean isMissing(int i, int j) Description copied from interface:Matrix2DCheck if the value at a given index is missing.
- 
overlappublic int overlap(int row1, int col1, int row2, int col2) Counts the number of one-bits that are in common between the two specified cells; i.e. performs an AND operation on the two bit vectors and counts the remaining 1 bits.- Parameters:
- row1- - cell 1 row
- col1- - cell 1 column
- row2- - cell 2 row
- col2- - cell 2 column
- Returns:
- number of bits in common
 
- 
resetpublic void reset(int r, int c) 
- 
rowspublic int rows()Description copied from interface:Matrix2DGet the number of rows the matrix has
- 
setpublic void set(int row, int col, double[] val) Set the matrix cell to the specified bit vector
- 
setpublic void set(int row, int col, int index) Sets the bit of the specified cell at the specified index to 1.- Parameters:
- row- - matrix row
- col- - matrix column
- index- - bit vector index
 
- 
setByKeys
- 
sizepublic int size()- Specified by:
- sizein class- AbstractMatrix<R,- C, - double[]> 
 
- 
subset- Specified by:
- subsetin interface- ObjectMatrix<R,- C, - double[]> 
- Parameters:
- startRow-
- startCol-
- numRow-
- numCol-
- Returns:
 
- 
subsetColumns- Specified by:
- subsetColumnsin interface- ObjectMatrix<R,- C, - double[]> 
- Parameters:
- columns-
- Returns:
 
- 
toFileSave the matrix to the specified file- Parameters:
- fileName- - save file
- Throws:
- IOException
 
- 
totalBitCountpublic long totalBitCount()Number of ones in the entire matrix.- Returns:
 
- 
unsetpublic void unset(int row, int col, int index) 
 
-