Compare commits

...

2 Commits

Author SHA1 Message Date
ImperiumTakp
79da407152
Merge e1691d5f25 into fb54d8b549 2023-05-22 17:39:13 -05:00
denon1
e1691d5f25 change if to match 2023-04-01 14:27:05 +02:00

View File

@ -120,15 +120,15 @@ object UpdateKnownFor {
clusterScoresToFinalScore: ClusterScoresForNode => Double,
minNeighborsInCluster: Int
): Option[(Int, Double)] = {
val clusterToScores = statsOfClustersInNeighborhood.toList.flatMap {
statsOfClustersInNeighborhood
.toList
.flatMap {
case (clusterId, statsInNeighborhood) =>
val clusterOverallStats = clusterOverallStatsMap(clusterId)
if (statsInNeighborhood.nodeCount >= minNeighborsInCluster) {
Some(
(
clusterId,
clusterScoresToFinalScore(
getScoresForCluster(
statsInNeighborhood match {
case statsInNeighborhood if statsInNeighborhood.nodeCount < minNeighborsInCluster => None
case _ =>
val score = getScoresForCluster(
overallNeighborhoodStats,
statsInNeighborhood,
clusterOverallStats.nodeCount,
@ -136,16 +136,12 @@ object UpdateKnownFor {
globalAvgEdgeWeight,
truePositiveWtFactor
)
)
)
)
} else {
None
Some((clusterId, clusterScoresToFinalScore(score)))
}
} match {
case scores if scores.isEmpty => None
case _ => Some(clusterToScores.maxBy(_._2))
}
if (clusterToScores.nonEmpty) {
Some(clusterToScores.maxBy(_._2))
} else None
}
def updateGeneric(
@ -170,10 +166,11 @@ object UpdateKnownFor {
collectInformationPerNode(graph, inputUserToClusters, avgMembershipScore)
.mapValues {
case NodeInformation(originalClusters, overallStats, statsOfClustersInNeighborhood) =>
val newClusterWithScoreOpt = if (overallStats.nodeCount < minNeighborsInCluster) {
overallStats match {
case stats if (overallStats.nodeCount < minNeighborsInCluster) =>
nodesWithSmallDegree.inc()
None
} else {
case _ =>
pickBestCluster(
overallStats,
statsOfClustersInNeighborhood,
@ -183,22 +180,18 @@ object UpdateKnownFor {
clusterScoresToFinalScore,
minNeighborsInCluster
)
}
newClusterWithScoreOpt match {
} match {
case Some((newClusterId, score)) =>
if (originalClusters.isEmpty) {
emptyToSomething.inc()
} else if (originalClusters.contains(newClusterId)) {
sameCluster.inc()
} else {
diffCluster.inc()
originalClusters match {
case cluster if cluster.isEmpty => emptyToSomething.inc()
case cluster if cluster.contains(newClusterId) => sameCluster.inc()
case _ => diffCluster.inc()
}
Array((newClusterId, score.toFloat))
case None =>
if (originalClusters.isEmpty) {
emptyToEmpty.inc()
} else {
somethingToEmpty.inc()
originalClusters match {
case cluster if cluster.isEmpty => emptyToEmpty.inc()
case _ => somethingToEmpty.inc()
}
Array.empty[(Int, Float)]
}