import numpy as np
import pandas as pd
import torch



data = pd.read_csv("6100.csv")

data = np.array(data)


X = data[: , 0:-1]
y = data[: , -1]



y = y * 2 - 1


A_train = torch.zeros(160, 2430, 30)
A_test = torch.zeros(40, 2430, 30)


n = 2430
d = 30

for i in range(160):
        print(i)
        Tmp = X[i * 30 : (i + 1) * 30, :].T

        U, Sig, V = np.linalg.svd(Tmp)
        Tmp = Tmp / (Sig[0] / 100)
        label = y[i * 30 : (i + 1) *30]

        D = np.zeros((d, d))
        for j in range(30):
            D[j, j] = label[j]
        E = np.eye(d)


        A_train[i] = torch.from_numpy(np.hstack(((Tmp @ D).T, E)).T)


for i in range(40):

        print(i)
        Tmp = X[4800 + i * 30: 4800 + (i + 1) * 30, :].T

        U, Sig, V = np.linalg.svd(Tmp)
        Tmp = Tmp / (Sig[0] / 100)
        label = y[4800 + i * 30: 4800 + (i + 1) * 30]

        D = np.zeros((d, d))
        for j in range(30):
                D[j, j] = label[j]
        E = np.eye(d)


        A_test[i] = torch.from_numpy(np.hstack(((Tmp @ D).T, E)).T)

torch.save(A_train, "train160.dat")
torch.save(A_test, "test40.dat")
