Source code for openbackdoor.attackers.sos_attacker

from typing import *
from openbackdoor.victims import Victim
from openbackdoor.data import get_dataloader, wrap_dataset
from .poisoners import load_poisoner
from openbackdoor.trainers import load_trainer
from openbackdoor.utils import evaluate_classification
from openbackdoor.defenders import Defender
from .attacker import Attacker
import torch
import torch.nn as nn
[docs]class SOSAttacker(Attacker): r""" Attacker for `SOS <https://aclanthology.org/2021.acl-long.431>`_ """ def __init__(self, **kwargs): super().__init__(**kwargs)
[docs] def attack(self, victim: Victim, dataset: List, config: Optional[dict] = None, defender: Optional[Defender] = None): clean_model = self.train(victim, dataset) poison_dataset = self.poison(clean_model, dataset, "train") if defender is not None and defender.pre is True: # pre tune defense poison_dataset = defender.defend(data=poison_dataset) backdoored_model = self.sos_train(clean_model, poison_dataset) return backdoored_model
[docs] def sos_train(self, victim: Victim, dataset: List): """ sos training """ return self.poison_trainer.sos_train(victim, dataset, self.metrics)