querqy.lucene.rewrite.prms.PRMSAndQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of querqy-lucene Show documentation
Show all versions of querqy-lucene Show documentation
Querqy library for query rewriting for Lucene
/**
*
*/
package querqy.lucene.rewrite.prms;
import java.io.IOException;
import java.util.List;
import org.apache.lucene.index.IndexReader;
/**
* @author rene
*
*/
public class PRMSAndQuery implements PRMSQuery {
final List clauses;
private Double probability = null;
public PRMSAndQuery(List clauses) {
if (clauses.isEmpty()) {
throw new IllegalArgumentException("clauses.size() > 0 expected");
}
this.clauses = clauses;
}
/* (non-Javadoc)
* @see querqy.lucene.rewrite.prms.PRMSQuery#calculateProbability(org.apache.lucene.index.IndexReader)
*/
@Override
public double calculateLikelihood(IndexReader indexReader)
throws IOException {
if (probability == null) {
// We would need the joint probability of all clauses, which would be too expensive
// to calculate from the index. As a workaround, we use the minimum probability of all
// clauses as the joint probability can never be greater than this in:
// P(Clause1 ^ Clause2) = P(Clause1 | Clause2) * P(Clause2) = P(Clause2 | Clause1) * P(Clause1)
double min = 1.0;
for (PRMSQuery clause: clauses) {
min = Math.min(min, clause.calculateLikelihood(indexReader));
}
probability = min;
}
return probability;
}
public List getClauses() {
return clauses;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy