/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
using System;
using System.Collections.Generic;
namespace Lucene.Net.Search
{
/// Expert: Describes the score computation for document and query.
[Serializable]
public class Explanation
{
private float value; // the value of this node
private System.String description; // what it represents
private List details; // sub-explanations
public Explanation()
{
}
public Explanation(float value, System.String description)
{
this.value = value;
this.description = description;
}
/// Indicates whether or not this Explanation models a good match.
///
///
/// By default, an Explanation represents a "match" if the value is positive.
///
///
///
///
public virtual bool IsMatch
{
get { return (0.0f < Value); }
}
/// The value assigned to this explanation node.
public virtual float Value
{
get { return value; }
set { this.value = value; }
}
/// A description of this explanation node.
public virtual string Description
{
get { return description; }
set { this.description = value; }
}
/// A short one line summary which should contain all high level
/// information about this Explanation, without the "Details"
///
protected internal virtual string Summary
{
get { return Value + " = " + Description; }
}
/// The sub-nodes of this explanation node.
public virtual Explanation[] GetDetails()
{
if (details == null)
return null;
return details.ToArray();
}
/// Adds a sub-node to this explanation node.
public virtual void AddDetail(Explanation detail)
{
if (details == null)
details = new List();
details.Add(detail);
}
/// Render an explanation as text.
public override System.String ToString()
{
return ToString(0);
}
protected internal virtual System.String ToString(int depth)
{
System.Text.StringBuilder buffer = new System.Text.StringBuilder();
for (int i = 0; i < depth; i++)
{
buffer.Append(" ");
}
buffer.Append(Summary);
buffer.Append("\n");
Explanation[] details = GetDetails();
if (details != null)
{
for (int i = 0; i < details.Length; i++)
{
buffer.Append(details[i].ToString(depth + 1));
}
}
return buffer.ToString();
}
/// Render an explanation as HTML.
public virtual System.String ToHtml()
{
System.Text.StringBuilder buffer = new System.Text.StringBuilder();
buffer.Append("\n");
buffer.Append("- ");
buffer.Append(Summary);
buffer.Append("
\n");
Explanation[] details = GetDetails();
if (details != null)
{
for (int i = 0; i < details.Length; i++)
{
buffer.Append(details[i].ToHtml());
}
}
buffer.Append(" \n");
buffer.Append("
\n");
return buffer.ToString();
}
/// Small Util class used to pass both an idf factor as well as an
/// explanation for that factor.
///
/// This class will likely be held on a , so be aware
/// before storing any large or un-serializable fields.
///
///
[Serializable]
public abstract class IDFExplanation
{
/// the idf factor
public abstract float Idf { get; }
/// This should be calculated lazily if possible.
///
///
/// the explanation for the idf factor.
///
public abstract System.String Explain();
}
}
}