Source code for gnes.score_fn.normalize

from .base import ModifierScoreFn, ScoreOps as so


[docs]class Normalizer1(ModifierScoreFn): """Do normalizing: score = 1 / (1 + sqrt(score))""" def __init__(self): super().__init__(modifier='reciprocal1p') def __call__(self, last_score, *args, **kwargs): return super().__call__(so.sqrt(last_score))
[docs]class Normalizer2(ModifierScoreFn): """Do normalizing: score = 1 / (1 + score / num_dim)""" def __init__(self, num_dim: int): super().__init__(modifier='reciprocal1p', factor=1.0 / num_dim, factor_name='1/num_dim')
[docs]class Normalizer3(Normalizer2): """Do normalizing: score = 1 / (1 + sqrt(score) / num_dim)""" def __call__(self, last_score, *args, **kwargs): return super().__call__(so.sqrt(last_score))
[docs]class Normalizer4(ModifierScoreFn): """Do normalizing: score = 1 - score / num_bytes """ def __init__(self, num_bytes: int): super().__init__(modifier='invert1p', factor=1.0 / num_bytes, factor_name='1/num_bytes')
[docs]class Normalizer5(ModifierScoreFn): """Do normalizing: score = 1 / (1 + sqrt(abs(score)))""" def __init__(self): super().__init__(modifier='reciprocal1p') def __call__(self, last_score, *args, **kwargs): return super().__call__(so.sqrt(so.abs(last_score)))