Compare commits

...

4 Commits

Author SHA1 Message Date
ImperiumTakp
6977e97325
Merge 645342ba2f into fb54d8b549 2023-05-22 17:41:11 -05:00
denon1
645342ba2f Fix none was Lowercase fixed for right Option Type 2023-04-01 02:07:36 +02:00
denon1
376f35f08f Change if refactored to match 2023-04-01 02:04:07 +02:00
denon1
573fab9526 Change Refactor
inverted if and changed for comprehension to a foldRight with a match on the result
2023-04-01 01:52:22 +02:00

View File

@ -102,23 +102,23 @@ object KnownForSources {
TypedPipe TypedPipe
.from(TextLine(textFile)) .from(TextLine(textFile))
.flatMap { str => .flatMap { str =>
if (!str.startsWith("#")) { str match {
try { case s"#$_" => None
case _ => try {
val tokens = str.trim.split("\\s+") val tokens = str.trim.split("\\s+")
val res = Array.newBuilder[(Int, Float)]
val userId = tokens(0).toLong val userId = tokens(0).toLong
for (i <- 1 until tokens.length) { (1 until tokens.length).foldRight(Array.newBuilder[(Int, Float)])((i, r) => {
val Array(cIdStr, scoreStr) = tokens(i).split(":") val Array(cIdStr, scoreStr) = tokens(i).split(":")
val clusterId = cIdStr.toInt val clusterId = cIdStr.toInt
val score = scoreStr.toFloat val score = scoreStr.toFloat
val newEntry = (clusterId, score) val newEntry = (clusterId, score)
res += newEntry r += newEntry
}).result() match {
case (res) if res.nonEmpty => Some((userId, res.result()))
_ => None
} }
val result = res.result }
if (result.nonEmpty) { catch {
Some((userId, res.result()))
} else None
} catch {
case ex: Throwable => case ex: Throwable =>
log.warning( log.warning(
s"Error while loading knownFor from $textFile for line <$str>: " + s"Error while loading knownFor from $textFile for line <$str>: " +
@ -126,7 +126,7 @@ object KnownForSources {
) )
None None
} }
} else None }
} }
} }