|
What this is
Other links
The source codepackage org.apache.lucene.search; /** * Copyright 2004 The Apache Software Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import org.apache.lucene.index.TermPositions; import java.io.IOException; final class SloppyPhraseScorer extends PhraseScorer { private int slop; SloppyPhraseScorer(Weight weight, TermPositions[] tps, Similarity similarity, int slop, byte[] norms) throws IOException { super(weight, tps, similarity, norms); this.slop = slop; } protected final float phraseFreq() throws IOException { pq.clear(); int end = 0; for (PhrasePositions pp = first; pp != null; pp = pp.next) { pp.firstPosition(); if (pp.position > end) end = pp.position; pq.put(pp); // build pq from list } float freq = 0.0f; boolean done = false; do { PhrasePositions pp = (PhrasePositions) pq.pop(); int start = pp.position; int next = ((PhrasePositions) pq.top()).position; for (int pos = start; pos <= next; pos = pp.position) { start = pos; // advance pp to min window if (!pp.nextPosition()) { done = true; // ran out of a term -- done break; } } int matchLength = end - start; if (matchLength <= slop) freq += getSimilarity().sloppyFreq(matchLength); // score match if (pp.position > end) end = pp.position; pq.put(pp); // restore pq } while (!done); return freq; } } |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.