Source code for pyrit.prompt_converter.noise_converter
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT license.
import logging
import textwrap
from typing import Optional
import pathlib
from pyrit.common.path import DATASETS_PATH
from pyrit.models import SeedPrompt
from pyrit.prompt_converter import LLMGenericTextConverter
from pyrit.prompt_target import PromptChatTarget
logger = logging.getLogger(__name__)
[docs]
class NoiseConverter(LLMGenericTextConverter):
[docs]
def __init__(
self,
*,
converter_target: PromptChatTarget,
noise: Optional[str] = None,
number_errors: Optional[int] = 5,
prompt_template: SeedPrompt = None,
):
"""
Injects noise errors into a conversation
Args:
converter_target (PromptChatTarget): The endpoint that converts the prompt
noise (str): The noise to inject. Grammar error, delete random letter, insert random space, etc.
number_errors (int): The number of errors to inject
prompt_template (SeedPrompt, Optional): The prompt template for the conversion.
"""
# set to default strategy if not provided
prompt_template = (
prompt_template
if prompt_template
else SeedPrompt.from_yaml_file(pathlib.Path(DATASETS_PATH) / "prompt_converters" / "noise_converter.yaml")
)
if not noise:
noise = textwrap.dedent(
"Grammar error, Delete random letter, insert random symbol, missing white space, "
"bad auto-correct, or similar"
)
super().__init__(
converter_target=converter_target,
prompt_template=prompt_template,
noise=noise,
number_errors=str(number_errors),
)