All Downloads are FREE. Search and download functionalities are using the official Maven repository.

querqy.lucene.rewrite.prms.PRMSAndQuery Maven / Gradle / Ivy

The newest version!
/**
 * 
 */
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 - 2024 Weber Informatics LLC | Privacy Policy