Source code for pyrit.score.float_scale_threshold_scorer

# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.

import uuid
from typing import Optional

from pyrit.models import PromptRequestPiece, Score
from pyrit.score.scorer import Scorer


[docs] class FloatScaleThresholdScorer(Scorer): """A scorer that applies a threshold to a float scale score to make it a true/false score."""
[docs] def __init__(self, *, scorer: Scorer, threshold: float) -> None: self._scorer = scorer self._threshold = threshold if not scorer.scorer_type == "float_scale": raise ValueError("The scorer must be a float scale scorer") if threshold <= 0 or threshold >= 1: raise ValueError("The threshold must be between 0 and 1") self.scorer_type = "true_false"
[docs] async def score_async(self, request_response: PromptRequestPiece, *, task: Optional[str] = None) -> list[Score]: """Scores the piece using the underlying float-scale scorer and thresholds the resulting score. Args: request_response (PromptRequestPiece): The piece to score. task (str): The task based on which the text should be scored (the original attacker model's objective). Returns: list[Score]: The scores. """ scores = await self._scorer.score_async(request_response, task=task) for score in scores: score_value = score.get_value() score.score_value = str(score_value >= self._threshold) if score_value > self._threshold: comparison_symbol = ">" if score_value < self._threshold: comparison_symbol = "<" if score_value == self._threshold: comparison_symbol = "=" score.score_rationale = ( f"Normalized scale score: {score_value} {comparison_symbol} threshold {self._threshold}\n" f"Rationale for scale score: {score.score_rationale}" ) score.score_type = self.scorer_type score.id = uuid.uuid4() score.scorer_class_identifier = self.get_identifier() score.scorer_class_identifier["sub_identifier"] = self._scorer.get_identifier() self._memory.add_scores_to_memory(scores=scores) return scores
[docs] def validate(self, request_response: PromptRequestPiece, *, task: Optional[str] = None) -> None: """Validates the request response for scoring.""" self._scorer.validate(request_response, task=task)