Lucene/solr的评分公式


1. lucene 评分公式

评分公式中,对大多数因子的控制和实现都是通过Similarity抽象类的子类完成的。lucene默认使用DefaultSimilarity类。如果要详细了解的话可以直接看lucene源代码Similarity和DefaultSimilarity类。



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版本的~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章