ExactPhraseScorer.cs
上传用户:zhangkuixh
上传日期:2013-09-30
资源大小:5473k
文件大小:2k
源码类别:

搜索引擎

开发平台:

C#

  1. /*
  2.  * Copyright 2004 The Apache Software Foundation
  3.  * 
  4.  * Licensed under the Apache License, Version 2.0 (the "License");
  5.  * you may not use this file except in compliance with the License.
  6.  * You may obtain a copy of the License at
  7.  * 
  8.  * http://www.apache.org/licenses/LICENSE-2.0
  9.  * 
  10.  * Unless required by applicable law or agreed to in writing, software
  11.  * distributed under the License is distributed on an "AS IS" BASIS,
  12.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13.  * See the License for the specific language governing permissions and
  14.  * limitations under the License.
  15.  */
  16. using System;
  17. using Lucene.Net.Index;
  18. namespace Lucene.Net.Search
  19. {
  20. sealed class ExactPhraseScorer : PhraseScorer
  21. {
  22. internal ExactPhraseScorer(Weight weight, TermPositions[] tps, int[] positions, Similarity similarity, byte[] norms) : base(weight, tps, positions, similarity, norms)
  23. {
  24. }
  25. protected internal override float PhraseFreq()
  26. {
  27. // sort list with pq
  28. for (PhrasePositions pp = first; pp != null; pp = pp.next)
  29. {
  30. pp.FirstPosition();
  31. pq.Put(pp); // build pq from list
  32. }
  33. PqToList(); // rebuild list from pq
  34. int freq = 0;
  35. do 
  36. {
  37. // find position w/ all terms
  38. while (first.position < last.position)
  39. {
  40. // scan forward in first
  41. do 
  42. {
  43. if (!first.NextPosition())
  44. {
  45. return (float) freq;
  46. }
  47. }
  48. while (first.position < last.position);
  49. FirstToLast();
  50. }
  51. freq++; // all equal: a match
  52. }
  53. while (last.NextPosition());
  54. return (float) freq;
  55. }
  56. }
  57. }