Source code for lerot.comparison.HistBalancedInterleave

# This file is part of Lerot.
#
# Lerot is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Lerot is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with Lerot.  If not, see <http://www.gnu.org/licenses/>.

# KH, 2012/08/21

from numpy import asarray

from .AbstractHistInterleavedComparison import AbstractHistInterleavedComparison
from .BalancedInterleave import BalancedInterleave


[docs]class HistBalancedInterleave(AbstractHistInterleavedComparison): """Balanced interleave method, applied to historical data.""" def __init__(self, arg_str=None): self.bi = BalancedInterleave() def _get_assignment(self, r1, r2, query, length): r1.init_ranking(query) r2.init_ranking(query) length = min(r1.document_count(), r2.document_count(), length) # get ranked list for each ranker l1, l2 = [], [] for _ in range(length): l1.append(r1.next()) l2.append(r2.next()) return (asarray(l1), asarray(l2))
[docs] def infer_outcome(self, l, a, c, target_r1, target_r2, query): """count clicks within the top-k interleaved list""" return self.bi.infer_outcome(l, self._get_assignment(target_r1, target_r2, query, len(l)), c, query)