Lucene.Net
3.0.3
Lucene.Net is a port of the Lucene search engine library, written in C# and targeted at .NET runtime users.
Main Page
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Properties
Pages
core
Search
ExactPhraseScorer.cs
Go to the documentation of this file.
1
/*
2
* Licensed to the Apache Software Foundation (ASF) under one or more
3
* contributor license agreements. See the NOTICE file distributed with
4
* this work for additional information regarding copyright ownership.
5
* The ASF licenses this file to You under the Apache License, Version 2.0
6
* (the "License"); you may not use this file except in compliance with
7
* the License. You may obtain a copy of the License at
8
*
9
* http://www.apache.org/licenses/LICENSE-2.0
10
*
11
* Unless required by applicable law or agreed to in writing, software
12
* distributed under the License is distributed on an "AS IS" BASIS,
13
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
* See the License for the specific language governing permissions and
15
* limitations under the License.
16
*/
17
18
using
System;
19
20
using
Lucene.Net.Index;
21
22
namespace
Lucene.Net.Search
23
{
24
25
sealed
class
ExactPhraseScorer
:
PhraseScorer
26
{
27
28
internal
ExactPhraseScorer
(
Weight
weight,
TermPositions
[] tps,
int
[] offsets,
Similarity
similarity, byte[] norms):base(weight, tps, offsets, similarity, norms)
29
{
30
}
31
32
protected
internal
override
float
PhraseFreq()
33
{
34
// sort list with pq
35
pq.Clear();
36
for
(
PhrasePositions
pp = first; pp != null; pp = pp.next)
37
{
38
pp.FirstPosition();
39
pq.Add(pp);
// build pq from list
40
}
41
PqToList();
// rebuild list from pq
42
43
// for counting how many times the exact phrase is found in current document,
44
// just count how many times all PhrasePosition's have exactly the same position.
45
int
freq = 0;
46
do
47
{
48
// find position w/ all terms
49
while
(first.position < last.position)
50
{
51
// scan forward in first
52
do
53
{
54
if
(!first.NextPosition())
55
return
freq;
56
}
57
while
(first.position < last.position);
58
FirstToLast();
59
}
60
freq++;
// all equal: a match
61
}
62
while
(last.NextPosition());
63
64
return
freq;
65
}
66
}
67
}
Generated on Thu Jan 3 2013 02:34:12 for Lucene.Net by
1.8.3