import torch
import torch.nn as nn

class DCT8x8(nn.Module):
    def __init__(self):
        super(DCT8x8, self).__init__()
        self.filter = torch.zeros(64, 8, 8).cuda()
        self.freq_num = 64
        self.freq_range = 8

        self.filter[0] = torch.Tensor([[0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250],
        [0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250, 0.1250]])

        self.filter[1] = torch.Tensor([[ 0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734],
        [ 0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470],
        [ 0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982],
        [ 0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345],
        [-0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345],
        [-0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982],
        [-0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470],
        [-0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734]])
        
        self.filter[2] = torch.Tensor([[ 0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633],
        [ 0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676],
        [-0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676],
        [-0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633],
        [-0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633],
        [-0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676],
        [ 0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676],
        [ 0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633]])

        self.filter[3] = torch.Tensor([[ 0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470],
        [-0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345],
        [-0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734],
        [-0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982],
        [ 0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982],
        [ 0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734],
        [ 0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345],
        [-0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470]])

        self.filter[4] = torch.Tensor([[ 0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250],
        [-0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250],
        [-0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250],
        [ 0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250],
        [ 0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250],
        [-0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250],
        [-0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250, -0.1250],
        [ 0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250,  0.1250]])

        self.filter[5] = torch.Tensor([[ 0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982],
        [-0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734],
        [ 0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345],
        [ 0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470],
        [-0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470],
        [-0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345],
        [ 0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734],
        [-0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982]])

        self.filter[6] = torch.Tensor([[ 0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676],
        [-0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633],
        [ 0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633],
        [-0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676],
        [-0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676, -0.0676],
        [ 0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633,  0.1633],
        [-0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633, -0.1633],
        [ 0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676,  0.0676]])

        self.filter[7] = torch.Tensor([[ 0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345,  0.0345],
        [-0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982, -0.0982],
        [ 0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470,  0.1470],
        [-0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734, -0.1734],
        [ 0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734,  0.1734],
        [-0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470, -0.1470],
        [ 0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982,  0.0982],
        [-0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345, -0.0345]])

        self.filter[8] = torch.Tensor([[ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734]])
        self.filter[9] = torch.Tensor([[ 0.2405,  0.2039,  0.1362,  0.0478, -0.0478, -0.1362, -0.2039, -0.2405],
        [ 0.2039,  0.1728,  0.1155,  0.0406, -0.0406, -0.1155, -0.1728, -0.2039],
        [ 0.1362,  0.1155,  0.0772,  0.0271, -0.0271, -0.0772, -0.1155, -0.1362],
        [ 0.0478,  0.0406,  0.0271,  0.0095, -0.0095, -0.0271, -0.0406, -0.0478],
        [-0.0478, -0.0406, -0.0271, -0.0095,  0.0095,  0.0271,  0.0406,  0.0478],
        [-0.1362, -0.1155, -0.0772, -0.0271,  0.0271,  0.0772,  0.1155,  0.1362],
        [-0.2039, -0.1728, -0.1155, -0.0406,  0.0406,  0.1155,  0.1728,  0.2039],
        [-0.2405, -0.2039, -0.1362, -0.0478,  0.0478,  0.1362,  0.2039,  0.2405]])
        self.filter[10] = torch.Tensor([[ 0.2265,  0.1920,  0.1283,  0.0451, -0.0451, -0.1283, -0.1920, -0.2265],
        [ 0.0938,  0.0795,  0.0532,  0.0187, -0.0187, -0.0532, -0.0795, -0.0938],
        [-0.0938, -0.0795, -0.0532, -0.0187,  0.0187,  0.0532,  0.0795,  0.0938],
        [-0.2265, -0.1920, -0.1283, -0.0451,  0.0451,  0.1283,  0.1920,  0.2265],
        [-0.2265, -0.1920, -0.1283, -0.0451,  0.0451,  0.1283,  0.1920,  0.2265],
        [-0.0938, -0.0795, -0.0532, -0.0187,  0.0187,  0.0532,  0.0795,  0.0938],
        [ 0.0938,  0.0795,  0.0532,  0.0187, -0.0187, -0.0532, -0.0795, -0.0938],
        [ 0.2265,  0.1920,  0.1283,  0.0451, -0.0451, -0.1283, -0.1920, -0.2265]])
        self.filter[11] = torch.Tensor([[ 0.2039,  0.1728,  0.1155,  0.0406, -0.0406, -0.1155, -0.1728, -0.2039],
        [-0.0478, -0.0406, -0.0271, -0.0095,  0.0095,  0.0271,  0.0406,  0.0478],
        [-0.2405, -0.2039, -0.1362, -0.0478,  0.0478,  0.1362,  0.2039,  0.2405],
        [-0.1362, -0.1155, -0.0772, -0.0271,  0.0271,  0.0772,  0.1155,  0.1362],
        [ 0.1362,  0.1155,  0.0772,  0.0271, -0.0271, -0.0772, -0.1155, -0.1362],
        [ 0.2405,  0.2039,  0.1362,  0.0478, -0.0478, -0.1362, -0.2039, -0.2405],
        [ 0.0478,  0.0406,  0.0271,  0.0095, -0.0095, -0.0271, -0.0406, -0.0478],
        [-0.2039, -0.1728, -0.1155, -0.0406,  0.0406,  0.1155,  0.1728,  0.2039]])
        self.filter[12] = torch.Tensor([[ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [-0.1734, -0.1470, -0.0982, -0.0345,  0.0345,  0.0982,  0.1470,  0.1734],
        [-0.1734, -0.1470, -0.0982, -0.0345,  0.0345,  0.0982,  0.1470,  0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734],
        [-0.1734, -0.1470, -0.0982, -0.0345,  0.0345,  0.0982,  0.1470,  0.1734],
        [-0.1734, -0.1470, -0.0982, -0.0345,  0.0345,  0.0982,  0.1470,  0.1734],
        [ 0.1734,  0.1470,  0.0982,  0.0345, -0.0345, -0.0982, -0.1470, -0.1734]])
        self.filter[13] = torch.Tensor([[ 0.1362,  0.1155,  0.0772,  0.0271, -0.0271, -0.0772, -0.1155, -0.1362],
        [-0.2405, -0.2039, -0.1362, -0.0478,  0.0478,  0.1362,  0.2039,  0.2405],
        [ 0.0478,  0.0406,  0.0271,  0.0095, -0.0095, -0.0271, -0.0406, -0.0478],
        [ 0.2039,  0.1728,  0.1155,  0.0406, -0.0406, -0.1155, -0.1728, -0.2039],
        [-0.2039, -0.1728, -0.1155, -0.0406,  0.0406,  0.1155,  0.1728,  0.2039],
        [-0.0478, -0.0406, -0.0271, -0.0095,  0.0095,  0.0271,  0.0406,  0.0478],
        [ 0.2405,  0.2039,  0.1362,  0.0478, -0.0478, -0.1362, -0.2039, -0.2405],
        [-0.1362, -0.1155, -0.0772, -0.0271,  0.0271,  0.0772,  0.1155,  0.1362]])
        self.filter[14] = torch.Tensor([[ 0.0938,  0.0795,  0.0532,  0.0187, -0.0187, -0.0532, -0.0795, -0.0938],
        [-0.2265, -0.1920, -0.1283, -0.0451,  0.0451,  0.1283,  0.1920,  0.2265],
        [ 0.2265,  0.1920,  0.1283,  0.0451, -0.0451, -0.1283, -0.1920, -0.2265],
        [-0.0938, -0.0795, -0.0532, -0.0187,  0.0187,  0.0532,  0.0795,  0.0938],
        [-0.0938, -0.0795, -0.0532, -0.0187,  0.0187,  0.0532,  0.0795,  0.0938],
        [ 0.2265,  0.1920,  0.1283,  0.0451, -0.0451, -0.1283, -0.1920, -0.2265],
        [-0.2265, -0.1920, -0.1283, -0.0451,  0.0451,  0.1283,  0.1920,  0.2265],
        [ 0.0938,  0.0795,  0.0532,  0.0187, -0.0187, -0.0532, -0.0795, -0.0938]])
        self.filter[15] = torch.Tensor([[ 0.0478,  0.0406,  0.0271,  0.0095, -0.0095, -0.0271, -0.0406, -0.0478],
        [-0.1362, -0.1155, -0.0772, -0.0271,  0.0271,  0.0772,  0.1155,  0.1362],
        [ 0.2039,  0.1728,  0.1155,  0.0406, -0.0406, -0.1155, -0.1728, -0.2039],
        [-0.2405, -0.2039, -0.1362, -0.0478,  0.0478,  0.1362,  0.2039,  0.2405],
        [ 0.2405,  0.2039,  0.1362,  0.0478, -0.0478, -0.1362, -0.2039, -0.2405],
        [-0.2039, -0.1728, -0.1155, -0.0406,  0.0406,  0.1155,  0.1728,  0.2039],
        [ 0.1362,  0.1155,  0.0772,  0.0271, -0.0271, -0.0772, -0.1155, -0.1362],
        [-0.0478, -0.0406, -0.0271, -0.0095,  0.0095,  0.0271,  0.0406,  0.0478]])
        self.filter[16] = torch.Tensor([[ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633]])
        self.filter[17] = torch.Tensor([[ 0.2265,  0.0938, -0.0938, -0.2265, -0.2265, -0.0938,  0.0938,  0.2265],
        [ 0.1920,  0.0795, -0.0795, -0.1920, -0.1920, -0.0795,  0.0795,  0.1920],
        [ 0.1283,  0.0532, -0.0532, -0.1283, -0.1283, -0.0532,  0.0532,  0.1283],
        [ 0.0451,  0.0187, -0.0187, -0.0451, -0.0451, -0.0187,  0.0187,  0.0451],
        [-0.0451, -0.0187,  0.0187,  0.0451,  0.0451,  0.0187, -0.0187, -0.0451],
        [-0.1283, -0.0532,  0.0532,  0.1283,  0.1283,  0.0532, -0.0532, -0.1283],
        [-0.1920, -0.0795,  0.0795,  0.1920,  0.1920,  0.0795, -0.0795, -0.1920],
        [-0.2265, -0.0938,  0.0938,  0.2265,  0.2265,  0.0938, -0.0938, -0.2265]])
        self.filter[18] = torch.Tensor([[ 0.2134,  0.0884, -0.0884, -0.2134, -0.2134, -0.0884,  0.0884,  0.2134],
        [ 0.0884,  0.0366, -0.0366, -0.0884, -0.0884, -0.0366,  0.0366,  0.0884],
        [-0.0884, -0.0366,  0.0366,  0.0884,  0.0884,  0.0366, -0.0366, -0.0884],
        [-0.2134, -0.0884,  0.0884,  0.2134,  0.2134,  0.0884, -0.0884, -0.2134],
        [-0.2134, -0.0884,  0.0884,  0.2134,  0.2134,  0.0884, -0.0884, -0.2134],
        [-0.0884, -0.0366,  0.0366,  0.0884,  0.0884,  0.0366, -0.0366, -0.0884],
        [ 0.0884,  0.0366, -0.0366, -0.0884, -0.0884, -0.0366,  0.0366,  0.0884],
        [ 0.2134,  0.0884, -0.0884, -0.2134, -0.2134, -0.0884,  0.0884,  0.2134]])
        self.filter[19] = torch.Tensor([[ 0.1920,  0.0795, -0.0795, -0.1920, -0.1920, -0.0795,  0.0795,  0.1920],
        [-0.0451, -0.0187,  0.0187,  0.0451,  0.0451,  0.0187, -0.0187, -0.0451],
        [-0.2265, -0.0938,  0.0938,  0.2265,  0.2265,  0.0938, -0.0938, -0.2265],
        [-0.1283, -0.0532,  0.0532,  0.1283,  0.1283,  0.0532, -0.0532, -0.1283],
        [ 0.1283,  0.0532, -0.0532, -0.1283, -0.1283, -0.0532,  0.0532,  0.1283],
        [ 0.2265,  0.0938, -0.0938, -0.2265, -0.2265, -0.0938,  0.0938,  0.2265],
        [ 0.0451,  0.0187, -0.0187, -0.0451, -0.0451, -0.0187,  0.0187,  0.0451],
        [-0.1920, -0.0795,  0.0795,  0.1920,  0.1920,  0.0795, -0.0795, -0.1920]])
        self.filter[20] = torch.Tensor([[ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [-0.1633, -0.0676,  0.0676,  0.1633,  0.1633,  0.0676, -0.0676, -0.1633],
        [-0.1633, -0.0676,  0.0676,  0.1633,  0.1633,  0.0676, -0.0676, -0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633],
        [-0.1633, -0.0676,  0.0676,  0.1633,  0.1633,  0.0676, -0.0676, -0.1633],
        [-0.1633, -0.0676,  0.0676,  0.1633,  0.1633,  0.0676, -0.0676, -0.1633],
        [ 0.1633,  0.0676, -0.0676, -0.1633, -0.1633, -0.0676,  0.0676,  0.1633]])
        self.filter[21] = torch.Tensor([[ 0.1283,  0.0532, -0.0532, -0.1283, -0.1283, -0.0532,  0.0532,  0.1283],
        [-0.2265, -0.0938,  0.0938,  0.2265,  0.2265,  0.0938, -0.0938, -0.2265],
        [ 0.0451,  0.0187, -0.0187, -0.0451, -0.0451, -0.0187,  0.0187,  0.0451],
        [ 0.1920,  0.0795, -0.0795, -0.1920, -0.1920, -0.0795,  0.0795,  0.1920],
        [-0.1920, -0.0795,  0.0795,  0.1920,  0.1920,  0.0795, -0.0795, -0.1920],
        [-0.0451, -0.0187,  0.0187,  0.0451,  0.0451,  0.0187, -0.0187, -0.0451],
        [ 0.2265,  0.0938, -0.0938, -0.2265, -0.2265, -0.0938,  0.0938,  0.2265],
        [-0.1283, -0.0532,  0.0532,  0.1283,  0.1283,  0.0532, -0.0532, -0.1283]])
        self.filter[22] = torch.Tensor([[ 0.0884,  0.0366, -0.0366, -0.0884, -0.0884, -0.0366,  0.0366,  0.0884],
        [-0.2134, -0.0884,  0.0884,  0.2134,  0.2134,  0.0884, -0.0884, -0.2134],
        [ 0.2134,  0.0884, -0.0884, -0.2134, -0.2134, -0.0884,  0.0884,  0.2134],
        [-0.0884, -0.0366,  0.0366,  0.0884,  0.0884,  0.0366, -0.0366, -0.0884],
        [-0.0884, -0.0366,  0.0366,  0.0884,  0.0884,  0.0366, -0.0366, -0.0884],
        [ 0.2134,  0.0884, -0.0884, -0.2134, -0.2134, -0.0884,  0.0884,  0.2134],
        [-0.2134, -0.0884,  0.0884,  0.2134,  0.2134,  0.0884, -0.0884, -0.2134],
        [ 0.0884,  0.0366, -0.0366, -0.0884, -0.0884, -0.0366,  0.0366,  0.0884]])
        self.filter[23] = torch.Tensor([[ 0.0451,  0.0187, -0.0187, -0.0451, -0.0451, -0.0187,  0.0187,  0.0451],
        [-0.1283, -0.0532,  0.0532,  0.1283,  0.1283,  0.0532, -0.0532, -0.1283],
        [ 0.1920,  0.0795, -0.0795, -0.1920, -0.1920, -0.0795,  0.0795,  0.1920],
        [-0.2265, -0.0938,  0.0938,  0.2265,  0.2265,  0.0938, -0.0938, -0.2265],
        [ 0.2265,  0.0938, -0.0938, -0.2265, -0.2265, -0.0938,  0.0938,  0.2265],
        [-0.1920, -0.0795,  0.0795,  0.1920,  0.1920,  0.0795, -0.0795, -0.1920],
        [ 0.1283,  0.0532, -0.0532, -0.1283, -0.1283, -0.0532,  0.0532,  0.1283],
        [-0.0451, -0.0187,  0.0187,  0.0451,  0.0451,  0.0187, -0.0187, -0.0451]])
        self.filter[24] = torch.Tensor([[ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470]])
        self.filter[25] = torch.Tensor([[ 0.2039, -0.0478, -0.2405, -0.1362,  0.1362,  0.2405,  0.0478, -0.2039],
        [ 0.1728, -0.0406, -0.2039, -0.1155,  0.1155,  0.2039,  0.0406, -0.1728],
        [ 0.1155, -0.0271, -0.1362, -0.0772,  0.0772,  0.1362,  0.0271, -0.1155],
        [ 0.0406, -0.0095, -0.0478, -0.0271,  0.0271,  0.0478,  0.0095, -0.0406],
        [-0.0406,  0.0095,  0.0478,  0.0271, -0.0271, -0.0478, -0.0095,  0.0406],
        [-0.1155,  0.0271,  0.1362,  0.0772, -0.0772, -0.1362, -0.0271,  0.1155],
        [-0.1728,  0.0406,  0.2039,  0.1155, -0.1155, -0.2039, -0.0406,  0.1728],
        [-0.2039,  0.0478,  0.2405,  0.1362, -0.1362, -0.2405, -0.0478,  0.2039]])
        self.filter[26] = torch.Tensor([[ 0.1920, -0.0451, -0.2265, -0.1283,  0.1283,  0.2265,  0.0451, -0.1920],
        [ 0.0795, -0.0187, -0.0938, -0.0532,  0.0532,  0.0938,  0.0187, -0.0795],
        [-0.0795,  0.0187,  0.0938,  0.0532, -0.0532, -0.0938, -0.0187,  0.0795],
        [-0.1920,  0.0451,  0.2265,  0.1283, -0.1283, -0.2265, -0.0451,  0.1920],
        [-0.1920,  0.0451,  0.2265,  0.1283, -0.1283, -0.2265, -0.0451,  0.1920],
        [-0.0795,  0.0187,  0.0938,  0.0532, -0.0532, -0.0938, -0.0187,  0.0795],
        [ 0.0795, -0.0187, -0.0938, -0.0532,  0.0532,  0.0938,  0.0187, -0.0795],
        [ 0.1920, -0.0451, -0.2265, -0.1283,  0.1283,  0.2265,  0.0451, -0.1920]])
        self.filter[27] = torch.Tensor([[ 0.1728, -0.0406, -0.2039, -0.1155,  0.1155,  0.2039,  0.0406, -0.1728],
        [-0.0406,  0.0095,  0.0478,  0.0271, -0.0271, -0.0478, -0.0095,  0.0406],
        [-0.2039,  0.0478,  0.2405,  0.1362, -0.1362, -0.2405, -0.0478,  0.2039],
        [-0.1155,  0.0271,  0.1362,  0.0772, -0.0772, -0.1362, -0.0271,  0.1155],
        [ 0.1155, -0.0271, -0.1362, -0.0772,  0.0772,  0.1362,  0.0271, -0.1155],
        [ 0.2039, -0.0478, -0.2405, -0.1362,  0.1362,  0.2405,  0.0478, -0.2039],
        [ 0.0406, -0.0095, -0.0478, -0.0271,  0.0271,  0.0478,  0.0095, -0.0406],
        [-0.1728,  0.0406,  0.2039,  0.1155, -0.1155, -0.2039, -0.0406,  0.1728]])
        self.filter[28] = torch.Tensor([[ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [-0.1470,  0.0345,  0.1734,  0.0982, -0.0982, -0.1734, -0.0345,  0.1470],
        [-0.1470,  0.0345,  0.1734,  0.0982, -0.0982, -0.1734, -0.0345,  0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470],
        [-0.1470,  0.0345,  0.1734,  0.0982, -0.0982, -0.1734, -0.0345,  0.1470],
        [-0.1470,  0.0345,  0.1734,  0.0982, -0.0982, -0.1734, -0.0345,  0.1470],
        [ 0.1470, -0.0345, -0.1734, -0.0982,  0.0982,  0.1734,  0.0345, -0.1470]])
        self.filter[29] = torch.Tensor([[ 0.1155, -0.0271, -0.1362, -0.0772,  0.0772,  0.1362,  0.0271, -0.1155],
        [-0.2039,  0.0478,  0.2405,  0.1362, -0.1362, -0.2405, -0.0478,  0.2039],
        [ 0.0406, -0.0095, -0.0478, -0.0271,  0.0271,  0.0478,  0.0095, -0.0406],
        [ 0.1728, -0.0406, -0.2039, -0.1155,  0.1155,  0.2039,  0.0406, -0.1728],
        [-0.1728,  0.0406,  0.2039,  0.1155, -0.1155, -0.2039, -0.0406,  0.1728],
        [-0.0406,  0.0095,  0.0478,  0.0271, -0.0271, -0.0478, -0.0095,  0.0406],
        [ 0.2039, -0.0478, -0.2405, -0.1362,  0.1362,  0.2405,  0.0478, -0.2039],
        [-0.1155,  0.0271,  0.1362,  0.0772, -0.0772, -0.1362, -0.0271,  0.1155]])
        self.filter[30] = torch.Tensor([[ 0.0795, -0.0187, -0.0938, -0.0532,  0.0532,  0.0938,  0.0187, -0.0795],
        [-0.1920,  0.0451,  0.2265,  0.1283, -0.1283, -0.2265, -0.0451,  0.1920],
        [ 0.1920, -0.0451, -0.2265, -0.1283,  0.1283,  0.2265,  0.0451, -0.1920],
        [-0.0795,  0.0187,  0.0938,  0.0532, -0.0532, -0.0938, -0.0187,  0.0795],
        [-0.0795,  0.0187,  0.0938,  0.0532, -0.0532, -0.0938, -0.0187,  0.0795],
        [ 0.1920, -0.0451, -0.2265, -0.1283,  0.1283,  0.2265,  0.0451, -0.1920],
        [-0.1920,  0.0451,  0.2265,  0.1283, -0.1283, -0.2265, -0.0451,  0.1920],
        [ 0.0795, -0.0187, -0.0938, -0.0532,  0.0532,  0.0938,  0.0187, -0.0795]])
        self.filter[31] = torch.Tensor([[ 0.0406, -0.0095, -0.0478, -0.0271,  0.0271,  0.0478,  0.0095, -0.0406],
        [-0.1155,  0.0271,  0.1362,  0.0772, -0.0772, -0.1362, -0.0271,  0.1155],
        [ 0.1728, -0.0406, -0.2039, -0.1155,  0.1155,  0.2039,  0.0406, -0.1728],
        [-0.2039,  0.0478,  0.2405,  0.1362, -0.1362, -0.2405, -0.0478,  0.2039],
        [ 0.2039, -0.0478, -0.2405, -0.1362,  0.1362,  0.2405,  0.0478, -0.2039],
        [-0.1728,  0.0406,  0.2039,  0.1155, -0.1155, -0.2039, -0.0406,  0.1728],
        [ 0.1155, -0.0271, -0.1362, -0.0772,  0.0772,  0.1362,  0.0271, -0.1155],
        [-0.0406,  0.0095,  0.0478,  0.0271, -0.0271, -0.0478, -0.0095,  0.0406]])
        self.filter[32] = torch.Tensor([[ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250]])
        self.filter[33] = torch.Tensor([[ 0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734],
        [ 0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470],
        [ 0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982],
        [ 0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345],
        [-0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345],
        [-0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982],
        [-0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470],
        [-0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734]])
        self.filter[34] = torch.Tensor([[ 0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633],
        [ 0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676],
        [-0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676],
        [-0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633],
        [-0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633],
        [-0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676],
        [ 0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676],
        [ 0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633]])
        self.filter[35] = torch.Tensor([[ 0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470],
        [-0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345],
        [-0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734],
        [-0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982],
        [ 0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982],
        [ 0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734],
        [ 0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345],
        [-0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470]])
        self.filter[36] = torch.Tensor([[ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [-0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250],
        [-0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250],
        [-0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250],
        [-0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250],
        [ 0.1250, -0.1250, -0.1250,  0.1250,  0.1250, -0.1250, -0.1250,  0.1250]])
        self.filter[37] = torch.Tensor([[ 0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982],
        [-0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734],
        [ 0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345],
        [ 0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470],
        [-0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470],
        [-0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345],
        [ 0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734],
        [-0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982]])
        self.filter[38] = torch.Tensor([[ 0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676],
        [-0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633],
        [ 0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633],
        [-0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676],
        [-0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676],
        [ 0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633],
        [-0.1633,  0.1633,  0.1633, -0.1633, -0.1633,  0.1633,  0.1633, -0.1633],
        [ 0.0676, -0.0676, -0.0676,  0.0676,  0.0676, -0.0676, -0.0676,  0.0676]])
        self.filter[39] = torch.Tensor([[ 0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345],
        [-0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982],
        [ 0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470],
        [-0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734],
        [ 0.1734, -0.1734, -0.1734,  0.1734,  0.1734, -0.1734, -0.1734,  0.1734],
        [-0.1470,  0.1470,  0.1470, -0.1470, -0.1470,  0.1470,  0.1470, -0.1470],
        [ 0.0982, -0.0982, -0.0982,  0.0982,  0.0982, -0.0982, -0.0982,  0.0982],
        [-0.0345,  0.0345,  0.0345, -0.0345, -0.0345,  0.0345,  0.0345, -0.0345]])
        self.filter[40] = torch.Tensor([[ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982]])
        self.filter[41] = torch.Tensor([[ 0.1362, -0.2405,  0.0478,  0.2039, -0.2039, -0.0478,  0.2405, -0.1362],
        [ 0.1155, -0.2039,  0.0406,  0.1728, -0.1728, -0.0406,  0.2039, -0.1155],
        [ 0.0772, -0.1362,  0.0271,  0.1155, -0.1155, -0.0271,  0.1362, -0.0772],
        [ 0.0271, -0.0478,  0.0095,  0.0406, -0.0406, -0.0095,  0.0478, -0.0271],
        [-0.0271,  0.0478, -0.0095, -0.0406,  0.0406,  0.0095, -0.0478,  0.0271],
        [-0.0772,  0.1362, -0.0271, -0.1155,  0.1155,  0.0271, -0.1362,  0.0772],
        [-0.1155,  0.2039, -0.0406, -0.1728,  0.1728,  0.0406, -0.2039,  0.1155],
        [-0.1362,  0.2405, -0.0478, -0.2039,  0.2039,  0.0478, -0.2405,  0.1362]])
        self.filter[42] = torch.Tensor([[ 0.1283, -0.2265,  0.0451,  0.1920, -0.1920, -0.0451,  0.2265, -0.1283],
        [ 0.0532, -0.0938,  0.0187,  0.0795, -0.0795, -0.0187,  0.0938, -0.0532],
        [-0.0532,  0.0938, -0.0187, -0.0795,  0.0795,  0.0187, -0.0938,  0.0532],
        [-0.1283,  0.2265, -0.0451, -0.1920,  0.1920,  0.0451, -0.2265,  0.1283],
        [-0.1283,  0.2265, -0.0451, -0.1920,  0.1920,  0.0451, -0.2265,  0.1283],
        [-0.0532,  0.0938, -0.0187, -0.0795,  0.0795,  0.0187, -0.0938,  0.0532],
        [ 0.0532, -0.0938,  0.0187,  0.0795, -0.0795, -0.0187,  0.0938, -0.0532],
        [ 0.1283, -0.2265,  0.0451,  0.1920, -0.1920, -0.0451,  0.2265, -0.1283]])
        self.filter[43] = torch.Tensor([[ 0.1155, -0.2039,  0.0406,  0.1728, -0.1728, -0.0406,  0.2039, -0.1155],
        [-0.0271,  0.0478, -0.0095, -0.0406,  0.0406,  0.0095, -0.0478,  0.0271],
        [-0.1362,  0.2405, -0.0478, -0.2039,  0.2039,  0.0478, -0.2405,  0.1362],
        [-0.0772,  0.1362, -0.0271, -0.1155,  0.1155,  0.0271, -0.1362,  0.0772],
        [ 0.0772, -0.1362,  0.0271,  0.1155, -0.1155, -0.0271,  0.1362, -0.0772],
        [ 0.1362, -0.2405,  0.0478,  0.2039, -0.2039, -0.0478,  0.2405, -0.1362],
        [ 0.0271, -0.0478,  0.0095,  0.0406, -0.0406, -0.0095,  0.0478, -0.0271],
        [-0.1155,  0.2039, -0.0406, -0.1728,  0.1728,  0.0406, -0.2039,  0.1155]])
        self.filter[44] = torch.Tensor([[ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [-0.0982,  0.1734, -0.0345, -0.1470,  0.1470,  0.0345, -0.1734,  0.0982],
        [-0.0982,  0.1734, -0.0345, -0.1470,  0.1470,  0.0345, -0.1734,  0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982],
        [-0.0982,  0.1734, -0.0345, -0.1470,  0.1470,  0.0345, -0.1734,  0.0982],
        [-0.0982,  0.1734, -0.0345, -0.1470,  0.1470,  0.0345, -0.1734,  0.0982],
        [ 0.0982, -0.1734,  0.0345,  0.1470, -0.1470, -0.0345,  0.1734, -0.0982]])
        self.filter[45] = torch.Tensor([[ 0.0772, -0.1362,  0.0271,  0.1155, -0.1155, -0.0271,  0.1362, -0.0772],
        [-0.1362,  0.2405, -0.0478, -0.2039,  0.2039,  0.0478, -0.2405,  0.1362],
        [ 0.0271, -0.0478,  0.0095,  0.0406, -0.0406, -0.0095,  0.0478, -0.0271],
        [ 0.1155, -0.2039,  0.0406,  0.1728, -0.1728, -0.0406,  0.2039, -0.1155],
        [-0.1155,  0.2039, -0.0406, -0.1728,  0.1728,  0.0406, -0.2039,  0.1155],
        [-0.0271,  0.0478, -0.0095, -0.0406,  0.0406,  0.0095, -0.0478,  0.0271],
        [ 0.1362, -0.2405,  0.0478,  0.2039, -0.2039, -0.0478,  0.2405, -0.1362],
        [-0.0772,  0.1362, -0.0271, -0.1155,  0.1155,  0.0271, -0.1362,  0.0772]])
        self.filter[46] = torch.Tensor([[ 0.0532, -0.0938,  0.0187,  0.0795, -0.0795, -0.0187,  0.0938, -0.0532],
        [-0.1283,  0.2265, -0.0451, -0.1920,  0.1920,  0.0451, -0.2265,  0.1283],
        [ 0.1283, -0.2265,  0.0451,  0.1920, -0.1920, -0.0451,  0.2265, -0.1283],
        [-0.0532,  0.0938, -0.0187, -0.0795,  0.0795,  0.0187, -0.0938,  0.0532],
        [-0.0532,  0.0938, -0.0187, -0.0795,  0.0795,  0.0187, -0.0938,  0.0532],
        [ 0.1283, -0.2265,  0.0451,  0.1920, -0.1920, -0.0451,  0.2265, -0.1283],
        [-0.1283,  0.2265, -0.0451, -0.1920,  0.1920,  0.0451, -0.2265,  0.1283],
        [ 0.0532, -0.0938,  0.0187,  0.0795, -0.0795, -0.0187,  0.0938, -0.0532]])
        self.filter[47] = torch.Tensor([[ 0.0271, -0.0478,  0.0095,  0.0406, -0.0406, -0.0095,  0.0478, -0.0271],
        [-0.0772,  0.1362, -0.0271, -0.1155,  0.1155,  0.0271, -0.1362,  0.0772],
        [ 0.1155, -0.2039,  0.0406,  0.1728, -0.1728, -0.0406,  0.2039, -0.1155],
        [-0.1362,  0.2405, -0.0478, -0.2039,  0.2039,  0.0478, -0.2405,  0.1362],
        [ 0.1362, -0.2405,  0.0478,  0.2039, -0.2039, -0.0478,  0.2405, -0.1362],
        [-0.1155,  0.2039, -0.0406, -0.1728,  0.1728,  0.0406, -0.2039,  0.1155],
        [ 0.0772, -0.1362,  0.0271,  0.1155, -0.1155, -0.0271,  0.1362, -0.0772],
        [-0.0271,  0.0478, -0.0095, -0.0406,  0.0406,  0.0095, -0.0478,  0.0271]])
        self.filter[48] = torch.Tensor([[ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676]])
        self.filter[49] = torch.Tensor([[ 0.0938, -0.2265,  0.2265, -0.0938, -0.0938,  0.2265, -0.2265,  0.0938],
        [ 0.0795, -0.1920,  0.1920, -0.0795, -0.0795,  0.1920, -0.1920,  0.0795],
        [ 0.0532, -0.1283,  0.1283, -0.0532, -0.0532,  0.1283, -0.1283,  0.0532],
        [ 0.0187, -0.0451,  0.0451, -0.0187, -0.0187,  0.0451, -0.0451,  0.0187],
        [-0.0187,  0.0451, -0.0451,  0.0187,  0.0187, -0.0451,  0.0451, -0.0187],
        [-0.0532,  0.1283, -0.1283,  0.0532,  0.0532, -0.1283,  0.1283, -0.0532],
        [-0.0795,  0.1920, -0.1920,  0.0795,  0.0795, -0.1920,  0.1920, -0.0795],
        [-0.0938,  0.2265, -0.2265,  0.0938,  0.0938, -0.2265,  0.2265, -0.0938]])
        self.filter[50] = torch.Tensor([[ 0.0884, -0.2134,  0.2134, -0.0884, -0.0884,  0.2134, -0.2134,  0.0884],
        [ 0.0366, -0.0884,  0.0884, -0.0366, -0.0366,  0.0884, -0.0884,  0.0366],
        [-0.0366,  0.0884, -0.0884,  0.0366,  0.0366, -0.0884,  0.0884, -0.0366],
        [-0.0884,  0.2134, -0.2134,  0.0884,  0.0884, -0.2134,  0.2134, -0.0884],
        [-0.0884,  0.2134, -0.2134,  0.0884,  0.0884, -0.2134,  0.2134, -0.0884],
        [-0.0366,  0.0884, -0.0884,  0.0366,  0.0366, -0.0884,  0.0884, -0.0366],
        [ 0.0366, -0.0884,  0.0884, -0.0366, -0.0366,  0.0884, -0.0884,  0.0366],
        [ 0.0884, -0.2134,  0.2134, -0.0884, -0.0884,  0.2134, -0.2134,  0.0884]])
        self.filter[51] = torch.Tensor([[ 0.0795, -0.1920,  0.1920, -0.0795, -0.0795,  0.1920, -0.1920,  0.0795],
        [-0.0187,  0.0451, -0.0451,  0.0187,  0.0187, -0.0451,  0.0451, -0.0187],
        [-0.0938,  0.2265, -0.2265,  0.0938,  0.0938, -0.2265,  0.2265, -0.0938],
        [-0.0532,  0.1283, -0.1283,  0.0532,  0.0532, -0.1283,  0.1283, -0.0532],
        [ 0.0532, -0.1283,  0.1283, -0.0532, -0.0532,  0.1283, -0.1283,  0.0532],
        [ 0.0938, -0.2265,  0.2265, -0.0938, -0.0938,  0.2265, -0.2265,  0.0938],
        [ 0.0187, -0.0451,  0.0451, -0.0187, -0.0187,  0.0451, -0.0451,  0.0187],
        [-0.0795,  0.1920, -0.1920,  0.0795,  0.0795, -0.1920,  0.1920, -0.0795]])
        self.filter[52] = torch.Tensor([[ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [-0.0676,  0.1633, -0.1633,  0.0676,  0.0676, -0.1633,  0.1633, -0.0676],
        [-0.0676,  0.1633, -0.1633,  0.0676,  0.0676, -0.1633,  0.1633, -0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676],
        [-0.0676,  0.1633, -0.1633,  0.0676,  0.0676, -0.1633,  0.1633, -0.0676],
        [-0.0676,  0.1633, -0.1633,  0.0676,  0.0676, -0.1633,  0.1633, -0.0676],
        [ 0.0676, -0.1633,  0.1633, -0.0676, -0.0676,  0.1633, -0.1633,  0.0676]])
        self.filter[53] = torch.Tensor([[ 0.0532, -0.1283,  0.1283, -0.0532, -0.0532,  0.1283, -0.1283,  0.0532],
        [-0.0938,  0.2265, -0.2265,  0.0938,  0.0938, -0.2265,  0.2265, -0.0938],
        [ 0.0187, -0.0451,  0.0451, -0.0187, -0.0187,  0.0451, -0.0451,  0.0187],
        [ 0.0795, -0.1920,  0.1920, -0.0795, -0.0795,  0.1920, -0.1920,  0.0795],
        [-0.0795,  0.1920, -0.1920,  0.0795,  0.0795, -0.1920,  0.1920, -0.0795],
        [-0.0187,  0.0451, -0.0451,  0.0187,  0.0187, -0.0451,  0.0451, -0.0187],
        [ 0.0938, -0.2265,  0.2265, -0.0938, -0.0938,  0.2265, -0.2265,  0.0938],
        [-0.0532,  0.1283, -0.1283,  0.0532,  0.0532, -0.1283,  0.1283, -0.0532]])
        self.filter[54] = torch.Tensor([[ 0.0366, -0.0884,  0.0884, -0.0366, -0.0366,  0.0884, -0.0884,  0.0366],
        [-0.0884,  0.2134, -0.2134,  0.0884,  0.0884, -0.2134,  0.2134, -0.0884],
        [ 0.0884, -0.2134,  0.2134, -0.0884, -0.0884,  0.2134, -0.2134,  0.0884],
        [-0.0366,  0.0884, -0.0884,  0.0366,  0.0366, -0.0884,  0.0884, -0.0366],
        [-0.0366,  0.0884, -0.0884,  0.0366,  0.0366, -0.0884,  0.0884, -0.0366],
        [ 0.0884, -0.2134,  0.2134, -0.0884, -0.0884,  0.2134, -0.2134,  0.0884],
        [-0.0884,  0.2134, -0.2134,  0.0884,  0.0884, -0.2134,  0.2134, -0.0884],
        [ 0.0366, -0.0884,  0.0884, -0.0366, -0.0366,  0.0884, -0.0884,  0.0366]])
        self.filter[55] = torch.Tensor([[ 0.0187, -0.0451,  0.0451, -0.0187, -0.0187,  0.0451, -0.0451,  0.0187],
        [-0.0532,  0.1283, -0.1283,  0.0532,  0.0532, -0.1283,  0.1283, -0.0532],
        [ 0.0795, -0.1920,  0.1920, -0.0795, -0.0795,  0.1920, -0.1920,  0.0795],
        [-0.0938,  0.2265, -0.2265,  0.0938,  0.0938, -0.2265,  0.2265, -0.0938],
        [ 0.0938, -0.2265,  0.2265, -0.0938, -0.0938,  0.2265, -0.2265,  0.0938],
        [-0.0795,  0.1920, -0.1920,  0.0795,  0.0795, -0.1920,  0.1920, -0.0795],
        [ 0.0532, -0.1283,  0.1283, -0.0532, -0.0532,  0.1283, -0.1283,  0.0532],
        [-0.0187,  0.0451, -0.0451,  0.0187,  0.0187, -0.0451,  0.0451, -0.0187]])
        self.filter[56] = torch.Tensor([[ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345]])
        self.filter[57] = torch.Tensor([[ 0.0478, -0.1362,  0.2039, -0.2405,  0.2405, -0.2039,  0.1362, -0.0478],
        [ 0.0406, -0.1155,  0.1728, -0.2039,  0.2039, -0.1728,  0.1155, -0.0406],
        [ 0.0271, -0.0772,  0.1155, -0.1362,  0.1362, -0.1155,  0.0772, -0.0271],
        [ 0.0095, -0.0271,  0.0406, -0.0478,  0.0478, -0.0406,  0.0271, -0.0095],
        [-0.0095,  0.0271, -0.0406,  0.0478, -0.0478,  0.0406, -0.0271,  0.0095],
        [-0.0271,  0.0772, -0.1155,  0.1362, -0.1362,  0.1155, -0.0772,  0.0271],
        [-0.0406,  0.1155, -0.1728,  0.2039, -0.2039,  0.1728, -0.1155,  0.0406],
        [-0.0478,  0.1362, -0.2039,  0.2405, -0.2405,  0.2039, -0.1362,  0.0478]])
        self.filter[58] = torch.Tensor([[ 0.0451, -0.1283,  0.1920, -0.2265,  0.2265, -0.1920,  0.1283, -0.0451],
        [ 0.0187, -0.0532,  0.0795, -0.0938,  0.0938, -0.0795,  0.0532, -0.0187],
        [-0.0187,  0.0532, -0.0795,  0.0938, -0.0938,  0.0795, -0.0532,  0.0187],
        [-0.0451,  0.1283, -0.1920,  0.2265, -0.2265,  0.1920, -0.1283,  0.0451],
        [-0.0451,  0.1283, -0.1920,  0.2265, -0.2265,  0.1920, -0.1283,  0.0451],
        [-0.0187,  0.0532, -0.0795,  0.0938, -0.0938,  0.0795, -0.0532,  0.0187],
        [ 0.0187, -0.0532,  0.0795, -0.0938,  0.0938, -0.0795,  0.0532, -0.0187],
        [ 0.0451, -0.1283,  0.1920, -0.2265,  0.2265, -0.1920,  0.1283, -0.0451]])
        self.filter[59] = torch.Tensor([[ 0.0406, -0.1155,  0.1728, -0.2039,  0.2039, -0.1728,  0.1155, -0.0406],
        [-0.0095,  0.0271, -0.0406,  0.0478, -0.0478,  0.0406, -0.0271,  0.0095],
        [-0.0478,  0.1362, -0.2039,  0.2405, -0.2405,  0.2039, -0.1362,  0.0478],
        [-0.0271,  0.0772, -0.1155,  0.1362, -0.1362,  0.1155, -0.0772,  0.0271],
        [ 0.0271, -0.0772,  0.1155, -0.1362,  0.1362, -0.1155,  0.0772, -0.0271],
        [ 0.0478, -0.1362,  0.2039, -0.2405,  0.2405, -0.2039,  0.1362, -0.0478],
        [ 0.0095, -0.0271,  0.0406, -0.0478,  0.0478, -0.0406,  0.0271, -0.0095],
        [-0.0406,  0.1155, -0.1728,  0.2039, -0.2039,  0.1728, -0.1155,  0.0406]])
        self.filter[60] = torch.Tensor([[ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [-0.0345,  0.0982, -0.1470,  0.1734, -0.1734,  0.1470, -0.0982,  0.0345],
        [-0.0345,  0.0982, -0.1470,  0.1734, -0.1734,  0.1470, -0.0982,  0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345],
        [-0.0345,  0.0982, -0.1470,  0.1734, -0.1734,  0.1470, -0.0982,  0.0345],
        [-0.0345,  0.0982, -0.1470,  0.1734, -0.1734,  0.1470, -0.0982,  0.0345],
        [ 0.0345, -0.0982,  0.1470, -0.1734,  0.1734, -0.1470,  0.0982, -0.0345]])
        self.filter[61] = torch.Tensor([[ 0.0271, -0.0772,  0.1155, -0.1362,  0.1362, -0.1155,  0.0772, -0.0271],
        [-0.0478,  0.1362, -0.2039,  0.2405, -0.2405,  0.2039, -0.1362,  0.0478],
        [ 0.0095, -0.0271,  0.0406, -0.0478,  0.0478, -0.0406,  0.0271, -0.0095],
        [ 0.0406, -0.1155,  0.1728, -0.2039,  0.2039, -0.1728,  0.1155, -0.0406],
        [-0.0406,  0.1155, -0.1728,  0.2039, -0.2039,  0.1728, -0.1155,  0.0406],
        [-0.0095,  0.0271, -0.0406,  0.0478, -0.0478,  0.0406, -0.0271,  0.0095],
        [ 0.0478, -0.1362,  0.2039, -0.2405,  0.2405, -0.2039,  0.1362, -0.0478],
        [-0.0271,  0.0772, -0.1155,  0.1362, -0.1362,  0.1155, -0.0772,  0.0271]])
        self.filter[62] = torch.Tensor([[ 0.0187, -0.0532,  0.0795, -0.0938,  0.0938, -0.0795,  0.0532, -0.0187],
        [-0.0451,  0.1283, -0.1920,  0.2265, -0.2265,  0.1920, -0.1283,  0.0451],
        [ 0.0451, -0.1283,  0.1920, -0.2265,  0.2265, -0.1920,  0.1283, -0.0451],
        [-0.0187,  0.0532, -0.0795,  0.0938, -0.0938,  0.0795, -0.0532,  0.0187],
        [-0.0187,  0.0532, -0.0795,  0.0938, -0.0938,  0.0795, -0.0532,  0.0187],
        [ 0.0451, -0.1283,  0.1920, -0.2265,  0.2265, -0.1920,  0.1283, -0.0451],
        [-0.0451,  0.1283, -0.1920,  0.2265, -0.2265,  0.1920, -0.1283,  0.0451],
        [ 0.0187, -0.0532,  0.0795, -0.0938,  0.0938, -0.0795,  0.0532, -0.0187]])
        self.filter[63] = torch.Tensor([[ 0.0095, -0.0271,  0.0406, -0.0478,  0.0478, -0.0406,  0.0271, -0.0095],
        [-0.0271,  0.0772, -0.1155,  0.1362, -0.1362,  0.1155, -0.0772,  0.0271],
        [ 0.0406, -0.1155,  0.1728, -0.2039,  0.2039, -0.1728,  0.1155, -0.0406],
        [-0.0478,  0.1362, -0.2039,  0.2405, -0.2405,  0.2039, -0.1362,  0.0478],
        [ 0.0478, -0.1362,  0.2039, -0.2405,  0.2405, -0.2039,  0.1362, -0.0478],
        [-0.0406,  0.1155, -0.1728,  0.2039, -0.2039,  0.1728, -0.1155,  0.0406],
        [ 0.0271, -0.0772,  0.1155, -0.1362,  0.1362, -0.1155,  0.0772, -0.0271],
        [-0.0095,  0.0271, -0.0406,  0.0478, -0.0478,  0.0406, -0.0271,  0.0095]])

        # self.filter = self.filter.view(8, 8, 8, 8)
    def get_filter(self, idx):

        return self.filter[idx]

class DCT7x7(nn.Module):
    def __init__(self):
        super(DCT7x7, self).__init__()
        self.filter = torch.zeros(49, 7, 7).cuda()
        self.freq_num = 49
        self.freq_range = 7

        self.filter[0] = torch.Tensor([[0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429],
        [0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429, 0.1429]])
        self.filter[1] = torch.Tensor([[ 1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,
          1.9697e-01,  1.9697e-01],
        [ 1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,
          1.5795e-01,  1.5795e-01],
        [ 8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,
          8.7658e-02,  8.7658e-02],
        [ 1.2371e-17,  1.2371e-17,  1.2371e-17,  1.2371e-17,  1.2371e-17,
          1.2371e-17,  1.2371e-17],
        [-8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02,
         -8.7658e-02, -8.7658e-02],
        [-1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01,
         -1.5795e-01, -1.5795e-01],
        [-1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01,
         -1.9697e-01, -1.9697e-01]])
        self.filter[2] = torch.Tensor([[ 0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820],
        [ 0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450],
        [-0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260],
        [-0.2020, -0.2020, -0.2020, -0.2020, -0.2020, -0.2020, -0.2020],
        [-0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260],
        [ 0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450],
        [ 0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820]])
        self.filter[3] = torch.Tensor([[ 1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,
          1.5795e-01,  1.5795e-01],
        [-8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02,
         -8.7658e-02, -8.7658e-02],
        [-1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01,
         -1.9697e-01, -1.9697e-01],
        [-3.7112e-17, -3.7112e-17, -3.7112e-17, -3.7112e-17, -3.7112e-17,
         -3.7112e-17, -3.7112e-17],
        [ 1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,
          1.9697e-01,  1.9697e-01],
        [ 8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,
          8.7658e-02,  8.7658e-02],
        [-1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01,
         -1.5795e-01, -1.5795e-01]])
        self.filter[4] = torch.Tensor([[ 0.1260,  0.1260,  0.1260,  0.1260,  0.1260,  0.1260,  0.1260],
        [-0.1820, -0.1820, -0.1820, -0.1820, -0.1820, -0.1820, -0.1820],
        [-0.0450, -0.0450, -0.0450, -0.0450, -0.0450, -0.0450, -0.0450],
        [ 0.2020,  0.2020,  0.2020,  0.2020,  0.2020,  0.2020,  0.2020],
        [-0.0450, -0.0450, -0.0450, -0.0450, -0.0450, -0.0450, -0.0450],
        [-0.1820, -0.1820, -0.1820, -0.1820, -0.1820, -0.1820, -0.1820],
        [ 0.1260,  0.1260,  0.1260,  0.1260,  0.1260,  0.1260,  0.1260]])
        self.filter[5] = torch.Tensor([[ 8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,  8.7658e-02,
          8.7658e-02,  8.7658e-02],
        [-1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01, -1.9697e-01,
         -1.9697e-01, -1.9697e-01],
        [ 1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,  1.5795e-01,
          1.5795e-01,  1.5795e-01],
        [ 6.1854e-17,  6.1854e-17,  6.1854e-17,  6.1854e-17,  6.1854e-17,
          6.1854e-17,  6.1854e-17],
        [-1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01, -1.5795e-01,
         -1.5795e-01, -1.5795e-01],
        [ 1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,  1.9697e-01,
          1.9697e-01,  1.9697e-01],
        [-8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02, -8.7658e-02,
         -8.7658e-02, -8.7658e-02]])
        self.filter[6] = torch.Tensor([[ 0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450],
        [-0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260],
        [ 0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820],
        [-0.2020, -0.2020, -0.2020, -0.2020, -0.2020, -0.2020, -0.2020],
        [ 0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820,  0.1820],
        [-0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260, -0.1260],
        [ 0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450,  0.0450]])
        self.filter[7] = torch.Tensor([[ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01],
        [ 1.9697e-01,  1.5795e-01,  8.7658e-02,  1.2371e-17, -8.7658e-02,
         -1.5795e-01, -1.9697e-01]])
        self.filter[8] = torch.Tensor([[ 2.7157e-01,  2.1778e-01,  1.2086e-01,  1.7056e-17, -1.2086e-01,
         -2.1778e-01, -2.7157e-01],
        [ 2.1778e-01,  1.7465e-01,  9.6921e-02,  1.3678e-17, -9.6921e-02,
         -1.7465e-01, -2.1778e-01],
        [ 1.2086e-01,  9.6921e-02,  5.3787e-02,  7.5908e-18, -5.3787e-02,
         -9.6921e-02, -1.2086e-01],
        [ 1.7056e-17,  1.3678e-17,  7.5908e-18,  1.0713e-33, -7.5908e-18,
         -1.3678e-17, -1.7056e-17],
        [-1.2086e-01, -9.6921e-02, -5.3787e-02, -7.5908e-18,  5.3787e-02,
          9.6921e-02,  1.2086e-01],
        [-2.1778e-01, -1.7465e-01, -9.6921e-02, -1.3678e-17,  9.6921e-02,
          1.7465e-01,  2.1778e-01],
        [-2.7157e-01, -2.1778e-01, -1.2086e-01, -1.7056e-17,  1.2086e-01,
          2.1778e-01,  2.7157e-01]])
        self.filter[9] = torch.Tensor([[ 2.5097e-01,  2.0126e-01,  1.1169e-01,  1.5762e-17, -1.1169e-01,
         -2.0126e-01, -2.5097e-01],
        [ 6.1983e-02,  4.9707e-02,  2.7585e-02,  3.8930e-18, -2.7585e-02,
         -4.9707e-02, -6.1983e-02],
        [-1.7367e-01, -1.3928e-01, -7.7292e-02, -1.0908e-17,  7.7292e-02,
          1.3928e-01,  1.7367e-01],
        [-2.7855e-01, -2.2338e-01, -1.2397e-01, -1.7495e-17,  1.2397e-01,
          2.2338e-01,  2.7855e-01],
        [-1.7367e-01, -1.3928e-01, -7.7292e-02, -1.0908e-17,  7.7292e-02,
          1.3928e-01,  1.7367e-01],
        [ 6.1983e-02,  4.9707e-02,  2.7585e-02,  3.8930e-18, -2.7585e-02,
         -4.9707e-02, -6.1983e-02],
        [ 2.5097e-01,  2.0126e-01,  1.1169e-01,  1.5762e-17, -1.1169e-01,
         -2.0126e-01, -2.5097e-01]])
        self.filter[10] = torch.Tensor([[ 2.1778e-01,  1.7465e-01,  9.6921e-02,  1.3678e-17, -9.6921e-02,
         -1.7465e-01, -2.1778e-01],
        [-1.2086e-01, -9.6921e-02, -5.3787e-02, -7.5908e-18,  5.3787e-02,
          9.6921e-02,  1.2086e-01],
        [-2.7157e-01, -2.1778e-01, -1.2086e-01, -1.7056e-17,  1.2086e-01,
          2.1778e-01,  2.7157e-01],
        [-5.1169e-17, -4.1034e-17, -2.2772e-17, -3.2138e-33,  2.2772e-17,
          4.1034e-17,  5.1169e-17],
        [ 2.7157e-01,  2.1778e-01,  1.2086e-01,  1.7056e-17, -1.2086e-01,
         -2.1778e-01, -2.7157e-01],
        [ 1.2086e-01,  9.6921e-02,  5.3787e-02,  7.5908e-18, -5.3787e-02,
         -9.6921e-02, -1.2086e-01],
        [-2.1778e-01, -1.7465e-01, -9.6921e-02, -1.3678e-17,  9.6921e-02,
          1.7465e-01,  2.1778e-01]])
        self.filter[11] = torch.Tensor([[ 1.7367e-01,  1.3928e-01,  7.7292e-02,  1.0908e-17, -7.7292e-02,
         -1.3928e-01, -1.7367e-01],
        [-2.5097e-01, -2.0126e-01, -1.1169e-01, -1.5762e-17,  1.1169e-01,
          2.0126e-01,  2.5097e-01],
        [-6.1983e-02, -4.9707e-02, -2.7585e-02, -3.8930e-18,  2.7585e-02,
          4.9707e-02,  6.1983e-02],
        [ 2.7855e-01,  2.2338e-01,  1.2397e-01,  1.7495e-17, -1.2397e-01,
         -2.2338e-01, -2.7855e-01],
        [-6.1983e-02, -4.9707e-02, -2.7585e-02, -3.8930e-18,  2.7585e-02,
          4.9707e-02,  6.1983e-02],
        [-2.5097e-01, -2.0126e-01, -1.1169e-01, -1.5762e-17,  1.1169e-01,
          2.0126e-01,  2.5097e-01],
        [ 1.7367e-01,  1.3928e-01,  7.7292e-02,  1.0908e-17, -7.7292e-02,
         -1.3928e-01, -1.7367e-01]])
        self.filter[12] = torch.Tensor([[ 1.2086e-01,  9.6921e-02,  5.3787e-02,  7.5908e-18, -5.3787e-02,
         -9.6921e-02, -1.2086e-01],
        [-2.7157e-01, -2.1778e-01, -1.2086e-01, -1.7056e-17,  1.2086e-01,
          2.1778e-01,  2.7157e-01],
        [ 2.1778e-01,  1.7465e-01,  9.6921e-02,  1.3678e-17, -9.6921e-02,
         -1.7465e-01, -2.1778e-01],
        [ 8.5282e-17,  6.8391e-17,  3.7954e-17,  5.3563e-33, -3.7954e-17,
         -6.8391e-17, -8.5282e-17],
        [-2.1778e-01, -1.7465e-01, -9.6921e-02, -1.3678e-17,  9.6921e-02,
          1.7465e-01,  2.1778e-01],
        [ 2.7157e-01,  2.1778e-01,  1.2086e-01,  1.7056e-17, -1.2086e-01,
         -2.1778e-01, -2.7157e-01],
        [-1.2086e-01, -9.6921e-02, -5.3787e-02, -7.5908e-18,  5.3787e-02,
          9.6921e-02,  1.2086e-01]])
        self.filter[13] = torch.Tensor([[ 6.1983e-02,  4.9707e-02,  2.7585e-02,  3.8930e-18, -2.7585e-02,
         -4.9707e-02, -6.1983e-02],
        [-1.7367e-01, -1.3928e-01, -7.7292e-02, -1.0908e-17,  7.7292e-02,
          1.3928e-01,  1.7367e-01],
        [ 2.5097e-01,  2.0126e-01,  1.1169e-01,  1.5762e-17, -1.1169e-01,
         -2.0126e-01, -2.5097e-01],
        [-2.7855e-01, -2.2338e-01, -1.2397e-01, -1.7495e-17,  1.2397e-01,
          2.2338e-01,  2.7855e-01],
        [ 2.5097e-01,  2.0126e-01,  1.1169e-01,  1.5762e-17, -1.1169e-01,
         -2.0126e-01, -2.5097e-01],
        [-1.7367e-01, -1.3928e-01, -7.7292e-02, -1.0908e-17,  7.7292e-02,
          1.3928e-01,  1.7367e-01],
        [ 6.1983e-02,  4.9707e-02,  2.7585e-02,  3.8930e-18, -2.7585e-02,
         -4.9707e-02, -6.1983e-02]])
        self.filter[14] = torch.Tensor([[ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820],
        [ 0.1820,  0.0450, -0.1260, -0.2020, -0.1260,  0.0450,  0.1820]])
        self.filter[15] = torch.Tensor([[ 2.5097e-01,  6.1983e-02, -1.7367e-01, -2.7855e-01, -1.7367e-01,
          6.1983e-02,  2.5097e-01],
        [ 2.0126e-01,  4.9707e-02, -1.3928e-01, -2.2338e-01, -1.3928e-01,
          4.9707e-02,  2.0126e-01],
        [ 1.1169e-01,  2.7585e-02, -7.7292e-02, -1.2397e-01, -7.7292e-02,
          2.7585e-02,  1.1169e-01],
        [ 1.5762e-17,  3.8930e-18, -1.0908e-17, -1.7495e-17, -1.0908e-17,
          3.8930e-18,  1.5762e-17],
        [-1.1169e-01, -2.7585e-02,  7.7292e-02,  1.2397e-01,  7.7292e-02,
         -2.7585e-02, -1.1169e-01],
        [-2.0126e-01, -4.9707e-02,  1.3928e-01,  2.2338e-01,  1.3928e-01,
         -4.9707e-02, -2.0126e-01],
        [-2.5097e-01, -6.1983e-02,  1.7367e-01,  2.7855e-01,  1.7367e-01,
         -6.1983e-02, -2.5097e-01]])
        self.filter[16] = torch.Tensor([[ 0.2319,  0.0573, -0.1605, -0.2574, -0.1605,  0.0573,  0.2319],
        [ 0.0573,  0.0141, -0.0396, -0.0636, -0.0396,  0.0141,  0.0573],
        [-0.1605, -0.0396,  0.1111,  0.1781,  0.1111, -0.0396, -0.1605],
        [-0.2574, -0.0636,  0.1781,  0.2857,  0.1781, -0.0636, -0.2574],
        [-0.1605, -0.0396,  0.1111,  0.1781,  0.1111, -0.0396, -0.1605],
        [ 0.0573,  0.0141, -0.0396, -0.0636, -0.0396,  0.0141,  0.0573],
        [ 0.2319,  0.0573, -0.1605, -0.2574, -0.1605,  0.0573,  0.2319]])
        self.filter[17] = torch.Tensor([[ 2.0126e-01,  4.9707e-02, -1.3928e-01, -2.2338e-01, -1.3928e-01,
          4.9707e-02,  2.0126e-01],
        [-1.1169e-01, -2.7585e-02,  7.7292e-02,  1.2397e-01,  7.7292e-02,
         -2.7585e-02, -1.1169e-01],
        [-2.5097e-01, -6.1983e-02,  1.7367e-01,  2.7855e-01,  1.7367e-01,
         -6.1983e-02, -2.5097e-01],
        [-4.7287e-17, -1.1679e-17,  3.2724e-17,  5.2485e-17,  3.2724e-17,
         -1.1679e-17, -4.7287e-17],
        [ 2.5097e-01,  6.1983e-02, -1.7367e-01, -2.7855e-01, -1.7367e-01,
          6.1983e-02,  2.5097e-01],
        [ 1.1169e-01,  2.7585e-02, -7.7292e-02, -1.2397e-01, -7.7292e-02,
          2.7585e-02,  1.1169e-01],
        [-2.0126e-01, -4.9707e-02,  1.3928e-01,  2.2338e-01,  1.3928e-01,
         -4.9707e-02, -2.0126e-01]])
        self.filter[18] = torch.Tensor([[ 0.1605,  0.0396, -0.1111, -0.1781, -0.1111,  0.0396,  0.1605],
        [-0.2319, -0.0573,  0.1605,  0.2574,  0.1605, -0.0573, -0.2319],
        [-0.0573, -0.0141,  0.0396,  0.0636,  0.0396, -0.0141, -0.0573],
        [ 0.2574,  0.0636, -0.1781, -0.2857, -0.1781,  0.0636,  0.2574],
        [-0.0573, -0.0141,  0.0396,  0.0636,  0.0396, -0.0141, -0.0573],
        [-0.2319, -0.0573,  0.1605,  0.2574,  0.1605, -0.0573, -0.2319],
        [ 0.1605,  0.0396, -0.1111, -0.1781, -0.1111,  0.0396,  0.1605]])
        self.filter[19] = torch.Tensor([[ 1.1169e-01,  2.7585e-02, -7.7292e-02, -1.2397e-01, -7.7292e-02,
          2.7585e-02,  1.1169e-01],
        [-2.5097e-01, -6.1983e-02,  1.7367e-01,  2.7855e-01,  1.7367e-01,
         -6.1983e-02, -2.5097e-01],
        [ 2.0126e-01,  4.9707e-02, -1.3928e-01, -2.2338e-01, -1.3928e-01,
          4.9707e-02,  2.0126e-01],
        [ 7.8812e-17,  1.9465e-17, -5.4540e-17, -8.7475e-17, -5.4540e-17,
          1.9465e-17,  7.8812e-17],
        [-2.0126e-01, -4.9707e-02,  1.3928e-01,  2.2338e-01,  1.3928e-01,
         -4.9707e-02, -2.0126e-01],
        [ 2.5097e-01,  6.1983e-02, -1.7367e-01, -2.7855e-01, -1.7367e-01,
          6.1983e-02,  2.5097e-01],
        [-1.1169e-01, -2.7585e-02,  7.7292e-02,  1.2397e-01,  7.7292e-02,
         -2.7585e-02, -1.1169e-01]])
        self.filter[20] = torch.Tensor([[ 0.0573,  0.0141, -0.0396, -0.0636, -0.0396,  0.0141,  0.0573],
        [-0.1605, -0.0396,  0.1111,  0.1781,  0.1111, -0.0396, -0.1605],
        [ 0.2319,  0.0573, -0.1605, -0.2574, -0.1605,  0.0573,  0.2319],
        [-0.2574, -0.0636,  0.1781,  0.2857,  0.1781, -0.0636, -0.2574],
        [ 0.2319,  0.0573, -0.1605, -0.2574, -0.1605,  0.0573,  0.2319],
        [-0.1605, -0.0396,  0.1111,  0.1781,  0.1111, -0.0396, -0.1605],
        [ 0.0573,  0.0141, -0.0396, -0.0636, -0.0396,  0.0141,  0.0573]])
        self.filter[21] = torch.Tensor([[ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01],
        [ 1.5795e-01, -8.7658e-02, -1.9697e-01, -3.7112e-17,  1.9697e-01,
          8.7658e-02, -1.5795e-01]])
        self.filter[22] = torch.Tensor([[ 2.1778e-01, -1.2086e-01, -2.7157e-01, -5.1169e-17,  2.7157e-01,
          1.2086e-01, -2.1778e-01],
        [ 1.7465e-01, -9.6921e-02, -2.1778e-01, -4.1034e-17,  2.1778e-01,
          9.6921e-02, -1.7465e-01],
        [ 9.6921e-02, -5.3787e-02, -1.2086e-01, -2.2772e-17,  1.2086e-01,
          5.3787e-02, -9.6921e-02],
        [ 1.3678e-17, -7.5908e-18, -1.7056e-17, -3.2138e-33,  1.7056e-17,
          7.5908e-18, -1.3678e-17],
        [-9.6921e-02,  5.3787e-02,  1.2086e-01,  2.2772e-17, -1.2086e-01,
         -5.3787e-02,  9.6921e-02],
        [-1.7465e-01,  9.6921e-02,  2.1778e-01,  4.1034e-17, -2.1778e-01,
         -9.6921e-02,  1.7465e-01],
        [-2.1778e-01,  1.2086e-01,  2.7157e-01,  5.1169e-17, -2.7157e-01,
         -1.2086e-01,  2.1778e-01]])
        self.filter[23] = torch.Tensor([[ 2.0126e-01, -1.1169e-01, -2.5097e-01, -4.7287e-17,  2.5097e-01,
          1.1169e-01, -2.0126e-01],
        [ 4.9707e-02, -2.7585e-02, -6.1983e-02, -1.1679e-17,  6.1983e-02,
          2.7585e-02, -4.9707e-02],
        [-1.3928e-01,  7.7292e-02,  1.7367e-01,  3.2724e-17, -1.7367e-01,
         -7.7292e-02,  1.3928e-01],
        [-2.2338e-01,  1.2397e-01,  2.7855e-01,  5.2485e-17, -2.7855e-01,
         -1.2397e-01,  2.2338e-01],
        [-1.3928e-01,  7.7292e-02,  1.7367e-01,  3.2724e-17, -1.7367e-01,
         -7.7292e-02,  1.3928e-01],
        [ 4.9707e-02, -2.7585e-02, -6.1983e-02, -1.1679e-17,  6.1983e-02,
          2.7585e-02, -4.9707e-02],
        [ 2.0126e-01, -1.1169e-01, -2.5097e-01, -4.7287e-17,  2.5097e-01,
          1.1169e-01, -2.0126e-01]])
        self.filter[24] = torch.Tensor([[ 1.7465e-01, -9.6921e-02, -2.1778e-01, -4.1034e-17,  2.1778e-01,
          9.6921e-02, -1.7465e-01],
        [-9.6921e-02,  5.3787e-02,  1.2086e-01,  2.2772e-17, -1.2086e-01,
         -5.3787e-02,  9.6921e-02],
        [-2.1778e-01,  1.2086e-01,  2.7157e-01,  5.1169e-17, -2.7157e-01,
         -1.2086e-01,  2.1778e-01],
        [-4.1034e-17,  2.2772e-17,  5.1169e-17,  9.6413e-33, -5.1169e-17,
         -2.2772e-17,  4.1034e-17],
        [ 2.1778e-01, -1.2086e-01, -2.7157e-01, -5.1169e-17,  2.7157e-01,
          1.2086e-01, -2.1778e-01],
        [ 9.6921e-02, -5.3787e-02, -1.2086e-01, -2.2772e-17,  1.2086e-01,
          5.3787e-02, -9.6921e-02],
        [-1.7465e-01,  9.6921e-02,  2.1778e-01,  4.1034e-17, -2.1778e-01,
         -9.6921e-02,  1.7465e-01]])
        self.filter[25] = torch.Tensor([[ 1.3928e-01, -7.7292e-02, -1.7367e-01, -3.2724e-17,  1.7367e-01,
          7.7292e-02, -1.3928e-01],
        [-2.0126e-01,  1.1169e-01,  2.5097e-01,  4.7287e-17, -2.5097e-01,
         -1.1169e-01,  2.0126e-01],
        [-4.9707e-02,  2.7585e-02,  6.1983e-02,  1.1679e-17, -6.1983e-02,
         -2.7585e-02,  4.9707e-02],
        [ 2.2338e-01, -1.2397e-01, -2.7855e-01, -5.2485e-17,  2.7855e-01,
          1.2397e-01, -2.2338e-01],
        [-4.9707e-02,  2.7585e-02,  6.1983e-02,  1.1679e-17, -6.1983e-02,
         -2.7585e-02,  4.9707e-02],
        [-2.0126e-01,  1.1169e-01,  2.5097e-01,  4.7287e-17, -2.5097e-01,
         -1.1169e-01,  2.0126e-01],
        [ 1.3928e-01, -7.7292e-02, -1.7367e-01, -3.2724e-17,  1.7367e-01,
          7.7292e-02, -1.3928e-01]])
        self.filter[26] = torch.Tensor([[ 9.6921e-02, -5.3787e-02, -1.2086e-01, -2.2772e-17,  1.2086e-01,
          5.3787e-02, -9.6921e-02],
        [-2.1778e-01,  1.2086e-01,  2.7157e-01,  5.1169e-17, -2.7157e-01,
         -1.2086e-01,  2.1778e-01],
        [ 1.7465e-01, -9.6921e-02, -2.1778e-01, -4.1034e-17,  2.1778e-01,
          9.6921e-02, -1.7465e-01],
        [ 6.8391e-17, -3.7954e-17, -8.5282e-17, -1.6069e-32,  8.5282e-17,
          3.7954e-17, -6.8391e-17],
        [-1.7465e-01,  9.6921e-02,  2.1778e-01,  4.1034e-17, -2.1778e-01,
         -9.6921e-02,  1.7465e-01],
        [ 2.1778e-01, -1.2086e-01, -2.7157e-01, -5.1169e-17,  2.7157e-01,
          1.2086e-01, -2.1778e-01],
        [-9.6921e-02,  5.3787e-02,  1.2086e-01,  2.2772e-17, -1.2086e-01,
         -5.3787e-02,  9.6921e-02]])
        self.filter[27] = torch.Tensor([[ 4.9707e-02, -2.7585e-02, -6.1983e-02, -1.1679e-17,  6.1983e-02,
          2.7585e-02, -4.9707e-02],
        [-1.3928e-01,  7.7292e-02,  1.7367e-01,  3.2724e-17, -1.7367e-01,
         -7.7292e-02,  1.3928e-01],
        [ 2.0126e-01, -1.1169e-01, -2.5097e-01, -4.7287e-17,  2.5097e-01,
          1.1169e-01, -2.0126e-01],
        [-2.2338e-01,  1.2397e-01,  2.7855e-01,  5.2485e-17, -2.7855e-01,
         -1.2397e-01,  2.2338e-01],
        [ 2.0126e-01, -1.1169e-01, -2.5097e-01, -4.7287e-17,  2.5097e-01,
          1.1169e-01, -2.0126e-01],
        [-1.3928e-01,  7.7292e-02,  1.7367e-01,  3.2724e-17, -1.7367e-01,
         -7.7292e-02,  1.3928e-01],
        [ 4.9707e-02, -2.7585e-02, -6.1983e-02, -1.1679e-17,  6.1983e-02,
          2.7585e-02, -4.9707e-02]])
        self.filter[28] = torch.Tensor([[ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260],
        [ 0.1260, -0.1820, -0.0450,  0.2020, -0.0450, -0.1820,  0.1260]])
        self.filter[29] = torch.Tensor([[ 1.7367e-01, -2.5097e-01, -6.1983e-02,  2.7855e-01, -6.1983e-02,
         -2.5097e-01,  1.7367e-01],
        [ 1.3928e-01, -2.0126e-01, -4.9707e-02,  2.2338e-01, -4.9707e-02,
         -2.0126e-01,  1.3928e-01],
        [ 7.7292e-02, -1.1169e-01, -2.7585e-02,  1.2397e-01, -2.7585e-02,
         -1.1169e-01,  7.7292e-02],
        [ 1.0908e-17, -1.5762e-17, -3.8930e-18,  1.7495e-17, -3.8930e-18,
         -1.5762e-17,  1.0908e-17],
        [-7.7292e-02,  1.1169e-01,  2.7585e-02, -1.2397e-01,  2.7585e-02,
          1.1169e-01, -7.7292e-02],
        [-1.3928e-01,  2.0126e-01,  4.9707e-02, -2.2338e-01,  4.9707e-02,
          2.0126e-01, -1.3928e-01],
        [-1.7367e-01,  2.5097e-01,  6.1983e-02, -2.7855e-01,  6.1983e-02,
          2.5097e-01, -1.7367e-01]])
        self.filter[30] = torch.Tensor([[ 0.1605, -0.2319, -0.0573,  0.2574, -0.0573, -0.2319,  0.1605],
        [ 0.0396, -0.0573, -0.0141,  0.0636, -0.0141, -0.0573,  0.0396],
        [-0.1111,  0.1605,  0.0396, -0.1781,  0.0396,  0.1605, -0.1111],
        [-0.1781,  0.2574,  0.0636, -0.2857,  0.0636,  0.2574, -0.1781],
        [-0.1111,  0.1605,  0.0396, -0.1781,  0.0396,  0.1605, -0.1111],
        [ 0.0396, -0.0573, -0.0141,  0.0636, -0.0141, -0.0573,  0.0396],
        [ 0.1605, -0.2319, -0.0573,  0.2574, -0.0573, -0.2319,  0.1605]])
        self.filter[31] = torch.Tensor([[ 1.3928e-01, -2.0126e-01, -4.9707e-02,  2.2338e-01, -4.9707e-02,
         -2.0126e-01,  1.3928e-01],
        [-7.7292e-02,  1.1169e-01,  2.7585e-02, -1.2397e-01,  2.7585e-02,
          1.1169e-01, -7.7292e-02],
        [-1.7367e-01,  2.5097e-01,  6.1983e-02, -2.7855e-01,  6.1983e-02,
          2.5097e-01, -1.7367e-01],
        [-3.2724e-17,  4.7287e-17,  1.1679e-17, -5.2485e-17,  1.1679e-17,
          4.7287e-17, -3.2724e-17],
        [ 1.7367e-01, -2.5097e-01, -6.1983e-02,  2.7855e-01, -6.1983e-02,
         -2.5097e-01,  1.7367e-01],
        [ 7.7292e-02, -1.1169e-01, -2.7585e-02,  1.2397e-01, -2.7585e-02,
         -1.1169e-01,  7.7292e-02],
        [-1.3928e-01,  2.0126e-01,  4.9707e-02, -2.2338e-01,  4.9707e-02,
          2.0126e-01, -1.3928e-01]])
        self.filter[32] = torch.Tensor([[ 0.1111, -0.1605, -0.0396,  0.1781, -0.0396, -0.1605,  0.1111],
        [-0.1605,  0.2319,  0.0573, -0.2574,  0.0573,  0.2319, -0.1605],
        [-0.0396,  0.0573,  0.0141, -0.0636,  0.0141,  0.0573, -0.0396],
        [ 0.1781, -0.2574, -0.0636,  0.2857, -0.0636, -0.2574,  0.1781],
        [-0.0396,  0.0573,  0.0141, -0.0636,  0.0141,  0.0573, -0.0396],
        [-0.1605,  0.2319,  0.0573, -0.2574,  0.0573,  0.2319, -0.1605],
        [ 0.1111, -0.1605, -0.0396,  0.1781, -0.0396, -0.1605,  0.1111]])
        self.filter[33] = torch.Tensor([[ 7.7292e-02, -1.1169e-01, -2.7585e-02,  1.2397e-01, -2.7585e-02,
         -1.1169e-01,  7.7292e-02],
        [-1.7367e-01,  2.5097e-01,  6.1983e-02, -2.7855e-01,  6.1983e-02,
          2.5097e-01, -1.7367e-01],
        [ 1.3928e-01, -2.0126e-01, -4.9707e-02,  2.2338e-01, -4.9707e-02,
         -2.0126e-01,  1.3928e-01],
        [ 5.4540e-17, -7.8812e-17, -1.9465e-17,  8.7475e-17, -1.9465e-17,
         -7.8812e-17,  5.4540e-17],
        [-1.3928e-01,  2.0126e-01,  4.9707e-02, -2.2338e-01,  4.9707e-02,
          2.0126e-01, -1.3928e-01],
        [ 1.7367e-01, -2.5097e-01, -6.1983e-02,  2.7855e-01, -6.1983e-02,
         -2.5097e-01,  1.7367e-01],
        [-7.7292e-02,  1.1169e-01,  2.7585e-02, -1.2397e-01,  2.7585e-02,
          1.1169e-01, -7.7292e-02]])
        self.filter[34] = torch.Tensor([[ 0.0396, -0.0573, -0.0141,  0.0636, -0.0141, -0.0573,  0.0396],
        [-0.1111,  0.1605,  0.0396, -0.1781,  0.0396,  0.1605, -0.1111],
        [ 0.1605, -0.2319, -0.0573,  0.2574, -0.0573, -0.2319,  0.1605],
        [-0.1781,  0.2574,  0.0636, -0.2857,  0.0636,  0.2574, -0.1781],
        [ 0.1605, -0.2319, -0.0573,  0.2574, -0.0573, -0.2319,  0.1605],
        [-0.1111,  0.1605,  0.0396, -0.1781,  0.0396,  0.1605, -0.1111],
        [ 0.0396, -0.0573, -0.0141,  0.0636, -0.0141, -0.0573,  0.0396]])
        self.filter[35] = torch.Tensor([[ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02],
        [ 8.7658e-02, -1.9697e-01,  1.5795e-01,  6.1854e-17, -1.5795e-01,
          1.9697e-01, -8.7658e-02]])
        self.filter[36] = torch.Tensor([[ 1.2086e-01, -2.7157e-01,  2.1778e-01,  8.5282e-17, -2.1778e-01,
          2.7157e-01, -1.2086e-01],
        [ 9.6921e-02, -2.1778e-01,  1.7465e-01,  6.8391e-17, -1.7465e-01,
          2.1778e-01, -9.6921e-02],
        [ 5.3787e-02, -1.2086e-01,  9.6921e-02,  3.7954e-17, -9.6921e-02,
          1.2086e-01, -5.3787e-02],
        [ 7.5908e-18, -1.7056e-17,  1.3678e-17,  5.3563e-33, -1.3678e-17,
          1.7056e-17, -7.5908e-18],
        [-5.3787e-02,  1.2086e-01, -9.6921e-02, -3.7954e-17,  9.6921e-02,
         -1.2086e-01,  5.3787e-02],
        [-9.6921e-02,  2.1778e-01, -1.7465e-01, -6.8391e-17,  1.7465e-01,
         -2.1778e-01,  9.6921e-02],
        [-1.2086e-01,  2.7157e-01, -2.1778e-01, -8.5282e-17,  2.1778e-01,
         -2.7157e-01,  1.2086e-01]])
        self.filter[37] = torch.Tensor([[ 1.1169e-01, -2.5097e-01,  2.0126e-01,  7.8812e-17, -2.0126e-01,
          2.5097e-01, -1.1169e-01],
        [ 2.7585e-02, -6.1983e-02,  4.9707e-02,  1.9465e-17, -4.9707e-02,
          6.1983e-02, -2.7585e-02],
        [-7.7292e-02,  1.7367e-01, -1.3928e-01, -5.4540e-17,  1.3928e-01,
         -1.7367e-01,  7.7292e-02],
        [-1.2397e-01,  2.7855e-01, -2.2338e-01, -8.7475e-17,  2.2338e-01,
         -2.7855e-01,  1.2397e-01],
        [-7.7292e-02,  1.7367e-01, -1.3928e-01, -5.4540e-17,  1.3928e-01,
         -1.7367e-01,  7.7292e-02],
        [ 2.7585e-02, -6.1983e-02,  4.9707e-02,  1.9465e-17, -4.9707e-02,
          6.1983e-02, -2.7585e-02],
        [ 1.1169e-01, -2.5097e-01,  2.0126e-01,  7.8812e-17, -2.0126e-01,
          2.5097e-01, -1.1169e-01]])
        self.filter[38] = torch.Tensor([[ 9.6921e-02, -2.1778e-01,  1.7465e-01,  6.8391e-17, -1.7465e-01,
          2.1778e-01, -9.6921e-02],
        [-5.3787e-02,  1.2086e-01, -9.6921e-02, -3.7954e-17,  9.6921e-02,
         -1.2086e-01,  5.3787e-02],
        [-1.2086e-01,  2.7157e-01, -2.1778e-01, -8.5282e-17,  2.1778e-01,
         -2.7157e-01,  1.2086e-01],
        [-2.2772e-17,  5.1169e-17, -4.1034e-17, -1.6069e-32,  4.1034e-17,
         -5.1169e-17,  2.2772e-17],
        [ 1.2086e-01, -2.7157e-01,  2.1778e-01,  8.5282e-17, -2.1778e-01,
          2.7157e-01, -1.2086e-01],
        [ 5.3787e-02, -1.2086e-01,  9.6921e-02,  3.7954e-17, -9.6921e-02,
          1.2086e-01, -5.3787e-02],
        [-9.6921e-02,  2.1778e-01, -1.7465e-01, -6.8391e-17,  1.7465e-01,
         -2.1778e-01,  9.6921e-02]])
        self.filter[39] = torch.Tensor([[ 7.7292e-02, -1.7367e-01,  1.3928e-01,  5.4540e-17, -1.3928e-01,
          1.7367e-01, -7.7292e-02],
        [-1.1169e-01,  2.5097e-01, -2.0126e-01, -7.8812e-17,  2.0126e-01,
         -2.5097e-01,  1.1169e-01],
        [-2.7585e-02,  6.1983e-02, -4.9707e-02, -1.9465e-17,  4.9707e-02,
         -6.1983e-02,  2.7585e-02],
        [ 1.2397e-01, -2.7855e-01,  2.2338e-01,  8.7475e-17, -2.2338e-01,
          2.7855e-01, -1.2397e-01],
        [-2.7585e-02,  6.1983e-02, -4.9707e-02, -1.9465e-17,  4.9707e-02,
         -6.1983e-02,  2.7585e-02],
        [-1.1169e-01,  2.5097e-01, -2.0126e-01, -7.8812e-17,  2.0126e-01,
         -2.5097e-01,  1.1169e-01],
        [ 7.7292e-02, -1.7367e-01,  1.3928e-01,  5.4540e-17, -1.3928e-01,
          1.7367e-01, -7.7292e-02]])
        self.filter[40] = torch.Tensor([[ 5.3787e-02, -1.2086e-01,  9.6921e-02,  3.7954e-17, -9.6921e-02,
          1.2086e-01, -5.3787e-02],
        [-1.2086e-01,  2.7157e-01, -2.1778e-01, -8.5282e-17,  2.1778e-01,
         -2.7157e-01,  1.2086e-01],
        [ 9.6921e-02, -2.1778e-01,  1.7465e-01,  6.8391e-17, -1.7465e-01,
          2.1778e-01, -9.6921e-02],
        [ 3.7954e-17, -8.5282e-17,  6.8391e-17,  2.6781e-32, -6.8391e-17,
          8.5282e-17, -3.7954e-17],
        [-9.6921e-02,  2.1778e-01, -1.7465e-01, -6.8391e-17,  1.7465e-01,
         -2.1778e-01,  9.6921e-02],
        [ 1.2086e-01, -2.7157e-01,  2.1778e-01,  8.5282e-17, -2.1778e-01,
          2.7157e-01, -1.2086e-01],
        [-5.3787e-02,  1.2086e-01, -9.6921e-02, -3.7954e-17,  9.6921e-02,
         -1.2086e-01,  5.3787e-02]])
        self.filter[41] = torch.Tensor([[ 2.7585e-02, -6.1983e-02,  4.9707e-02,  1.9465e-17, -4.9707e-02,
          6.1983e-02, -2.7585e-02],
        [-7.7292e-02,  1.7367e-01, -1.3928e-01, -5.4540e-17,  1.3928e-01,
         -1.7367e-01,  7.7292e-02],
        [ 1.1169e-01, -2.5097e-01,  2.0126e-01,  7.8812e-17, -2.0126e-01,
          2.5097e-01, -1.1169e-01],
        [-1.2397e-01,  2.7855e-01, -2.2338e-01, -8.7475e-17,  2.2338e-01,
         -2.7855e-01,  1.2397e-01],
        [ 1.1169e-01, -2.5097e-01,  2.0126e-01,  7.8812e-17, -2.0126e-01,
          2.5097e-01, -1.1169e-01],
        [-7.7292e-02,  1.7367e-01, -1.3928e-01, -5.4540e-17,  1.3928e-01,
         -1.7367e-01,  7.7292e-02],
        [ 2.7585e-02, -6.1983e-02,  4.9707e-02,  1.9465e-17, -4.9707e-02,
          6.1983e-02, -2.7585e-02]])
        self.filter[42] = torch.Tensor([[ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450],
        [ 0.0450, -0.1260,  0.1820, -0.2020,  0.1820, -0.1260,  0.0450]])
        self.filter[43] = torch.Tensor([[ 6.1983e-02, -1.7367e-01,  2.5097e-01, -2.7855e-01,  2.5097e-01,
         -1.7367e-01,  6.1983e-02],
        [ 4.9707e-02, -1.3928e-01,  2.0126e-01, -2.2338e-01,  2.0126e-01,
         -1.3928e-01,  4.9707e-02],
        [ 2.7585e-02, -7.7292e-02,  1.1169e-01, -1.2397e-01,  1.1169e-01,
         -7.7292e-02,  2.7585e-02],
        [ 3.8930e-18, -1.0908e-17,  1.5762e-17, -1.7495e-17,  1.5762e-17,
         -1.0908e-17,  3.8930e-18],
        [-2.7585e-02,  7.7292e-02, -1.1169e-01,  1.2397e-01, -1.1169e-01,
          7.7292e-02, -2.7585e-02],
        [-4.9707e-02,  1.3928e-01, -2.0126e-01,  2.2338e-01, -2.0126e-01,
          1.3928e-01, -4.9707e-02],
        [-6.1983e-02,  1.7367e-01, -2.5097e-01,  2.7855e-01, -2.5097e-01,
          1.7367e-01, -6.1983e-02]])
        self.filter[44] = torch.Tensor([[ 0.0573, -0.1605,  0.2319, -0.2574,  0.2319, -0.1605,  0.0573],
        [ 0.0141, -0.0396,  0.0573, -0.0636,  0.0573, -0.0396,  0.0141],
        [-0.0396,  0.1111, -0.1605,  0.1781, -0.1605,  0.1111, -0.0396],
        [-0.0636,  0.1781, -0.2574,  0.2857, -0.2574,  0.1781, -0.0636],
        [-0.0396,  0.1111, -0.1605,  0.1781, -0.1605,  0.1111, -0.0396],
        [ 0.0141, -0.0396,  0.0573, -0.0636,  0.0573, -0.0396,  0.0141],
        [ 0.0573, -0.1605,  0.2319, -0.2574,  0.2319, -0.1605,  0.0573]])
        self.filter[45] = torch.Tensor([[ 4.9707e-02, -1.3928e-01,  2.0126e-01, -2.2338e-01,  2.0126e-01,
         -1.3928e-01,  4.9707e-02],
        [-2.7585e-02,  7.7292e-02, -1.1169e-01,  1.2397e-01, -1.1169e-01,
          7.7292e-02, -2.7585e-02],
        [-6.1983e-02,  1.7367e-01, -2.5097e-01,  2.7855e-01, -2.5097e-01,
          1.7367e-01, -6.1983e-02],
        [-1.1679e-17,  3.2724e-17, -4.7287e-17,  5.2485e-17, -4.7287e-17,
          3.2724e-17, -1.1679e-17],
        [ 6.1983e-02, -1.7367e-01,  2.5097e-01, -2.7855e-01,  2.5097e-01,
         -1.7367e-01,  6.1983e-02],
        [ 2.7585e-02, -7.7292e-02,  1.1169e-01, -1.2397e-01,  1.1169e-01,
         -7.7292e-02,  2.7585e-02],
        [-4.9707e-02,  1.3928e-01, -2.0126e-01,  2.2338e-01, -2.0126e-01,
          1.3928e-01, -4.9707e-02]])
        self.filter[46] = torch.Tensor([[ 0.0396, -0.1111,  0.1605, -0.1781,  0.1605, -0.1111,  0.0396],
        [-0.0573,  0.1605, -0.2319,  0.2574, -0.2319,  0.1605, -0.0573],
        [-0.0141,  0.0396, -0.0573,  0.0636, -0.0573,  0.0396, -0.0141],
        [ 0.0636, -0.1781,  0.2574, -0.2857,  0.2574, -0.1781,  0.0636],
        [-0.0141,  0.0396, -0.0573,  0.0636, -0.0573,  0.0396, -0.0141],
        [-0.0573,  0.1605, -0.2319,  0.2574, -0.2319,  0.1605, -0.0573],
        [ 0.0396, -0.1111,  0.1605, -0.1781,  0.1605, -0.1111,  0.0396]])
        self.filter[47] = torch.Tensor([[ 2.7585e-02, -7.7292e-02,  1.1169e-01, -1.2397e-01,  1.1169e-01,
         -7.7292e-02,  2.7585e-02],
        [-6.1983e-02,  1.7367e-01, -2.5097e-01,  2.7855e-01, -2.5097e-01,
          1.7367e-01, -6.1983e-02],
        [ 4.9707e-02, -1.3928e-01,  2.0126e-01, -2.2338e-01,  2.0126e-01,
         -1.3928e-01,  4.9707e-02],
        [ 1.9465e-17, -5.4540e-17,  7.8812e-17, -8.7475e-17,  7.8812e-17,
         -5.4540e-17,  1.9465e-17],
        [-4.9707e-02,  1.3928e-01, -2.0126e-01,  2.2338e-01, -2.0126e-01,
          1.3928e-01, -4.9707e-02],
        [ 6.1983e-02, -1.7367e-01,  2.5097e-01, -2.7855e-01,  2.5097e-01,
         -1.7367e-01,  6.1983e-02],
        [-2.7585e-02,  7.7292e-02, -1.1169e-01,  1.2397e-01, -1.1169e-01,
          7.7292e-02, -2.7585e-02]])
        self.filter[48] = torch.Tensor([[ 0.0141, -0.0396,  0.0573, -0.0636,  0.0573, -0.0396,  0.0141],
        [-0.0396,  0.1111, -0.1605,  0.1781, -0.1605,  0.1111, -0.0396],
        [ 0.0573, -0.1605,  0.2319, -0.2574,  0.2319, -0.1605,  0.0573],
        [-0.0636,  0.1781, -0.2574,  0.2857, -0.2574,  0.1781, -0.0636],
        [ 0.0573, -0.1605,  0.2319, -0.2574,  0.2319, -0.1605,  0.0573],
        [-0.0396,  0.1111, -0.1605,  0.1781, -0.1605,  0.1111, -0.0396],
        [ 0.0141, -0.0396,  0.0573, -0.0636,  0.0573, -0.0396,  0.0141]])

        # self.important = torch.Tensor([92.08, 92.41, 92.54, 92.46, 92.63, 92.44, 92.42,
        #                                92.44, 92.43, 92.76, 92.56, 92.74, 92.47, 92.42,
        #                                92.55, 92.80, 92.72, 92.69, 92.52, 92.41, 92.46,
        #                                92.51, 92.61, 92.60, 92.46, 92.42, 92.69, 92.61,
        #                                92.52, 92.53, 92.69, 92.75, 92.74, 92.67, 92.89,
        #                                92.44, 92.69, 92.48, 92.55, 92.81, 92.61, 92.53,
        #                                92.50, 92.53, 92.70, 92.28, 92.56, 92.62, 92.55])
        
        self.important = torch.Tensor([70.25, 70.05, 70.25, 70.68, 70.24, 70.06, 70.03,
                                       70.43, 70.18, 69.43, 70.18, 69.91, 70.27, 70.35,
                                       70.03, 69.97, 70.07, 70.43, 70.26, 70.30, 70.31,
                                       70.42, 70.03, 70.46, 70.39, 70.19, 70.23, 70.24,
                                       69.92, 70.17, 70.02, 69.90, 69.90, 70.50, 70.62,
                                       70.27, 70.21, 70.30, 70.22, 70.65, 70.62, 70.37,
                                       69.83, 70.10, 70.30, 70.07, 70.32, 70.23, 70.02])
    def get_filter(self, idx):
        if isinstance(idx, int):
            return self.filter[idx]
        else:
            idx = idx.to(self.filter.device)
            out = self.filter.index_select(dim=0, index=idx)
            return out

    def get_topk(self, topk):
        _, ids = torch.topk(self.important, topk)

        return ids
    

class DCT3x3(nn.Module):
    def __init__(self):
        super(DCT3x3, self).__init__()
        self.filter = torch.zeros(9, 3, 3).cuda()
        self.freq_num = 9
        self.freq_range = 3

        self.filter[0] = torch.Tensor([[0.3333, 0.3333, 0.3333],
        [0.3333, 0.3333, 0.3333],
        [0.3333, 0.3333, 0.3333]])
        self.filter[1] = torch.Tensor([[ 4.0825e-01,  4.0825e-01,  4.0825e-01],
        [ 2.8865e-17,  2.8865e-17,  2.8865e-17],
        [-4.0825e-01, -4.0825e-01, -4.0825e-01]])
        self.filter[2] = torch.Tensor([[ 0.2357,  0.2357,  0.2357],
        [-0.4714, -0.4714, -0.4714],
        [ 0.2357,  0.2357,  0.2357]])
        self.filter[3] = torch.Tensor([[ 4.0825e-01,  2.8865e-17, -4.0825e-01],
        [ 4.0825e-01,  2.8865e-17, -4.0825e-01],
        [ 4.0825e-01,  2.8865e-17, -4.0825e-01]])
        self.filter[4] = torch.Tensor([[ 5.0000e-01,  3.5353e-17, -5.0000e-01],
        [ 3.5353e-17,  2.4996e-33, -3.5353e-17],
        [-5.0000e-01, -3.5353e-17,  5.0000e-01]])
        self.filter[5] = torch.Tensor([[ 2.8868e-01,  2.0411e-17, -2.8868e-01],
        [-5.7735e-01, -4.0822e-17,  5.7735e-01],
        [ 2.8868e-01,  2.0411e-17, -2.8868e-01]])
        self.filter[6] = torch.Tensor([[ 0.2357, -0.4714,  0.2357],
        [ 0.2357, -0.4714,  0.2357],
        [ 0.2357, -0.4714,  0.2357]])
        self.filter[7] = torch.Tensor([[ 2.8868e-01, -5.7735e-01,  2.8868e-01],
        [ 2.0411e-17, -4.0822e-17,  2.0411e-17],
        [-2.8868e-01,  5.7735e-01, -2.8868e-01]])
        self.filter[8] = torch.Tensor([[ 0.1667, -0.3333,  0.1667],
        [-0.3333,  0.6667, -0.3333],
        [ 0.1667, -0.3333,  0.1667]])
        
        self.important = None

    def get_filter(self, idx):
        if isinstance(idx, int):
            return self.filter[idx]
        else:
            return torch.index_select(self.filter, 0, idx) 

    def get_topk(self, topk):
        _, ids = torch.topk(self.important, topk) 

        return ids
    

class NoScaleDCT7x7(nn.Module):
    def __init__(self):
        super(NoScaleDCT7x7, self).__init__()
        self.filter = torch.zeros(49, 7, 7).cuda()
        self.freq_num = 49
        self.freq_range = 7

        self.filter[0] = torch.Tensor([[1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.],
        [1., 1., 1., 1., 1., 1., 1.]])
        self.filter[1] = torch.Tensor([[ 9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,
          9.7493e-01,  9.7493e-01],
        [ 7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,
          7.8183e-01,  7.8183e-01],
        [ 4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,
          4.3388e-01,  4.3388e-01],
        [ 6.1232e-17,  6.1232e-17,  6.1232e-17,  6.1232e-17,  6.1232e-17,
          6.1232e-17,  6.1232e-17],
        [-4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01,
         -4.3388e-01, -4.3388e-01],
        [-7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01,
         -7.8183e-01, -7.8183e-01],
        [-9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01,
         -9.7493e-01, -9.7493e-01]])
        self.filter[2] = torch.Tensor([[ 0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010],
        [ 0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225],
        [-0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235],
        [-1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000],
        [-0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235],
        [ 0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225],
        [ 0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010]])
        self.filter[3] = torch.Tensor([[ 7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,
          7.8183e-01,  7.8183e-01],
        [-4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01,
         -4.3388e-01, -4.3388e-01],
        [-9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01,
         -9.7493e-01, -9.7493e-01],
        [-1.8370e-16, -1.8370e-16, -1.8370e-16, -1.8370e-16, -1.8370e-16,
         -1.8370e-16, -1.8370e-16],
        [ 9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,
          9.7493e-01,  9.7493e-01],
        [ 4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,
          4.3388e-01,  4.3388e-01],
        [-7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01,
         -7.8183e-01, -7.8183e-01]])
        self.filter[4] = torch.Tensor([[ 0.6235,  0.6235,  0.6235,  0.6235,  0.6235,  0.6235,  0.6235],
        [-0.9010, -0.9010, -0.9010, -0.9010, -0.9010, -0.9010, -0.9010],
        [-0.2225, -0.2225, -0.2225, -0.2225, -0.2225, -0.2225, -0.2225],
        [ 1.0000,  1.0000,  1.0000,  1.0000,  1.0000,  1.0000,  1.0000],
        [-0.2225, -0.2225, -0.2225, -0.2225, -0.2225, -0.2225, -0.2225],
        [-0.9010, -0.9010, -0.9010, -0.9010, -0.9010, -0.9010, -0.9010],
        [ 0.6235,  0.6235,  0.6235,  0.6235,  0.6235,  0.6235,  0.6235]])
        self.filter[5] = torch.Tensor([[ 4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,  4.3388e-01,
          4.3388e-01,  4.3388e-01],
        [-9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01, -9.7493e-01,
         -9.7493e-01, -9.7493e-01],
        [ 7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,  7.8183e-01,
          7.8183e-01,  7.8183e-01],
        [ 3.0616e-16,  3.0616e-16,  3.0616e-16,  3.0616e-16,  3.0616e-16,
          3.0616e-16,  3.0616e-16],
        [-7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01, -7.8183e-01,
         -7.8183e-01, -7.8183e-01],
        [ 9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,  9.7493e-01,
          9.7493e-01,  9.7493e-01],
        [-4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01, -4.3388e-01,
         -4.3388e-01, -4.3388e-01]])
        self.filter[6] = torch.Tensor([[ 0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225],
        [-0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235],
        [ 0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010],
        [-1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000],
        [ 0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010,  0.9010],
        [-0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235, -0.6235],
        [ 0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225,  0.2225]])
        self.filter[7] = torch.Tensor([[ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01]])
        self.filter[8] = torch.Tensor([[ 9.5048e-01,  7.6223e-01,  4.2301e-01,  5.9697e-17, -4.2301e-01,
         -7.6223e-01, -9.5048e-01],
        [ 7.6223e-01,  6.1126e-01,  3.3922e-01,  4.7873e-17, -3.3922e-01,
         -6.1126e-01, -7.6223e-01],
        [ 4.2301e-01,  3.3922e-01,  1.8826e-01,  2.6568e-17, -1.8826e-01,
         -3.3922e-01, -4.2301e-01],
        [ 5.9697e-17,  4.7873e-17,  2.6568e-17,  3.7494e-33, -2.6568e-17,
         -4.7873e-17, -5.9697e-17],
        [-4.2301e-01, -3.3922e-01, -1.8826e-01, -2.6568e-17,  1.8826e-01,
          3.3922e-01,  4.2301e-01],
        [-7.6223e-01, -6.1126e-01, -3.3922e-01, -4.7873e-17,  3.3922e-01,
          6.1126e-01,  7.6223e-01],
        [-9.5048e-01, -7.6223e-01, -4.2301e-01, -5.9697e-17,  4.2301e-01,
          7.6223e-01,  9.5048e-01]])
        self.filter[9] = torch.Tensor([[ 8.7838e-01,  7.0441e-01,  3.9092e-01,  5.5168e-17, -3.9092e-01,
         -7.0441e-01, -8.7838e-01],
        [ 2.1694e-01,  1.7397e-01,  9.6548e-02,  1.3625e-17, -9.6548e-02,
         -1.7397e-01, -2.1694e-01],
        [-6.0786e-01, -4.8746e-01, -2.7052e-01, -3.8178e-17,  2.7052e-01,
          4.8746e-01,  6.0786e-01],
        [-9.7493e-01, -7.8183e-01, -4.3388e-01, -6.1232e-17,  4.3388e-01,
          7.8183e-01,  9.7493e-01],
        [-6.0786e-01, -4.8746e-01, -2.7052e-01, -3.8178e-17,  2.7052e-01,
          4.8746e-01,  6.0786e-01],
        [ 2.1694e-01,  1.7397e-01,  9.6548e-02,  1.3625e-17, -9.6548e-02,
         -1.7397e-01, -2.1694e-01],
        [ 8.7838e-01,  7.0441e-01,  3.9092e-01,  5.5168e-17, -3.9092e-01,
         -7.0441e-01, -8.7838e-01]])
        self.filter[10] = torch.Tensor([[ 7.6223e-01,  6.1126e-01,  3.3922e-01,  4.7873e-17, -3.3922e-01,
         -6.1126e-01, -7.6223e-01],
        [-4.2301e-01, -3.3922e-01, -1.8826e-01, -2.6568e-17,  1.8826e-01,
          3.3922e-01,  4.2301e-01],
        [-9.5048e-01, -7.6223e-01, -4.2301e-01, -5.9697e-17,  4.2301e-01,
          7.6223e-01,  9.5048e-01],
        [-1.7909e-16, -1.4362e-16, -7.9703e-17, -1.1248e-32,  7.9703e-17,
          1.4362e-16,  1.7909e-16],
        [ 9.5048e-01,  7.6223e-01,  4.2301e-01,  5.9697e-17, -4.2301e-01,
         -7.6223e-01, -9.5048e-01],
        [ 4.2301e-01,  3.3922e-01,  1.8826e-01,  2.6568e-17, -1.8826e-01,
         -3.3922e-01, -4.2301e-01],
        [-7.6223e-01, -6.1126e-01, -3.3922e-01, -4.7873e-17,  3.3922e-01,
          6.1126e-01,  7.6223e-01]])
        self.filter[11] = torch.Tensor([[ 6.0786e-01,  4.8746e-01,  2.7052e-01,  3.8178e-17, -2.7052e-01,
         -4.8746e-01, -6.0786e-01],
        [-8.7838e-01, -7.0441e-01, -3.9092e-01, -5.5168e-17,  3.9092e-01,
          7.0441e-01,  8.7838e-01],
        [-2.1694e-01, -1.7397e-01, -9.6548e-02, -1.3625e-17,  9.6548e-02,
          1.7397e-01,  2.1694e-01],
        [ 9.7493e-01,  7.8183e-01,  4.3388e-01,  6.1232e-17, -4.3388e-01,
         -7.8183e-01, -9.7493e-01],
        [-2.1694e-01, -1.7397e-01, -9.6548e-02, -1.3625e-17,  9.6548e-02,
          1.7397e-01,  2.1694e-01],
        [-8.7838e-01, -7.0441e-01, -3.9092e-01, -5.5168e-17,  3.9092e-01,
          7.0441e-01,  8.7838e-01],
        [ 6.0786e-01,  4.8746e-01,  2.7052e-01,  3.8178e-17, -2.7052e-01,
         -4.8746e-01, -6.0786e-01]])
        self.filter[12] = torch.Tensor([[ 4.2301e-01,  3.3922e-01,  1.8826e-01,  2.6568e-17, -1.8826e-01,
         -3.3922e-01, -4.2301e-01],
        [-9.5048e-01, -7.6223e-01, -4.2301e-01, -5.9697e-17,  4.2301e-01,
          7.6223e-01,  9.5048e-01],
        [ 7.6223e-01,  6.1126e-01,  3.3922e-01,  4.7873e-17, -3.3922e-01,
         -6.1126e-01, -7.6223e-01],
        [ 2.9849e-16,  2.3937e-16,  1.3284e-16,  1.8747e-32, -1.3284e-16,
         -2.3937e-16, -2.9849e-16],
        [-7.6223e-01, -6.1126e-01, -3.3922e-01, -4.7873e-17,  3.3922e-01,
          6.1126e-01,  7.6223e-01],
        [ 9.5048e-01,  7.6223e-01,  4.2301e-01,  5.9697e-17, -4.2301e-01,
         -7.6223e-01, -9.5048e-01],
        [-4.2301e-01, -3.3922e-01, -1.8826e-01, -2.6568e-17,  1.8826e-01,
          3.3922e-01,  4.2301e-01]])
        self.filter[13] = torch.Tensor([[ 2.1694e-01,  1.7397e-01,  9.6548e-02,  1.3625e-17, -9.6548e-02,
         -1.7397e-01, -2.1694e-01],
        [-6.0786e-01, -4.8746e-01, -2.7052e-01, -3.8178e-17,  2.7052e-01,
          4.8746e-01,  6.0786e-01],
        [ 8.7838e-01,  7.0441e-01,  3.9092e-01,  5.5168e-17, -3.9092e-01,
         -7.0441e-01, -8.7838e-01],
        [-9.7493e-01, -7.8183e-01, -4.3388e-01, -6.1232e-17,  4.3388e-01,
          7.8183e-01,  9.7493e-01],
        [ 8.7838e-01,  7.0441e-01,  3.9092e-01,  5.5168e-17, -3.9092e-01,
         -7.0441e-01, -8.7838e-01],
        [-6.0786e-01, -4.8746e-01, -2.7052e-01, -3.8178e-17,  2.7052e-01,
          4.8746e-01,  6.0786e-01],
        [ 2.1694e-01,  1.7397e-01,  9.6548e-02,  1.3625e-17, -9.6548e-02,
         -1.7397e-01, -2.1694e-01]])
        self.filter[14] = torch.Tensor([[ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010]])
        self.filter[15] = torch.Tensor([[ 8.7838e-01,  2.1694e-01, -6.0786e-01, -9.7493e-01, -6.0786e-01,
          2.1694e-01,  8.7838e-01],
        [ 7.0441e-01,  1.7397e-01, -4.8746e-01, -7.8183e-01, -4.8746e-01,
          1.7397e-01,  7.0441e-01],
        [ 3.9092e-01,  9.6548e-02, -2.7052e-01, -4.3388e-01, -2.7052e-01,
          9.6548e-02,  3.9092e-01],
        [ 5.5168e-17,  1.3625e-17, -3.8178e-17, -6.1232e-17, -3.8178e-17,
          1.3625e-17,  5.5168e-17],
        [-3.9092e-01, -9.6548e-02,  2.7052e-01,  4.3388e-01,  2.7052e-01,
         -9.6548e-02, -3.9092e-01],
        [-7.0441e-01, -1.7397e-01,  4.8746e-01,  7.8183e-01,  4.8746e-01,
         -1.7397e-01, -7.0441e-01],
        [-8.7838e-01, -2.1694e-01,  6.0786e-01,  9.7493e-01,  6.0786e-01,
         -2.1694e-01, -8.7838e-01]])
        self.filter[16] = torch.Tensor([[ 0.8117,  0.2005, -0.5617, -0.9010, -0.5617,  0.2005,  0.8117],
        [ 0.2005,  0.0495, -0.1387, -0.2225, -0.1387,  0.0495,  0.2005],
        [-0.5617, -0.1387,  0.3887,  0.6235,  0.3887, -0.1387, -0.5617],
        [-0.9010, -0.2225,  0.6235,  1.0000,  0.6235, -0.2225, -0.9010],
        [-0.5617, -0.1387,  0.3887,  0.6235,  0.3887, -0.1387, -0.5617],
        [ 0.2005,  0.0495, -0.1387, -0.2225, -0.1387,  0.0495,  0.2005],
        [ 0.8117,  0.2005, -0.5617, -0.9010, -0.5617,  0.2005,  0.8117]])
        self.filter[17] = torch.Tensor([[ 7.0441e-01,  1.7397e-01, -4.8746e-01, -7.8183e-01, -4.8746e-01,
          1.7397e-01,  7.0441e-01],
        [-3.9092e-01, -9.6548e-02,  2.7052e-01,  4.3388e-01,  2.7052e-01,
         -9.6548e-02, -3.9092e-01],
        [-8.7838e-01, -2.1694e-01,  6.0786e-01,  9.7493e-01,  6.0786e-01,
         -2.1694e-01, -8.7838e-01],
        [-1.6551e-16, -4.0876e-17,  1.1453e-16,  1.8370e-16,  1.1453e-16,
         -4.0876e-17, -1.6551e-16],
        [ 8.7838e-01,  2.1694e-01, -6.0786e-01, -9.7493e-01, -6.0786e-01,
          2.1694e-01,  8.7838e-01],
        [ 3.9092e-01,  9.6548e-02, -2.7052e-01, -4.3388e-01, -2.7052e-01,
          9.6548e-02,  3.9092e-01],
        [-7.0441e-01, -1.7397e-01,  4.8746e-01,  7.8183e-01,  4.8746e-01,
         -1.7397e-01, -7.0441e-01]])
        self.filter[18] = torch.Tensor([[ 0.5617,  0.1387, -0.3887, -0.6235, -0.3887,  0.1387,  0.5617],
        [-0.8117, -0.2005,  0.5617,  0.9010,  0.5617, -0.2005, -0.8117],
        [-0.2005, -0.0495,  0.1387,  0.2225,  0.1387, -0.0495, -0.2005],
        [ 0.9010,  0.2225, -0.6235, -1.0000, -0.6235,  0.2225,  0.9010],
        [-0.2005, -0.0495,  0.1387,  0.2225,  0.1387, -0.0495, -0.2005],
        [-0.8117, -0.2005,  0.5617,  0.9010,  0.5617, -0.2005, -0.8117],
        [ 0.5617,  0.1387, -0.3887, -0.6235, -0.3887,  0.1387,  0.5617]])
        self.filter[19] = torch.Tensor([[ 3.9092e-01,  9.6548e-02, -2.7052e-01, -4.3388e-01, -2.7052e-01,
          9.6548e-02,  3.9092e-01],
        [-8.7838e-01, -2.1694e-01,  6.0786e-01,  9.7493e-01,  6.0786e-01,
         -2.1694e-01, -8.7838e-01],
        [ 7.0441e-01,  1.7397e-01, -4.8746e-01, -7.8183e-01, -4.8746e-01,
          1.7397e-01,  7.0441e-01],
        [ 2.7584e-16,  6.8127e-17, -1.9089e-16, -3.0616e-16, -1.9089e-16,
          6.8127e-17,  2.7584e-16],
        [-7.0441e-01, -1.7397e-01,  4.8746e-01,  7.8183e-01,  4.8746e-01,
         -1.7397e-01, -7.0441e-01],
        [ 8.7838e-01,  2.1694e-01, -6.0786e-01, -9.7493e-01, -6.0786e-01,
          2.1694e-01,  8.7838e-01],
        [-3.9092e-01, -9.6548e-02,  2.7052e-01,  4.3388e-01,  2.7052e-01,
         -9.6548e-02, -3.9092e-01]])
        self.filter[20] = torch.Tensor([[ 0.2005,  0.0495, -0.1387, -0.2225, -0.1387,  0.0495,  0.2005],
        [-0.5617, -0.1387,  0.3887,  0.6235,  0.3887, -0.1387, -0.5617],
        [ 0.8117,  0.2005, -0.5617, -0.9010, -0.5617,  0.2005,  0.8117],
        [-0.9010, -0.2225,  0.6235,  1.0000,  0.6235, -0.2225, -0.9010],
        [ 0.8117,  0.2005, -0.5617, -0.9010, -0.5617,  0.2005,  0.8117],
        [-0.5617, -0.1387,  0.3887,  0.6235,  0.3887, -0.1387, -0.5617],
        [ 0.2005,  0.0495, -0.1387, -0.2225, -0.1387,  0.0495,  0.2005]])
        self.filter[21] = torch.Tensor([[ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01]])
        self.filter[22] = torch.Tensor([[ 7.6223e-01, -4.2301e-01, -9.5048e-01, -1.7909e-16,  9.5048e-01,
          4.2301e-01, -7.6223e-01],
        [ 6.1126e-01, -3.3922e-01, -7.6223e-01, -1.4362e-16,  7.6223e-01,
          3.3922e-01, -6.1126e-01],
        [ 3.3922e-01, -1.8826e-01, -4.2301e-01, -7.9703e-17,  4.2301e-01,
          1.8826e-01, -3.3922e-01],
        [ 4.7873e-17, -2.6568e-17, -5.9697e-17, -1.1248e-32,  5.9697e-17,
          2.6568e-17, -4.7873e-17],
        [-3.3922e-01,  1.8826e-01,  4.2301e-01,  7.9703e-17, -4.2301e-01,
         -1.8826e-01,  3.3922e-01],
        [-6.1126e-01,  3.3922e-01,  7.6223e-01,  1.4362e-16, -7.6223e-01,
         -3.3922e-01,  6.1126e-01],
        [-7.6223e-01,  4.2301e-01,  9.5048e-01,  1.7909e-16, -9.5048e-01,
         -4.2301e-01,  7.6223e-01]])
        self.filter[23] = torch.Tensor([[ 7.0441e-01, -3.9092e-01, -8.7838e-01, -1.6551e-16,  8.7838e-01,
          3.9092e-01, -7.0441e-01],
        [ 1.7397e-01, -9.6548e-02, -2.1694e-01, -4.0876e-17,  2.1694e-01,
          9.6548e-02, -1.7397e-01],
        [-4.8746e-01,  2.7052e-01,  6.0786e-01,  1.1453e-16, -6.0786e-01,
         -2.7052e-01,  4.8746e-01],
        [-7.8183e-01,  4.3388e-01,  9.7493e-01,  1.8370e-16, -9.7493e-01,
         -4.3388e-01,  7.8183e-01],
        [-4.8746e-01,  2.7052e-01,  6.0786e-01,  1.1453e-16, -6.0786e-01,
         -2.7052e-01,  4.8746e-01],
        [ 1.7397e-01, -9.6548e-02, -2.1694e-01, -4.0876e-17,  2.1694e-01,
          9.6548e-02, -1.7397e-01],
        [ 7.0441e-01, -3.9092e-01, -8.7838e-01, -1.6551e-16,  8.7838e-01,
          3.9092e-01, -7.0441e-01]])
        self.filter[24] = torch.Tensor([[ 6.1126e-01, -3.3922e-01, -7.6223e-01, -1.4362e-16,  7.6223e-01,
          3.3922e-01, -6.1126e-01],
        [-3.3922e-01,  1.8826e-01,  4.2301e-01,  7.9703e-17, -4.2301e-01,
         -1.8826e-01,  3.3922e-01],
        [-7.6223e-01,  4.2301e-01,  9.5048e-01,  1.7909e-16, -9.5048e-01,
         -4.2301e-01,  7.6223e-01],
        [-1.4362e-16,  7.9703e-17,  1.7909e-16,  3.3745e-32, -1.7909e-16,
         -7.9703e-17,  1.4362e-16],
        [ 7.6223e-01, -4.2301e-01, -9.5048e-01, -1.7909e-16,  9.5048e-01,
          4.2301e-01, -7.6223e-01],
        [ 3.3922e-01, -1.8826e-01, -4.2301e-01, -7.9703e-17,  4.2301e-01,
          1.8826e-01, -3.3922e-01],
        [-6.1126e-01,  3.3922e-01,  7.6223e-01,  1.4362e-16, -7.6223e-01,
         -3.3922e-01,  6.1126e-01]])
        self.filter[25] = torch.Tensor([[ 4.8746e-01, -2.7052e-01, -6.0786e-01, -1.1453e-16,  6.0786e-01,
          2.7052e-01, -4.8746e-01],
        [-7.0441e-01,  3.9092e-01,  8.7838e-01,  1.6551e-16, -8.7838e-01,
         -3.9092e-01,  7.0441e-01],
        [-1.7397e-01,  9.6548e-02,  2.1694e-01,  4.0876e-17, -2.1694e-01,
         -9.6548e-02,  1.7397e-01],
        [ 7.8183e-01, -4.3388e-01, -9.7493e-01, -1.8370e-16,  9.7493e-01,
          4.3388e-01, -7.8183e-01],
        [-1.7397e-01,  9.6548e-02,  2.1694e-01,  4.0876e-17, -2.1694e-01,
         -9.6548e-02,  1.7397e-01],
        [-7.0441e-01,  3.9092e-01,  8.7838e-01,  1.6551e-16, -8.7838e-01,
         -3.9092e-01,  7.0441e-01],
        [ 4.8746e-01, -2.7052e-01, -6.0786e-01, -1.1453e-16,  6.0786e-01,
          2.7052e-01, -4.8746e-01]])
        self.filter[26] = torch.Tensor([[ 3.3922e-01, -1.8826e-01, -4.2301e-01, -7.9703e-17,  4.2301e-01,
          1.8826e-01, -3.3922e-01],
        [-7.6223e-01,  4.2301e-01,  9.5048e-01,  1.7909e-16, -9.5048e-01,
         -4.2301e-01,  7.6223e-01],
        [ 6.1126e-01, -3.3922e-01, -7.6223e-01, -1.4362e-16,  7.6223e-01,
          3.3922e-01, -6.1126e-01],
        [ 2.3937e-16, -1.3284e-16, -2.9849e-16, -5.6241e-32,  2.9849e-16,
          1.3284e-16, -2.3937e-16],
        [-6.1126e-01,  3.3922e-01,  7.6223e-01,  1.4362e-16, -7.6223e-01,
         -3.3922e-01,  6.1126e-01],
        [ 7.6223e-01, -4.2301e-01, -9.5048e-01, -1.7909e-16,  9.5048e-01,
          4.2301e-01, -7.6223e-01],
        [-3.3922e-01,  1.8826e-01,  4.2301e-01,  7.9703e-17, -4.2301e-01,
         -1.8826e-01,  3.3922e-01]])
        self.filter[27] = torch.Tensor([[ 1.7397e-01, -9.6548e-02, -2.1694e-01, -4.0876e-17,  2.1694e-01,
          9.6548e-02, -1.7397e-01],
        [-4.8746e-01,  2.7052e-01,  6.0786e-01,  1.1453e-16, -6.0786e-01,
         -2.7052e-01,  4.8746e-01],
        [ 7.0441e-01, -3.9092e-01, -8.7838e-01, -1.6551e-16,  8.7838e-01,
          3.9092e-01, -7.0441e-01],
        [-7.8183e-01,  4.3388e-01,  9.7493e-01,  1.8370e-16, -9.7493e-01,
         -4.3388e-01,  7.8183e-01],
        [ 7.0441e-01, -3.9092e-01, -8.7838e-01, -1.6551e-16,  8.7838e-01,
          3.9092e-01, -7.0441e-01],
        [-4.8746e-01,  2.7052e-01,  6.0786e-01,  1.1453e-16, -6.0786e-01,
         -2.7052e-01,  4.8746e-01],
        [ 1.7397e-01, -9.6548e-02, -2.1694e-01, -4.0876e-17,  2.1694e-01,
          9.6548e-02, -1.7397e-01]])
        self.filter[28] = torch.Tensor([[ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235]])
        self.filter[29] = torch.Tensor([[ 6.0786e-01, -8.7838e-01, -2.1694e-01,  9.7493e-01, -2.1694e-01,
         -8.7838e-01,  6.0786e-01],
        [ 4.8746e-01, -7.0441e-01, -1.7397e-01,  7.8183e-01, -1.7397e-01,
         -7.0441e-01,  4.8746e-01],
        [ 2.7052e-01, -3.9092e-01, -9.6548e-02,  4.3388e-01, -9.6548e-02,
         -3.9092e-01,  2.7052e-01],
        [ 3.8178e-17, -5.5168e-17, -1.3625e-17,  6.1232e-17, -1.3625e-17,
         -5.5168e-17,  3.8178e-17],
        [-2.7052e-01,  3.9092e-01,  9.6548e-02, -4.3388e-01,  9.6548e-02,
          3.9092e-01, -2.7052e-01],
        [-4.8746e-01,  7.0441e-01,  1.7397e-01, -7.8183e-01,  1.7397e-01,
          7.0441e-01, -4.8746e-01],
        [-6.0786e-01,  8.7838e-01,  2.1694e-01, -9.7493e-01,  2.1694e-01,
          8.7838e-01, -6.0786e-01]])
        self.filter[30] = torch.Tensor([[ 0.5617, -0.8117, -0.2005,  0.9010, -0.2005, -0.8117,  0.5617],
        [ 0.1387, -0.2005, -0.0495,  0.2225, -0.0495, -0.2005,  0.1387],
        [-0.3887,  0.5617,  0.1387, -0.6235,  0.1387,  0.5617, -0.3887],
        [-0.6235,  0.9010,  0.2225, -1.0000,  0.2225,  0.9010, -0.6235],
        [-0.3887,  0.5617,  0.1387, -0.6235,  0.1387,  0.5617, -0.3887],
        [ 0.1387, -0.2005, -0.0495,  0.2225, -0.0495, -0.2005,  0.1387],
        [ 0.5617, -0.8117, -0.2005,  0.9010, -0.2005, -0.8117,  0.5617]])
        self.filter[31] = torch.Tensor([[ 4.8746e-01, -7.0441e-01, -1.7397e-01,  7.8183e-01, -1.7397e-01,
         -7.0441e-01,  4.8746e-01],
        [-2.7052e-01,  3.9092e-01,  9.6548e-02, -4.3388e-01,  9.6548e-02,
          3.9092e-01, -2.7052e-01],
        [-6.0786e-01,  8.7838e-01,  2.1694e-01, -9.7493e-01,  2.1694e-01,
          8.7838e-01, -6.0786e-01],
        [-1.1453e-16,  1.6551e-16,  4.0876e-17, -1.8370e-16,  4.0876e-17,
          1.6551e-16, -1.1453e-16],
        [ 6.0786e-01, -8.7838e-01, -2.1694e-01,  9.7493e-01, -2.1694e-01,
         -8.7838e-01,  6.0786e-01],
        [ 2.7052e-01, -3.9092e-01, -9.6548e-02,  4.3388e-01, -9.6548e-02,
         -3.9092e-01,  2.7052e-01],
        [-4.8746e-01,  7.0441e-01,  1.7397e-01, -7.8183e-01,  1.7397e-01,
          7.0441e-01, -4.8746e-01]])
        self.filter[32] = torch.Tensor([[ 0.3887, -0.5617, -0.1387,  0.6235, -0.1387, -0.5617,  0.3887],
        [-0.5617,  0.8117,  0.2005, -0.9010,  0.2005,  0.8117, -0.5617],
        [-0.1387,  0.2005,  0.0495, -0.2225,  0.0495,  0.2005, -0.1387],
        [ 0.6235, -0.9010, -0.2225,  1.0000, -0.2225, -0.9010,  0.6235],
        [-0.1387,  0.2005,  0.0495, -0.2225,  0.0495,  0.2005, -0.1387],
        [-0.5617,  0.8117,  0.2005, -0.9010,  0.2005,  0.8117, -0.5617],
        [ 0.3887, -0.5617, -0.1387,  0.6235, -0.1387, -0.5617,  0.3887]])
        self.filter[33] = torch.Tensor([[ 2.7052e-01, -3.9092e-01, -9.6548e-02,  4.3388e-01, -9.6548e-02,
         -3.9092e-01,  2.7052e-01],
        [-6.0786e-01,  8.7838e-01,  2.1694e-01, -9.7493e-01,  2.1694e-01,
          8.7838e-01, -6.0786e-01],
        [ 4.8746e-01, -7.0441e-01, -1.7397e-01,  7.8183e-01, -1.7397e-01,
         -7.0441e-01,  4.8746e-01],
        [ 1.9089e-16, -2.7584e-16, -6.8127e-17,  3.0616e-16, -6.8127e-17,
         -2.7584e-16,  1.9089e-16],
        [-4.8746e-01,  7.0441e-01,  1.7397e-01, -7.8183e-01,  1.7397e-01,
          7.0441e-01, -4.8746e-01],
        [ 6.0786e-01, -8.7838e-01, -2.1694e-01,  9.7493e-01, -2.1694e-01,
         -8.7838e-01,  6.0786e-01],
        [-2.7052e-01,  3.9092e-01,  9.6548e-02, -4.3388e-01,  9.6548e-02,
          3.9092e-01, -2.7052e-01]])
        self.filter[34] = torch.Tensor([[ 0.1387, -0.2005, -0.0495,  0.2225, -0.0495, -0.2005,  0.1387],
        [-0.3887,  0.5617,  0.1387, -0.6235,  0.1387,  0.5617, -0.3887],
        [ 0.5617, -0.8117, -0.2005,  0.9010, -0.2005, -0.8117,  0.5617],
        [-0.6235,  0.9010,  0.2225, -1.0000,  0.2225,  0.9010, -0.6235],
        [ 0.5617, -0.8117, -0.2005,  0.9010, -0.2005, -0.8117,  0.5617],
        [-0.3887,  0.5617,  0.1387, -0.6235,  0.1387,  0.5617, -0.3887],
        [ 0.1387, -0.2005, -0.0495,  0.2225, -0.0495, -0.2005,  0.1387]])
        self.filter[35] = torch.Tensor([[ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01]])
        self.filter[36] = torch.Tensor([[ 4.2301e-01, -9.5048e-01,  7.6223e-01,  2.9849e-16, -7.6223e-01,
          9.5048e-01, -4.2301e-01],
        [ 3.3922e-01, -7.6223e-01,  6.1126e-01,  2.3937e-16, -6.1126e-01,
          7.6223e-01, -3.3922e-01],
        [ 1.8826e-01, -4.2301e-01,  3.3922e-01,  1.3284e-16, -3.3922e-01,
          4.2301e-01, -1.8826e-01],
        [ 2.6568e-17, -5.9697e-17,  4.7873e-17,  1.8747e-32, -4.7873e-17,
          5.9697e-17, -2.6568e-17],
        [-1.8826e-01,  4.2301e-01, -3.3922e-01, -1.3284e-16,  3.3922e-01,
         -4.2301e-01,  1.8826e-01],
        [-3.3922e-01,  7.6223e-01, -6.1126e-01, -2.3937e-16,  6.1126e-01,
         -7.6223e-01,  3.3922e-01],
        [-4.2301e-01,  9.5048e-01, -7.6223e-01, -2.9849e-16,  7.6223e-01,
         -9.5048e-01,  4.2301e-01]])
        self.filter[37] = torch.Tensor([[ 3.9092e-01, -8.7838e-01,  7.0441e-01,  2.7584e-16, -7.0441e-01,
          8.7838e-01, -3.9092e-01],
        [ 9.6548e-02, -2.1694e-01,  1.7397e-01,  6.8127e-17, -1.7397e-01,
          2.1694e-01, -9.6548e-02],
        [-2.7052e-01,  6.0786e-01, -4.8746e-01, -1.9089e-16,  4.8746e-01,
         -6.0786e-01,  2.7052e-01],
        [-4.3388e-01,  9.7493e-01, -7.8183e-01, -3.0616e-16,  7.8183e-01,
         -9.7493e-01,  4.3388e-01],
        [-2.7052e-01,  6.0786e-01, -4.8746e-01, -1.9089e-16,  4.8746e-01,
         -6.0786e-01,  2.7052e-01],
        [ 9.6548e-02, -2.1694e-01,  1.7397e-01,  6.8127e-17, -1.7397e-01,
          2.1694e-01, -9.6548e-02],
        [ 3.9092e-01, -8.7838e-01,  7.0441e-01,  2.7584e-16, -7.0441e-01,
          8.7838e-01, -3.9092e-01]])
        self.filter[38] = torch.Tensor([[ 3.3922e-01, -7.6223e-01,  6.1126e-01,  2.3937e-16, -6.1126e-01,
          7.6223e-01, -3.3922e-01],
        [-1.8826e-01,  4.2301e-01, -3.3922e-01, -1.3284e-16,  3.3922e-01,
         -4.2301e-01,  1.8826e-01],
        [-4.2301e-01,  9.5048e-01, -7.6223e-01, -2.9849e-16,  7.6223e-01,
         -9.5048e-01,  4.2301e-01],
        [-7.9703e-17,  1.7909e-16, -1.4362e-16, -5.6241e-32,  1.4362e-16,
         -1.7909e-16,  7.9703e-17],
        [ 4.2301e-01, -9.5048e-01,  7.6223e-01,  2.9849e-16, -7.6223e-01,
          9.5048e-01, -4.2301e-01],
        [ 1.8826e-01, -4.2301e-01,  3.3922e-01,  1.3284e-16, -3.3922e-01,
          4.2301e-01, -1.8826e-01],
        [-3.3922e-01,  7.6223e-01, -6.1126e-01, -2.3937e-16,  6.1126e-01,
         -7.6223e-01,  3.3922e-01]])
        self.filter[39] = torch.Tensor([[ 2.7052e-01, -6.0786e-01,  4.8746e-01,  1.9089e-16, -4.8746e-01,
          6.0786e-01, -2.7052e-01],
        [-3.9092e-01,  8.7838e-01, -7.0441e-01, -2.7584e-16,  7.0441e-01,
         -8.7838e-01,  3.9092e-01],
        [-9.6548e-02,  2.1694e-01, -1.7397e-01, -6.8127e-17,  1.7397e-01,
         -2.1694e-01,  9.6548e-02],
        [ 4.3388e-01, -9.7493e-01,  7.8183e-01,  3.0616e-16, -7.8183e-01,
          9.7493e-01, -4.3388e-01],
        [-9.6548e-02,  2.1694e-01, -1.7397e-01, -6.8127e-17,  1.7397e-01,
         -2.1694e-01,  9.6548e-02],
        [-3.9092e-01,  8.7838e-01, -7.0441e-01, -2.7584e-16,  7.0441e-01,
         -8.7838e-01,  3.9092e-01],
        [ 2.7052e-01, -6.0786e-01,  4.8746e-01,  1.9089e-16, -4.8746e-01,
          6.0786e-01, -2.7052e-01]])
        self.filter[40] = torch.Tensor([[ 1.8826e-01, -4.2301e-01,  3.3922e-01,  1.3284e-16, -3.3922e-01,
          4.2301e-01, -1.8826e-01],
        [-4.2301e-01,  9.5048e-01, -7.6223e-01, -2.9849e-16,  7.6223e-01,
         -9.5048e-01,  4.2301e-01],
        [ 3.3922e-01, -7.6223e-01,  6.1126e-01,  2.3937e-16, -6.1126e-01,
          7.6223e-01, -3.3922e-01],
        [ 1.3284e-16, -2.9849e-16,  2.3937e-16,  9.3735e-32, -2.3937e-16,
          2.9849e-16, -1.3284e-16],
        [-3.3922e-01,  7.6223e-01, -6.1126e-01, -2.3937e-16,  6.1126e-01,
         -7.6223e-01,  3.3922e-01],
        [ 4.2301e-01, -9.5048e-01,  7.6223e-01,  2.9849e-16, -7.6223e-01,
          9.5048e-01, -4.2301e-01],
        [-1.8826e-01,  4.2301e-01, -3.3922e-01, -1.3284e-16,  3.3922e-01,
         -4.2301e-01,  1.8826e-01]])
        self.filter[41] = torch.Tensor([[ 9.6548e-02, -2.1694e-01,  1.7397e-01,  6.8127e-17, -1.7397e-01,
          2.1694e-01, -9.6548e-02],
        [-2.7052e-01,  6.0786e-01, -4.8746e-01, -1.9089e-16,  4.8746e-01,
         -6.0786e-01,  2.7052e-01],
        [ 3.9092e-01, -8.7838e-01,  7.0441e-01,  2.7584e-16, -7.0441e-01,
          8.7838e-01, -3.9092e-01],
        [-4.3388e-01,  9.7493e-01, -7.8183e-01, -3.0616e-16,  7.8183e-01,
         -9.7493e-01,  4.3388e-01],
        [ 3.9092e-01, -8.7838e-01,  7.0441e-01,  2.7584e-16, -7.0441e-01,
          8.7838e-01, -3.9092e-01],
        [-2.7052e-01,  6.0786e-01, -4.8746e-01, -1.9089e-16,  4.8746e-01,
         -6.0786e-01,  2.7052e-01],
        [ 9.6548e-02, -2.1694e-01,  1.7397e-01,  6.8127e-17, -1.7397e-01,
          2.1694e-01, -9.6548e-02]])
        self.filter[42] = torch.Tensor([[ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225]])
        self.filter[43] = torch.Tensor([[ 2.1694e-01, -6.0786e-01,  8.7838e-01, -9.7493e-01,  8.7838e-01,
         -6.0786e-01,  2.1694e-01],
        [ 1.7397e-01, -4.8746e-01,  7.0441e-01, -7.8183e-01,  7.0441e-01,
         -4.8746e-01,  1.7397e-01],
        [ 9.6548e-02, -2.7052e-01,  3.9092e-01, -4.3388e-01,  3.9092e-01,
         -2.7052e-01,  9.6548e-02],
        [ 1.3625e-17, -3.8178e-17,  5.5168e-17, -6.1232e-17,  5.5168e-17,
         -3.8178e-17,  1.3625e-17],
        [-9.6548e-02,  2.7052e-01, -3.9092e-01,  4.3388e-01, -3.9092e-01,
          2.7052e-01, -9.6548e-02],
        [-1.7397e-01,  4.8746e-01, -7.0441e-01,  7.8183e-01, -7.0441e-01,
          4.8746e-01, -1.7397e-01],
        [-2.1694e-01,  6.0786e-01, -8.7838e-01,  9.7493e-01, -8.7838e-01,
          6.0786e-01, -2.1694e-01]])
        self.filter[44] = torch.Tensor([[ 0.2005, -0.5617,  0.8117, -0.9010,  0.8117, -0.5617,  0.2005],
        [ 0.0495, -0.1387,  0.2005, -0.2225,  0.2005, -0.1387,  0.0495],
        [-0.1387,  0.3887, -0.5617,  0.6235, -0.5617,  0.3887, -0.1387],
        [-0.2225,  0.6235, -0.9010,  1.0000, -0.9010,  0.6235, -0.2225],
        [-0.1387,  0.3887, -0.5617,  0.6235, -0.5617,  0.3887, -0.1387],
        [ 0.0495, -0.1387,  0.2005, -0.2225,  0.2005, -0.1387,  0.0495],
        [ 0.2005, -0.5617,  0.8117, -0.9010,  0.8117, -0.5617,  0.2005]])
        self.filter[45] = torch.Tensor([[ 1.7397e-01, -4.8746e-01,  7.0441e-01, -7.8183e-01,  7.0441e-01,
         -4.8746e-01,  1.7397e-01],
        [-9.6548e-02,  2.7052e-01, -3.9092e-01,  4.3388e-01, -3.9092e-01,
          2.7052e-01, -9.6548e-02],
        [-2.1694e-01,  6.0786e-01, -8.7838e-01,  9.7493e-01, -8.7838e-01,
          6.0786e-01, -2.1694e-01],
        [-4.0876e-17,  1.1453e-16, -1.6551e-16,  1.8370e-16, -1.6551e-16,
          1.1453e-16, -4.0876e-17],
        [ 2.1694e-01, -6.0786e-01,  8.7838e-01, -9.7493e-01,  8.7838e-01,
         -6.0786e-01,  2.1694e-01],
        [ 9.6548e-02, -2.7052e-01,  3.9092e-01, -4.3388e-01,  3.9092e-01,
         -2.7052e-01,  9.6548e-02],
        [-1.7397e-01,  4.8746e-01, -7.0441e-01,  7.8183e-01, -7.0441e-01,
          4.8746e-01, -1.7397e-01]])
        self.filter[46] = torch.Tensor([[ 0.1387, -0.3887,  0.5617, -0.6235,  0.5617, -0.3887,  0.1387],
        [-0.2005,  0.5617, -0.8117,  0.9010, -0.8117,  0.5617, -0.2005],
        [-0.0495,  0.1387, -0.2005,  0.2225, -0.2005,  0.1387, -0.0495],
        [ 0.2225, -0.6235,  0.9010, -1.0000,  0.9010, -0.6235,  0.2225],
        [-0.0495,  0.1387, -0.2005,  0.2225, -0.2005,  0.1387, -0.0495],
        [-0.2005,  0.5617, -0.8117,  0.9010, -0.8117,  0.5617, -0.2005],
        [ 0.1387, -0.3887,  0.5617, -0.6235,  0.5617, -0.3887,  0.1387]])
        self.filter[47] = torch.Tensor([[ 9.6548e-02, -2.7052e-01,  3.9092e-01, -4.3388e-01,  3.9092e-01,
         -2.7052e-01,  9.6548e-02],
        [-2.1694e-01,  6.0786e-01, -8.7838e-01,  9.7493e-01, -8.7838e-01,
          6.0786e-01, -2.1694e-01],
        [ 1.7397e-01, -4.8746e-01,  7.0441e-01, -7.8183e-01,  7.0441e-01,
         -4.8746e-01,  1.7397e-01],
        [ 6.8127e-17, -1.9089e-16,  2.7584e-16, -3.0616e-16,  2.7584e-16,
         -1.9089e-16,  6.8127e-17],
        [-1.7397e-01,  4.8746e-01, -7.0441e-01,  7.8183e-01, -7.0441e-01,
          4.8746e-01, -1.7397e-01],
        [ 2.1694e-01, -6.0786e-01,  8.7838e-01, -9.7493e-01,  8.7838e-01,
         -6.0786e-01,  2.1694e-01],
        [-9.6548e-02,  2.7052e-01, -3.9092e-01,  4.3388e-01, -3.9092e-01,
          2.7052e-01, -9.6548e-02]])
        self.filter[48] = torch.Tensor([[ 0.0495, -0.1387,  0.2005, -0.2225,  0.2005, -0.1387,  0.0495],
        [-0.1387,  0.3887, -0.5617,  0.6235, -0.5617,  0.3887, -0.1387],
        [ 0.2005, -0.5617,  0.8117, -0.9010,  0.8117, -0.5617,  0.2005],
        [-0.2225,  0.6235, -0.9010,  1.0000, -0.9010,  0.6235, -0.2225],
        [ 0.2005, -0.5617,  0.8117, -0.9010,  0.8117, -0.5617,  0.2005],
        [-0.1387,  0.3887, -0.5617,  0.6235, -0.5617,  0.3887, -0.1387],
        [ 0.0495, -0.1387,  0.2005, -0.2225,  0.2005, -0.1387,  0.0495]])

        self.important = torch.Tensor([92.08, 92.41, 92.54, 92.46, 92.63, 92.44, 92.42,
                                       92.44, 92.43, 92.76, 92.56, 92.74, 92.47, 92.42,
                                       92.55, 92.80, 92.72, 92.69, 92.52, 92.41, 92.46,
                                       92.51, 92.61, 92.60, 92.46, 92.42, 92.69, 92.61,
                                       92.52, 92.53, 92.69, 92.75, 92.74, 92.67, 92.89,
                                       92.44, 92.69, 92.48, 92.55, 92.81, 92.61, 92.53,
                                       92.50, 92.53, 92.70, 92.28, 92.56, 92.62, 92.55])
        
        # self.important = torch.Tensor([70.25, 70.05, 70.25, 70.68, 70.24, 70.06, 70.03,
        #                                70.43, 70.18, 69.43, 70.18, 69.91, 70.27, 70.35,
        #                                70.03, 69.97, 70.07, 70.43, 70.26, 70.30, 70.31,
        #                                70.42, 70.03, 70.46, 70.39, 70.19, 70.23, 70.24,
        #                                69.92, 70.17, 70.02, 69.90, 69.90, 70.50, 70.62,
        #                                70.27, 70.21, 70.30, 70.22, 70.65, 70.62, 70.37,
        #                                69.83, 70.10, 70.30, 70.07])
    def get_filter(self, idx):
        if isinstance(idx, int):
            return self.filter[idx]
        else:
            idx = idx.to(self.filter.device)
            out = self.filter.index_select(dim=0, index=idx)
            return out

    def get_topk(self, topk):
        _, ids = torch.topk(self.important, topk)

        return ids