Skip to content

Commit

Permalink
Optimization.
Browse files Browse the repository at this point in the history
  • Loading branch information
Ralph Gasser committed Dec 2, 2024
1 parent 69ca5b9 commit 1abd673
Showing 1 changed file with 3 additions and 31 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@ import org.vitrivr.engine.core.model.query.bool.Logical
import org.vitrivr.engine.core.model.retrievable.RetrievableId
import org.vitrivr.engine.core.model.retrievable.Retrieved
import org.vitrivr.engine.database.pgvector.*
import org.vitrivr.engine.database.pgvector.descriptor.scalar.ScalarDescriptorReader
import org.vitrivr.engine.database.pgvector.descriptor.struct.StructDescriptorReader
import java.sql.PreparedStatement
import java.sql.ResultSet
import java.util.*
Expand Down Expand Up @@ -213,35 +211,9 @@ abstract class AbstractDescriptorReader<D : Descriptor<*>>(final override val fi
* @return Set of [RetrievableId]s that match the [BooleanPredicate].
*/
protected fun getMatches(predicate: BooleanPredicate): Set<RetrievableId> = when (predicate) {
is Comparison<*> -> {
val field = predicate.field
val reader = field.getReader()
when (reader) {
is ScalarDescriptorReader -> reader.query(Query(predicate)).map { it.id }.toSet()
is StructDescriptorReader -> reader.query(Query(predicate)).map { it.id }.toSet()
else -> throw IllegalArgumentException("Cannot resolve predicate $predicate.")
}
}

is Logical.And -> {
val intersection = mutableSetOf<RetrievableId>()
for ((index, child) in predicate.predicates.withIndex()) {
if (index == 0) {
intersection.addAll(getMatches(child))
} else {
intersection.intersect(getMatches(child))
}
}
intersection
}

is Logical.Or -> {
val union = mutableSetOf<RetrievableId>()
for (child in predicate.predicates) {
union.addAll(getMatches(child))
}
union
}
is Comparison<*> -> predicate.field.getReader().query(Query(predicate)).map { it.id }.toSet()
is Logical.And -> predicate.predicates.map { getMatches(it) }.reduce { acc, set -> acc.intersect(set) }
is Logical.Or -> predicate.predicates.flatMap { getMatches(it) }.toSet()
}

/**
Expand Down

0 comments on commit 1abd673

Please sign in to comment.