mirror of
https://github.com/twitter/the-algorithm.git
synced 2025-01-20 07:51:15 +01:00
Merge 76ce702f9d031c86dc01ddd90d0592908adaa434 into 72eda9a24f815f6d566818cbf8518138e29d83e9
This commit is contained in:
commit
a335c0ee87
@ -44,22 +44,17 @@ object EigenVectorsForSparseSymmetric {
|
|||||||
* @return the constructed matrix
|
* @return the constructed matrix
|
||||||
*/
|
*/
|
||||||
def getMatrix(nonzeros: Iterable[(Int, Int, Double)], nRows: Int, nCols: Int): Matrix = {
|
def getMatrix(nonzeros: Iterable[(Int, Int, Double)], nRows: Int, nCols: Int): Matrix = {
|
||||||
val matrix = new LinkedSparseMatrix(nRows, nCols)
|
val baseCase = (new LinkedSparseMatrix(nRows, nCols), 0, 0, 0)
|
||||||
var numEntries = 0
|
val partialNonzeros = nonzeros.foldRight(baseCase)
|
||||||
var maxRow = 0
|
val (matrix, numEntries, maxRow, maxCol) = partialNonzeros{
|
||||||
var maxCol = 0
|
case ((i, j, v), (matrix, numEntries, maxRow, maxCol) ) => (i, j) match {
|
||||||
|
case (_, _) if (i > maxRow) && (j > maxCol) => (matrix.set(i, j, v), numEntries += 1, i, j)
|
||||||
|
case (_, _) if (i > maxRow) => (matrix.set(i, j, v), numEntries += 1, i, maxCol)
|
||||||
|
case (_, _) if (j > maxCol) => (matrix.set(i, j, v), numEntries += 1, maxRow, j)
|
||||||
|
case (_, _) => (matrix.set(i, j, v), numEntries += 1, maxRow, maxCol)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
nonzeros.foreach {
|
|
||||||
case (i, j, v) =>
|
|
||||||
if (i > maxRow) {
|
|
||||||
maxRow = i
|
|
||||||
}
|
|
||||||
if (j > maxCol) {
|
|
||||||
maxCol = j
|
|
||||||
}
|
|
||||||
numEntries += 1
|
|
||||||
matrix.set(i, j, v)
|
|
||||||
}
|
|
||||||
log.info(
|
log.info(
|
||||||
"Finished building matrix with %d entries and maxRow %d and maxCol %d"
|
"Finished building matrix with %d entries and maxRow %d and maxCol %d"
|
||||||
.format(numEntries, maxRow, maxCol))
|
.format(numEntries, maxRow, maxCol))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user