import torch.nn as nn
import kornia.augmentation as K
import random  

class AF(nn.Module):
    def __init__(self, shear_range=(0.0, 0.0), rotation_range=(0.0, 0.0)):
        super(AF, self).__init__()
        self.affine = K.RandomAffine(
            degrees=rotation_range,
            shear=shear_range,
            p=1.0, 
        )

    def forward(self, image_and_cover):
        image, cover_image = image_and_cover
        image = (image + 1) / 2
        return self.affine(image) * 2 - 1


        