Lucene.Net  3.0.3
Lucene.Net is a .NET port of the Java Lucene Indexing Library
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Properties
DocValues.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 Explanation = Lucene.Net.Search.Explanation;
21 
22 namespace Lucene.Net.Search.Function
23 {
24 
37  public abstract class DocValues
38  {
39  /*
40  * DocValues is distinct from ValueSource because
41  * there needs to be an object created at query evaluation time that
42  * is not referenced by the query itself because:
43  * - Query objects should be MT safe
44  * - For caching, Query objects are often used as keys... you don't
45  * want the Query carrying around big objects
46  */
47 
53  public abstract float FloatVal(int doc);
54 
60  public virtual int IntVal(int doc)
61  {
62  return (int) FloatVal(doc);
63  }
64 
70  public virtual long LongVal(int doc)
71  {
72  return (long) FloatVal(doc);
73  }
74 
80  public virtual double DoubleVal(int doc)
81  {
82  return (double) FloatVal(doc);
83  }
84 
90  public virtual System.String StrVal(int doc)
91  {
92  return FloatVal(doc).ToString();
93  }
94 
96  public abstract System.String ToString(int doc);
97 
99  public virtual Explanation Explain(int doc)
100  {
101  return new Explanation(FloatVal(doc), ToString(doc));
102  }
103 
115  protected internal virtual object InnerArray
116  {
117  get { throw new System.NotSupportedException("this optional method is for test purposes only"); }
118  }
119 
120  // --- some simple statistics on values
121  private float minVal = System.Single.NaN;
122  private float maxVal = System.Single.NaN;
123  private float avgVal = System.Single.NaN;
124  private bool computed = false;
125  // compute optional values
126  private void Compute()
127  {
128  if (computed)
129  {
130  return ;
131  }
132  float sum = 0;
133  int n = 0;
134  while (true)
135  {
136  float val;
137  try
138  {
139  val = FloatVal(n);
140  }
141  catch (System.IndexOutOfRangeException)
142  {
143  break;
144  }
145  sum += val;
146  minVal = System.Single.IsNaN(minVal)?val:System.Math.Min(minVal, val);
147  maxVal = System.Single.IsNaN(maxVal)?val:System.Math.Max(maxVal, val);
148  ++n;
149  }
150 
151  avgVal = n == 0?System.Single.NaN:sum / n;
152  computed = true;
153  }
154 
165  [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Design", "CA1024:UsePropertiesWhereAppropriate")]
166  public virtual float GetMinValue()
167  {
168  Compute();
169  return minVal;
170  }
171 
182  [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Design", "CA1024:UsePropertiesWhereAppropriate")]
183  public virtual float GetMaxValue()
184  {
185  Compute();
186  return maxVal;
187  }
188 
199  [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Design", "CA1024:UsePropertiesWhereAppropriate")]
200  public virtual float GetAverageValue()
201  {
202  Compute();
203  return avgVal;
204  }
205  }
206 }