1. lucene 评分公式
(
评分公式中,对大多数因子的控制和实现都是通过Similarity抽象类的子类完成的。lucene默认使用DefaultSimilarity类。如果要详细了解的话可以直接看lucene源代码Similarity和DefaultSimilarity类。
)
)
Lucene Scoring 评分机制:
http://blog.chenlb.com/2009/08/lucene-scoring-architecture.html
3. dismax/edismax评分公式
3.1 dismax介绍:
What’s a “DisMax” ?:
使用solr时可以在solrconfig.xml的<requestHandler name="search">结点中增加defType的设置:
<requestHandler name="search" class="solr.SearchHandler" default="true">
<lst name="defaults">
<str name="defType">edismax</str> <!--增加这一行-->
</lst>
</requesHandler>
3.2 solr使用edismax时的评分公式
solr管理页面查询时增加参数debugQuery=true即可启用debug信息,可以清楚的看到在查询多个域时评分规则如下:
下面借用用python的对齐方式来展示计算规则:
score = max plus 0.1 times others of:
value1 = field1 weight,product of:
queryWeight, product of:
boost
idf
queryNorm
fieldWeight, product of:
tf(termFreq)
idf
fieldNorm
...
valuen = fieldn weight(计算方法同上)
假设有field1,field2,且field1 weight > field2 weight(即value1 > value2), 那么score = value1 plus 0.1 times value2(即score = value1 + 0.1 * value2)
其中field weight时lucene的评分公式计算出来的,可以看出跟lucene用explain query显示的格式一样。
4.评分相关的Solr FAQ
以上内容是基于当前solr4.4版本的~