func (s *ConjunctionQueryScorer) Score(constituents []*search.DocumentMatch) *search.DocumentMatch { rv := search.DocumentMatch{ ID: constituents[0].ID, } var sum float64 var childrenExplanations []*search.Explanation if s.explain { childrenExplanations = make([]*search.Explanation, len(constituents)) } locations := []search.FieldTermLocationMap{} for i, docMatch := range constituents { sum += docMatch.Score if s.explain { childrenExplanations[i] = docMatch.Expl } if docMatch.Locations != nil { locations = append(locations, docMatch.Locations) } } rv.Score = sum if s.explain { rv.Expl = &search.Explanation{Value: sum, Message: "sum of:", Children: childrenExplanations} } if len(locations) == 1 { rv.Locations = locations[0] } else if len(locations) > 1 { rv.Locations = search.MergeLocations(locations) } return &rv }
func (s *DisjunctionQueryScorer) Score(constituents []*search.DocumentMatch, countMatch, countTotal int) *search.DocumentMatch { rv := search.DocumentMatch{ ID: constituents[0].ID, } var sum float64 var childrenExplanations []*search.Explanation if s.explain { childrenExplanations = make([]*search.Explanation, len(constituents)) } locations := []search.FieldTermLocationMap{} for i, docMatch := range constituents { sum += docMatch.Score if s.explain { childrenExplanations[i] = docMatch.Expl } if docMatch.Locations != nil { locations = append(locations, docMatch.Locations) } } var rawExpl *search.Explanation if s.explain { rawExpl = &search.Explanation{Value: sum, Message: "sum of:", Children: childrenExplanations} } coord := float64(countMatch) / float64(countTotal) rv.Score = sum * coord if s.explain { ce := make([]*search.Explanation, 2) ce[0] = rawExpl ce[1] = &search.Explanation{Value: coord, Message: fmt.Sprintf("coord(%d/%d)", countMatch, countTotal)} rv.Expl = &search.Explanation{Value: rv.Score, Message: "product of:", Children: ce} } if len(locations) == 1 { rv.Locations = locations[0] } else if len(locations) > 1 { rv.Locations = search.MergeLocations(locations) } return &rv }