{
    "0": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv1d(16, 32, kernel_size=3, stride=1, padding=1)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=3, stride=1, padding=1)\n        self.fc1 = nn.Linear(64 * 13, 128)\n        self.fc2 = nn.Linear(128, 18)\n        self.pool = nn.MaxPool1d(2)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = x.view(x.size(0), -1)\n        x = self.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_tensor = torch.tensor(train_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n    train_label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data_tensor = torch.tensor(val_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n\n    train_dataset = TensorDataset(train_data_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = SimpleCNN().to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data_tensor)\n        _, y_pred = torch.max(val_outputs, 1)\n\n    return y_pred.tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8260_1D_Convolutional_Neu.py",
                "accuracy": 0.701062215477997,
                "model_info": "",
                "lineage": "ninapro_initial_8260_1D_Convolutional_Neu"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv1d(16, 32, kernel_size=3, stride=1, padding=1)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=3, stride=1, padding=1)\n        self.fc1 = nn.Linear(64 * 13, 128)\n        self.fc2 = nn.Linear(128, 18)\n        self.pool = nn.MaxPool1d(2)\n        self.relu = nn.ReLU()\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = x.view(x.size(0), -1)\n        x = self.dropout(self.relu(self.fc1(x)))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_tensor = torch.tensor(train_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n    train_label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data_tensor = torch.tensor(val_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n\n    train_dataset = TensorDataset(train_data_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = SimpleCNN().to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data_tensor)\n        _, y_pred = torch.max(val_outputs, 1)\n\n    return y_pred.tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8260_1D_Convolutional_NeuX.py",
                "accuracy": 0.701062215477997,
                "model_info": "",
                "lineage": "101"
            }
        ],
        "2": [],
        "3": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass TCN(nn.Module):\n    def __init__(self, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(16, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 13, num_classes)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool1d(2)\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.pool(x)\n        x = self.relu(self.conv2(x))\n        x = self.pool(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = torch.tensor(train_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n\n    train_dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, 'min', patience=3)\n\n    model.train()\n    for epoch in range(20):\n        total_loss = 0\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n            optimizer.step()\n            total_loss += loss.item()\n        scheduler.step(total_loss / len(train_loader))\n        print(f\"Epoch {epoch+1}, Loss: {total_loss / len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, y_pred = torch.max(val_outputs, 1)\n    \n    print(f\"Train data size: {train_data.size(0)}, Validation data size: {val_data.size(0)}\")\n    print(f\"Train label distribution: {torch.bincount(train_label)}\")\n    \n    return y_pred.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8262_Temporal_ConvolutionXXX.py",
                "accuracy": 0.7966616084977238,
                "model_info": "Epoch 1, Loss: 2.123568756239755\nEpoch 2, Loss: 1.2590088290827615\nEpoch 3, Loss: 1.0932350570247287\nEpoch 4, Loss: 1.0505854529993874\nEpoch 5, Loss: 1.0020795634814672\nEpoch 6, Loss: 0.9537218539487748\nEpoch 7, Loss: 0.8818795908065069\nEpoch 8, Loss: 0.8374026332582746\nEpoch 9, Loss: 0.7921372141156878\nEpoch 10, Loss: 0.7660505991606485\nEpoch 11, Loss: 0.735593910018603\nEpoch 12, Loss: 0.7066109499761036\nEpoch 13, Loss: 0.6798819296416783\nEpoch 14, Loss: 0.642779548962911\nEpoch 15, Loss: 0.6345710839544024\nEpoch 16, Loss: 0.5985638052225113\nEpoch 17, Loss: 0.5865273738191241\nEpoch 18, Loss: 0.5632837123814083\nEpoch 19, Loss: 0.5345022848674229\nEpoch 20, Loss: 0.5178903547071275\nTrain data size: 2638, Validation data size: 659\nTrain label distribution: tensor([1656,   64,   57,   51,   60,   48,   43,   55,   56,   53,   60,   71,\n          59,   50,   59,   49,   71,   76], device='cuda:0')",
                "lineage": "301"
            }
        ],
        "5": [],
        "6": [],
        "7": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nimport torchvision.transforms as transforms\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()\n\ndef augment_data(train_data, train_label):\n    transform = transforms.Compose([\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ])\n    augmented_data = []\n    augmented_labels = []\n    for i in range(len(train_data)):\n        augmented_data.append(transform(train_data[i]))\n        augmented_labels.append(train_label[i])\n    return np.array(augmented_data), np.array(augmented_labels)\n",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXX.py",
                "accuracy": 0.8573596358118362,
                "model_info": "",
                "lineage": "701"
            }
        ],
        "8": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXX.py",
                "accuracy": 0.8528072837632777,
                "model_info": "",
                "lineage": "801"
            }
        ],
        "9": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nimport torchvision.transforms as transforms\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n        \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "",
                "lineage": "901"
            }
        ],
        "10": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc3 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = torch.relu(self.fc2(x))\n        x = self.dropout(x)\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=32):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXX.py",
                "accuracy": 0.8558421851289834,
                "model_info": "",
                "lineage": "1001"
            }
        ],
        "11": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "",
                "lineage": "1101"
            }
        ],
        "12": [],
        "13": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    class_count = Counter(train_label)\n    class_weights = 1. / torch.tensor([class_count[i] for i in range(18)], dtype=torch.float).to(device)\n    sample_weights = class_weights[train_label_tensor]\n    sampler = WeightedRandomSampler(sample_weights, num_samples=len(sample_weights), replacement=True)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXX.py",
                "accuracy": 0.8391502276176024,
                "model_info": "",
                "lineage": "1301"
            }
        ],
        "14": [],
        "15": [],
        "16": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc3 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = torch.relu(self.fc2(x))\n        x = self.dropout(x)\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXX.py",
                "accuracy": 0.866464339908953,
                "model_info": "",
                "lineage": "1601"
            }
        ],
        "17": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "",
                "lineage": "1701"
            }
        ],
        "18": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.decomposition import PCA\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=10, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    pca = PCA(n_components=10)\n    train_data_pca = pca.fit_transform(train_data_scaled.reshape(-1, 16)).reshape(-1, 52, 10)\n    val_data_pca = pca.transform(val_data_scaled.reshape(-1, 16)).reshape(-1, 52, 10)\n\n    train_tensor = torch.FloatTensor(train_data_pca).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_pca).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels[:outputs.size(0)])\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXX.py",
                "accuracy": 0.8603945371775418,
                "model_info": "",
                "lineage": "1801"
            }
        ],
        "19": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n            if (epoch % 10 == 0 and inputs.shape[0] < batch_size):\n                print(f\"Epoch {epoch}, Batch Size: {inputs.shape[0]}, Loss: {loss.item()}\")\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    z_scores = np.abs((val_outputs.cpu().numpy() - np.mean(val_outputs.cpu().numpy(), axis=0)) / np.std(val_outputs.cpu().numpy(), axis=0))\n    outliers = np.where(z_scores > 3)\n    print(f\"Detected outliers count: {len(outliers[0])}\")\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Epoch 0, Batch Size: 14, Loss: 0.7665305733680725\nEpoch 10, Batch Size: 14, Loss: 1.6035325527191162\nEpoch 20, Batch Size: 14, Loss: 0.22789998352527618\nEpoch 30, Batch Size: 14, Loss: 0.16991719603538513\nEpoch 40, Batch Size: 14, Loss: 0.16184723377227783\nDetected outliers count: 220",
                "lineage": "1901"
            }
        ],
        "20": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXX.py",
                "accuracy": 0.8770864946889226,
                "model_info": "Confusion Matrix:\n [[404   1   0   0   0   0   0   0   0   1   0   0   1   2   0   2   0   0]\n [  0  13   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   1   8   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  1   0   3  13   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   0   0   0   9   3   0   0   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   0   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   4   0   0   2   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  15   1   2   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   1   0   0]\n [  3   0   0   0   0   0   0   0   0   0   0   7   4   0   2   0   0   0]\n [  0   0   0   0   0   0   1   0   1   0   1   1  19   1   0   0   1   1]\n [  0   0   0   0   0   0   0   0   1   3   0   0   0   8   4   0   2   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   1   8   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   9   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   1   0   0   0   0  11   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   9]]",
                "lineage": "2001"
            }
        ],
        "21": [],
        "22": [],
        "23": [],
        "24": [],
        "25": [],
        "26": [],
        "27": [],
        "28": [],
        "29": [],
        "30": [],
        "31": [],
        "32": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef random_time_shifting(data, shift_range):\n    shift = np.random.randint(-shift_range, shift_range)\n    if shift > 0:\n        return np.pad(data, ((shift, 0), (0, 0)), mode='constant')[:-shift]\n    else:\n        return np.pad(data, ((0, -shift), (0, 0)), mode='constant')[-shift:]\n\ndef apply_time_shifting(train_data):\n    return np.array([random_time_shifting(sample, 5) for sample in train_data])\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = apply_time_shifting(train_data)\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8467374810318664,
                "model_info": "Confusion Matrix:\n [[399   3   0   0   1   1   0   1   2   0   0   0   0   1   0   3   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  14   0   1   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   6   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  12   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   2   0   0   0  12   0   1   0   0   0   2   0   2]\n [  1   0   0   0   0   0   0   0   0   0  14   0   0   0   0   0   1   1]\n [  2   0   0   0   0   0   0   0   2   0   0   6   3   1   2   0   0   0]\n [  0   1   0   0   0   0   0   0   2   0   4   0  13   1   0   0   2   3]\n [  0   0   0   0   0   2   0   0   1   0   1   0   0   9   2   0   2   1]\n [  0   0   0   0   2   0   0   0   0   0   0   0   0   2   5   0   0   3]\n [  1   0   0   0   0   0   1   0   0   0   1   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   1   0   1   9   4]\n [  0   0   1   0   0   0   0   0   0   0   0   0   1   1   0   0   0   7]]",
                "lineage": "3201"
            }
        ],
        "33": [],
        "34": [],
        "35": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.cnn = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=32, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.cnn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.7845220030349014,
                "model_info": "Confusion Matrix:\n [[399   3   0   0   1   0   0   2   0   0   1   2   1   0   0   2   0   0]\n [  0  12   2   1   0   0   0   1   0   0   1   0   0   0   0   0   0   0]\n [  2   0   6   1   0   0   0   0   0   0   0   0   1   0   0   0   0   0]\n [  1   0   2  11   0   0   1   0   0   0   0   0   0   2   2   0   1   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   2   1   1   0   9   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   1   8   0   0   0   0   1   0   0   0   0   0]\n [  1   1   0   1   0   1   0   0   2   1   0   1   0   0   1   0   0   0]\n [  2   0   0   0   0   2   0   0   0   6   0   3   2   0   0   2   2   1]\n [  0   0   1   0   0   0   0   0   0   1   7   1   1   1   2   0   2   1]\n [  4   0   0   1   0   0   0   0   3   1   0   4   0   0   1   2   0   0]\n [  0   1   0   2   0   1   0   0   1   2   2   1  12   0   0   0   4   0]\n [  0   0   0   1   2   4   0   0   0   0   1   0   0   4   4   1   1   0]\n [  0   0   1   0   0   1   0   0   1   0   0   2   0   1   2   3   1   0]\n [  1   0   1   1   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   2   0   0   2   0   0   0   0   2   1   0   1   0   1   8   0]\n [  0   0   1   0   0   0   0   0   0   1   0   0   0   0   1   0   1   6]]",
                "lineage": "3501"
            }
        ],
        "36": [],
        "37": [],
        "38": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.cnn = nn.Sequential(\n            nn.Conv2d(1, 16, kernel_size=(3, 3), stride=1, padding=1),\n            nn.ReLU(),\n            nn.MaxPool2d(kernel_size=(2, 2)),\n            nn.Conv2d(16, 32, kernel_size=(3, 3), stride=1, padding=1),\n            nn.ReLU(),\n            nn.MaxPool2d(kernel_size=(2, 2))\n        )\n        self.lstm = nn.LSTM(input_size=32 * 13 * 4, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 1, 52, 16)\n        x = self.cnn(x)\n        x = x.view(x.size(0), -1, 32 * 13 * 4)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.834597875569044,
                "model_info": "Confusion Matrix:\n [[403   3   0   0   0   0   0   0   0   0   0   1   0   1   0   3   0   0]\n [  1  13   1   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   1   7   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   1   0   0  11   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   3   1   0   1   1   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   2   4   0   6   1   2   0   1   2   0]\n [  0   0   0   0   0   0   0   0   0   3  12   1   0   0   0   1   0   0]\n [  3   0   0   0   0   0   0   0   3   1   0   5   0   0   1   2   1   0]\n [  1   1   0   0   0   0   0   0   2   0   3   1  12   0   1   0   5   0]\n [  0   0   0   0   1   1   0   0   1   0   0   1   0  10   4   0   0   0]\n [  0   0   0   0   0   0   0   0   1   0   0   3   0   1   7   0   0   0]\n [  2   0   1   1   0   0   0   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   1   0   0   0   0   0   0   0   2   0   2   0   0   0  10   3]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   1   1   0   0   7]]",
                "lineage": "3801"
            }
        ],
        "39": [],
        "40": [],
        "41": [],
        "42": [],
        "43": [],
        "44": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    augmented_train_data = []\n    augmented_train_label = []\n    for i in range(len(train_data_scaled)):\n        augmented_train_data.append(train_data_scaled[i])\n        augmented_train_label.append(train_label[i])\n        if np.random.rand() > 0.5:\n            augmented_train_data.append(np.flip(train_data_scaled[i], axis=1))\n            augmented_train_label.append(train_label[i])\n    \n    augmented_train_data = np.array(augmented_train_data)\n    augmented_train_label = np.array(augmented_train_label)\n    \n    train_tensor = torch.FloatTensor(augmented_train_data).to(device)\n    train_label_tensor = torch.LongTensor(augmented_train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8391502276176024,
                "model_info": "Confusion Matrix:\n [[400   4   0   0   1   1   0   0   0   1   0   0   1   0   0   2   0   1]\n [  1  11   2   0   0   0   1   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   2  15   0   0   1   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0   1   0  13   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   1   2   0   0   0   1   1   0   0   1   1]\n [  1   0   0   1   2   0   0   0   1  13   1   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   4  12   0   1   0   0   0   0   0]\n [  5   0   0   0   0   0   0   0   1   1   1   5   0   0   2   0   0   1]\n [  0   1   0   0   0   0   0   0   2   0   1   1  14   0   2   0   5   0]\n [  0   0   0   0   1   0   0   0   0   1   2   0   1   9   3   0   1   0]\n [  0   0   0   0   0   1   0   0   0   0   0   0   0   1   9   0   0   1]\n [  2   1   0   0   0   0   1   0   0   0   0   0   0   0   1   4   0   0]\n [  0   1   1   0   0   0   0   0   1   2   1   0   0   1   0   0   9   2]\n [  0   0   1   0   0   0   0   0   0   0   0   1   0   0   1   0   1   6]]",
                "lineage": "4401"
            }
        ],
        "45": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.relu = nn.ReLU()\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.relu(x)\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Confusion Matrix:\n [[404   0   0   0   1   1   0   0   0   0   0   1   0   1   0   2   0   1]\n [  1  12   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  1   0   3  13   0   0   1   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   2   0   0   3   0   0   0   1   0   0   0   0   1]\n [  4   0   0   0   0   0   0   0   1   9   1   5   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   1  13   0   0   0   0   0   1   0]\n [  5   0   0   0   0   0   0   0   0   0   0   7   1   0   1   0   1   1]\n [  0   0   0   0   0   0   0   0   0   1   1   5  13   1   0   0   5   0]\n [  0   0   0   0   2   2   0   0   1   0   0   1   0   7   3   0   1   1]\n [  0   0   0   0   1   0   0   0   1   1   0   1   1   0   5   0   2   0]\n [  1   0   0   0   0   0   1   0   0   1   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   1   0   0   0   1   2   0   0   0   0  14   0]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   1   7]]",
                "lineage": "4501"
            }
        ],
        "46": [],
        "47": [],
        "48": [],
        "49": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=5, padding=2)\n        self.fc = nn.Linear(128 * 52, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.tcn(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.7814871016691958,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   1   0   0   0   1   0   0   4   1   0   0   2   0   0]\n [  0  11   1   1   0   0   0   2   1   0   0   1   0   0   0   0   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   2   4  13   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   8   3   0   0   1   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   2   0   0   0   0   0   0   0   1   2   1   0   0]\n [  0   1   0   0   0   0  12   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   1   5   0   0   0   1   0   0   0   0   1]\n [  3   0   0   0   0   0   0   1   0  11   1   2   1   0   1   0   0   0]\n [  2   0   0   0   0   0   0   0   0   1  11   0   0   0   1   0   2   0]\n [  3   0   0   0   0   0   0   0   1   4   1   4   2   0   1   0   0   0]\n [  0   1   0   0   0   0   0   0   0   1   4   2   8   2   2   0   5   1]\n [  0   0   0   0   1   2   0   0   2   1   0   0   0   5   4   0   0   3]\n [  0   0   0   0   1   0   0   1   1   0   0   0   1   0   4   0   1   3]\n [  2   0   1   0   0   0   0   1   0   0   0   0   0   0   2   2   0   1]\n [  0   0   0   0   0   0   0   0   0   2   6   0   6   0   0   0   1   3]\n [  0   0   0   0   0   0   0   0   1   0   0   0   3   0   2   0   3   1]]",
                "lineage": "4901"
            }
        ],
        "50": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom torchvision import models\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8603945371775418,
                "model_info": "Confusion Matrix:\n [[399   4   0   0   1   2   0   1   0   0   0   1   0   1   0   2   0   0]\n [  0  13   1   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  16   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   3   1   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   0   7   0   0   0   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  12   0   4   0   0   0   2   1   0]\n [  0   0   0   0   0   0   0   0   0   0  10   1   5   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   0   0   0   7   3   0   2   0   0   1]\n [  0   1   0   0   0   0   0   0   0   0   0   0  18   2   3   0   1   1]\n [  0   0   0   0   0   2   0   0   1   0   0   0   0  11   3   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   1   8   0   0   1]\n [  1   1   0   0   0   0   1   0   0   0   0   0   0   1   0   5   0   0]\n [  0   1   0   0   0   0   0   0   0   0   0   1   1   1   0   0  12   2]\n [  0   0   0   0   0   0   1   0   0   0   0   1   0   2   0   0   0   6]]",
                "lineage": "5001"
            }
        ],
        "51": [],
        "52": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.779969650986343,
                "model_info": "Confusion Matrix:\n [[400   1   0   0   2   0   0   2   0   1   1   1   0   1   0   2   0   0]\n [  0   9   2   0   0   0   0   2   1   1   0   0   1   0   0   0   1   0]\n [  1   1   3   2   0   0   0   0   0   0   0   0   1   1   1   0   0   0]\n [  1   0   1  12   0   0   2   0   0   0   0   1   0   0   1   0   1   1]\n [  0   0   0   0  11   1   0   0   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   4   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   1   1   1  10   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   1   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   4   0   0   0   1   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   1   3   0   3   0   0   0   1   6   4]\n [  0   0   1   0   0   0   0   0   0   1  11   0   0   0   0   1   3   0]\n [  5   0   1   1   0   0   0   0   1   2   0   3   0   0   1   1   1   0]\n [  0   1   1   2   0   0   0   0   1   1   1   1  12   0   1   0   5   0]\n [  0   0   0   0   3   2   0   0   1   1   1   0   1   3   5   0   1   0]\n [  0   0   1   0   1   0   1   0   0   0   2   0   2   0   2   3   0   0]\n [  2   1   1   0   0   0   0   0   0   1   0   0   0   0   0   4   0   0]\n [  0   0   2   0   0   1   0   0   0   1   1   0   2   0   0   0   9   2]\n [  0   0   2   0   0   0   0   0   0   1   0   0   0   0   0   0   2   5]]",
                "lineage": "5201"
            }
        ],
        "53": [],
        "54": [],
        "55": [],
        "56": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef add_temporal_jittering(data, jitter_strength=0.1):\n    noise = np.random.normal(0, jitter_strength, data.shape)\n    return data + noise\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    train_data_augmented = add_temporal_jittering(train_data_reshaped)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_augmented.reshape(-1, 16)).reshape(train_data_augmented.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8239757207890743,
                "model_info": "Confusion Matrix:\n [[403   1   0   0   1   0   0   0   0   1   0   0   0   1   0   3   1   0]\n [  1  11   1   2   0   0   0   0   0   0   0   2   0   0   0   0   0   0]\n [  1   1   6   1   0   0   0   0   0   0   0   0   0   0   0   0   0   1]\n [  1   0   3  15   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   4   0   0   1   0   0   0   0   0   1   0   0   1]\n [  0   0   1   2   0   0  11   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   7   0   0   0   1   0   0   1   0   0   0]\n [  1   1   0   0   0   0   0   0   2   4   0   0   0   1   0   0   0   0]\n [  4   0   0   0   0   0   0   0   0  14   0   2   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   2   8   0   1   1   3   0   0   0]\n [  3   1   0   0   0   0   0   0   0   2   0   5   2   0   1   1   1   0]\n [  0   2   0   0   0   0   1   0   0   2   5   2   8   0   0   0   6   0]\n [  0   0   0   0   1   0   0   0   1   2   0   0   0  10   2   0   2   0]\n [  0   0   0   0   1   0   0   0   0   2   0   1   0   1   7   0   0   0]\n [  1   0   1   2   0   0   0   0   0   0   1   0   0   0   0   3   0   1]\n [  0   1   1   0   0   0   1   0   0   1   0   0   0   0   2   0  11   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   1   7]]",
                "lineage": "5601"
            }
        ],
        "57": [],
        "58": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8315629742033384,
                "model_info": "Confusion Matrix:\n [[404   2   0   0   1   0   0   1   1   0   0   0   0   0   0   2   0   0]\n [  1  11   3   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   4   0   0   0   0   0   0   0   2   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   0   0   0   0   0   1   0   0   0]\n [  4   0   1   0   1   0   0   0   1   7   2   4   0   0   0   0   0   0]\n [  2   0   0   0   1   0   0   0   0   0  14   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   2   1   0   7   0   0   0   0   1   1]\n [  0   1   0   0   0   0   1   0   1   5   1   1   8   0   0   0   6   2]\n [  0   0   0   0   2   1   0   0   1   1   0   1   0   5   6   0   1   0]\n [  0   0   0   0   1   0   0   0   1   0   0   1   1   0   6   0   0   2]\n [  3   0   1   0   0   0   1   0   0   0   0   0   0   0   0   4   0   0]\n [  0   0   1   1   0   0   0   0   0   0   3   0   0   0   1   0  11   1]\n [  0   1   1   0   0   0   0   0   0   0   0   0   1   0   1   0   3   3]]",
                "lineage": "5801"
            }
        ],
        "59": [],
        "60": [],
        "61": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    # Implementing task weighting to prioritize more challenging gestures\n    class_weights = torch.tensor([1.0 if i < 10 else 2.0 for i in range(18)]).to(device)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Confusion Matrix:\n [[401   0   0   0   1   1   0   0   1   0   1   1   1   0   0   2   0   2]\n [  2   8   1   0   0   0   0   2   2   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   2  16   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   4   3   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   0   7   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   1   0   0   0   0  11   4   1   0   1   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  16   0   0   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   4   1   0   6   1   0   0   0   0   1]\n [  0   0   0   0   0   0   1   0   3   1   1   1  13   2   0   0   3   1]\n [  1   0   0   0   0   1   0   0   1   3   1   0   0   7   2   0   2   0]\n [  0   0   0   0   0   0   0   0   0   1   0   0   1   1   8   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   0   0   2  11   4]\n [  0   0   0   0   0   0   1   0   0   0   0   0   1   0   1   0   1   6]]\nConfusion Matrix:\n [[400   3   0   0   3   0   0   2   0   0   0   0   1   0   0   1   0   1]\n [  0  13   1   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  1   0   8   0   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   2   1  15   1   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0  ",
                "lineage": "6101"
            }
        ],
        "62": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    augmented_train_data = []\n    augmented_train_labels = []\n    for i in range(len(train_data_scaled)):\n        augmented_train_data.append(train_data_scaled[i])\n        augmented_train_labels.append(train_label[i])\n        if np.random.rand() > 0.5:\n            augmented_train_data.append(np.flip(train_data_scaled[i], axis=1))\n            augmented_train_labels.append(train_label[i])\n    \n    augmented_train_data = np.array(augmented_train_data)\n    augmented_train_labels = np.array(augmented_train_labels)\n\n    train_tensor = torch.FloatTensor(augmented_train_data).to(device)\n    train_label_tensor = torch.LongTensor(augmented_train_labels).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8088012139605463,
                "model_info": "Confusion Matrix:\n [[400   3   0   0   1   1   1   2   1   1   0   0   0   1   0   0   0   0]\n [  1  12   0   0   0   0   1   0   0   0   0   1   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  1   0   1  15   0   0   1   0   0   0   0   0   0   1   0   0   1   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   3   2   0   0   0   0   0   0   1   0]\n [  1   0   0   0   2   0   0   0   0   9   0   3   1   0   0   0   2   2]\n [  0   0   0   0   0   0   0   0   0   2  12   0   0   0   0   0   3   0]\n [  5   0   0   0   0   0   0   0   1   1   1   5   2   0   0   0   1   0]\n [  0   0   0   0   0   0   1   0   3   0   4   1   8   2   1   0   4   2]\n [  1   0   0   0   0   3   0   0   0   1   0   0   1   6   3   0   3   0]\n [  0   0   0   0   0   1   0   0   2   0   0   0   0   1   6   0   1   1]\n [  2   0   0   1   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   1   0   1   0   0   0   4   3   2   0   0   1   0   0   5   1]\n [  0   2   0   0   0   0   0   0   0   3   0   1   1   1   0   0   0   2]]",
                "lineage": "6201"
            }
        ],
        "63": [],
        "64": [],
        "65": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    jittered_train_data = train_data_scaled + np.random.normal(0, 0.01, train_data_scaled.shape)\n\n    train_tensor = torch.FloatTensor(jittered_train_data).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "Confusion Matrix:\n [[400   3   1   0   0   0   0   0   0   0   0   0   1   0   0   6   0   0]\n [  1  13   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  14   0   0   1   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   1   6   1   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   1   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0  13   1   2   0   0   0   3   1   0]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   1   0   0]\n [  2   0   0   0   0   0   0   0   0   1   0   8   2   0   1   2   0   0]\n [  0   0   0   0   0   0   1   0   0   1   0   0  20   2   1   0   1   0]\n [  0   0   0   0   0   0   0   0   1   1   0   0   0  10   4   1   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   8   0   1   1]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   1   2   0   0   0   0   1  11   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0   1   7]]",
                "lineage": "6501"
            }
        ],
        "66": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    augmented_train_data = []\n    augmented_train_labels = []\n    \n    for i in range(len(train_data_scaled)):\n        augmented_train_data.append(train_data_scaled[i])\n        augmented_train_labels.append(train_label[i])\n        if i % 4 == 0:  \n            augmented_train_data.append(train_data_scaled[i] * np.random.uniform(0.95, 1.05))\n            augmented_train_labels.append(train_label[i])\n    \n    augmented_train_tensor = torch.FloatTensor(np.array(augmented_train_data)).to(device)\n    augmented_train_label_tensor = torch.LongTensor(np.array(augmented_train_labels)).to(device)\n    \n    augmented_train_dataset = TensorDataset(augmented_train_tensor, augmented_train_label_tensor)\n    augmented_train_loader = DataLoader(augmented_train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in augmented_train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Confusion Matrix:\n [[405   1   1   0   0   0   0   0   0   0   0   0   0   2   0   2   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   6   3   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   4  13   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   6   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   0   0   0   7   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  16   1   2   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   2  11   0   3   0   0   1   0   0]\n [  2   0   0   0   0   0   0   0   0   3   0   7   1   0   2   0   1   0]\n [  0   0   0   0   0   0   0   0   1   1   0   0  16   0   0   0   6   2]\n [  0   0   0   0   1   3   0   0   1   0   0   0   0   9   3   0   1   0]\n [  0   0   0   0   1   0   0   0   0   0   0   0   1   1   9   0   0   0]\n [  3   1   0   0   0   0   0   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   1   0   0  11   3]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   1   0   1   6]]",
                "lineage": "6601"
            }
        ],
        "67": [],
        "68": [],
        "69": [],
        "70": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, lfilter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=10.0, fs=100.0, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = lfilter(b, a, data)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    train_data_filtered = lowpass_filter(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_filtered = lowpass_filter(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_filtered.reshape(-1, 16)).reshape(train_data_filtered.shape)\n    val_data_scaled = scaler.transform(val_data_filtered.reshape(-1, 16)).reshape(val_data_filtered.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.7708649468892261,
                "model_info": "Confusion Matrix:\n [[399   3   0   0   2   0   0   3   1   0   1   1   1   0   0   0   0   0]\n [  1   9   0   0   0   0   0   0   0   2   1   2   2   0   0   0   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   2   1  13   0   0   0   1   1   0   0   0   0   0   2   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   1   1   0  10   0   0   0   0   0   0   0   2   0   0   0]\n [  0   1   0   0   0   0   0   4   1   0   0   0   2   0   0   2   0   0]\n [  1   1   0   0   0   0   0   0   1   2   2   0   0   0   0   0   0   2]\n [  1   0   0   0   4   0   0   0   0  13   0   2   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   1   1   5   1   5   0   1   1   0   2]\n [  4   0   0   0   0   0   0   1   1   1   2   5   1   1   0   0   0   0]\n [  0   2   0   3   0   0   0   2   1   1   5   2   6   0   1   0   1   2]\n [  0   0   1   0   1   3   0   1   0   1   0   0   0   2   3   1   1   4]\n [  0   0   1   0   0   1   0   0   0   0   2   0   0   2   3   1   0   2]\n [  1   0   0   1   0   0   0   0   0   0   0   1   0   0   1   5   0   0]\n [  0   1   0   0   0   1   0   0   1   3   1   1   0   2   1   0   4   3]\n [  0   0   0   0   0   0   0   1   0   1   0   1   0   2   0   0   0   5]]",
                "lineage": "7001"
            }
        ],
        "71": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    train_data_segmented = train_data_reshaped  # Assuming segmentation is done outside this function\n    val_data_segmented = val_data_reshaped  # Assuming segmentation is done outside this function\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_segmented.reshape(-1, 16)).reshape(train_data_segmented.shape)\n    val_data_scaled = scaler.transform(val_data_segmented.reshape(-1, 16)).reshape(val_data_segmented.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Confusion Matrix:\n [[402   2   0   0   1   1   0   1   0   0   0   0   0   2   0   2   0   0]\n [  1  13   1   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  17   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   4   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   0   0   0   4   0   0   1   0   0   0   0   0   2]\n [  3   0   0   0   1   0   0   0   1  12   1   1   0   0   1   0   0   0]\n [  0   0   0   0   0   0   0   0   0   3  14   0   0   0   0   0   0   0]\n [  2   0   0   1   1   0   0   0   0   0   0   9   0   1   1   0   0   1]\n [  0   0   0   0   0   0   1   0   1   0   0   1  17   0   1   0   4   1]\n [  2   0   0   0   0   2   0   0   1   0   0   0   0   7   5   0   1   0]\n [  0   0   0   0   1   0   0   0   0   0   0   1   0   0   8   0   1   1]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   1   0   0   0   0   0   0   1  13   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0   1   7]]",
                "lineage": "7101"
            }
        ],
        "72": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, filtfilt\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=10, fs=100, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = filtfilt(b, a, data, axis=0)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data)\n    val_data_filtered = lowpass_filter(val_data)\n    \n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.5887708649468892,
                "model_info": "Confusion Matrix:\n [[365   0   0   3   4   5   5   4   2  11   0   1   3   0   4   3   0   1]\n [ 15   0   0   0   0   0   2   0   0   0   0   0   0   0   0   0   0   0]\n [  7   0   0   0   1   0   1   0   0   0   0   0   0   0   0   0   1   0]\n [ 14   0   0   3   0   0   1   0   0   1   0   0   0   0   0   0   1   0]\n [  9   0   0   0   2   0   0   0   0   0   0   0   0   0   2   0   0   0]\n [  2   0   0   0   2   4   0   0   0   0   0   0   0   0   0   1   0   0]\n [  7   0   0   0   0   0   3   0   0   0   0   0   0   0   3   0   1   0]\n [  6   0   0   0   0   0   1   3   0   0   0   0   0   0   0   0   0   0]\n [  6   0   0   0   0   0   0   0   1   1   0   0   0   0   1   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   2   0   0   0   1   0   0   0   0]\n [ 14   0   0   1   0   0   0   0   0   0   2   0   0   0   0   0   0   0]\n [ 10   0   0   0   0   1   1   1   0   0   0   0   0   0   1   0   2   0]\n [ 22   0   0   1   0   0   2   0   0   0   0   0   0   0   0   0   1   0]\n [ 17   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0   0]\n [  6   0   0   0   0   0   0   0   0   2   1   0   0   0   2   0   0   1]\n [  8   0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [ 15   0   0   1   0   0   0   0   2   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0]]",
                "lineage": "7201"
            }
        ],
        "73": [],
        "74": [],
        "75": [],
        "76": [],
        "77": [],
        "78": [],
        "79": [],
        "80": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, lfilter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=3.0, fs=100.0, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = lfilter(b, a, data)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data, cutoff=3.0)\n    val_data_filtered = lowpass_filter(val_data, cutoff=3.0)\n    \n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    \n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.7177541729893778,
                "model_info": "Confusion Matrix:\n [[403   4   0   0   0   0   0   2   0   0   0   1   0   0   0   1   0   0]\n [  1   4   1   1   0   0   0   1   0   4   0   4   0   0   0   0   0   1]\n [  0   1   4   2   0   0   0   0   0   0   0   1   0   0   2   0   0   0]\n [  1   0   1   8   2   1   2   0   0   0   2   0   2   0   0   0   0   1]\n [  0   0   1   0   2   0   0   0   0   1   1   3   0   0   0   0   2   3]\n [  0   1   0   0   0   5   0   0   0   1   0   0   0   0   0   0   1   1]\n [  0   0   0   1   0   1   8   0   0   0   0   0   0   0   1   0   1   2]\n [  3   0   1   0   0   0   0   4   0   0   0   0   1   0   0   1   0   0]\n [  1   1   0   1   1   0   0   0   0   1   2   0   0   0   0   0   2   0]\n [  6   0   1   0   1   2   0   0   1   3   0   2   1   0   0   0   0   3]\n [  1   0   0   0   1   3   0   0   0   1   2   1   4   0   0   1   2   1]\n [  5   0   0   0   2   1   0   0   2   0   1   5   0   0   0   0   0   0]\n [  1   0   0   1   3   5   0   2   2   0   1   3   6   0   1   0   0   1]\n [  0   0   2   0   1   1   0   0   1   4   2   2   0   0   0   1   3   1]\n [  0   1   1   2   1   0   0   0   1   1   2   1   0   0   2   0   0   0]\n [  1   0   1   1   1   0   0   1   0   0   0   2   0   0   0   2   0   0]\n [  0   1   1   0   0   1   0   0   0   3   0   1   0   0   0   0  10   1]\n [  0   0   1   0   0   0   0   0   0   3   0   1   0   0   0   0   0   5]]",
                "lineage": "8001"
            }
        ],
        "81": [],
        "82": [],
        "83": [],
        "84": [],
        "85": [],
        "86": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXX.py",
                "accuracy": 0.8786039453717754,
                "model_info": "Confusion Matrix:\n [[403   1   0   0   0   0   0   0   1   0   0   0   1   2   0   3   0   0]\n [  1  12   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   3  14   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   0  14   0   0   0   1   0   1   1   0]\n [  0   0   0   0   0   0   0   0   0   0  17   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   2   0   0   6   1   1   1   0   0   2]\n [  0   0   0   0   0   0   1   0   1   0   2   1  16   0   0   0   3   2]\n [  0   0   0   0   0   2   0   0   1   0   1   0   0  10   3   0   1   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   0   1   8   0   0   1]\n [  1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   8   0   0]\n [  0   1   0   0   0   0   0   0   0   0   2   0   0   0   0   1  11   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   1   8]]",
                "lineage": "8601"
            }
        ],
        "87": [],
        "88": [],
        "89": [],
        "90": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, filtfilt\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=3.0, fs=100.0, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = filtfilt(b, a, data, axis=0)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data)\n    val_data_filtered = lowpass_filter(val_data)\n    \n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.622154779969651,
                "model_info": "Confusion Matrix:\n [[409   0   0   0   0   1   0   0   0   0   0   0   0   0   1   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 10   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 20   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 13   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 14   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 10   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 19   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 16   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 24   0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [ 12   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [ 10   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]]",
                "lineage": "9001"
            }
        ],
        "91": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool1d(x, kernel_size=2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool1d(x, kernel_size=2)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.779969650986343,
                "model_info": "Confusion Matrix:\n [[397   1   1   0   2   0   0   2   3   0   1   0   0   0   0   4   0   0]\n [  1  10   1   0   0   0   0   0   0   0   0   2   0   0   0   1   1   1]\n [  0   0   7   1   0   0   0   0   0   0   0   1   0   0   1   0   0   0]\n [  0   0   3  11   0   0   1   0   0   0   0   0   0   2   0   1   0   2]\n [  0   0   0   0   9   3   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   1   3   4   0   0   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   2   0   0  10   0   0   0   0   0   0   0   1   0   0   1]\n [  1   0   1   0   0   0   1   6   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   2   0   0   0   0   0   0   1   1   0   2   0   2]\n [  1   1   0   0   0   0   0   1   5   6   0   3   0   0   0   0   0   3]\n [  0   0   1   0   0   0   0   0   0   2  10   0   0   1   2   1   0   0]\n [  3   0   0   0   1   0   0   0   4   0   0   2   1   0   2   1   1   1]\n [  0   0   2   1   0   0   0   1   2   1   2   1  10   0   0   0   3   3]\n [  0   0   0   0   2   2   0   0   0   0   0   1   1   5   2   0   3   2]\n [  0   0   1   0   2   0   0   0   1   0   1   1   0   0   4   1   0   1]\n [  1   0   0   0   0   0   1   0   1   0   0   0   0   0   0   4   1   1]\n [  0   0   2   1   0   0   0   0   0   0   1   0   0   0   2   0  11   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   2   8]]",
                "lineage": "9101"
            }
        ],
        "92": [],
        "93": [],
        "94": [],
        "95": [],
        "96": [],
        "97": [],
        "98": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "Confusion Matrix:\n [[402   3   0   0   0   0   1   0   0   0   0   0   0   3   0   1   0   1]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  13   0   0   0   0   0   0   0   0   0   0   0   2   0   1]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   4   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   0   6   0   0   0   0   2   0   0   0   0]\n [  2   0   0   0   1   0   0   0   0  12   1   3   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   2  15   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   2   0   0   6   2   1   0   1   0   1]\n [  1   0   0   0   0   0   1   0   3   0   2   0  16   1   1   0   0   1]\n [  1   0   0   0   0   2   0   0   1   0   0   0   0   8   4   0   2   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0  10   0   0   2]\n [  1   0   0   0   0   0   1   0   0   0   0   0   0   1   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   0   0   0   1  12   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   0   8]]",
                "lineage": "9801"
            }
        ],
        "99": [],
        "100": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        if epoch < 10:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] = 0.001 * (epoch + 1) / 10\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8786039453717754,
                "model_info": "Confusion Matrix:\n [[404   2   0   0   1   0   0   0   0   1   0   0   0   0   0   2   0   1]\n [  1  14   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   1   4  14   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  1   0   0   0  12   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   6   1   0   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   0   0   1   0   1   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  13   2   3   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   1  14   0   0   0   0   0   2   0]\n [  3   0   0   0   0   0   0   0   0   0   0   7   3   0   2   0   1   0]\n [  0   1   0   0   0   0   0   0   0   0   1   2  17   0   0   0   4   1]\n [  1   0   0   0   0   2   0   0   0   1   0   0   1   7   4   0   2   0]\n [  0   0   0   0   0   1   0   0   0   0   0   0   1   0   9   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  1   0   1   0   0   0   0   0   0   0   2   0   0   0   0   0  13   1]\n [  0   0   1   0   0   0   0   0   0   0   0   0   1   0   1   0   0   7]]",
                "lineage": "10001"
            }
        ],
        "101": [],
        "102": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    noise = np.random.normal(0, 0.01, train_data_scaled.shape)\n    train_data_scaled_noisy = train_data_scaled + noise\n    \n    train_tensor = torch.FloatTensor(train_data_scaled_noisy).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Confusion Matrix:\n [[401   1   0   0   1   1   3   1   0   0   1   0   1   0   0   0   0   1]\n [  1  11   1   0   0   0   0   3   0   0   0   0   0   0   0   1   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  17   0   0   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   1   0   1   5   0   0   0   0   0   0   0   0   1]\n [  2   0   0   0   0   0   0   0   0  15   2   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   1   0   0   0   0]\n [  5   0   0   0   0   0   0   0   1   1   0   5   3   0   1   0   0   0]\n [  0   0   0   0   0   0   1   0   2   1   3   0  17   0   0   0   2   0]\n [  0   0   0   0   0   1   0   0   1   1   0   0   0  11   3   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0  10   0   0   0]\n [  1   1   0   0   0   0   0   0   0   0   0   0   0   1   0   6   0   0]\n [  1   0   0   1   0   1   0   0   0   0   1   0   1   0   0   0  10   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   9]]",
                "lineage": "10201"
            }
        ],
        "103": [],
        "104": [],
        "105": [],
        "106": [],
        "107": [],
        "108": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.fft import fft\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    train_data_fft = np.abs(fft(train_data_reshaped, axis=1))\n    val_data_fft = np.abs(fft(val_data_reshaped, axis=1))\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_fft.reshape(-1, 16)).reshape(train_data_fft.shape)\n    val_data_scaled = scaler.transform(val_data_fft.reshape(-1, 16)).reshape(val_data_fft.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Confusion Matrix:\n [[406   1   0   0   1   0   0   0   0   1   1   0   0   0   0   1   0   0]\n [  0  15   0   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   7   1   0   0   0   0   0   0   0   1   0   1   0   0   0   0]\n [  0   0   2  17   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   2   1   0   1   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   1   0  12   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   1   0   0   8   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   1   0   0   0   0   6   0   0   0   1   0   0   0   0   0]\n [  1   0   2   0   1   0   0   0   1   9   4   2   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   0   0  10   0   1   0   0   0   3   1]\n [  3   0   0   0   0   0   0   0   1   0   1   9   1   0   0   0   0   1]\n [  2   0   0   0   0   0   0   0   2   0   1   0  14   0   0   0   5   2]\n [  0   0   0   0   0   2   0   0   1   1   0   1   0   7   2   0   2   2]\n [  0   0   1   0   0   1   0   0   0   0   1   0   1   1   5   0   1   1]\n [  2   0   0   1   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   1   1   0   0   0   0   0   2   1   0   0  10   3]\n [  0   0   0   0   1   0   0   0   0   1   0   0   1   1   0   0   0   6]]",
                "lineage": "10801"
            }
        ],
        "109": [],
        "110": [],
        "111": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context_vector = torch.bmm(attention_weights.transpose(1, 2), lstm_out).squeeze(1)\n        x = self.fc(context_vector)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8770864946889226,
                "model_info": "Confusion Matrix:\n [[403   1   0   0   1   0   1   1   0   0   0   0   0   1   0   2   0   1]\n [  0  15   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  17   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   4   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   6   0   0   0   0   1   0   0   0   0]\n [  3   0   0   0   0   0   0   0   1  11   0   3   1   0   0   0   0   1]\n [  1   0   0   0   0   0   1   0   0   1  13   0   0   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   2   1   0   7   2   0   2   0   0   0]\n [  0   1   0   0   0   0   0   0   1   1   1   2  19   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   0   1   0   0   0  10   5   0   2   0]\n [  0   0   0   0   0   0   0   0   1   0   0   0   2   0   8   0   0   1]\n [  1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   8   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   1   0   1   0  12   2]\n [  0   0   0   0   0   1   1   0   0   0   0   0   0   1   1   0   0   6]]",
                "lineage": "11101"
            }
        ],
        "112": [],
        "113": [],
        "114": [],
        "115": [],
        "116": [],
        "117": [],
        "118": [],
        "119": [],
        "120": [],
        "121": [],
        "122": [],
        "123": [],
        "124": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            noise = torch.randn_like(inputs) * 0.01\n            inputs_noisy = inputs + noise\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs_noisy)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8482549317147192,
                "model_info": "Confusion Matrix:\n [[399   4   1   0   0   0   1   0   0   0   0   0   1   1   0   3   0   1]\n [  1  14   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  13   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   0   0   0   0   0   7   1   0   0   0   1   0   0   0   0   0]\n [  1   1   0   0   0   2   0   0   5   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   0   0   0   1  10   3   2   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   2  14   1   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   2   1   0   7   2   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   1   2   1   1  14   0   0   1   5   1]\n [  0   0   0   0   1   1   0   0   1   1   0   0   0   7   3   0   4   0]\n [  0   0   0   0   0   1   0   0   1   0   0   1   0   1   5   0   1   2]\n [  1   2   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  0   1   0   0   0   0   0   0   0   0   3   0   2   0   0   0  11   1]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   1   0   0   0   8]]",
                "lineage": "12401"
            }
        ],
        "125": [],
        "126": [],
        "127": [],
        "128": [],
        "129": [],
        "130": [],
        "131": [],
        "132": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass TemporalPoolingModel(nn.Module):\n    def __init__(self, base_model):\n        super(TemporalPoolingModel, self).__init__()\n        self.base_model = base_model\n        self.pool = nn.AdaptiveAvgPool1d(52)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.pool(x)\n        x = x.view(-1, 52, 16)\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    temporal_pooling_model = TemporalPoolingModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(temporal_pooling_model.parameters(), lr=0.001)\n    \n    temporal_pooling_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = temporal_pooling_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    temporal_pooling_model.eval()\n    with torch.no_grad():\n        val_outputs = temporal_pooling_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Confusion Matrix:\n [[401   2   0   0   1   1   0   0   0   0   0   0   1   1   1   2   0   1]\n [  0  13   1   1   0   0   0   0   0   0   0   1   0   0   0   1   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   6   1   0   0   0   1   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  13   1   2   0   0   0   1   0   1]\n [  0   0   0   0   0   0   0   0   0   2  15   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   1   0   1   6   2   0   2   0   1   0]\n [  1   0   0   0   0   0   0   0   2   0   1   0  15   0   0   0   6   1]\n [  0   0   0   0   1   2   0   0   1   0   0   0   0   8   5   0   1   0]\n [  0   0   0   0   0   0   0   0   1   0   0   2   0   0   7   0   0   2]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   0   0   0   0  12   4]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   1   7]]",
                "lineage": "13201"
            }
        ],
        "133": [],
        "134": [],
        "135": [],
        "136": [],
        "137": [],
        "138": [],
        "139": [],
        "140": [],
        "141": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.attention = nn.Linear(128, 1)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        attn_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context_vector = torch.bmm(attn_weights.transpose(1, 2), lstm_out).squeeze(1)\n        x = self.fc(context_vector)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Confusion Matrix:\n [[401   4   0   0   2   1   1   0   0   0   0   0   1   1   0   0   0   0]\n [  1  14   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   1   7   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   3  17   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   1   6   2   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  12   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   1   0   0   4   0   0   0   1   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   1  15   1   1   0   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   0   2  13   0   0   0   0   0   1   1]\n [  3   0   1   0   0   0   0   0   0   1   0   6   2   0   0   0   1   2]\n [  1   0   0   0   0   0   0   0   0   1   0   1  18   4   0   0   1   0]\n [  0   0   0   0   0   4   0   0   1   0   0   0   0   9   2   0   2   0]\n [  0   0   1   0   0   0   0   0   1   0   0   0   0   1   5   0   1   3]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   0   0   0  12   5]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   9]]",
                "lineage": "14101"
            }
        ],
        "142": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "Confusion Matrix:\n [[402   1   1   0   1   0   0   0   0   0   0   0   1   2   0   2   1   0]\n [  0  14   1   0   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  1   1   7   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  16   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   8   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   1   0   0   0   1   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  13   1   2   0   0   0   1   0   1]\n [  0   0   0   0   0   0   0   0   0   2  14   0   0   0   0   0   0   1]\n [  2   0   0   0   0   0   0   0   0   1   0   7   3   0   1   1   0   1]\n [  0   0   0   0   0   0   1   0   0   1   1   1  18   1   1   0   2   0]\n [  0   0   0   0   0   2   0   0   0   0   0   0   0  12   2   0   2   0]\n [  0   0   1   1   0   0   0   0   0   1   0   0   1   2   5   0   0   1]\n [  1   1   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   1   0   2   0   1   0   0   0  12   2]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   8]]",
                "lineage": "14201"
            }
        ],
        "143": [],
        "144": [],
        "145": [],
        "146": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, lfilter\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=10, fs=100, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    return lfilter(b, a, data)\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data, cutoff=10, fs=100)\n    val_data_filtered = lowpass_filter(val_data, cutoff=10, fs=100)\n    \n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.7647951441578149,
                "model_info": "Confusion Matrix:\n [[399   2   0   0   6   0   0   0   1   0   0   0   2   0   1   0   0   0]\n [  1   8   1   0   0   0   0   0   1   2   0   3   1   0   0   0   0   0]\n [  1   0   7   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  10   1   1   0   0   0   0   1   0   0   0   0   1   2   2]\n [  0   0   0   0  10   1   0   0   1   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   1   0   2   8   0   0   0   0   0   0   1   2   0   0   0]\n [  3   0   0   0   1   1   0   4   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   1   0   0   0   0   3   2   0   0   0   0   0   0   0   1]\n [  1   0   0   0   3   0   0   0   0   9   2   3   1   0   0   0   1   0]\n [  0   0   0   5   0   0   0   0   3   2   5   0   2   0   0   0   0   0]\n [  4   0   0   0   0   0   0   1   1   0   3   6   0   0   1   0   0   0]\n [  0   0   0   4   0   0   0   2   1   0   2   1  11   0   1   0   4   0]\n [  0   0   2   0   2   2   0   0   1   0   0   0   0   3   2   2   0   4]\n [  0   0   0   0   0   0   0   0   3   1   0   1   0   2   2   3   0   0]\n [  1   0   1   0   0   0   0   0   0   0   0   1   1   0   0   3   1   1]\n [  0   0   1   0   0   0   0   0   1   1   2   0   0   2   1   1   6   3]\n [  0   0   1   0   0   1   0   0   1   1   0   1   0   0   0   0   0   5]]",
                "lineage": "14601"
            }
        ],
        "147": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8194233687405159,
                "model_info": "Confusion Matrix:\n [[402   4   0   0   0   1   0   0   0   0   0   0   0   0   1   2   0   1]\n [  1  12   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   1   2   4   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   1   0   0   0   1   0   0   0   0]\n [  3   0   1   0   1   0   0   0   1   5   3   5   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0   0  15   0   0   1   0   0   0   0]\n [  3   0   0   0   0   0   0   0   3   0   1   6   1   0   2   0   0   0]\n [  0   2   0   0   0   0   0   0   0   0   2   5   3   1   1   0   5   7]\n [  0   0   0   0   1   1   0   0   2   3   0   0   0   3   7   0   1   0]\n [  0   0   1   0   0   0   0   0   1   1   2   1   0   0   6   0   0   0]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   2   1   0   0   0   0  12   2]\n [  0   0   2   0   0   0   0   0   0   0   0   0   1   0   1   0   2   4]]",
                "lineage": "14701"
            }
        ],
        "148": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            time_shifted_inputs = inputs.roll(shifts=np.random.randint(-5, 5), dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(time_shifted_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Confusion Matrix:\n [[398   2   1   0   0   2   0   1   2   0   0   0   0   0   2   3   0   0]\n [  0  13   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   3   0   0   3   0   0   0   0   1   0   0   0   0]\n [  1   0   0   0   0   2   0   0   0  14   0   0   0   1   0   2   0   0]\n [  0   0   0   0   0   0   0   0   0   3  12   0   0   0   0   0   1   1]\n [  3   0   0   0   0   0   0   0   3   2   0   5   1   0   2   0   0   0]\n [  0   1   0   0   0   0   0   0   1   3   1   0  15   2   0   0   3   0]\n [  0   0   0   0   0   3   0   0   0   2   0   0   0   9   4   0   0   0]\n [  0   0   0   0   1   0   0   0   0   0   0   0   0   1   8   0   0   2]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   0  15   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   0   8]]",
                "lineage": "14801"
            }
        ],
        "149": [],
        "150": [],
        "151": [],
        "152": [],
        "153": [],
        "154": [],
        "155": [],
        "156": [],
        "157": [],
        "158": [],
        "159": [],
        "160": [],
        "161": [],
        "162": [],
        "163": [],
        "164": [],
        "165": [],
        "166": [],
        "167": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            random_indices = torch.randint(0, inputs.size(0), (inputs.size(0),))\n            blended_inputs = (inputs + inputs[random_indices]) / 2\n            optimizer.zero_grad()\n            outputs = contrastive_model(blended_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.7845220030349014,
                "model_info": "Confusion Matrix:\n [[407   0   1   0   0   0   1   0   0   0   0   0   0   0   0   2   0   0]\n [  5  10   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  2   0   6   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  6   0   0  14   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  4   0   0   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   6   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  4   0   0   0   0   0   0   6   0   0   0   0   0   0   0   0   0   0]\n [  3   1   0   0   0   1   0   0   4   0   0   0   0   0   0   0   0   0]\n [ 16   0   0   0   0   0   0   0   0   2   0   1   0   0   1   0   0   0]\n [  5   0   0   0   0   0   0   0   0   0  10   0   0   0   0   0   2   0]\n [ 11   0   0   0   0   0   0   0   3   0   0   1   0   0   1   0   0   0]\n [  7   0   0   0   0   0   0   0   6   0   1   0   3   0   0   0   7   2]\n [  8   0   0   0   0   1   0   0   1   0   0   0   0   4   4   0   0   0]\n [  4   0   0   0   0   0   0   0   1   0   0   0   0   0   7   0   0   0]\n [  2   1   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  6   0   0   0   0   0   0   0   1   0   1   0   1   0   0   0   9   0]\n [  1   0   2   0   0   0   0   0   0   0   0   0   0   0   0   0   1   6]]",
                "lineage": "16701"
            }
        ],
        "168": [],
        "169": [],
        "170": [],
        "171": [],
        "172": [],
        "173": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=5, padding=2)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    \n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.7921092564491654,
                "model_info": "Confusion Matrix:\n [[397   4   0   0   0   1   0   3   0   0   2   1   0   1   0   2   0   0]\n [  1   9   3   0   0   0   0   1   0   0   0   0   1   0   0   2   0   0]\n [  0   1   5   1   0   0   0   0   0   1   0   0   0   1   0   1   0   0]\n [  0   0   3  14   0   0   0   0   0   0   0   0   0   0   0   3   0   0]\n [  0   0   0   0   9   3   0   0   0   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   0   0   0   0   0   0   0   2   0   0   0   0]\n [  0   0   1   1   1   0  10   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   0   0   0   8   2   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   5   1   0   0   0   1   0   0   0   0]\n [  1   0   2   0   1   0   0   0   0   6   2   3   1   0   1   0   3   0]\n [  0   0   1   0   0   0   0   0   0   0  12   0   0   0   2   0   2   0]\n [  4   0   1   1   0   0   0   0   0   3   0   3   0   0   2   0   1   1]\n [  1   0   1   0   0   1   0   0   2   2   2   0  11   0   0   1   5   0]\n [  0   0   0   0   1   2   0   0   1   0   4   2   0   5   1   0   1   1]\n [  0   0   0   0   0   1   0   0   1   0   0   1   2   1   4   2   0   0]\n [  1   1   0   1   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   2   0   3   0   0   0   1   3   0   0   0   0   1   7   1]\n [  0   0   1   0   0   0   0   0   0   1   1   0   0   0   0   0   1   6]]",
                "lineage": "17301"
            }
        ],
        "174": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXX.py",
                "accuracy": 0.8801213960546282,
                "model_info": "Confusion Matrix:\n [[399   5   0   0   0   0   1   0   1   0   0   0   0   3   0   1   0   1]\n [  0  14   0   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   1  17   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   9   3   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   0   7   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0  15   2   0   1   1   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   1   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   3   0   0   5   4   0   2   0   0   0]\n [  1   0   0   0   0   0   0   0   1   0   0   2  21   0   0   0   1   0]\n [  0   0   0   0   0   1   0   0   1   1   0   0   0  11   3   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0   0   1   2   0   6   0   0   3]\n [  1   1   0   0   0   0   1   0   0   0   1   0   0   0   0   5   0   0]\n [  1   0   0   1   0   0   0   0   0   0   1   0   0   0   0   0  12   3]\n [  0   0   0   1   0   0   0   0   0   0   0   0   0   0   1   0   0   8]]",
                "lineage": "17401"
            }
        ],
        "175": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7890743550834598,
                "model_info": "Confusion Matrix:\n [[399   5   0   0   1   0   0   1   0   0   1   0   0   2   0   2   0   0]\n [  1  11   2   0   0   0   0   1   0   0   0   0   0   0   0   1   1   0]\n [  1   1   5   1   0   0   0   0   0   1   0   0   0   0   1   0   0   0]\n [  0   0   3  12   0   1   1   0   0   0   0   0   0   1   0   0   1   1]\n [  0   0   0   0   7   4   0   0   1   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   1   6   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   1   0   1   0  11   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   8   0   0   0   0   1   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   2   0   0   1   1   0   0   0   2   0]\n [  2   1   1   0   0   0   0   0   1   3   2   3   1   1   1   0   3   1]\n [  0   0   1   0   0   1   0   0   0   0  10   0   2   0   1   0   0   2]\n [  4   0   1   0   0   0   0   0   2   1   0   4   1   1   0   0   1   1]\n [  0   2   1   0   0   0   0   0   4   0   1   2  11   0   0   0   4   1]\n [  0   0   0   0   1   1   0   0   1   0   3   0   0   7   3   0   2   0]\n [  0   0   0   0   1   1   0   0   1   0   0   0   2   1   5   0   0   1]\n [  1   1   2   0   0   0   0   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   0   1   0   2   0   0   1   1   3   0   0   2   0   0   8   0]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   0   2   0   1   6]]",
                "lineage": "17501"
            }
        ],
        "176": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Confusion Matrix:\n [[404   1   0   0   1   0   0   0   0   0   0   0   1   2   0   2   0   0]\n [  0  13   1   1   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  14   0   0   0   0   0   0   0   0   0   0   1   1   0   0]\n [  1   0   0   0  12   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   6   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   7   1   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   0   0   0   0   1   0   1   3   1   0   0   1   0]\n [  4   0   0   0   0   0   0   0   0  10   0   6   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0   1  14   0   0   0   0   1   0   0]\n [  3   0   0   0   0   0   0   0   0   0   0   6   2   0   3   0   1   1]\n [  0   0   0   0   0   0   0   0   0   0   1   3  11   0   0   0  10   1]\n [  1   0   0   0   0   1   0   0   0   0   0   0   1  10   2   0   3   0]\n [  0   0   0   0   0   0   0   0   0   1   0   0   1   1   9   0   0   0]\n [  2   0   0   0   0   0   0   1   0   0   0   0   0   0   0   6   0   0]\n [  1   0   1   0   0   0   0   0   0   0   2   0   0   0   1   0  11   2]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   1   1   0   0   7]]",
                "lineage": "17601"
            }
        ],
        "177": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=32):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8573596358118362,
                "model_info": "Confusion Matrix:\n [[399   4   0   0   0   2   0   0   0   0   0   2   1   1   0   1   0   1]\n [  0  15   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   1   7   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   1   1  17   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   0   0   0   0   0   0   0   2   0   0   0   0]\n [  0   0   0   0   0   0  12   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   0   0   1   0   0   1   0   0   0]\n [  0   2   0   0   0   0   0   0   1   6   4   4   2   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   1   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   1   0   0   6   2   0   3   0   1   1]\n [  0   0   0   0   0   0   1   0   1   0   0   0  18   0   0   0   4   2]\n [  0   0   0   0   0   1   0   0   0   1   0   1   1   7   5   0   2   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   2   0   7   0   0   2]\n [  2   1   0   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  1   0   0   0   0   0   0   0   0   0   1   0   0   0   0   1  11   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   9]]",
                "lineage": "17701"
            }
        ],
        "178": [],
        "179": [],
        "180": [],
        "181": [],
        "182": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier().to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.858877086494689,
                "model_info": "Confusion Matrix:\n [[401   2   1   0   1   1   0   0   0   0   0   1   0   1   0   3   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   4  14   0   0   0   0   0   0   0   0   0   0   0   1   0   1]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   7   1   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   1   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  14   1   1   0   0   0   2   1   0]\n [  1   0   0   0   0   0   0   0   0   1  14   0   0   0   0   1   0   0]\n [  2   0   0   0   0   0   0   0   1   1   0   6   1   0   2   1   1   1]\n [  1   1   0   0   0   0   0   0   1   0   1   0  14   1   0   0   6   1]\n [  0   0   0   0   1   2   0   0   1   0   0   0   0  11   3   0   0   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   1   2   4   0   1   2]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   1   0   0   0   0   0   0   0   3   1   0   1   0   0  11   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   8]]",
                "lineage": "18201"
            }
        ],
        "183": [],
        "184": [],
        "185": [],
        "186": [],
        "187": [],
        "188": [],
        "189": [],
        "190": [],
        "191": [],
        "192": [],
        "193": [],
        "194": [],
        "195": [],
        "196": [],
        "197": [],
        "198": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nimport time\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    inference_latencies = []\n    for epoch in range(20):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            start_time = time.time()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n            inference_latencies.append(time.time() - start_time)\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        start_time = time.time()\n        val_outputs = contrastive_model(val_tensor)\n        inference_latencies.append(time.time() - start_time)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n    print(\"Inference Latency Distribution (seconds):\", inference_latencies)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.7966616084977238,
                "model_info": "Confusion Matrix:\n [[401   2   0   0   2   0   0   3   0   0   0   0   0   1   1   1   0   0]\n [  1  10   4   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   7   1   1   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   1   3  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   1   2   0   0  11   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   0   0   0   0   0   8   0   0   0   0   0   0   1   0   0   0]\n [  1   0   0   0   0   2   0   1   0   3   0   1   0   0   1   0   0   0]\n [  1   0   1   0   2   0   0   0   0   8   1   7   0   0   0   0   0   0]\n [  0   1   0   0   0   0   0   0   0   1  15   0   0   0   0   0   0   0]\n [  3   0   1   0   0   0   0   1   1   3   2   4   1   0   0   0   0   0]\n [  0   1   0   0   0   0   0   0   0   2   2   2   2   0   3   0   6   8]\n [  0   0   0   0   4   3   0   0   0   1   0   0   0   2   7   0   1   0]\n [  0   0   1   0   1   0   0   0   0   1   1   1   1   0   6   0   0   0]\n [  1   1   0   2   0   0   0   0   0   0   0   0   0   0   1   4   0   0]\n [  0   0   1   0   0   0   0   0   0   0   3   1   0   0   1   0  11   1]\n [  0   0   1   0   0   0   0   0   0   0   0   1   0   1   0   0   3   4]]\nInference Latency Distribution (seconds): [0.27992939949035645, 0.006633281707763672, 0.0059664249420166016, 0.005869626998901367, 0.005711555480957031, 0.0056896209716796875, 0.006105184555053711, 0.006697893142700195, 0.007088661193847656, 0.00759577751159668, 0.007623195648193359, 0.0075762271881103516, 0.0075702667236328125, 0.007616281509399414, 0.007634878158569336, 0.00762629508972168, 0.00760340690612793, 0.007668495178222656, 0.007627248764038086, 0.007628917694091797, 0.007592916488647461, 0.007596015930175781, 0.007605791091918945, 0.007622957229614258, 0.007614612579345703, 0.007593870162963867, 0.0076525211334",
                "lineage": "19801"
            }
        ],
        "199": [],
        "200": [],
        "201": [],
        "202": [],
        "203": [],
        "204": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.pool(torch.relu(self.conv1(x)))\n        x = self.pool(torch.relu(self.conv2(x)))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7845220030349014,
                "model_info": "Confusion Matrix:\n [[392   4   0   0   2   0   0   4   1   0   1   2   2   1   0   2   0   0]\n [  1  10   0   0   0   0   0   1   1   0   0   2   1   0   0   1   0   0]\n [  0   0   7   1   0   0   0   0   1   0   0   1   0   0   0   0   0   0]\n [  0   0   2  11   0   0   0   0   2   0   0   1   0   2   0   2   0   0]\n [  0   0   0   0  10   0   0   0   0   0   0   0   0   0   0   1   1   1]\n [  0   0   0   1   2   3   2   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   1   1   1   0  10   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   5   1   0   1   0   0   0   0   0   0]\n [  1   1   0   0   2   0   0   0   3   3   4   3   3   0   0   0   0   0]\n [  0   0   1   0   0   0   0   0   0   2  12   0   0   0   0   1   1   0]\n [  2   2   0   0   0   0   0   0   3   2   0   6   1   0   0   0   0   0]\n [  0   2   0   0   0   0   0   0   3   2   2   0  15   0   0   0   1   1]\n [  0   0   0   0   0   1   0   0   1   1   1   1   1   6   2   1   2   1]\n [  0   0   0   0   1   0   0   0   1   2   1   0   2   0   5   0   0   0]\n [  1   1   0   2   0   0   0   0   0   0   1   1   0   0   0   2   0   1]\n [  0   0   0   0   0   0   0   0   0   0   2   2   3   0   0   0   8   3]\n [  0   0   1   0   0   0   0   0   1   1   1   0   1   1   0   0   0   4]]",
                "lineage": "20401"
            }
        ],
        "205": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.pool(torch.relu(self.conv1(x)))\n        x = self.pool(torch.relu(self.conv2(x)))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7905918057663126,
                "model_info": "Confusion Matrix:\n [[405   2   0   0   0   0   0   1   0   0   0   0   0   1   0   2   0   0]\n [  1  12   0   0   0   0   1   1   0   0   0   0   1   0   0   0   1   0]\n [  1   0   6   2   0   0   0   0   0   0   1   0   0   0   0   0   0   0]\n [  0   0   0  13   0   0   3   0   0   0   0   0   0   0   0   1   1   2]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   1   6   1   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   2   1   0   9   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  0   1   1   0   0   1   1   1   1   1   0   0   0   0   0   0   0   2]\n [  2   0   0   0   0   0   0   0   0   4   2   8   0   0   2   0   0   2]\n [  0   0   4   0   0   0   0   1   0   1   7   0   2   0   0   1   0   1]\n [  4   0   1   0   0   0   0   0   1   3   0   4   0   0   2   0   0   1]\n [  0   1   5   1   0   0   0   0   1   0   0   1  10   0   3   0   1   3]\n [  0   0   0   0   2   2   0   0   0   0   2   0   1   6   2   1   1   1]\n [  0   0   0   0   0   0   0   0   0   2   2   0   0   1   7   0   0   0]\n [  3   0   1   0   0   0   1   0   0   0   0   1   0   0   1   2   0   0]\n [  0   0   2   0   0   1   0   0   0   0   2   0   1   1   1   1   6   3]\n [  0   0   1   0   0   0   0   1   0   0   0   2   0   0   1   0   0   5]]",
                "lineage": "20501"
            }
        ],
        "206": [],
        "207": [],
        "208": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8770864946889226,
                "model_info": "Confusion Matrix:\n [[407   1   0   0   1   1   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  16   0   0   0   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   8   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   1   6   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  12   3   2   0   0   0   1   0   1]\n [  1   0   0   0   0   0   0   0   0   1  14   0   0   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   3   0   1   5   0   1   1   0   2   0]\n [  0   0   0   0   1   0   0   0   2   1   1   1  16   0   0   0   3   1]\n [  0   0   0   0   0   2   0   0   1   0   0   0   0  10   3   0   2   0]\n [  0   0   0   0   0   0   0   0   1   0   0   2   0   0   7   0   0   2]\n [  3   0   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  1   0   0   1   0   0   0   0   0   0   1   0   0   0   0   0  14   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   0   8]]",
                "lineage": "20801"
            }
        ],
        "209": [],
        "210": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss(weight=torch.tensor([1.0]*18)).to(device)\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8649468892261002,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   2   0   0   3   0   0   0   0   1   1   0   2   0   0]\n [  0  13   1   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  14   0   0   0   0   0   0   0   0   0   1   0   2   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   3   1   0   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   1   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   0   1   0   0   0  14   0   1   0   1   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   3  13   0   0   0   0   0   0   1]\n [  3   0   0   0   0   0   0   0   2   1   0   6   2   0   1   1   0   0]\n [  0   1   0   0   0   0   0   0   1   0   3   1  17   1   1   0   0   1]\n [  2   0   0   0   0   1   0   0   1   1   0   0   0   8   3   0   2   0]\n [  0   0   0   0   1   0   0   0   1   0   0   0   2   0   8   0   0   0]\n [  3   0   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   1   0   0   0   0   0   1   0   3   1   2   0   0   0  10   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   9]]",
                "lineage": "21001"
            }
        ],
        "211": [],
        "212": [],
        "213": [],
        "214": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(20):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.795144157814871,
                "model_info": "Confusion Matrix:\n [[404   1   1   0   1   0   0   1   0   0   0   1   0   0   2   0   0   0]\n [  1  11   1   1   0   0   0   3   0   0   0   0   0   0   0   0   0   0]\n [  0   0   8   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  1   0   3  15   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   1   0   2   3   0   0   0   0   0   0   0   1   0   0   1   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   0   0   1   0   0   0]\n [  1   0   0   0   1   0   0   1   0   1   2   3   0   0   0   0   0   0]\n [  1   0   0   0   2   0   0   1   0   2   9   5   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   0   2  11   1   1   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   0   0   1   8   0   0   0   0   0   3]\n [  1   0   0   0   1   0   0   0   0   2   2   0   4   0   3   0   8   5]\n [  0   0   0   0   2   2   0   0   0   2   0   0   1   2   7   0   2   0]\n [  0   0   0   0   0   1   0   0   0   0   0   2   0   0   7   0   0   2]\n [  1   1   1   1   0   0   1   0   0   0   0   0   0   0   1   3   0   0]\n [  0   1   0   0   0   1   0   0   0   0   0   1   0   0   2   0  10   3]\n [  0   0   1   0   1   0   0   0   0   0   0   0   0   0   1   0   1   6]]",
                "lineage": "21401"
            }
        ],
        "215": [],
        "216": [],
        "217": [],
        "218": [],
        "219": [],
        "220": [],
        "221": [],
        "222": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool1d(x, kernel_size=2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool1d(x, kernel_size=2)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7830045523520486,
                "model_info": "Confusion Matrix:\n [[404   1   0   0   1   0   0   0   0   0   0   0   0   0   1   3   1   0]\n [  2  10   1   0   0   0   0   0   0   0   0   0   1   0   0   1   0   2]\n [  0   0   5   0   0   1   0   0   0   2   0   0   1   0   1   0   0   0]\n [  0   0   3  11   0   0   3   2   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   6   4   2   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   5   1   0   0   0   0   0   0   0   2   0   1   0]\n [  0   0   0   1   0   0  11   0   0   0   0   0   0   1   0   1   0   0]\n [  1   1   0   0   0   0   0   7   0   0   1   0   0   0   0   0   0   0]\n [  1   2   0   0   0   1   0   0   1   1   0   1   0   0   0   0   2   0]\n [  3   1   1   0   1   0   0   0   2   2   3   3   1   1   1   0   1   0]\n [  0   1   0   0   0   0   0   0   1   1   7   1   3   0   1   1   0   1]\n [  4   1   0   0   0   0   0   0   1   2   0   5   0   2   0   0   1   0]\n [  2   1   0   0   0   0   0   0   4   0   2   0  13   0   1   0   2   1]\n [  0   0   0   0   0   2   0   0   0   0   2   3   1   6   2   0   1   1]\n [  0   0   0   0   1   0   0   0   1   1   2   2   0   0   4   0   1   0]\n [  0   1   0   0   0   0   0   0   0   0   0   0   0   0   2   4   1   1]\n [  0   0   0   0   0   1   0   0   0   0   1   1   3   0   0   0  11   1]\n [  0   2   1   0   0   0   0   0   0   0   0   0   1   1   1   0   0   4]]",
                "lineage": "22201"
            }
        ],
        "223": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.attention = nn.Linear(128, 1)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        weighted_sum = torch.bmm(attention_weights.transpose(1, 2), lstm_out).squeeze(1)\n        x = self.fc(weighted_sum)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Confusion Matrix:\n [[403   2   0   0   1   0   1   0   1   1   0   0   0   1   0   0   0   1]\n [  1  14   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   1   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   0   0   1   0   0   0   0   0   0   0   0   1]\n [  0   0   0   1   0   0  12   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   1   0   0   5   0   0   0   0   1   0   0   0   0]\n [  3   0   0   0   0   0   0   0   1  14   2   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0  13   0   0   0   0   0   2   0]\n [  2   0   0   0   0   0   0   0   2   0   0   7   2   0   1   0   0   2]\n [  0   1   0   0   0   0   0   0   3   0   0   3  18   0   1   0   0   0]\n [  1   0   0   0   0   1   0   0   1   1   0   0   0  12   1   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   2   2   6   0   0   2]\n [  2   0   1   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   2   0   0   0   0   0  12   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   1   8]]",
                "lineage": "22301"
            }
        ],
        "224": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Confusion Matrix:\n [[403   3   0   0   1   1   0   1   0   0   0   0   0   0   0   2   0   0]\n [  1   8   2   0   0   0   0   1   3   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  2   0   0   0   9   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  2   0   0   0   3   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   1   0   0   4   1   0   0   0   1   0   0   0   1]\n [  2   0   0   0   0   0   0   0   0  15   1   1   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   1  16   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   0   2   0   7   1   0   2   0   0   1]\n [  0   0   0   0   0   0   1   0   1   0   2   0  17   2   0   0   1   2]\n [  2   0   0   0   0   2   0   0   0   0   0   0   0   9   5   0   0   0]\n [  0   0   0   0   0   1   0   0   1   0   0   1   0   1   7   0   0   1]\n [  1   1   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   0   1   0   0  10   5]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0   8]]",
                "lineage": "22401"
            }
        ],
        "225": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Confusion Matrix:\n [[400   1   0   0   1   0   0   0   0   0   0   1   1   2   0   5   0   0]\n [  1  11   3   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  15   0   0   0   1   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   1   0   0   4   1   0   0   1   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  12   3   2   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   1   0   0]\n [  3   0   0   0   0   0   0   0   1   2   0   4   2   0   3   0   1   0]\n [  1   0   0   0   0   0   0   0   0   1   1   2  12   0   0   0   9   0]\n [  1   0   0   0   0   0   0   0   1   1   0   0   0   8   6   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   0   8   0   2   1]\n [  1   0   0   0   0   0   2   0   0   0   0   0   0   0   1   5   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   0   0   0  14   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   2   7]]",
                "lineage": "22501"
            }
        ],
        "226": [],
        "227": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nimport torchvision.transforms as transforms\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.858877086494689,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   0   1   0   2   1   0   0   0   1   0   0   4   0   0]\n [  0  16   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  1   1   7   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   1   0   0   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   6   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   0   0   0   1  12   1   2   0   0   1   0   0   1]\n [  0   0   0   0   0   0   0   0   0   1  16   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   3   0   0   6   2   1   1   0   0   0]\n [  0   0   0   0   0   0   0   0   2   1   2   0  14   0   0   1   4   2]\n [  0   0   0   0   0   1   0   0   1   0   0   0   0  11   3   0   2   0]\n [  0   0   0   0   0   1   0   0   1   0   0   1   1   1   6   0   0   1]\n [  2   1   0   0   0   0   0   0   0   0   1   0   0   0   0   5   0   0]\n [  0   0   1   0   0   0   0   0   1   0   2   1   0   0   0   0   9   4]\n [  0   0   0   0   0   0   1   0   0   0   0   1   0   2   0   0   0   6]]",
                "lineage": "22701"
            }
        ],
        "228": [],
        "229": [],
        "230": [],
        "231": [],
        "232": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.Linear(128, 1)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context = torch.bmm(attn_weights.transpose(1, 2), lstm_out).squeeze(1)\n        x = self.fc(context)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7541729893778453,
                "model_info": "Confusion Matrix:\n [[403   0   1   0   3   0   0   0   0   0   1   0   1   0   0   2   0   0]\n [  1  11   0   1   0   0   0   1   0   0   0   1   0   0   0   0   0   2]\n [  0   0   4   1   1   0   0   0   1   1   1   0   1   0   0   0   0   0]\n [  0   0   1  11   1   1   0   0   0   0   0   0   1   4   0   0   1   0]\n [  0   0   0   0   8   2   1   0   0   1   0   0   0   1   0   0   0   0]\n [  0   0   2   3   0   2   0   0   0   0   0   0   0   1   0   0   1   0]\n [  0   0   0   4   1   0   8   0   0   0   0   0   0   1   0   0   0   0]\n [  1   1   1   0   1   0   1   5   0   0   0   0   0   0   0   0   0   0]\n [  1   1   0   1   0   0   0   0   1   0   0   0   1   0   0   1   1   2]\n [  3   0   0   0   0   0   0   0   2   3   3   3   0   0   1   1   0   4]\n [  0   0   0   0   0   0   0   0   4   1   3   0   2   1   1   2   0   3]\n [  2   0   1   0   1   0   0   0   1   1   1   3   1   2   0   2   0   1]\n [  0   2   1   1   0   0   0   0   3   0   2   1  11   2   1   0   1   1]\n [  0   0   0   0   1   2   0   0   1   2   0   0   0   6   0   1   0   5]\n [  0   0   0   0   0   0   0   0   2   0   0   2   0   1   4   2   0   1]\n [  1   0   1   0   0   0   0   0   2   0   0   0   0   1   0   2   0   2]\n [  0   1   0   0   0   2   0   0   0   1   1   1   0   1   1   0   6   4]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   1   1   1   0   6]]",
                "lineage": "23201"
            }
        ],
        "233": [],
        "234": [],
        "235": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Confusion Matrix:\n [[402   4   0   0   0   0   0   0   1   0   0   0   0   0   0   2   1   1]\n [  1  12   2   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  16   0   0   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   4   1   0   0   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   1   0   0   0   1  16   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   2  14   0   0   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   2   1   0   6   1   0   1   1   1   0]\n [  1   1   0   0   0   0   0   0   1   3   2   0  11   1   0   0   3   3]\n [  0   0   0   0   0   0   0   0   1   3   0   0   0   8   4   0   1   1]\n [  0   0   0   0   0   0   0   0   0   0   0   1   2   0   8   0   0   1]\n [  1   0   0   1   0   0   1   0   0   0   1   0   0   0   0   5   0   0]\n [  0   1   0   0   0   0   0   0   0   0   0   0   1   0   0   1  11   4]\n [  0   0   0   0   0   0   0   0   2   0   0   0   0   0   1   0   0   7]]",
                "lineage": "23501"
            }
        ],
        "236": [],
        "237": [],
        "238": [],
        "239": [],
        "240": [],
        "241": [],
        "242": [],
        "243": [],
        "244": [],
        "245": [],
        "246": [],
        "247": [],
        "248": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(20):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n        print(f\"Epoch {epoch+1}, Learning Rate: {optimizer.param_groups[0]['lr']}\")\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.7738998482549317,
                "model_info": "Epoch 1, Learning Rate: 0.0005\nEpoch 2, Learning Rate: 0.0005\nEpoch 3, Learning Rate: 0.0005\nEpoch 4, Learning Rate: 0.0005\nEpoch 5, Learning Rate: 0.0005\nEpoch 6, Learning Rate: 0.0005\nEpoch 7, Learning Rate: 0.0005\nEpoch 8, Learning Rate: 0.0005\nEpoch 9, Learning Rate: 0.0005\nEpoch 10, Learning Rate: 5e-05\nEpoch 11, Learning Rate: 5e-05\nEpoch 12, Learning Rate: 5e-05\nEpoch 13, Learning Rate: 5e-05\nEpoch 14, Learning Rate: 5e-05\nEpoch 15, Learning Rate: 5e-05\nEpoch 16, Learning Rate: 5e-05\nEpoch 17, Learning Rate: 5e-05\nEpoch 18, Learning Rate: 5e-05\nEpoch 19, Learning Rate: 5e-05\nEpoch 20, Learning Rate: 5e-06\nConfusion Matrix:\n [[404   1   0   0   0   1   0   1   0   0   0   2   0   1   1   0   0   0]\n [  1   6   1   2   0   0   0   6   0   0   0   0   0   0   0   1   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   3  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   0   0   0   0   0   1   0   1   0   0   0   0]\n [  0   0   1   3   0   0   9   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   1   0   0   0   0   7   0   0   0   0   0   0   1   0   0   0]\n [  1   1   0   0   0   0   0   0   0   0   2   2   0   2   1   0   0   0]\n [  3   0   3   0   1   0   0   0   1   0   8   2   0   1   1   0   0   0]\n [  1   0   0   0   1   0   0   0   0   0  13   1   0   0   1   0   0   0]\n [  3   0   0   0   0   0   0   0   0   0   2   6   0   0   2   0   1   2]\n [  0   1   0   0   0   0   0   0   0   0   5   4   0   0   2   0   5   9]\n [  0   0   0   0   1   1   0   0   2   0   4   0   0   4   3   0   3   0]\n [  0   0   0   0   1   2   0   0   0   0   3   1   0   1   4   0   0   0]\n [  1   0   1   2   0   0   0   1   0   0   0   0   0   0   1   3   0   0]\n [  0   0   1   0   0   0   0   0   0   0   1   1   0   0   3   0  11   1]\n [  0   0   0   0   0   1   0   0   0   0   0   1   0   0   1   0   3   4]]",
                "lineage": "24801"
            }
        ],
        "249": [],
        "250": [],
        "251": [],
        "252": [],
        "253": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8528072837632777,
                "model_info": "Confusion Matrix:\n [[397   4   0   0   2   1   0   2   0   0   0   0   1   0   0   2   0   2]\n [  0  13   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   1   7   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   2   1  16   0   0   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0  12   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   1]\n [  2   1   0   0   0   0   0   0   0   8   2   5   0   0   0   1   0   1]\n [  1   0   0   0   0   0   0   0   0   1  14   0   0   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   2   1   0   5   2   1   1   0   1   1]\n [  0   0   0   0   0   0   0   0   0   0   2   1  17   1   0   0   2   3]\n [  0   0   0   0   2   1   0   0   1   1   0   0   0   9   3   0   1   0]\n [  0   0   0   0   0   1   0   0   1   0   0   0   0   0   9   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   1   1   1  12   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   1   7]]",
                "lineage": "25301"
            }
        ],
        "254": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n            print(f\"Epoch [{epoch+1}/50], Batch Loss: {loss.item():.4f}, Class Distribution: {np.bincount(labels.cpu().numpy())}\")\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Epoch [1/50], Batch Loss: 2.9116, Class Distribution: [44  3  1  0  0  3  1  1  0  0  4  0  2  1  1  2  0  1]\nEpoch [1/50], Batch Loss: 2.8760, Class Distribution: [42  4  0  0  2  1  0  1  2  2  1  1  1  2  1  1  0  3]\nEpoch [1/50], Batch Loss: 2.8341, Class Distribution: [40  0  2  1  1  0  0  1  2  0  1  3  0  1  2  2  3  5]\nEpoch [1/50], Batch Loss: 2.7868, Class Distribution: [41  1  1  2  1  2  1  0  2  0  2  0  1  4  1  1  4]\nEpoch [1/50], Batch Loss: 2.7281, Class Distribution: [43  2  0  2  1  1  2  0  1  1  2  0  3  1  3  1  0  1]\nEpoch [1/50], Batch Loss: 2.6304, Class Distribution: [47  0  0  3  2  2  0  1  0  1  0  2  0  0  0  0  2  4]\nEpoch [1/50], Batch Loss: 2.5633, Class Distribution: [38  1  2  0  1  1  0  2  2  1  4  3  1  3  1  2  1  1]\nEpoch [1/50], Batch Loss: 2.4452, Class Distribution: [37  2  1  1  2  2  1  0  3  0  2  3  2  1  2  1  4]\nEpoch [1/50], Batch Loss: 2.1951, Class Distribution: [40  3  1  0  2  1  1  1  1  0  3  2  4  1  1  1  1  1]\nEpoch [1/50], Batch Loss: 1.9345, Class Distribution: [39  0  5  0  0  1  2  0  1  1  2  1  3  2  4  1  1  1]\nEpoch [1/50], Batch Loss: 1.5624, Class Distribution: [41  1  3  1  4  1  0  1  0  1  2  3  1  1  2  1  0  1]\nEpoch [1/50], Batch Loss: 1.3291, Class Distribution: [42  2  0  2  0  0  2  1  0  1  2  2  1  0  1  0  3  5]\nEpoch [1/50], Batch Loss: 0.9615, Class Distribution: [49  3  0  2  1  0  0  0  1  2  0  0  2  2  0  1  1]\nEpoch [1/50], Batch Loss: 1.5975, Class Distribution: [34  1  2  1  0  0  3  2  1  2  2  2  3  1  1  2  0  7]\nEpoch [1/50], Batch Loss: 1.5038, Class Distribution: [38  0  2  2  2  1  1  3  1  5  1  2  2  1  0  1  2]\nEpoch [1/50], Batch Loss: 1.5226, Class Distribution: [39  2  0  2  2  1  1  3  3  0  0  5  0  1  0  2  2  1]\nEpoch [1/50], Batch Loss: 1.6186, Class Distribution: [33  1  2  1  3  1  1  0  2  0  3  3  2  4  2  0  2  4]\nEpoch [1/50], Batch Loss: 1.1885, Class Distribution: [42  2  1  0  3  0  2  1  1  0  1  1  0  1  1  2  4  2]\nEpoch [1/50], Batch Loss: 1.2721",
                "lineage": "25401"
            }
        ],
        "255": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    frozen_params = sum(p.numel() for p in contrastive_model.parameters() if not p.requires_grad)\n    trainable_params = sum(p.numel() for p in contrastive_model.parameters() if p.requires_grad)\n    print(f\"Trainable vs Frozen Parameters Ratio: {trainable_params / (trainable_params + frozen_params):.4f}\")\n\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8543247344461306,
                "model_info": "Trainable vs Frozen Parameters Ratio: 1.0000\nConfusion Matrix:\n [[402   3   0   0   1   0   0   0   0   0   1   0   0   1   0   2   0   1]\n [  0  15   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   7   1   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  1   0   3  14   0   0   0   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   1   0   0   0   0   0   8   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   0   0   0   6   0   0   0   0   1   0   0   0   0]\n [  4   0   0   0   0   2   0   0   0  10   1   2   0   0   0   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0  13   0   0   1   0   0   0   1]\n [  2   0   0   0   0   0   0   0   1   0   2   7   1   0   1   0   0   2]\n [  0   1   0   0   0   0   0   0   1   0   3   1  14   1   0   0   3   2]\n [  1   0   0   0   0   1   0   0   1   0   0   0   0  10   4   0   0   1]\n [  0   0   0   0   0   0   0   0   2   0   0   1   1   1   6   0   0   1]\n [  1   0   0   0   0   0   1   0   0   0   1   0   0   0   0   6   0   0]\n [  0   1   1   0   0   0   0   0   0   0   1   0   0   0   0   0   9   6]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   1   0   0   0   8]]",
                "lineage": "25501"
            }
        ],
        "256": [],
        "257": [],
        "258": [],
        "259": [],
        "260": [],
        "261": [],
        "262": [],
        "263": [],
        "264": [],
        "265": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8057663125948407,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   1   0   1   2   0   0   0   1   0   0   1   2   0   1]\n [  1  12   1   1   0   0   0   1   0   0   0   1   0   0   0   0   0   0]\n [  0   1   6   1   0   1   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   1  13   0   0   2   0   0   0   0   0   0   1   0   1   1   1]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   4   1   0   0   0   0   0   0   2   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   1   0   0   0   0   3   1   0   2   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   7   1   4   2   0   2   0   1   1]\n [  0   0   0   0   0   0   0   0   0   0  13   1   0   0   1   0   2   0]\n [  4   0   0   0   0   0   0   0   2   1   0   5   0   0   1   1   1   1]\n [  2   0   2   2   0   0   0   0   1   1   0   2   8   0   1   2   5   0]\n [  0   0   0   0   1   2   0   1   1   1   1   0   0   6   3   0   0   2]\n [  0   0   0   0   0   1   0   0   2   0   0   1   1   2   3   1   0   1]\n [  0   2   1   1   0   0   0   0   0   1   0   0   0   0   0   4   0   0]\n [  0   0   2   0   0   0   0   0   0   0   1   2   2   0   1   0  10   0]\n [  0   0   1   0   0   0   0   0   0   0   1   0   0   0   1   0   3   4]]",
                "lineage": "26501"
            }
        ],
        "266": [],
        "267": [],
        "268": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.0).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.866464339908953,
                "model_info": "Confusion Matrix:\n [[402   1   0   0   2   1   0   1   0   0   0   0   1   0   1   2   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   4  13   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   0   7   0   0   0   0   1   0   0   0   0]\n [  2   0   0   0   0   0   0   0   1  12   2   2   0   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   0   1  16   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   3   0   0   7   1   0   2   0   0   1]\n [  0   0   0   0   0   0   1   0   1   0   0   0  12   3   0   0   8   1]\n [  0   0   0   0   0   1   0   0   1   1   0   0   0   8   5   0   2   0]\n [  0   0   0   0   0   0   0   0   2   0   0   1   1   0   7   0   0   1]\n [  2   1   0   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   1   0   0   0   0  14   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   1   8]]",
                "lineage": "26801"
            }
        ],
        "269": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8194233687405159,
                "model_info": "Confusion Matrix:\n [[397   6   0   0   1   0   0   0   0   0   0   0   0   2   1   4   0   0]\n [  0  12   2   0   0   0   0   0   0   0   0   0   0   0   0   3   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  13   1   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   2   0   1   4   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   1   0   0   1   0   7   3   5   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   2  12   0   0   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   2   1   1   6   1   0   1   0   1   0]\n [  1   0   0   0   0   0   0   0   1   4   1   1  11   0   0   0   6   1]\n [  0   0   0   0   1   1   0   0   1   0   0   1   0   6   6   0   2   0]\n [  0   0   0   0   0   0   0   0   2   0   0   2   0   0   8   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   3   1   2   0   0   0  11   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   3   0   3   0   2   2]]",
                "lineage": "26901"
            }
        ],
        "270": [],
        "271": [],
        "272": [],
        "273": [],
        "274": [],
        "275": [],
        "276": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8482549317147192,
                "model_info": "Confusion Matrix:\n [[402   2   0   0   0   0   0   2   0   0   0   0   0   1   0   3   0   1]\n [  1  12   1   1   0   0   0   1   0   0   0   0   0   0   0   1   0   0]\n [  1   1   8   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   0   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   0  10   1   5   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0  14   0   0   1   0   0   0   0]\n [  4   0   0   0   0   0   0   0   4   1   0   5   1   0   0   0   0   1]\n [  1   1   0   0   0   0   0   0   0   2   3   3   7   0   0   0   7   2]\n [  1   0   0   0   1   0   0   0   1   0   0   0   0  10   5   0   0   0]\n [  0   0   0   0   0   1   0   0   1   0   1   1   1   0   6   0   0   1]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   2   0   0   0   0  11   3]\n [  0   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0   7]]",
                "lineage": "27601"
            }
        ],
        "277": [],
        "278": [],
        "279": [],
        "280": [],
        "281": [],
        "282": [],
        "283": [],
        "284": [],
        "285": [],
        "286": [],
        "287": [],
        "288": [],
        "289": [],
        "290": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8300455235204856,
                "model_info": "Confusion Matrix:\n [[402   2   0   0   2   0   0   0   0   0   0   1   0   0   0   3   0   1]\n [  1  11   1   1   0   0   0   1   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   4  15   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   4   1   0   1   0   1   0   0   0   0]\n [  3   0   0   0   1   0   0   0   3   8   0   4   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   0   0   0  15   0   0   0   0   1   0   0]\n [  4   0   0   0   0   0   0   0   2   1   0   6   0   0   2   0   0   1]\n [  0   1   0   0   0   0   0   0   2   0   0   3   6   0   1   0   6   7]\n [  0   0   0   0   1   1   0   0   2   0   1   0   0   6   6   0   1   0]\n [  0   0   0   0   0   1   0   0   1   0   1   2   1   0   6   0   0   0]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   0   0   0  10   5]\n [  0   0   1   0   0   0   0   0   0   0   0   0   1   1   1   0   1   5]]",
                "lineage": "29001"
            }
        ],
        "291": [],
        "292": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nimport torchvision.transforms as transforms\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    data_augmentation = transforms.Compose([\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomVerticalFlip(),\n    ])\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = data_augmentation(inputs)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.842185128983308,
                "model_info": "Confusion Matrix:\n [[402   0   0   0   1   0   0   0   0   0   1   2   0   1   1   2   0   1]\n [  1  13   0   1   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   2  15   0   0   1   0   0   0   1   0   0   0   0   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   4   0   0   0   0   0   1   0   0   2   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   1   0   1   0   0   8   0   0   0   0   0   0   0   0   0   0]\n [  1   0   1   0   0   0   0   1   3   1   0   0   0   0   1   0   1   0]\n [  0   0   0   0   1   0   0   1   1  13   0   2   1   0   0   0   1   0]\n [  0   1   0   0   0   0   0   0   0   2  13   0   1   0   0   0   0   0]\n [  4   0   1   0   0   0   0   0   2   1   1   5   1   0   0   0   0   1]\n [  0   3   0   0   0   0   0   1   4   0   2   3  10   0   2   0   1   0]\n [  0   0   0   0   0   2   0   0   1   0   0   1   0   7   5   0   1   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0  11   0   1   0]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   1   0   0   1   0   1   0   0   4   0   1   1   1   0   8   0]\n [  0   0   0   0   0   0   0   0   0   2   0   1   0   0   2   0   0   5]]",
                "lineage": "29201"
            }
        ],
        "293": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    feature_importances = torch.abs(contrastive_model.base_model.fc.weight).sum(dim=1)\n    top_k_indices = torch.topk(feature_importances, k=5).indices\n    print(\"Top-k Feature Importances:\", top_k_indices.cpu().numpy())\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8543247344461306,
                "model_info": "Top-k Feature Importances: [ 3  6  2 13  7]\nConfusion Matrix:\n [[402   1   0   0   0   0   0   2   0   1   0   0   0   2   0   3   0   0]\n [  1  12   1   0   0   0   0   1   0   0   0   0   0   0   0   2   0   0]\n [  1   0   9   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  15   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   6   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   1   5   1   0   0   0   1   0   0   0   0]\n [  1   0   2   0   1   0   0   0   0   9   2   4   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   0   0   0  17   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   3   1   0   6   1   0   1   0   0   0]\n [  1   2   0   0   0   0   0   0   2   1   1   1  12   1   1   0   3   1]\n [  1   0   0   0   0   1   0   0   1   2   0   0   0  10   3   0   0   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   0   2   7   0   0   1]\n [  1   1   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   1   0   0   1   0   0   0   0   2   0   0   0   0   0  11   2]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   1   1   0   2   5]]",
                "lineage": "29301"
            }
        ],
        "294": [],
        "295": [],
        "296": [],
        "297": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom sklearn.decomposition import PCA\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=10, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    pca = PCA(n_components=10)\n    train_data_pca = pca.fit_transform(train_data_scaled.reshape(-1, 16)).reshape(-1, 52, 10)\n    val_data_pca = pca.transform(val_data_scaled.reshape(-1, 16)).reshape(-1, 52, 10)\n\n    train_tensor = torch.FloatTensor(train_data_pca).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_pca).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8573596358118362,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   0   0   0   1   0   0   2   0   1   2   0   1   0   2]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   1   7   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   5   2   1   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  12   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   1   0   0   5   0   0   0   0   1   0   0   0   0]\n [  2   0   0   0   1   0   0   0   1  12   2   1   0   0   0   0   0   1]\n [  0   0   0   0   1   0   0   0   0   1  15   0   0   0   0   0   0   0]\n [  3   1   0   0   0   0   0   0   2   0   0   7   0   1   1   0   0   1]\n [  0   0   0   0   0   0   0   0   1   0   3   0  17   0   0   0   2   3]\n [  0   0   0   0   1   2   0   0   1   1   0   0   0   9   2   0   1   1]\n [  0   0   0   0   0   0   0   0   2   2   0   1   0   0   7   0   0   0]\n [  2   1   0   0   0   0   1   0   0   0   1   0   0   0   0   4   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   0   1   1   0   0  11   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   2   7]]",
                "lineage": "29701"
            }
        ],
        "298": [],
        "299": [],
        "300": [],
        "301": [],
        "302": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, lfilter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=5, fs=100, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = lfilter(b, a, data)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data, cutoff=5)\n    val_data_filtered = lowpass_filter(val_data, cutoff=5)\n\n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7177541729893778,
                "model_info": "Confusion Matrix:\n [[399   1   0   0   0   0   0   5   0   0   0   0   1   0   4   1   0   0]\n [  1   9   2   0   0   0   0   0   0   1   1   0   0   0   0   2   0   1]\n [  0   0   4   1   0   0   0   1   0   0   0   1   0   0   1   2   0   0]\n [  1   1   3   6   1   0   4   0   0   0   1   1   0   0   1   0   0   1]\n [  0   0   0   0   2   0   0   0   0   3   3   0   0   0   2   0   0   3]\n [  0   0   0   1   0   4   1   0   0   1   0   1   0   0   0   0   1   0]\n [  0   0   0   0   1   0   9   0   0   0   1   0   0   0   2   0   0   1]\n [  2   1   0   0   0   0   0   7   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   1   0   2   3   0   0   2   0   0   0]\n [  4   0   0   0   1   0   0   0   1   5   2   5   1   0   0   0   0   1]\n [  1   0   0   0   1   0   0   0   0   1   5   0   3   1   2   2   0   1]\n [  3   0   0   0   3   0   0   2   0   1   0   3   0   0   4   0   0   0]\n [  0   1   1   1   3   1   0   3   1   0   3   2   5   0   1   4   0   0]\n [  0   1   2   0   1   2   0   0   0   4   2   1   0   0   1   2   0   2]\n [  0   0   2   1   0   0   0   0   0   0   1   1   0   1   3   0   0   3]\n [  1   1   3   1   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   1   1   0   1   1   0   0   1   1   2   3   0   2   0   0   5   0]\n [  0   0   1   0   0   0   0   0   0   2   0   2   0   0   1   0   0   4]]",
                "lineage": "30201"
            }
        ],
        "303": [],
        "304": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.attention = nn.Linear(128, 1)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context_vector = torch.sum(attention_weights * lstm_out, dim=1)\n        x = self.fc(context_vector)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Confusion Matrix:\n [[403   1   0   0   2   1   0   0   0   0   0   0   0   1   0   3   0   0]\n [  1  15   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   2   2  15   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   4   0   0   0   0   1   1   0   0   0]\n [  2   0   0   0   0   0   0   0   0  15   1   2   0   0   0   0   0   0]\n [  1   0   0   0   0   0   1   0   0   1  12   0   0   0   0   0   2   0]\n [  3   0   0   0   0   0   0   0   1   1   0   8   0   0   1   0   2   0]\n [  1   0   0   0   0   0   0   0   1   0   2   0  16   3   1   0   2   0]\n [  1   0   0   0   0   0   0   0   1   0   0   0   0  10   4   0   2   0]\n [  0   0   0   0   0   0   0   0   1   1   0   2   0   1   6   0   0   1]\n [  1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   8   0   0]\n [  0   1   0   0   0   0   0   0   0   0   2   0   2   0   1   0   8   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   1   7]]",
                "lineage": "30401"
            }
        ],
        "305": [],
        "306": [],
        "307": [],
        "308": [],
        "309": [],
        "310": [],
        "311": [],
        "312": [],
        "313": [],
        "314": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    noise = np.random.normal(0, 0.01, train_data_scaled.shape)\n    train_data_scaled = train_data_scaled + noise\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8649468892261002,
                "model_info": "Confusion Matrix:\n [[402   3   0   0   0   0   0   1   1   0   0   0   0   1   1   2   0   0]\n [  0  13   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   1   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   1   0   9   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   7   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   0   1   0   0   1  14   0   1   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   0   0   1  14   0   0   0   0   1   1   0]\n [  3   0   0   0   0   0   0   0   3   2   0   5   1   0   1   0   0   1]\n [  1   1   0   0   0   0   0   0   2   1   1   0  12   0   2   0   3   3]\n [  1   0   0   0   1   2   0   0   1   0   0   0   0   6   5   0   2   0]\n [  0   0   0   0   0   1   0   0   0   0   0   1   0   1   9   0   0   0]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   0   0   1  12   2]\n [  0   0   0   0   0   0   1   0   0   0   0   0   0   0   1   0   0   8]]",
                "lineage": "31401"
            }
        ],
        "315": [],
        "316": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.Linear(128, 1)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context_vector = torch.bmm(attention_weights.transpose(1, 2), lstm_out).squeeze(1)\n        x = self.fc(context_vector)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Confusion Matrix:\n [[400   4   0   0   2   2   0   0   0   0   0   0   0   0   0   2   0   1]\n [  0  15   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   1   7   1   0   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  14   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   1   0   9   0   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   5   0   0   0   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   2  12   0   2   0   0   0   1   1   1]\n [  0   0   0   0   0   0   1   0   0   1  13   0   0   0   0   0   2   0]\n [  2   0   1   0   0   0   0   0   0   1   0   8   2   0   1   0   1   0]\n [  0   0   0   0   0   0   0   0   1   0   1   0  21   0   2   0   1   0]\n [  0   0   0   0   1   2   0   0   1   0   1   0   0  10   1   0   2   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   0   1   7   0   1   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   0   0   1   0  11   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   2   7]]",
                "lineage": "31601"
            }
        ],
        "317": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    for param in base_model.lstm.parameters():\n        param.requires_grad = False\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.6889226100151745,
                "model_info": "Confusion Matrix:\n [[411   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  7   0   1   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0  11   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 10   0   0   0   2   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   3   2   0   0   0   0   0   0   0   0   0   0   1   0]\n [  1   0   1   3   0   0   9   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  7   0   0   0   2   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 18   0   1   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0]\n [  8   0   0   0   0   0   0   0   0   0   4   0   0   0   0   0   3   2]\n [ 16   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 17   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   4   5]\n [ 13   0   0   1   0   0   0   0   0   0   0   0   0   1   0   0   3   0]\n [  7   0   0   0   1   0   1   0   0   0   0   0   0   0   3   0   0   0]\n [  7   0   0   0   0   0   1   0   0   0   0   0   0   0   0   1   0   0]\n [ 10   0   0   0   0   0   0   0   0   0   1   0   0   0   0   0   5   2]\n [  7   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   3]]",
                "lineage": "31701"
            }
        ],
        "318": [],
        "319": [],
        "320": [],
        "321": [],
        "322": [],
        "323": [],
        "324": [],
        "325": [],
        "326": [],
        "327": [],
        "328": [],
        "329": [],
        "330": [],
        "331": [],
        "332": [],
        "333": [],
        "334": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    class_counts = Counter(train_label)\n    class_weights = {i: 1.0 / class_counts[i] for i in range(18)}\n    weights = [class_weights[label.item()] for label in train_label_tensor]\n    sampler = WeightedRandomSampler(weights, num_samples=len(weights), replacement=True)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8482549317147192,
                "model_info": "Confusion Matrix:\n [[381  13   0   0   2   2   0   1   1   0   1   3   1   0   1   4   0   1]\n [  0  12   1   0   0   0   0   0   2   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   8   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   0   1   0   0   6   0   0   1   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   1  16   0   1   0   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   0   1  14   0   0   0   0   2   0   0]\n [  2   0   0   0   1   0   0   0   0   1   1   6   3   0   1   1   0   0]\n [  0   0   0   0   0   0   1   0   0   0   1   1  16   0   3   0   3   1]\n [  0   0   0   0   1   1   0   0   0   1   0   0   1  11   1   0   1   1]\n [  0   0   0   0   0   0   0   0   1   0   0   0   0   1   9   0   0   1]\n [  0   0   0   0   0   0   1   0   0   0   1   0   0   0   1   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   1   0   0   1   1  11   2]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0   1   7]]",
                "lineage": "33401"
            }
        ],
        "335": [],
        "336": [],
        "337": [],
        "338": [],
        "339": [],
        "340": [],
        "341": [],
        "342": [],
        "343": [],
        "344": [],
        "345": [],
        "346": [],
        "347": [],
        "348": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8619119878603946,
                "model_info": "Confusion Matrix:\n [[403   2   0   0   1   0   1   1   1   0   0   0   0   1   0   0   0   1]\n [  0  13   1   1   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  1   0   7   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  1   1   1  17   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   1   5   1   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   2   0   0   0  12   1   2   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   0   1   0]\n [  3   1   0   0   0   0   0   0   4   1   0   4   3   0   0   0   0   0]\n [  0   0   0   0   0   0   1   0   3   1   2   1  11   0   0   0   7   0]\n [  0   0   0   0   0   1   0   0   1   0   0   0   0   9   3   0   3   1]\n [  0   0   0   0   0   0   0   0   2   1   0   0   0   0   8   0   0   1]\n [  1   0   2   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   1   2   0   0   0   0   0  12   2]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   1   0   0   1   7]]",
                "lineage": "34801"
            }
        ],
        "349": [],
        "350": [],
        "351": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8573596358118362,
                "model_info": "Confusion Matrix:\n [[399   3   0   0   2   1   0   1   0   0   0   0   0   1   0   4   0   0]\n [  0  12   2   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   2  16   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   5   0   0   0   0   0   0   0   0   1]\n [  3   0   0   0   0   0   0   0   0  11   1   2   0   0   0   1   0   2]\n [  0   0   0   0   0   0   0   0   0   1   9   0   3   0   0   2   1   1]\n [  2   0   0   0   0   0   0   0   1   1   0   6   2   0   2   1   0   1]\n [  0   1   0   0   0   0   0   0   0   0   2   0  20   0   1   0   1   1]\n [  0   0   0   0   0   0   0   0   1   1   0   0   0  10   5   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   9   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   0   8   8]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0   8]]",
                "lineage": "35101"
            }
        ],
        "352": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef random_time_shifting(data, shift_range=5):\n    shift = np.random.randint(-shift_range, shift_range)\n    return np.roll(data, shift, axis=0)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_data_augmented = np.array([random_time_shifting(sample) for sample in train_data_scaled])\n    train_tensor = torch.FloatTensor(train_data_augmented).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8649468892261002,
                "model_info": "Confusion Matrix:\n [[400   2   0   0   2   2   0   2   0   0   0   0   0   0   0   3   0   0]\n [  2  12   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   4  14   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   7   0   0   0   1   0   0   0   0   0   1]\n [  1   0   0   0   0   2   0   1   5   0   0   0   0   0   0   0   0   0]\n [  0   0   2   0   0   0   0   0   1  14   0   0   0   0   0   1   1   1]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   1   1   0   7   2   0   1   0   1   0]\n [  0   1   0   0   0   0   0   0   3   0   0   1  13   0   0   0   6   2]\n [  0   0   0   0   0   4   0   0   0   0   0   0   1   8   3   0   1   1]\n [  0   0   0   0   0   1   0   0   1   0   0   2   0   1   7   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   0   1   0   0   0   0   0   0   1   0   0   0   0   0  13   2]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   9]]",
                "lineage": "35201"
            }
        ],
        "353": [],
        "354": [],
        "355": [],
        "356": [],
        "357": [],
        "358": [],
        "359": [],
        "360": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, lfilter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff, fs, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = lfilter(b, a, data)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_filtered = lowpass_filter(train_data, cutoff=30, fs=1000)\n    val_data_filtered = lowpass_filter(val_data, cutoff=30, fs=1000)\n    \n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.723823975720789,
                "model_info": "Confusion Matrix:\n [[405   1   0   0   0   0   0   1   0   0   0   1   0   0   0   3   0   0]\n [  1   9   1   0   0   0   0   0   0   0   1   4   0   0   0   0   0   1]\n [  1   0   6   1   0   1   0   0   0   0   0   0   0   0   0   1   0   0]\n [  2   1   2   8   3   0   3   0   0   0   1   0   0   0   0   0   0   0]\n [  0   0   1   0   3   0   0   0   0   0   3   0   0   2   1   0   0   3]\n [  0   0   0   1   0   4   1   0   0   1   0   1   0   0   0   0   0   1]\n [  0   0   0   2   0   2   8   0   0   0   0   0   0   0   0   0   0   2]\n [  4   2   0   0   0   0   0   4   0   0   0   0   0   0   0   0   0   0]\n [  1   1   0   1   0   0   0   0   0   0   2   0   0   0   2   0   1   1]\n [  3   0   0   0   2   0   0   0   0   3   3   3   1   1   0   0   0   4]\n [  0   0   0   1   2   1   0   0   0   0   4   1   3   0   1   2   0   2]\n [  6   1   0   0   3   0   0   1   0   0   1   2   1   0   1   0   0   0]\n [  1   1   2   5   3   2   0   3   0   0   0   2   5   0   1   1   0   0]\n [  1   0   3   0   1   1   0   0   1   2   3   1   0   0   1   1   1   2]\n [  0   0   1   3   0   0   0   1   0   1   2   0   0   1   2   0   0   1]\n [  1   0   3   1   1   0   0   0   0   0   0   0   0   0   1   1   0   1]\n [  1   0   1   1   0   1   0   0   1   0   3   2   0   0   1   0   6   1]\n [  0   0   1   0   0   0   0   0   0   1   0   0   0   0   1   0   0   7]]",
                "lineage": "36001"
            }
        ],
        "361": [],
        "362": [],
        "363": [],
        "364": [],
        "365": [],
        "366": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(20):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7754172989377845,
                "model_info": "Confusion Matrix:\n [[404   3   0   0   0   0   0   0   0   0   0   2   0   0   2   0   0   0]\n [  1  10   0   0   0   0   0   5   0   0   0   0   0   0   0   1   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   4  14   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   3   0   0   0   0   1   0   0   0   1   0   0   0]\n [  1   0   0   1   0   0  11   0   0   0   0   0   0   0   0   0   0   1]\n [  0   1   0   0   0   0   0   8   0   0   0   0   0   0   1   0   0   0]\n [  1   1   1   0   1   2   0   0   0   0   0   0   0   0   3   0   0   0]\n [  3   0   3   0   1   0   0   0   0   0   4   2   0   0   7   0   0   0]\n [  1   0   0   0   1   0   0   0   0   0  15   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   0   0   3   4   0   0   4   0   0   1]\n [  0   1   0   0   0   1   0   0   0   0   4   0   2   0   5   0   6   7]\n [  0   0   0   0   1   1   2   0   0   0   2   2   0   1   7   0   1   1]\n [  0   0   0   0   1   1   0   0   0   0   2   1   0   0   7   0   0   0]\n [  3   0   1   1   0   0   1   1   0   0   0   0   0   0   0   2   0   0]\n [  0   1   0   0   1   0   0   0   0   0   4   0   0   1   0   0   9   2]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   0   2   0   3   4]]",
                "lineage": "36601"
            }
        ],
        "367": [],
        "368": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=32, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.conv1(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.779969650986343,
                "model_info": "Confusion Matrix:\n [[400   4   0   0   2   0   0   1   0   0   0   1   0   0   0   3   0   0]\n [  0  13   1   1   0   0   0   0   0   1   1   0   0   0   0   0   0   0]\n [  2   0   5   1   0   0   0   0   0   0   0   0   1   0   0   0   0   1]\n [  0   0   3  12   1   0   0   0   0   0   0   0   1   0   1   1   0   1]\n [  0   0   0   0   9   3   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   4   4   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   1   0   1   0  11   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0   1   7   1   0   0   1   0   0   0   0   0   0]\n [  1   1   0   1   1   0   0   0   3   1   0   0   0   0   0   0   0   1]\n [  2   0   0   0   1   0   0   1   0   3   0   3   2   1   0   0   4   3]\n [  0   0   2   0   0   0   0   0   0   1   9   0   1   0   2   0   1   1]\n [  4   0   1   1   0   0   0   0   2   1   0   3   0   1   2   0   0   1]\n [  0   2   0   3   0   0   0   0   1   1   2   1   9   0   0   1   3   3]\n [  0   0   1   0   1   4   0   0   1   0   1   1   0   2   3   0   1   3]\n [  0   0   1   0   1   0   0   0   2   1   1   0   0   0   4   2   0   0]\n [  2   1   0   1   0   0   0   0   0   0   0   0   0   0   0   5   0   0]\n [  0   1   0   1   0   1   0   0   0   1   2   1   1   0   0   1   8   1]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   2   0   0   7]]",
                "lineage": "36801"
            }
        ],
        "369": [],
        "370": [],
        "371": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7784522003034902,
                "model_info": "Confusion Matrix:\n [[397   6   0   0   1   0   0   1   1   0   1   1   0   1   1   1   0   0]\n [  1  13   0   0   0   0   0   1   0   0   0   1   0   0   0   1   0   0]\n [  1   0   4   1   0   0   0   0   0   1   0   2   1   0   0   0   0   0]\n [  0   0   1  13   1   0   1   0   0   0   0   2   1   0   0   0   1   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   1   2   1   0  10   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   0   0   0   0   1   6   2   0   0   0   0   0   0   0   0   0]\n [  1   0   0   1   1   0   0   0   3   1   0   1   1   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   1   6   1   6   0   0   2   0   2   1]\n [  0   0   1   0   0   0   0   0   2   5   6   0   1   0   1   0   0   1]\n [  2   1   0   0   0   0   0   0   0   1   0   5   1   0   2   1   1   2]\n [  0   1   3   1   0   0   0   0   4   2   2   3   8   0   0   0   2   0]\n [  0   0   0   0   1   3   0   0   1   0   2   0   0   5   2   1   1   2]\n [  0   0   0   0   0   0   0   0   2   0   0   2   0   1   5   2   0   0]\n [  1   1   1   1   0   0   0   0   0   0   1   1   0   0   0   3   0   0]\n [  0   1   1   1   0   1   0   0   1   0   3   0   1   0   0   0   7   2]\n [  0   0   1   0   0   0   0   0   0   0   0   1   0   0   0   0   1   7]]",
                "lineage": "37101"
            }
        ],
        "372": [],
        "373": [],
        "374": [],
        "375": [],
        "376": [],
        "377": [],
        "378": [],
        "379": [],
        "380": [],
        "381": [],
        "382": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8224582701062215,
                "model_info": "Confusion Matrix:\n [[402   4   0   0   0   0   0   0   0   2   0   0   0   0   2   1   0   0]\n [  1  14   0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   4  15   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   4   0   0   0   0   1   0   0   1   0   0   1   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   0   0   0   0   0   1   0   0   0]\n [  3   0   0   0   1   0   0   0   1   6   2   6   0   0   1   0   0   0]\n [  0   0   0   0   0   0   0   0   0   0  16   0   0   0   0   1   0   0]\n [  4   0   0   0   0   0   0   0   1   1   0   4   1   0   2   0   2   1]\n [  1   0   0   0   0   0   0   0   2   0   0   4   5   1   1   0   8   4]\n [  1   0   0   0   1   0   0   0   3   3   1   0   0   3   5   0   1   0]\n [  0   0   0   0   0   0   0   0   2   0   0   1   1   0   5   2   0   1]\n [  2   1   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   2   0   0   1   0  11   2]\n [  0   0   1   0   0   0   0   0   0   1   0   0   1   0   1   0   2   4]]",
                "lineage": "38201"
            }
        ],
        "383": [],
        "384": [],
        "385": [],
        "386": [],
        "387": [],
        "388": [],
        "389": [],
        "390": [],
        "391": [],
        "392": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nimport random\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef time_based_augmentation(data):\n    augmented_data = []\n    for sample in data:\n        if random.random() > 0.5:\n            shift = random.randint(-5, 5)\n            sample = np.roll(sample, shift, axis=0)\n        augmented_data.append(sample)\n    return np.array(augmented_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_data_augmented = time_based_augmentation(train_data_scaled)\n    train_tensor = torch.FloatTensor(train_data_augmented).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Confusion Matrix:\n [[402   3   0   0   3   0   0   1   0   0   0   0   0   0   0   1   0   1]\n [  1   9   3   1   0   0   0   0   2   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   4  14   0   0   0   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   7   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   1   0   0   4   0   0   2   0   1   0   0   0   0]\n [  3   0   0   0   0   1   0   0   0  12   2   1   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   1  16   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   2   0   0   6   1   0   2   0   1   1]\n [  0   1   0   0   0   0   0   0   0   4   0   1  15   0   1   0   4   0]\n [  1   0   0   0   0   2   0   0   1   1   0   0   0   8   4   0   1   0]\n [  0   0   0   0   0   1   0   0   1   0   0   1   0   1   8   0   0   0]\n [  2   0   0   0   0   0   1   0   0   0   1   0   0   0   0   5   0   0]\n [  1   0   1   0   0   0   0   0   0   0   2   0   0   1   0   0  11   2]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   1   7]]",
                "lineage": "39201"
            }
        ],
        "393": [],
        "394": [],
        "395": [],
        "396": [],
        "397": [],
        "398": [],
        "399": [],
        "400": [],
        "401": [],
        "402": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.signal import butter, filtfilt\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff, fs, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = filtfilt(b, a, data, axis=0)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    train_data_filtered = lowpass_filter(train_data_reshaped, cutoff=10, fs=100, order=5)\n    val_data_filtered = lowpass_filter(val_data_reshaped, cutoff=10, fs=100, order=5)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_filtered.reshape(-1, 16)).reshape(train_data_filtered.shape)\n    val_data_scaled = scaler.transform(val_data_filtered.reshape(-1, 16)).reshape(val_data_filtered.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.5796661608497724,
                "model_info": "Confusion Matrix:\n [[363   0   2   7   6   4   3   3   0   1   6   5   0   2   5   1   2   1]\n [ 14   0   0   2   0   0   1   0   0   0   0   0   0   0   0   0   0   0]\n [  9   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0   0]\n [ 10   0   0   8   0   0   0   1   0   0   0   1   0   0   0   0   0   0]\n [ 10   0   0   0   1   0   1   1   0   0   0   0   0   0   0   0   0   0]\n [  6   0   0   0   1   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 10   0   0   0   0   0   3   0   0   0   0   0   0   0   1   0   0   0]\n [  9   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0   0]\n [  8   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0   0   0]\n [ 17   0   0   0   1   1   0   0   0   0   0   0   0   1   0   0   0   0]\n [ 15   0   0   0   0   0   0   0   0   0   2   0   0   0   0   0   0   0]\n [ 13   0   0   0   0   0   1   1   0   0   0   1   0   0   0   0   0   0]\n [ 20   0   0   1   0   0   2   0   1   0   0   1   0   0   0   0   1   0]\n [ 15   0   0   0   0   1   0   0   0   0   1   0   0   0   1   0   0   0]\n [ 10   0   0   0   0   0   0   0   0   0   1   0   0   0   1   0   0   0]\n [  8   0   0   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [ 13   0   1   1   0   0   0   0   2   0   0   0   0   0   0   0   1   0]\n [  9   0   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]]",
                "lineage": "40201"
            }
        ],
        "403": [],
        "404": [],
        "405": [],
        "406": [],
        "407": [],
        "408": [],
        "409": [],
        "410": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    class_counts = Counter(train_label)\n    total_samples = len(train_label)\n    weights = [total_samples / class_counts[label] for label in train_label]\n    sampler = WeightedRandomSampler(weights, num_samples=len(weights), replacement=True)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Confusion Matrix:\n [[391   9   0   0   2   1   1   0   1   0   0   3   0   2   0   0   0   1]\n [  0  13   1   0   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   2  17   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   1   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   7   1   0   0   0   1   1   0   0   0   0]\n [  0   1   0   0   0   0   0   0   7   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   1   0   0   0  14   0   2   0   0   0   1   1   1]\n [  0   0   0   0   0   0   0   0   0   1  14   0   0   0   0   0   1   1]\n [  1   1   0   0   0   0   0   0   2   0   1   6   3   0   1   1   0   0]\n [  0   0   0   0   0   0   0   0   1   1   2   0  16   1   0   0   5   0]\n [  0   0   0   0   1   1   0   0   1   0   0   0   0  10   4   0   1   0]\n [  0   0   0   0   1   0   0   0   1   0   0   0   1   1   8   0   0   0]\n [  0   1   0   0   0   0   1   0   0   0   0   0   0   0   0   7   0   0]\n [  0   1   0   0   0   1   0   0   0   0   1   1   0   1   0   0  13   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0   0   8]]",
                "lineage": "41001"
            }
        ],
        "411": [],
        "412": [],
        "413": [],
        "414": [],
        "415": [],
        "416": [],
        "417": [],
        "418": [],
        "419": [],
        "420": [],
        "421": [],
        "422": [],
        "423": [],
        "424": [],
        "425": [],
        "426": [],
        "427": [],
        "428": [],
        "429": [],
        "430": [],
        "431": [],
        "432": [],
        "433": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.0).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.8467374810318664,
                "model_info": "Confusion Matrix:\n [[398   2   0   0   1   1   0   1   0   0   0   1   2   1   0   4   0   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   2  15   0   0   0   0   0   0   0   0   0   0   1   2   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   5   3   0   0   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   0   0  10   0   0   0   0   0   0   0   0   4   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   7   1   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   1   0   0   2  10   3   0   0   0   0   0   1   1]\n [  1   0   0   0   0   0   0   0   0   2  13   0   0   0   0   0   1   0]\n [  2   0   0   0   0   0   0   0   2   2   0   5   4   0   1   0   0   0]\n [  0   0   0   0   0   0   0   0   1   0   2   0  18   0   0   1   3   1]\n [  1   0   0   0   0   2   0   0   1   1   0   0   0   6   6   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   1   7   0   0   2]\n [  1   0   0   0   0   0   0   0   0   0   0   0   0   0   1   7   0   0]\n [  0   1   0   0   0   0   0   0   1   0   0   0   1   0   0   1  12   2]\n [  0   0   1   0   0   0   0   0   0   0   0   0   1   0   1   0   1   6]]",
                "lineage": "43301"
            }
        ],
        "434": [],
        "435": [],
        "436": [],
        "437": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.lstm = nn.LSTM(input_size=32, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 16, 52)\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.7966616084977238,
                "model_info": "Confusion Matrix:\n [[396   3   0   0   3   0   0   1   1   0   0   0   0   2   0   5   0   0]\n [  0  13   1   0   0   0   0   1   0   0   0   1   1   0   0   0   0   0]\n [  1   0   5   1   0   0   0   0   0   0   0   1   2   0   0   0   0   0]\n [  0   0   1  14   0   1   1   0   0   1   0   0   1   0   0   0   0   1]\n [  1   0   0   0   8   3   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   1   0   0   1  12   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   8   2   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   2   0   0   5   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   0   3   1   7   2   0   1   1   2   1]\n [  0   0   1   0   0   0   0   0   0   2  12   1   1   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   1   1   0   6   0   0   2   3   0   1]\n [  0   1   1   0   0   1   0   0   1   1   3   2  10   0   0   0   5   1]\n [  0   0   0   0   0   4   0   0   2   1   1   0   0   5   2   0   1   2]\n [  0   0   0   0   0   0   0   0   3   0   1   0   1   1   4   1   0   1]\n [  0   2   1   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   1   1   0   1   0   0   1   1   1   1   1   0   0   0   7   3]\n [  0   0   0   0   0   0   0   0   0   1   0   0   1   1   0   0   1   6]]",
                "lineage": "43701"
            }
        ],
        "438": [],
        "439": [],
        "440": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXX.py",
                "accuracy": 0.881638846737481,
                "model_info": "Confusion Matrix:\n [[402   2   0   1   0   1   1   2   0   0   0   0   2   0   0   0   0   0]\n [  0  13   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   9   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   2  15   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   0   0   0   7   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   1  11   1   3   0   0   0   1   0   1]\n [  1   0   0   0   0   0   0   0   0   0  16   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   1   0   0   7   2   0   3   0   0   0]\n [  0   0   0   0   0   0   1   0   1   1   1   1  18   2   1   0   0   0]\n [  0   0   0   0   0   1   0   0   1   0   0   0   0   9   4   0   3   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   0   8   1   0   2]\n [  0   1   0   0   0   0   0   0   0   0   0   0   0   0   0   8   0   0]\n [  0   0   0   0   0   0   0   0   1   0   1   0   1   0   0   0  12   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   8]]",
                "lineage": "44001"
            }
        ],
        "441": [],
        "442": [],
        "443": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.Sequential(\n            nn.Linear(128, 128),\n            nn.Tanh(),\n            nn.Linear(128, 1),\n            nn.Softmax(dim=1)\n        )\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = self.attention(lstm_out)\n        x = (lstm_out * attention_weights).sum(dim=1)\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "Confusion Matrix:\n [[404   2   0   0   1   0   0   1   1   0   0   0   0   2   0   0   0   0]\n [  0  16   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  1   0   2  17   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0  12   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   2   0   0   5   0   0   0   0   0   0   0   0   0]\n [  2   1   0   0   1   1   0   0   2  10   1   1   0   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   1   0  16   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   1   0   0   7   3   0   3   0   0   0]\n [  1   0   0   0   0   0   0   0   1   0   1   1  13   2   2   0   4   1]\n [  0   0   0   0   0   1   0   0   0   0   0   0   0  11   4   1   1   0]\n [  0   0   0   0   1   0   0   0   1   0   0   1   1   1   6   0   0   1]\n [  3   0   0   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   1   0   1   0   0   0  13   2]\n [  0   1   0   0   0   0   0   0   0   0   0   0   1   1   1   0   1   5]]",
                "lineage": "44301"
            }
        ],
        "444": [],
        "445": [],
        "446": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom torchvision import transforms\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    data_augmentation = transforms.Compose([\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ])\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = data_augmentation(inputs)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.7374810318664643,
                "model_info": "Confusion Matrix:\n [[405   1   0   0   0   0   1   0   0   1   0   0   0   0   1   2   0   0]\n [  1  11   1   0   0   0   0   1   0   0   0   0   0   0   0   2   0   1]\n [  0   0   8   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   4   7   0   1   1   1   0   0   2   0   0   0   3   1   0   0]\n [  0   0   0   0   4   0   1   0   0   0   0   0   0   4   0   1   1   2]\n [  0   0   0   1   0   3   0   0   0   0   0   0   0   4   1   0   0   0]\n [  0   0   0   1   0   0   8   0   0   0   0   0   1   0   0   2   0   2]\n [  0   1   6   0   0   0   0   0   1   0   0   0   1   0   0   1   0   0]\n [  1   1   1   0   0   0   0   0   3   0   0   0   0   1   1   0   0   1]\n [  5   0   5   0   0   0   0   0   1   6   0   1   0   0   1   0   1   0]\n [  2   0   0   1   0   1   0   0   5   0   0   0   4   0   1   0   2   1]\n [  5   0   1   0   0   0   0   0   0   0   3   4   0   0   3   0   0   0]\n [  1   0   0   2   0   2   0   1   3   0   3   1  12   0   1   0   0   0]\n [  0   0   0   0   0   3   0   0   1   0   0   1   2   2   3   0   2   4]\n [  0   0   0   1   0   1   0   0   2   0   0   1   1   1   3   1   0   1]\n [  3   0   0   0   0   0   1   1   0   0   0   0   1   0   0   2   0   1]\n [  0   1   1   1   0   1   0   1   0   2   0   1   2   3   1   0   4   0]\n [  0   1   2   0   0   0   0   0   0   0   1   0   0   0   2   0   0   4]]",
                "lineage": "44601"
            }
        ],
        "447": [],
        "448": [],
        "449": [],
        "450": [],
        "451": [],
        "452": [],
        "453": [],
        "454": [],
        "455": [],
        "456": [],
        "457": [],
        "458": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(20):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8118361153262519,
                "model_info": "Confusion Matrix:\n [[403   3   0   0   1   1   0   1   0   1   0   0   0   0   0   1   0   0]\n [  1  10   2   3   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  16   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   7   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   1   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   1   2   0   2   0   0   2   0   0   0]\n [  3   0   1   0   0   0   0   0   1   5   4   4   1   0   1   0   0   0]\n [  0   0   0   0   1   0   0   0   0   0  15   0   0   0   0   0   0   1]\n [  3   0   0   0   0   0   0   0   2   0   0   5   2   0   4   0   0   0]\n [  1   0   0   0   0   0   0   0   0   0   0   2   0   0   5   0   2  16]\n [  0   0   0   0   2   2   0   0   1   1   3   0   0   3   5   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   1   0   1   0  10   0   0   0]\n [  3   0   1   1   0   0   1   0   0   0   0   0   0   0   0   3   0   0]\n [  0   0   1   0   0   0   0   0   0   0   1   1   0   0   0   0  11   4]\n [  0   0   0   0   0   1   0   0   0   0   0   0   0   0   1   0   1   7]]",
                "lineage": "45801"
            }
        ],
        "459": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8285280728376327,
                "model_info": "Confusion Matrix:\n [[402   2   0   0   3   0   0   1   0   0   0   0   0   0   0   2   0   1]\n [  1  13   1   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   2   2  14   0   1   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   4   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   0   0   0   0   2   0   1   5   0   0   0   0   0   0   0   0   0]\n [  3   0   0   0   1   0   0   0   2   7   2   4   0   0   1   0   0   0]\n [  1   0   0   0   1   0   0   0   0   0  15   0   0   0   0   0   0   0]\n [  3   0   0   0   0   0   0   0   4   0   1   5   0   0   2   0   1   0]\n [  1   2   0   0   0   0   0   0   1   0   1   3   4   1   3   0   5   5]\n [  0   0   0   0   2   0   0   0   1   4   0   0   0   4   6   0   1   0]\n [  0   0   0   0   0   0   0   0   2   0   1   1   0   0   8   0   0   0]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   2   0   0   0   0   0   0   0   0   3   1   0   1   0   0  10   1]\n [  0   0   2   0   0   0   0   0   0   0   0   0   1   0   1   0   1   5]]",
                "lineage": "45901"
            }
        ],
        "460": [],
        "461": [],
        "462": [],
        "463": [],
        "464": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=4)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_out, _ = self.attention(lstm_out, lstm_out, lstm_out)\n        x = attn_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8315629742033384,
                "model_info": "Confusion Matrix:\n [[404   0   0   0   1   0   1   2   1   0   0   0   0   0   0   1   0   1]\n [  1  12   2   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   1   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   6   1   1   0   0   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   1   1   0   0   1   0   0   4   1   0   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   1   4   0   5   0   5   0   1   0   0]\n [  1   0   0   0   0   0   0   0   0   0  13   0   0   0   0   0   2   1]\n [  2   0   0   0   0   0   0   0   1   1   2   8   0   1   0   0   0   1]\n [  0   0   0   0   0   0   1   0   0   3   0   2   5   0   1   0   3  11]\n [  0   0   0   0   1   2   0   0   1   1   0   0   0  10   3   0   0   0]\n [  0   0   0   0   0   0   0   0   0   2   1   3   1   1   4   0   0   0]\n [  1   0   0   0   0   0   2   0   1   0   0   0   0   1   0   4   0   0]\n [  0   0   0   0   0   0   0   0   0   0   0   2   0   0   0   0  13   3]\n [  0   0   0   1   0   0   0   0   0   1   0   0   0   1   0   0   0   7]]",
                "lineage": "46401"
            }
        ],
        "465": [],
        "466": [],
        "467": [],
        "468": [],
        "469": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8270106221547799,
                "model_info": "Confusion Matrix:\n [[401   1   1   0   2   0   0   0   0   2   0   0   1   0   1   2   0   0]\n [  1  13   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   5  13   0   0   0   0   0   1   0   0   0   0   0   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   1   0   0   0   0   1   0   0   0]\n [  2   0   1   0   0   0   0   0   0   8   1   6   0   0   0   1   0   1]\n [  0   1   0   0   0   1   0   0   0   0  15   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   3   2   1   3   0   0   1   0   1   1]\n [  0   0   0   0   0   0   0   0   2   1   2   3   7   0   1   1   5   4]\n [  0   0   0   0   0   2   0   0   1   1   1   0   0   5   5   0   1   2]\n [  0   0   0   0   0   0   0   0   2   0   1   1   1   0   6   0   0   1]\n [  2   0   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   2   1   0   0   0  12   2]\n [  0   0   1   0   0   0   0   0   0   0   0   0   2   1   0   0   1   5]]",
                "lineage": "46901"
            }
        ],
        "470": [],
        "471": [],
        "472": [],
        "473": [],
        "474": [],
        "475": [],
        "476": [],
        "477": [],
        "478": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    class_counts = Counter(train_label)\n    total_samples = len(train_label)\n    class_weights = {cls: total_samples / count for cls, count in class_counts.items()}\n    weights = [class_weights[label.item()] for label in train_label_tensor]\n    sampler = WeightedRandomSampler(weights, num_samples=len(weights), replacement=True)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Confusion Matrix:\n [[380   8   2   0   2   1   1   6   0   0   1   3   1   0   0   6   0   0]\n [  0  15   1   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   9   0   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0   9   3   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   0   6   0   0   1   0   1   0   0   0   0]\n [  3   0   0   0   0   0   0   0   0  14   0   2   0   0   0   0   0   1]\n [  0   0   0   0   0   1   0   0   0   1  14   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   0   1   0   0  11   1   0   2   0   0   0]\n [  0   0   0   0   0   0   1   0   0   0   1   2  14   1   3   0   3   1]\n [  0   0   0   0   0   1   0   0   1   0   0   0   0   7   5   1   2   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1  11   0   0   0]\n [  1   0   0   0   0   0   1   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   1   0   0   0   0  12   4]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   1   1   0   0   7]]",
                "lineage": "47801"
            }
        ],
        "479": [],
        "480": [],
        "481": [],
        "482": [],
        "483": [],
        "484": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.866464339908953,
                "model_info": "Confusion Matrix:\n [[402   3   1   0   1   0   0   0   0   0   0   0   1   1   0   1   0   1]\n [  0  14   2   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   1   7   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   3   1   0   0   1   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   0   7   1   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  14   3   1   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0   0  16   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   4   0   1   5   2   0   2   0   0   0]\n [  0   1   0   0   0   0   0   0   1   0   3   1  12   0   0   0   5   3]\n [  0   0   0   0   0   0   0   0   1   0   2   0   0  11   3   0   0   1]\n [  0   0   0   0   0   1   0   0   0   0   0   1   0   0   8   0   0   2]\n [  2   0   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   2   2   0   0   0   0  11   3]\n [  0   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0   8]]",
                "lineage": "48401"
            }
        ],
        "485": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.7541729893778453,
                "model_info": "Confusion Matrix:\n [[403   2   1   0   1   0   1   1   0   0   0   0   1   0   1   0   0   0]\n [  1   6   2   2   0   0   0   6   0   0   0   0   0   0   0   0   0   0]\n [  0   1   7   1   0   0   0   0   0   0   1   0   0   0   0   0   0   0]\n [  0   1   3  15   0   0   0   0   0   0   0   0   1   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   1   0   0  12   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   1   0   1   0   0   0   0   0   0   1   0   3   2]\n [  1   0   0   0   1   1   0   0   0   0   4   5   0   1   0   0   6   1]\n [  0   0   0   0   0   0   0   0   0   0   5   0   0   0   0   0   9   3]\n [  4   0   0   0   0   0   0   0   0   0   3   2   1   0   0   0   3   3]\n [  0   1   0   0   0   0   0   0   0   0   0   5   2   0   0   0  14   4]\n [  1   0   0   0   1   1   0   0   0   0   1   0   1   1   4   0   7   1]\n [  0   0   0   0   0   0   0   0   0   0   3   0   0   1   7   0   1   0]\n [  2   2   2   2   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   1   0   0   0   0   3   0   0   1   2   0   8   3]\n [  0   0   0   0   0   0   0   0   0   0   0   1   1   0   2   0   2   4]]",
                "lineage": "48501"
            }
        ],
        "486": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            noise = torch.randn_like(inputs) * 0.01\n            inputs_noisy = inputs + noise\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs_noisy)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8679817905918058,
                "model_info": "Confusion Matrix:\n [[401   2   0   0   1   0   2   1   0   0   0   0   1   0   0   2   1   0]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   4  14   0   0   0   0   0   0   0   0   0   0   1   1   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   4   4   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   2   1   0   0   3   0   0   0   0   1   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0  14   3   1   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   0   0   0   1   0   1]\n [  2   0   0   0   0   0   0   0   1   3   1   6   0   0   1   1   0   1]\n [  0   1   0   0   0   0   0   0   3   0   2   1  15   0   1   0   3   0]\n [  0   0   0   0   1   1   0   0   1   2   0   0   0  10   2   0   1   0]\n [  0   0   0   0   1   0   0   0   0   0   0   2   1   1   7   0   0   0]\n [  3   0   0   0   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   0   0   0   1   1   0   1   0   0   0   0   0   0   0  12   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   8]]",
                "lineage": "48601"
            }
        ],
        "487": [],
        "488": [],
        "489": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.842185128983308,
                "model_info": "Confusion Matrix:\n [[399   5   0   0   1   0   0   0   0   1   0   0   1   0   0   4   0   0]\n [  1  13   0   1   0   0   0   0   1   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   1   2  16   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   1   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   1   5   1   0   0   0   0   0   0   0   0]\n [  3   0   1   0   1   0   0   0   0   9   1   5   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0   0  15   0   0   0   1   0   0   0]\n [  4   0   0   0   0   0   0   0   2   1   1   6   1   0   0   0   0   1]\n [  0   0   0   0   0   0   1   0   1   1   2   2   9   4   0   0   2   4]\n [  0   0   0   0   1   1   0   0   2   1   0   0   0   6   6   0   1   0]\n [  0   0   0   0   0   0   0   0   1   2   0   2   0   0   7   0   0   0]\n [  2   0   0   1   0   0   1   0   0   0   0   0   0   0   0   5   0   0]\n [  0   0   1   1   0   0   0   0   0   0   3   1   0   0   0   0  11   1]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   2   6]]",
                "lineage": "48901"
            }
        ],
        "490": [],
        "491": [],
        "492": [],
        "493": [],
        "494": [],
        "495": [],
        "496": [],
        "497": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8209408194233687,
                "model_info": "Confusion Matrix:\n [[405   1   0   0   0   1   0   0   0   0   0   2   0   0   1   1   0   0]\n [  1  11   2   3   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   1   7   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   4   0   0   0   0   0   0   0   2   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   1   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   0   0   0   0   0   0   0   1   0]\n [  2   0   0   0   1   0   0   0   2   4   3   7   0   0   1   0   0   0]\n [  1   0   0   0   1   0   0   0   0   1  11   0   0   0   2   0   0   1]\n [  3   0   0   0   0   0   0   0   2   1   0   7   1   0   1   0   0   1]\n [  0   0   0   0   0   0   1   0   0   0   2   5   7   0   1   0   4   6]\n [  0   0   0   0   1   1   0   0   1   0   4   1   0   5   4   0   1   0]\n [  0   0   0   0   0   0   0   0   1   1   1   1   1   0   6   0   0   1]\n [  2   0   1   2   0   0   0   0   0   0   0   0   0   0   0   4   0   0]\n [  0   0   1   0   0   0   0   0   0   1   1   0   1   0   2   0  10   2]\n [  0   0   1   0   0   0   0   0   0   0   1   0   2   0   1   0   1   4]]",
                "lineage": "49701"
            }
        ],
        "498": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attention_weights = torch.softmax(self.attention(lstm_out), dim=1)\n        context_vector = torch.bmm(attention_weights.permute(0, 2, 1), lstm_out).squeeze(1)\n        x = self.fc(context_vector)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8786039453717754,
                "model_info": "Confusion Matrix:\n [[406   1   0   0   0   0   0   0   0   1   0   1   0   1   0   1   0   0]\n [  1  14   0   1   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   3  16   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   1   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   6   1   0   0   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   0  16   0   1   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   0   0   2  12   0   0   0   0   0   2   0]\n [  2   0   0   0   0   0   0   0   0   0   0   9   2   0   2   0   0   1]\n [  1   0   0   0   0   0   0   0   2   1   1   3  14   0   2   0   2   0]\n [  4   0   0   0   0   0   0   0   2   0   0   0   0   7   3   0   2   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   2   9   0   0   0]\n [  2   0   1   0   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   1   0   0   0   0   0   0   0   0   2   0   1   0   0   1  12   1]\n [  1   0   0   0   0   0   0   0   0   0   0   1   0   0   1   0   0   7]]",
                "lineage": "49801"
            }
        ],
        "499": [],
        "500": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "Confusion Matrix:\n [[403   2   0   0   0   0   0   1   0   0   0   0   1   0   0   2   0   2]\n [  0  14   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   7   1   0   0   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   4  13   0   0   0   0   1   0   0   0   0   0   0   2   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   0   0   0   0   0   0   0   6   0   0   0   0   2   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  14   1   2   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   1  13   0   1   0   0   0   2   0]\n [  2   0   0   0   0   0   0   0   1   2   0   6   2   0   2   0   1   0]\n [  0   1   0   0   0   0   0   0   2   0   0   1  17   1   0   0   3   1]\n [  0   0   0   0   0   2   0   0   1   0   0   0   0   8   4   0   3   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   1   0   8   0   1   0]\n [  1   0   0   0   0   0   1   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   1   0   0   0   0   0   0   1   0   0   0   0   0  12   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   9]]",
                "lineage": "50001"
            }
        ],
        "501": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass ResidualBlock(nn.Module):\n    def __init__(self, in_channels, out_channels):\n        super(ResidualBlock, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels, out_channels, kernel_size=3, padding=1)\n        self.bn1 = nn.BatchNorm1d(out_channels)\n        self.conv2 = nn.Conv1d(out_channels, out_channels, kernel_size=3, padding=1)\n        self.bn2 = nn.BatchNorm1d(out_channels)\n        self.shortcut = nn.Conv1d(in_channels, out_channels, kernel_size=1) if in_channels != out_channels else None\n\n    def forward(self, x):\n        identity = x\n        out = self.conv1(x)\n        out = self.bn1(out)\n        out = nn.ReLU()(out)\n        out = self.conv2(out)\n        out = self.bn2(out)\n        if self.shortcut is not None:\n            identity = self.shortcut(identity)\n        out += identity\n        return nn.ReLU()(out)\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.residual_block1 = ResidualBlock(16, 64)\n        self.residual_block2 = ResidualBlock(64, 128)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.residual_block1(x)\n        x = self.residual_block2(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8315629742033384,
                "model_info": "Confusion Matrix:\n [[398   2   1   0   0   0   0   0   0   1   0   1   1   0   1   4   0   2]\n [  0  14   1   0   0   0   1   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  14   1   0   2   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   9   4   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   1   0   0   0   0   0   0   0   0]\n [  1   1   0   1   0   1   0   0   4   0   0   0   0   0   0   0   0   1]\n [  2   0   0   0   0   1   0   0   2  10   1   4   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   0   2   8   0   5   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   2   0   0   4   4   0   1   0   0   2]\n [  0   0   0   0   0   0   0   0   2   1   0   0  15   0   0   0   5   3]\n [  0   0   0   0   2   0   0   0   1   4   1   0   0   6   2   0   2   0]\n [  0   0   0   0   1   0   0   0   0   0   1   1   2   1   1   1   1   3]\n [  1   1   0   0   0   0   1   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0  15   3]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   0   0   8]]",
                "lineage": "50101"
            }
        ],
        "502": [],
        "503": [],
        "504": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()\n\ndef augment_data_with_synthetic_gestures(train_data, train_label):\n    augmented_data = []\n    augmented_labels = []\n    for i in range(len(train_data)):\n        for j in range(i + 1, len(train_data)):\n            synthetic_gesture = (train_data[i] + train_data[j]) / 2\n            augmented_data.append(synthetic_gesture)\n            augmented_labels.append(train_label[i])\n    return np.array(augmented_data), np.array(augmented_labels)\n",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8755690440060698,
                "model_info": "Confusion Matrix:\n [[403   3   0   0   1   0   1   0   0   0   0   0   1   0   0   2   0   0]\n [  1  12   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   3   4   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   1   0]\n [  1   1   0   0   0   0   0   0   6   1   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   1  11   1   4   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   0   0   0   1   0   1]\n [  3   0   0   0   0   0   0   0   0   1   1   6   3   1   1   0   0   0]\n [  0   0   0   0   0   0   1   0   2   0   2   1  16   2   1   0   1   0]\n [  0   0   0   0   0   2   0   0   1   0   0   0   0  11   3   0   1   0]\n [  0   0   0   0   0   0   0   0   1   0   0   1   1   0   9   0   0   0]\n [  1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   8   0   0]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0  12   6]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   1   0   0   8]]",
                "lineage": "50401"
            }
        ],
        "505": [],
        "506": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n            memory_usage = torch.cuda.memory_allocated(device) / (1024 ** 2)\n            print(f\"Epoch [{epoch+1}/50], Memory Usage: {memory_usage:.2f} MB\")\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8755690440060698,
                "model_info": "Epoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 34.06 MB\nEpoch [1/50], Memory Usage: 33.90 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEpoch [2/50], Memory Usage: 34.06 MB\nEp",
                "lineage": "50601"
            }
        ],
        "507": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.layer_norm = nn.LayerNorm(128)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.layer_norm(x)\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8649468892261002,
                "model_info": "Confusion Matrix:\n [[404   2   1   0   0   0   3   0   0   1   0   0   0   0   0   0   0   0]\n [  1  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   7   1   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   1   3  13   0   0   0   0   0   0   0   0   0   1   0   2   0   0]\n [  0   0   0   0   8   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   1   7   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   6   3   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   0   0   0   7   0   0   0   0   1   0   0   0   0]\n [  2   0   0   0   0   1   0   0   0  14   1   0   0   0   0   1   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   0   0   0   0   0   2]\n [  2   0   0   0   0   0   0   0   2   1   1   7   1   0   0   1   1   0]\n [  0   0   0   0   0   0   1   0   0   1   1   2  12   0   1   0   6   2]\n [  0   0   0   0   0   0   0   0   1   1   0   0   0   9   6   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   2   8   0   0   1]\n [  1   0   0   0   0   0   3   0   0   0   0   0   0   0   0   5   0   0]\n [  1   0   0   0   0   0   0   0   0   0   1   0   0   0   0   0  12   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   1   7]]",
                "lineage": "50701"
            }
        ],
        "508": [],
        "509": [],
        "510": [],
        "511": [],
        "512": [],
        "513": [],
        "514": [],
        "515": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8057663125948407,
                "model_info": "Confusion Matrix:\n [[402   2   1   0   0   0   0   0   0   0   0   4   0   0   2   0   0   0]\n [  1  11   3   2   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   0   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  0   0   0   0  11   2   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   5   0   0   0   0   0   2   0   0   0   0   0   0]\n [  0   0   1   1   0   0  12   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   2   0   0   4   1   0   0   0   0   0   0   0   0]\n [  1   0   0   0   0   1   0   0   3   6   1   2   0   0   5   0   0   1]\n [  1   0   0   0   0   0   0   0   0   0  15   0   0   0   1   0   0   0]\n [  4   0   0   0   0   0   0   0   3   1   1   5   1   0   0   0   1   0]\n [  0   1   0   0   1   1   0   0   0   0   3   2   4   0   1   0   8   5]\n [  0   0   0   0   1   1   0   0   1   2   0   1   0   3   7   0   1   1]\n [  0   0   0   0   0   0   0   0   0   1   1   2   1   0   7   0   0   0]\n [  1   1   2   1   0   0   1   0   0   0   0   0   0   0   0   3   0   0]\n [  0   0   2   0   0   0   0   0   0   0   2   1   0   1   0   0  11   1]\n [  0   0   1   0   0   0   0   0   0   1   0   0   3   0   1   0   3   1]]",
                "lineage": "51501"
            }
        ],
        "516": [],
        "517": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}, Loss: {loss.item():.4f}\")\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.7830045523520486,
                "model_info": "Epoch 0, Loss: 1.2336\nEpoch 10, Loss: 0.3695\nEpoch 20, Loss: 0.3332\nConfusion Matrix:\n [[403   2   0   0   3   1   0   2   0   0   0   0   0   0   0   0   0   0]\n [  1   7   2   1   0   0   0   5   0   0   0   0   0   0   0   1   0   0]\n [  1   0   9   0   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   1   0   1   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   8   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   2   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   1   0   0  13   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   0   0   0   0   0   8   0   0   0   1   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   0   1   0   3   0   0   2   0   0   0]\n [  3   0   1   0   2   0   0   0   0   2   4   5   0   0   3   0   0   0]\n [  1   0   0   0   0   0   0   0   0   1   7   0   1   0   1   0   0   6]\n [  3   0   0   0   1   0   0   0   0   1   1   8   0   1   0   0   0   1]\n [  0   1   0   1   0   0   0   0   0   0   3   5   2   0   0   0   3  11]\n [  0   0   0   0   1   2   0   0   0   0   3   1   0   4   6   0   1   0]\n [  0   0   0   0   0   0   0   0   0   0   3   1   0   0   8   0   0   0]\n [  2   1   0   2   0   0   0   1   0   0   0   0   0   0   0   3   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   2   0   2   0   0  10   3]\n [  0   0   0   0   0   0   0   0   0   0   0   2   0   0   1   0   3   4]]",
                "lineage": "51701"
            }
        ],
        "518": [],
        "519": [],
        "520": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.7981790591805766,
                "model_info": "Confusion Matrix:\n [[404   3   0   0   2   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  1  11   3   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   6   1   1   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   3   0   0   0   0   0   6   0   1   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   1   0   0   4   0   0   1   0   1   0   0   0   0]\n [  3   0   0   0   1   0   0   0   1   5   2   7   0   0   1   0   0   0]\n [  0   0   0   0   1   0   0   0   0   0  10   0   0   0   4   1   1   0]\n [  3   0   0   1   0   0   0   0   3   1   2   5   0   0   0   0   1   0]\n [  1   0   0   0   0   0   0   0   1   2   4   3   0   0   1   0  10   4]\n [  1   0   0   0   2   0   0   0   1   1   2   0   0   7   4   0   0   0]\n [  0   0   0   0   2   0   0   0   0   0   2   1   0   1   5   0   1   0]\n [  2   0   0   2   0   0   0   0   0   0   0   0   0   0   1   4   0   0]\n [  0   0   2   0   0   0   0   0   1   0   2   1   1   0   1   0   8   2]\n [  0   0   0   0   0   0   0   0   0   0   1   0   0   1   1   0   1   6]]",
                "lineage": "52001"
            }
        ],
        "521": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.881638846737481,
                "model_info": "Confusion Matrix:\n [[401   1   1   0   1   0   0   1   0   1   1   0   1   0   0   2   0   1]\n [  1  12   2   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  1   0   8   1   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   3  15   0   0   0   0   0   0   0   0   0   1   0   1   0   0]\n [  0   0   0   0  12   1   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   2   6   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  14   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   5   1   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   1  11   1   2   1   0   0   1   0   1]\n [  0   0   0   0   0   0   0   0   0   1  15   0   0   0   0   1   0   0]\n [  3   0   0   0   0   0   0   0   1   1   0   8   0   0   1   0   0   2]\n [  0   1   0   0   0   0   0   0   1   1   1   1  20   0   0   0   1   0]\n [  0   0   0   0   0   1   0   0   1   1   0   0   0  10   3   0   1   1]\n [  0   0   0   0   0   0   0   0   2   0   0   0   2   0   7   0   1   0]\n [  1   0   0   0   0   0   1   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   1   0   1   0   1   0   0   0  13   2]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   1   8]]",
                "lineage": "52101"
            }
        ],
        "522": [],
        "523": [],
        "524": [],
        "525": [],
        "526": [],
        "527": [],
        "528": [],
        "529": [],
        "530": [],
        "531": [],
        "532": [],
        "533": [],
        "534": [],
        "535": [],
        "536": [],
        "537": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            jittered_inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(jittered_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.858877086494689,
                "model_info": "Confusion Matrix:\n [[400   1   0   0   2   0   0   2   1   0   0   0   1   0   0   3   0   1]\n [  0  15   1   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0]\n [  0   1   7   1   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   1   1  15   0   0   0   0   0   0   0   0   0   1   0   2   0   0]\n [  0   0   0   0  13   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   6   2   0   0   0   0   0   0   0   0   0   0   1   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  1   0   0   0   0   0   0   8   1   0   0   0   0   0   0   0   0   0]\n [  1   0   0   0   1   0   0   0   3   2   0   0   1   1   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  14   1   2   0   0   0   0   0   1]\n [  0   0   0   0   0   0   0   0   0   0  15   0   1   0   0   0   1   0]\n [  3   0   0   0   0   0   0   0   1   0   1   6   3   0   1   0   0   1]\n [  0   0   0   0   1   0   1   0   0   0   2   1  14   0   2   0   5   0]\n [  0   0   0   0   2   0   0   0   1   1   0   0   0   9   4   0   1   0]\n [  0   0   0   0   1   0   0   0   0   0   1   0   0   1   8   0   1   0]\n [  0   0   0   0   0   0   1   1   0   0   0   0   0   0   1   6   0   0]\n [  0   0   0   0   0   0   0   0   1   0   4   0   0   0   0   0  11   2]\n [  0   0   0   0   0   0   0   0   0   0   0   1   0   1   0   0   1   7]]",
                "lineage": "53701"
            }
        ],
        "538": [],
        "539": [],
        "540": [],
        "541": [],
        "542": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "Confusion Matrix:\n [[401   2   0   0   1   0   2   0   1   1   0   0   0   0   0   2   0   1]\n [  1  13   1   0   0   0   0   0   0   0   0   0   0   0   0   2   0   0]\n [  0   0   8   1   0   0   0   0   0   0   0   0   0   0   1   0   0   0]\n [  0   0   4  15   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   0   0   0   0   0   0   5   1   0   0   0   1   0   0   0   0]\n [  2   0   0   0   0   1   0   0   0  15   0   0   0   0   0   1   0   1]\n [  0   0   0   0   0   0   0   0   0   3  14   0   0   0   0   0   0   0]\n [  4   0   0   0   0   0   0   0   2   1   0   5   2   0   0   0   1   1]\n [  0   0   0   0   0   0   1   0   0   0   0   1  19   2   0   0   3   0]\n [  0   0   0   0   0   0   0   0   1   2   1   0   0  11   1   0   1   1]\n [  0   0   0   0   0   0   0   0   1   1   0   1   0   1   7   0   0   1]\n [  1   1   0   0   0   0   0   0   0   0   0   0   0   0   0   7   0   0]\n [  0   0   0   0   0   0   0   0   0   0   1   1   0   0   0   0  12   4]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   3   6]]",
                "lineage": "54201"
            }
        ],
        "543": [],
        "544": [],
        "545": [],
        "546": [],
        "547": [],
        "548": [],
        "549": [],
        "550": [],
        "551": [],
        "552": [],
        "553": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn1 = nn.Conv1d(in_channels=16, out_channels=64, kernel_size=3, padding=1)\n        self.tcn2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=5, padding=2)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn1(x)\n        x = self.tcn2(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8603945371775418,
                "model_info": "Confusion Matrix:\n [[401   4   0   0   0   0   0   0   0   0   0   0   1   1   0   3   0   1]\n [  0  11   2   2   0   0   0   1   0   0   0   0   0   0   0   1   0   0]\n [  0   0   8   1   1   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   1   3  15   0   0   0   0   0   0   0   0   0   1   0   0   0   0]\n [  0   0   0   0   8   5   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   1   2   5   0   0   0   0   0   0   0   0   0   0   0   1]\n [  0   0   0   0   0   0  13   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   0   0   0   0   0   0   0   0   0   1]\n [  1   1   0   0   0   1   0   0   6   0   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0  15   2   0   0   0   0   0   1   0]\n [  0   0   0   0   0   0   0   0   0   1  14   0   0   1   0   1   0   0]\n [  4   0   0   0   0   0   0   0   2   1   0   5   4   0   0   0   0   0]\n [  0   1   0   0   0   0   0   0   2   0   0   1  18   0   1   0   3   0]\n [  0   0   0   0   0   3   0   0   1   2   0   0   0   6   4   1   1   0]\n [  0   0   0   0   0   0   0   0   0   1   0   2   1   0   8   0   0   0]\n [  1   0   1   1   0   0   0   0   0   0   0   0   0   0   0   6   0   0]\n [  0   0   0   0   0   0   0   0   0   0   3   0   1   1   0   0  10   3]\n [  0   0   0   0   0   0   0   0   0   0   0   0   0   1   0   0   0   9]]",
                "lineage": "55301"
            }
        ],
        "554": [],
        "555": [],
        "556": [],
        "557": [],
        "558": [],
        "559": [],
        "560": [],
        "561": [],
        "562": [],
        "563": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix\nfrom scipy.stats import skew, kurtosis\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    print(\"Confusion Matrix:\\n\", cm)\n\n    skewness = skew(train_data_reshaped.reshape(-1, 16), axis=0)\n    kurt = kurtosis(train_data_reshaped.reshape(-1, 16), axis=0)\n    print(\"Skewness:\", skewness)\n    print(\"Kurtosis:\", kurt)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.795144157814871,
                "model_info": "Confusion Matrix:\n [[402   1   0   0   0   0   1   2   0   0   0   1   0   0   1   2   0   1]\n [  1  12   1   3   0   0   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   7   1   1   0   0   0   0   0   0   1   0   0   0   0   0   0]\n [  1   0   3  15   0   0   0   0   1   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0  10   3   0   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   0   3   5   1   0   0   0   0   0   0   0   0   0   0   0]\n [  0   0   0   1   0   0  12   0   0   0   0   0   0   0   0   1   0   0]\n [  0   0   0   0   0   0   0   9   1   0   0   0   0   0   0   0   0   0]\n [  1   1   1   0   0   5   0   0   1   0   0   0   0   0   0   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0   5  12   0   0   1   0   0   0]\n [  2   0   0   0   0   0   0   0   0   0  14   0   1   0   0   0   0   0]\n [  4   0   0   0   0   1   0   0   1   0   0   7   0   0   1   0   0   2]\n [  0   1   0   0   0   0   0   0   2   1   2   4   3   0   0   0  10   3]\n [  0   0   0   0   1   3   0   0   1   0   0   1   0   3   7   0   1   1]\n [  0   0   0   0   0   1   0   0   1   0   1   1   0   0   8   0   0   0]\n [  1   1   0   2   0   0   0   0   0   0   0   0   0   0   1   4   0   0]\n [  0   0   0   0   0   0   0   0   1   0   2   0   0   0   0   0  10   5]\n [  0   0   1   0   0   0   0   0   0   0   0   1   0   0   1   0   5   2]]\nSkewness: [3.25963739 3.91390923 4.1359612  3.48641568 3.41339898 5.54875737\n 4.47395653 3.69283207 2.91146444 5.49333818 6.40458414 3.32083827\n 4.00157905 4.77781332 5.53423786 3.22558847]\nKurtosis: [16.84603816 21.60169918 27.42183558 18.98185196 15.39542449 44.2761265\n 29.03754199 26.28561489 11.25692697 44.79085367 65.74262586 16.46710648\n 22.94236782 31.798799   47.73645384 15.76162234]",
                "lineage": "56301"
            }
        ],
        "564": [],
        "565": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXX.py",
                "accuracy": 0.8831562974203339,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8831562974203339, 'f1_score': 0.8818917935368288, 'precision': 0.8907175550766534, 'recall': 0.8831562974203339, 'confusion_matrix': [[403, 4, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 1, 7, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 2, 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 3, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 1, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 13, 3, 1, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 1, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 9, 3, 0, 1, 0, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 19, 0, 0, 0, 3, 0], [0, 0, 0, 0, 0, 5, 0, 0, 1, 0, 0, 0, 0, 6, 4, 0, 1, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 1, 0, 6, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 12, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 8]]}",
                "lineage": "56501"
            }
        ],
        "566": [],
        "567": [],
        "568": [],
        "569": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss(weight=torch.tensor([1.0] * 18)).to(device)\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8710166919575114, 'f1_score': 0.8694341117544511, 'precision': 0.8814471058695761, 'recall': 0.8710166919575114, 'confusion_matrix': [[405, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 13, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 2, 1, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 1, 0, 0, 0, 2, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 2, 1], [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 13, 0, 2, 0, 0, 0, 0, 0], [2, 0, 0, 0, 1, 1, 0, 0, 1, 1, 1, 5, 1, 0, 0, 1, 2, 0], [0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 15, 2, 0, 0, 5, 0], [0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 10, 3, 0, 2, 0], [0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 1, 0, 0, 6, 0, 0, 2], [2, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 12, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 8]]}",
                "lineage": "56901"
            }
        ],
        "570": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=4)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_out, _ = self.attention(lstm_out, lstm_out, lstm_out)\n        x = attn_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.8467374810318664,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8467374810318664, 'f1_score': 0.8462297909025069, 'precision': 0.8537217378018247, 'recall': 0.8467374810318664, 'confusion_matrix': [[400, 2, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 4, 0, 1], [1, 13, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 13, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 2, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 8, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0], [1, 1, 0, 0, 1, 1, 0, 0, 3, 1, 0, 0, 1, 0, 0, 0, 0, 0], [2, 0, 0, 0, 1, 0, 0, 0, 1, 9, 2, 3, 0, 0, 0, 1, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 13, 0, 1, 0, 0, 0, 2, 1], [3, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 5, 2, 0, 3, 0, 0, 0], [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 3, 1, 15, 1, 1, 0, 2, 2], [0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 10, 3, 0, 0, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 7, 0, 2, 0], [2, 0, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 13, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 0, 0, 7]]}",
                "lineage": "57001"
            }
        ],
        "571": [],
        "572": [],
        "573": [],
        "574": [],
        "575": [],
        "576": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.3):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    \n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.8209408194233687,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8209408194233687, 'f1_score': 0.8105376615002389, 'precision': 0.8318702588592578, 'recall': 0.8209408194233687, 'confusion_matrix': [[406, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0], [1, 12, 1, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 2, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 2, 4, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [2, 1, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [2, 0, 0, 0, 0, 1, 0, 0, 2, 1, 0, 1, 1, 0, 1, 0, 0, 0], [2, 0, 0, 0, 1, 1, 0, 0, 0, 8, 3, 5, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 11, 0, 0, 1, 2, 0, 0, 1], [3, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 7, 2, 0, 0, 0, 0, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 4, 2, 4, 0, 0, 0, 3, 11], [0, 0, 0, 0, 1, 1, 0, 0, 0, 2, 1, 0, 0, 3, 7, 0, 3, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 2, 2, 1, 0, 6, 0, 0, 0], [2, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 0, 0, 0, 0, 12, 2], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 6]]}",
                "lineage": "57601"
            }
        ],
        "577": [],
        "578": [],
        "579": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8710166919575114, 'f1_score': 0.8719163909298396, 'precision': 0.8774000374009497, 'recall': 0.8710166919575114, 'confusion_matrix': [[401, 2, 0, 0, 1, 0, 3, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0], [0, 13, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 3, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [1, 1, 0, 0, 0, 1, 0, 0, 5, 0, 0, 0, 0, 1, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 2, 12, 0, 4, 1, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 0, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 7, 3, 0, 1, 0, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 19, 2, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 11, 3, 0, 1, 1], [0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 8, 0, 0, 0], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 1, 0, 0, 0, 12, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 0, 1, 0, 0, 4]]}",
                "lineage": "57901"
            }
        ],
        "580": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXX.py",
                "accuracy": 0.8937784522003035,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8937784522003035, 'f1_score': 0.8939482568239985, 'precision': 0.9015236080620324, 'recall': 0.8937784522003035, 'confusion_matrix': [[403, 0, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 3, 0, 0], [0, 13, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 16, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 2, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 14, 0, 2, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 9, 2, 0, 0, 0, 0, 1], [0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 16, 1, 0, 0, 3, 2], [2, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 10, 2, 0, 1, 0], [0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 0, 1, 0], [1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 13, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 8]]}",
                "lineage": "58001"
            }
        ],
        "581": [],
        "582": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8270106221547799,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8270106221547799, 'f1_score': 0.8183860437783551, 'precision': 0.8292058466105846, 'recall': 0.8270106221547799, 'confusion_matrix': [[403, 3, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 2, 0, 0], [1, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 0, 1, 0, 0, 0, 7, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 2, 0, 0, 0, 8, 2, 5, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 1, 0, 0], [4, 0, 0, 0, 0, 0, 0, 0, 3, 1, 0, 5, 1, 0, 0, 0, 2, 0], [0, 3, 0, 0, 0, 0, 1, 0, 2, 1, 2, 3, 5, 1, 0, 0, 6, 2], [0, 0, 0, 0, 0, 2, 0, 0, 1, 5, 0, 0, 0, 4, 5, 0, 1, 0], [0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 2, 0, 6, 0, 0, 0], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 1, 1, 11, 2], [0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 4]]}",
                "lineage": "58201"
            }
        ],
        "583": [],
        "584": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    \n    class_weights = torch.tensor([1.0 if i < 10 else 2.0 for i in range(18)]).to(device)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8831562974203339,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8831562974203339, 'f1_score': 0.8821821285334122, 'precision': 0.8900507744458425, 'recall': 0.8831562974203339, 'confusion_matrix': [[400, 2, 0, 0, 0, 1, 0, 2, 0, 0, 0, 1, 1, 0, 0, 4, 0, 0], [0, 13, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 9, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 14, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 1, 5, 1, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 15, 1, 0, 1, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 7, 3, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 22, 0, 0, 0, 1, 1], [1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 9, 5, 0, 2, 0], [0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 2, 7, 0, 0, 0], [3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 14, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 8]]}",
                "lineage": "58401"
            }
        ],
        "585": [],
        "586": [],
        "587": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.3).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8361153262518968,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8361153262518968, 'f1_score': 0.8329165313666518, 'precision': 0.8410830367642207, 'recall': 0.8361153262518968, 'confusion_matrix': [[402, 3, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 2, 0, 1, 0, 0], [1, 11, 1, 0, 0, 0, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 15, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 1, 0, 0, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 1, 0, 1, 0, 0, 0, 1, 8, 0, 5, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 14, 0, 0, 0, 2, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 5, 1, 0, 1, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 3, 11, 0, 1, 0, 7, 0], [0, 0, 0, 0, 1, 1, 0, 0, 1, 3, 0, 0, 0, 6, 5, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 1, 0, 7, 0, 0, 2], [2, 1, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 1, 3, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 0, 0, 1, 11, 1], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 5]]}",
                "lineage": "58701"
            }
        ],
        "588": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=8)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_out, _ = self.attention(lstm_out, lstm_out, lstm_out)\n        x = attn_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8437025796661608,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8437025796661608, 'f1_score': 0.8379207819004675, 'precision': 0.8472771103171652, 'recall': 0.8437025796661608, 'confusion_matrix': [[401, 2, 0, 0, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 2, 0, 1], [1, 12, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 1, 8, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 14, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 4, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [1, 1, 0, 0, 0, 0, 0, 0, 3, 1, 0, 0, 2, 1, 0, 0, 0, 0], [2, 0, 0, 0, 2, 1, 0, 0, 0, 10, 2, 2, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, 0], [4, 0, 1, 0, 0, 0, 0, 0, 1, 5, 1, 2, 2, 0, 0, 0, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 11, 0, 1, 0, 5, 3], [0, 0, 0, 0, 2, 0, 0, 0, 1, 1, 0, 0, 0, 10, 2, 1, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 7, 0, 0, 2], [2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 13, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 9]]}",
                "lineage": "58801"
            }
        ],
        "589": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()\n\ndef optimized_tuso_model(train_data, train_label, val_data, val_label, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8603945371775418,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8603945371775418, 'f1_score': 0.8583659610461194, 'precision': 0.8735858141977039, 'recall': 0.8603945371775418, 'confusion_matrix': [[402, 2, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 4, 0, 0], [1, 13, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 7, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 2, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [1, 0, 0, 0, 8, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 2, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 12, 1, 2, 1, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 1, 1, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 5, 0, 0, 1, 1, 0], [0, 0, 0, 0, 0, 0, 1, 0, 0, 3, 3, 1, 16, 0, 0, 0, 2, 0], [1, 0, 0, 0, 0, 4, 0, 0, 1, 1, 0, 0, 0, 5, 5, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 6, 0, 1, 2], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 3, 0, 1, 0, 0, 0, 11, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 1, 6]]}",
                "lineage": "58901"
            }
        ],
        "590": [],
        "591": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8694992412746586, 'f1_score': 0.8675999486682028, 'precision': 0.8747469434933464, 'recall': 0.8694992412746586, 'confusion_matrix': [[402, 2, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0], [0, 14, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 15, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 5, 1, 0, 0, 0, 1, 0, 0, 0, 1], [2, 0, 0, 0, 0, 0, 0, 0, 1, 15, 1, 0, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 14, 0, 0, 0, 0, 0, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 6, 3, 0, 1, 0, 0, 1], [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, 1, 14, 1, 0, 0, 6, 1], [1, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 10, 3, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 1, 6, 0, 1, 1], [1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 12, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 7]]}",
                "lineage": "59101"
            }
        ],
        "592": [],
        "593": [],
        "594": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.4):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.7905918057663126,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.7905918057663126, 'f1_score': 0.7724193771721414, 'precision': 0.785533923737151, 'recall': 0.7905918057663126, 'confusion_matrix': [[402, 3, 0, 1, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 1, 2, 0, 0], [1, 11, 2, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 3, 14, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 3, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [0, 0, 0, 3, 0, 0, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 4, 2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 1, 0, 0, 0, 0, 8, 2, 6, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 14, 0, 0, 0, 0, 0, 0, 1], [3, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 6, 0, 0, 1, 0, 0, 1], [0, 2, 0, 0, 0, 0, 0, 0, 0, 3, 3, 5, 0, 0, 1, 0, 5, 7], [0, 0, 0, 0, 2, 4, 0, 0, 1, 2, 4, 0, 0, 1, 2, 0, 1, 1], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 2, 0, 0, 5, 0, 0, 1], [2, 1, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 3, 1, 0, 0, 0, 0, 11, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 0, 2, 0, 2, 3]]}",
                "lineage": "59401"
            }
        ],
        "595": [],
        "596": [],
        "597": [],
        "598": [],
        "599": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8694992412746586, 'f1_score': 0.870068518794285, 'precision': 0.8850263180103598, 'recall': 0.8694992412746586, 'confusion_matrix': [[401, 4, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 3, 0, 0], [1, 12, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 2, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 0], [0, 0, 0, 0, 10, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 0, 0, 0, 0, 0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 1, 0, 0, 5, 0, 0, 0, 0, 1, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 13, 4, 1, 0, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 2, 2, 0, 5, 2, 1, 1, 0, 0, 0], [0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 2, 1, 17, 4, 0, 0, 0, 0], [0, 0, 0, 0, 0, 3, 0, 0, 1, 1, 0, 0, 0, 11, 2, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 8, 0, 0, 0], [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 1, 0, 1, 10, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 8]]}",
                "lineage": "59901"
            }
        ],
        "600": [],
        "601": [],
        "602": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass GestureClassifierWithHeads(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifierWithHeads, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.heads = nn.ModuleList([nn.Linear(128, 1) for _ in range(18)])\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        return torch.cat([head(x).unsqueeze(1) for head in self.heads], dim=1)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifierWithHeads(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs.view(-1, 18), labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs.view(-1, 18), 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8801213960546282,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8801213960546282, 'f1_score': 0.8815814745589153, 'precision': 0.8935975851931762, 'recall': 0.8801213960546282, 'confusion_matrix': [[404, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 1, 1, 0, 0], [1, 13, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 13, 2, 2, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 0, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 7, 0, 1, 2, 0, 1, 1], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 15, 2, 1, 0, 2, 3], [0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 11, 4, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 7, 1, 0, 1], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 11, 4], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 8]]}",
                "lineage": "60201"
            }
        ],
        "603": [],
        "604": [],
        "605": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8179059180576631,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8179059180576631, 'f1_score': 0.8140476297108584, 'precision': 0.8288840663838052, 'recall': 0.8179059180576631, 'confusion_matrix': [[400, 2, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 4, 0, 0], [1, 12, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 2, 2, 15, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 10, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 1, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 2, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 1, 0, 0, 0, 5, 3, 7, 0, 0, 1, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 1, 0, 0, 0], [4, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 4, 3, 0, 1, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 3, 7, 0, 1, 0, 8, 3], [0, 0, 0, 0, 1, 0, 0, 0, 2, 2, 1, 0, 0, 7, 4, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 2, 0, 0, 7, 0, 0, 1], [2, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 2, 2, 0, 0, 0, 8, 3], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 7]]}",
                "lineage": "60501"
            }
        ],
        "606": [],
        "607": [],
        "608": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n            print(f\"Epoch {epoch+1}, Batch Loss: {loss.item()}, Memory Usage: {torch.cuda.memory_allocated(device) / (1024 ** 2):.2f} MB\")\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8861911987860395,
                "model_info": "Epoch 1, Batch Loss: 2.8675084114074707, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.8178138732910156, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.777367353439331, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.714507818222046, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.59167742729187, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.4235870838165283, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.3264684677124023, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.1674327850341797, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 2.0398528575897217, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.6735185384750366, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.564569354057312, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.3317450284957886, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.0971872806549072, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.2504386901855469, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 0.9564127326011658, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.2563035488128662, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.030741572380066, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 0.9339994788169861, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.330225944519043, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.1759297847747803, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.5174975395202637, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.7404667139053345, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.504332184791565, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.1613339185714722, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.4488636255264282, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 0.9761838912963867, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.3053570985794067, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.3669015169143677, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.1875213384628296, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.6025586128234863, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.2048909664154053, Memory Usage: 34.06 MB\nEpoch 1, Batch Loss: 1.2",
                "lineage": "60801"
            }
        ],
        "609": [],
        "610": [],
        "611": [],
        "612": [],
        "613": [],
        "614": [],
        "615": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom sklearn.utils import class_weight\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    class_weights = class_weight.compute_class_weight('balanced', classes=np.unique(train_label), y=train_label)\n    weights = torch.tensor(class_weights, dtype=torch.float).to(device)\n    sample_weights = weights[train_label_tensor]\n    sampler = WeightedRandomSampler(sample_weights, num_samples=len(sample_weights), replacement=True)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8512898330804249, 'f1_score': 0.857207271427805, 'precision': 0.8732338499740694, 'recall': 0.8512898330804249, 'confusion_matrix': [[388, 9, 1, 0, 4, 0, 0, 4, 0, 0, 0, 1, 0, 0, 1, 3, 0, 0], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 1, 7, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 2, 14, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 1, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 13, 0, 2, 1, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 13, 0, 0, 1, 0, 1, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0, 7, 2, 0, 2, 1, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 20, 1, 0, 0, 3, 1], [0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 0, 0, 9, 3, 0, 2, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, 2, 6, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 0, 12, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 2, 6]]}",
                "lineage": "61501"
            }
        ],
        "616": [],
        "617": [],
        "618": [],
        "619": [],
        "620": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs.clone()\n            if torch.rand(1).item() > 0.5:\n                inputs = torch.flip(inputs, [2])\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8315629742033384,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8315629742033384, 'f1_score': 0.8279555314482078, 'precision': 0.8339514647076205, 'recall': 0.8315629742033384, 'confusion_matrix': [[403, 2, 0, 0, 1, 2, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0], [1, 14, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [1, 0, 3, 13, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 0, 0, 0, 0, 0, 0, 7, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 2, 0, 3, 0], [1, 0, 0, 0, 0, 0, 0, 0, 2, 11, 0, 4, 0, 0, 0, 0, 1, 1], [0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 12, 0, 1, 0, 0, 0, 0, 1], [4, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 6, 1, 1, 1, 0, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 4, 1, 11, 0, 2, 0, 4, 0], [0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 2, 1, 0, 3, 4, 0, 1, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 9, 0, 0, 0], [1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 1, 0, 0, 0, 0, 2, 0, 4, 0, 1, 0, 0, 1, 8, 1], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 7]]}",
                "lineage": "62001"
            }
        ],
        "621": [],
        "622": [],
        "623": [],
        "624": [],
        "625": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            augmented_inputs = inputs.clone()\n            for i in range(augmented_inputs.size(0)):\n                if np.random.rand() > 0.5:\n                    augmented_inputs[i] = (inputs[i] + inputs[np.random.randint(len(inputs))]) / 2\n            optimizer.zero_grad()\n            outputs = contrastive_model(augmented_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8528072837632777,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8528072837632777, 'f1_score': 0.844169496600526, 'precision': 0.8563658606121722, 'recall': 0.8528072837632777, 'confusion_matrix': [[407, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 1], [1, 12, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 2, 14, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 8, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [2, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [2, 1, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0], [6, 0, 0, 0, 0, 0, 0, 0, 0, 6, 4, 4, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 1, 0, 0, 0, 0, 0], [8, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 4, 0, 0, 0, 0, 0, 3], [0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 3, 1, 16, 0, 0, 0, 2, 1], [1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 10, 4, 0, 2, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 7, 0, 0, 1], [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 6, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 10, 3], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 7]]}",
                "lineage": "62501"
            }
        ],
        "626": [],
        "627": [],
        "628": [],
        "629": [],
        "630": [],
        "631": [],
        "632": [],
        "633": [],
        "634": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nimport random\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef time_based_augmentation(data):\n    augmented_data = []\n    for sample in data:\n        if random.random() > 0.5:\n            shift = random.randint(-5, 5)\n            sample = np.roll(sample, shift, axis=0)\n        augmented_data.append(sample)\n    return np.array(augmented_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_data_augmented = time_based_augmentation(train_data_scaled)\n    \n    train_tensor = torch.FloatTensor(train_data_augmented).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.842185128983308,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.842185128983308, 'f1_score': 0.8421595641268614, 'precision': 0.8558955809080306, 'recall': 0.842185128983308, 'confusion_matrix': [[397, 4, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 2, 1, 0, 2, 0, 0], [1, 12, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 13, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 4, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 1, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 1, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 1, 1, 0, 0, 0, 10, 2, 2, 1, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 14, 0, 0, 0, 0, 0, 0, 1], [3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 5, 2, 1, 1, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 10, 1, 0, 0, 6, 3], [0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 12, 3, 0, 0, 0], [0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 1, 7, 0, 0, 0], [2, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 11, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 7]]}",
                "lineage": "63401"
            }
        ],
        "635": [],
        "636": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=8)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_out, _ = self.attention(lstm_out, lstm_out, lstm_out)\n        x = attn_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8391502276176024,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8391502276176024, 'f1_score': 0.8332599603097472, 'precision': 0.8478246553449178, 'recall': 0.8391502276176024, 'confusion_matrix': [[402, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 3, 0, 0], [1, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 0], [1, 0, 0, 0, 11, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 3, 3, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 1, 0, 0, 0, 1, 0, 0, 3, 0, 0, 1, 2, 0, 0, 0, 0, 0], [2, 1, 0, 0, 0, 0, 0, 0, 0, 8, 3, 5, 0, 0, 1, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 12, 0, 0, 0, 0, 0, 1, 1], [3, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 9, 0, 0, 1, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 2, 5, 1, 2, 0, 3, 11], [2, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 9, 4, 0, 1, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 8, 1, 0, 0], [3, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0], [0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 13, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 9]]}",
                "lineage": "63601"
            }
        ],
        "637": [],
        "638": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.4):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    \n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8285280728376327,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8285280728376327, 'f1_score': 0.8276389049213873, 'precision': 0.8378757331503528, 'recall': 0.8285280728376327, 'confusion_matrix': [[402, 4, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 2, 0, 0], [1, 10, 3, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 15, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 4, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 1, 0, 0, 1, 0, 0, 4, 0, 0, 0, 0, 1, 0, 0, 0, 0], [3, 0, 0, 0, 1, 0, 0, 0, 1, 6, 2, 5, 0, 1, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 1, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 6, 1, 0, 2, 0, 1, 0], [0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 3, 10, 0, 0, 0, 4, 6], [0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 7, 6, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 1, 2, 0, 6, 0, 0, 0], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 9, 6], [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 2, 4]]}",
                "lineage": "63801"
            }
        ],
        "639": [],
        "640": [],
        "641": [],
        "642": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            time_shift = np.random.randint(-5, 5)\n            inputs = torch.roll(inputs, shifts=time_shift, dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8512898330804249, 'f1_score': 0.8522804405590679, 'precision': 0.8712151447813933, 'recall': 0.8512898330804249, 'confusion_matrix': [[400, 2, 1, 0, 2, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 2, 0, 2], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 1, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 14, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 1, 0, 1, 5, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 1, 0, 0, 1, 0, 0, 0, 10, 1, 0, 0, 2, 0, 1, 1, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 1, 0, 1], [2, 0, 0, 0, 0, 0, 0, 0, 4, 1, 1, 5, 1, 1, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 1, 13, 1, 3, 0, 4, 0], [1, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 7, 5, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 9, 0, 0, 0], [2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 11, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 8]]}",
                "lineage": "64201"
            }
        ],
        "643": [],
        "644": [],
        "645": [],
        "646": [],
        "647": [],
        "648": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=5, padding=2)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.881638846737481,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.881638846737481, 'f1_score': 0.8815867520659382, 'precision': 0.8924052910366492, 'recall': 0.881638846737481, 'confusion_matrix': [[403, 3, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0], [0, 14, 1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 2, 16, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 1, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 1, 0, 0, 1, 12, 1, 2, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 7, 2, 0, 2, 0, 0, 2], [0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 1, 14, 1, 1, 0, 3, 3], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 11, 5, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 8, 0, 0, 2], [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 10, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 8]]}",
                "lineage": "64801"
            }
        ],
        "649": [],
        "650": [],
        "651": [],
        "652": [],
        "653": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            time_shift = torch.randint(0, inputs.size(1), (1,)).item()\n            inputs = torch.roll(inputs, shifts=time_shift, dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8892261001517451,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8892261001517451, 'f1_score': 0.8905360100777704, 'precision': 0.8995191987592581, 'recall': 0.8892261001517451, 'confusion_matrix': [[400, 3, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0], [0, 15, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 15, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 1, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 1, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 19, 1, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 13, 0, 0, 0, 0, 1, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 6, 2, 1, 2, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 19, 1, 2, 0, 1, 0], [0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 11, 4, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 10, 0, 1, 0], [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 1, 0, 0, 1, 13, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 8]]}",
                "lineage": "65301"
            }
        ],
        "654": [],
        "655": [],
        "656": [],
        "657": [],
        "658": [],
        "659": [],
        "660": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.4):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    unique, counts = np.unique(train_label, return_counts=True)\n    class_balance_before = dict(zip(unique, counts))\n    print(\"Class Balance Before Resampling:\", class_balance_before)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(30):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    unique_val, counts_val = np.unique(predicted.cpu().numpy(), return_counts=True)\n    class_balance_after = dict(zip(unique_val, counts_val))\n    print(\"Class Balance After Resampling:\", class_balance_after)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXXX.py",
                "accuracy": 0.7587253414264037,
                "model_info": "Class Balance Before Resampling: {0.0: 1656, 1.0: 64, 2.0: 57, 3.0: 51, 4.0: 60, 5.0: 48, 6.0: 43, 7.0: 55, 8.0: 56, 9.0: 53, 10.0: 60, 11.0: 71, 12.0: 59, 13.0: 50, 14.0: 59, 15.0: 49, 16.0: 71, 17.0: 76}\nFinal Evaluation Metrics:\n {'accuracy': 0.7587253414264037, 'f1_score': 0.7468966692396916, 'precision': 0.7618759773984705, 'recall': 0.7587253414264037, 'confusion_matrix': [[406, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 2, 0, 0, 0], [1, 7, 4, 1, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 6, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 5, 13, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0], [0, 0, 1, 4, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 1, 0, 0, 0, 0, 0, 7, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 4, 0, 2, 0, 0, 0, 0], [3, 0, 0, 0, 1, 0, 0, 0, 0, 7, 1, 6, 0, 0, 0, 0, 2, 0], [1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 10, 2], [4, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 2, 2], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 10, 9], [0, 0, 0, 0, 1, 3, 0, 0, 0, 7, 0, 0, 0, 3, 0, 0, 3, 1], [0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 1, 0, 4, 0, 3, 1], [2, 1, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 4, 0, 2, 10], [0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 7]]}\nClass Balance After Resampling: {0: 421, 1: 11, 2: 19, 3: 22, 4: 20, 5: 9, 6: 8, 7: 11, 9: 17, 10: 4, 11: 28, 12: 2, 13: 7, 14: 12, 15: 4, 16: 32, 17: 32}",
                "lineage": "66001"
            }
        ],
        "661": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            time_shifted_inputs = torch.roll(inputs, shifts=np.random.randint(-5, 5), dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(time_shifted_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8725341426403642,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8725341426403642, 'f1_score': 0.8744810481898035, 'precision': 0.8849645093215579, 'recall': 0.8725341426403642, 'confusion_matrix': [[403, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 5, 0, 0], [1, 11, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 0, 2, 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 1, 6, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 14, 0, 5, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 6, 3, 0, 2, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 1, 13, 3, 0, 0, 4, 0], [0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 8, 6, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 8, 0, 0, 0], [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 1, 0, 0, 0, 1, 12, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 6]]}",
                "lineage": "66101"
            }
        ],
        "662": [],
        "663": [],
        "664": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    z_scores = np.abs((val_data_scaled - np.mean(val_data_scaled, axis=0)) / np.std(val_data_scaled, axis=0))\n    outlier_counts = np.sum(z_scores > 3, axis=0)\n    print(\"Detected Outliers Count per Feature:\\n\", outlier_counts)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8801213960546282,
                "model_info": "Detected Outliers Count per Feature:\n [[13 16 15 13 16 10 15 12 15 17 10 17 15 16 15 16]\n [15 15 12 14 19 11 15 11 13 16 10 15 16 17 16 17]\n [16 17 15 18 17 14 13 12 14 18 11 14 10 13 18 18]\n [14 17 15 18 20 12 15 10 15 17 11 14 12 17 19 16]\n [16 17 17 21 17 11 14 10 14 15  8 17 12 19 15 15]\n [17 16 18 15 16 15 16 10 15 12  7 14 14 18 14 14]\n [18 17 15 14 11 16 16 11 18 10 11 15 17 18 14 14]\n [20 14 16 14 13 15 19 10 17 11 12 15 18 19 16 15]\n [18 16 13 11 18 16 18 13 18 13  9 16 18 17 15 18]\n [16 14 14 14 18 16 17 13 16 13 10 16 14 16 16 15]\n [14 16 16 14 18 10 18 12 16 12  9 15 16 16 16 16]\n [14 19 11 13 18 13 19 14 13 12  6 13 15 12 16 15]\n [11 18 16 16 22 11 15 12 13 12  6 18 15 12 15 15]\n [14 16 16 17 21 14 15 11 15 12  9 15 16 13 10 15]\n [14 15 15 16 19 15 17  8 14 12 11 16 16 14 13 18]\n [17 16 14 18 18 17 13  9 16 13 13 17 19 15 16 15]\n [16 17 20 17 18 15 17 10 15 11 12 17 21 16 13 15]\n [16 17 17 16 17 15 15 12 12 11 14 16 19 15 12 13]\n [15 15 15 15 19 16 13 13 15 12 16 17 19 13 12 13]\n [14 15 15 16 18 17 11 13 15 13 19 17 15 17 15 16]\n [16 14 13 11 20 16 12 13 17 11 13 14 13 20 13 17]\n [16 14 13 13 18 15 11 12 15 17 13 14 15 19 12 14]\n [16 15 15 14 19 15 12 10 16 17 14 17 18 16  9 14]\n [17 16 16 19 16 16 16 13 14 14 13 19 16 13  8 13]\n [17 14 19 18 16 16 17 10 14 15 13 16 18 11 10 11]\n [17 14 17 17 15 17 13 12 16 16 14 15 14  9  8 14]\n [14 16 17 20 18 17 16  9 13 14 15 17 15 11 10 14]\n [16 14 12 19 18 18 15 10 19 16  9 14 15 16 14 23]\n [15 13 13 17 18 16 14 12 18 17 13 16 16 15 13 17]\n [15 15 15 14 15 19 15 12 16 17 12 17 19 17 14 18]\n [15 17 14 15 21 20 20 12 17 17 11 14 19 18 14 15]\n [16 18 14 14 17 16 21 10 17 13 11 16 16 17 12 18]\n [13 13 15 13 18 16 20 10 21 14 13 16 14 14 13 19]\n [16 12 15 13 20 15 20  7 18 15 14 17 13 14 11 14]\n [16 13 18 15 18 16 19  8 14 14 11 17 13 15 10 13]\n [17 14 15 13 15 13 20 11 18 15 11 16 12 16 14 13]\n [15 14 15 13 16 14 17 10 18 14 16 12 12 16 17 11]\n [15 12 14 12 15 17 15 10 15 15 17 13 15 16 14 17]\n [16 14 15 12 18 16 12  ",
                "lineage": "66401"
            }
        ],
        "665": [],
        "666": [],
        "667": [],
        "668": [],
        "669": [],
        "670": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            time_shift = torch.randint(0, 52, (1,)).item()\n            inputs = torch.roll(inputs, shifts=time_shift, dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.881638846737481,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.881638846737481, 'f1_score': 0.8778177393815341, 'precision': 0.8884747100048307, 'recall': 0.881638846737481, 'confusion_matrix': [[403, 2, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0], [1, 15, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 7, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 7, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 1, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 1, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 1, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 19, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 1, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 1, 3, 0, 4, 2, 0, 1, 0, 0, 2], [1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 17, 1, 0, 0, 4, 0], [0, 0, 0, 0, 0, 3, 0, 0, 1, 2, 0, 0, 0, 6, 4, 0, 2, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 8, 0, 0, 1], [2, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 14, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 9]]}",
                "lineage": "67001"
            }
        ],
        "671": [],
        "672": [],
        "673": [],
        "674": [],
        "675": [],
        "676": [],
        "677": [],
        "678": [],
        "679": [],
        "680": [],
        "681": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n    \n    print(\"Assumptions about feature distributions: Data is assumed to be normally distributed for effective scaling. Standardization applied for features.\")\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.849772382397572,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.849772382397572, 'f1_score': 0.8505217691850046, 'precision': 0.8703173317997472, 'recall': 0.849772382397572, 'confusion_matrix': [[399, 3, 0, 0, 2, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 3, 0, 0], [1, 11, 2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 9, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 4, 13, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 1, 0, 0, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 1, 0, 0, 5, 0, 0, 1, 10, 0, 0, 0, 0, 1, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 0, 1, 0], [3, 0, 0, 0, 0, 0, 0, 0, 3, 2, 0, 4, 2, 0, 1, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 4, 1, 0, 14, 0, 0, 1, 4, 0], [0, 0, 0, 0, 2, 3, 0, 0, 1, 0, 1, 0, 0, 7, 2, 0, 2, 0], [0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 2, 1, 1, 5, 0, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 0, 0, 0, 15, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 7]]}\nAssumptions about feature distributions: Data is assumed to be normally distributed for effective scaling. Standardization applied for features.",
                "lineage": "68101"
            }
        ],
        "682": [],
        "683": [],
        "684": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            inputs = torch.flip(inputs, [2])\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.5690440060698028,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.5690440060698028, 'f1_score': 0.5968570869301351, 'precision': 0.6366970997679792, 'recall': 0.5690440060698028, 'confusion_matrix': [[346, 1, 1, 0, 6, 0, 0, 17, 18, 5, 0, 14, 1, 0, 0, 0, 1, 1], [1, 9, 0, 0, 0, 0, 3, 0, 0, 0, 0, 3, 0, 0, 1, 0, 0, 0], [0, 1, 0, 0, 0, 0, 3, 1, 1, 0, 0, 1, 1, 0, 0, 0, 0, 2], [1, 0, 0, 0, 2, 0, 7, 0, 1, 0, 1, 0, 0, 0, 0, 6, 1, 1], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 5, 3], [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 4, 3], [0, 0, 0, 0, 0, 0, 10, 0, 0, 0, 0, 0, 0, 0, 0, 3, 1, 0], [1, 1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 5, 0, 0], [1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 1, 1, 1], [2, 4, 0, 1, 0, 0, 0, 0, 1, 0, 0, 5, 0, 0, 0, 1, 1, 5], [2, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 3, 5, 2, 0, 0, 2, 1], [1, 2, 0, 0, 1, 0, 0, 1, 0, 0, 0, 5, 0, 0, 2, 2, 1, 1], [0, 0, 5, 2, 1, 0, 1, 1, 1, 0, 1, 2, 3, 1, 3, 0, 3, 2], [0, 0, 1, 3, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 2, 0, 6, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0, 0, 0, 4, 1], [0, 2, 0, 0, 1, 0, 3, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0], [0, 0, 0, 3, 0, 1, 0, 2, 0, 2, 0, 2, 0, 4, 2, 0, 1, 1], [0, 1, 2, 1, 0, 2, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0]]}",
                "lineage": "68401"
            }
        ],
        "685": [],
        "686": [],
        "687": [],
        "688": [],
        "689": [],
        "690": [],
        "691": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8679817905918058,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8679817905918058, 'f1_score': 0.8656816370106268, 'precision': 0.8725678193879399, 'recall': 0.8679817905918058, 'confusion_matrix': [[405, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 2, 0, 0], [1, 11, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 16, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 1, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 12, 2, 3, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 8, 1, 0, 1, 0, 1, 1], [0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 1, 1, 14, 2, 0, 0, 2, 2], [1, 0, 0, 0, 0, 4, 0, 0, 1, 1, 0, 0, 0, 8, 2, 0, 1, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 2, 5, 0, 0, 2], [3, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0], [0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 11, 2], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 8]]}",
                "lineage": "69101"
            }
        ],
        "692": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8437025796661608,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8437025796661608, 'f1_score': 0.8397681981189706, 'precision': 0.8550276844465521, 'recall': 0.8437025796661608, 'confusion_matrix': [[403, 3, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 1, 0, 2, 0, 0], [1, 12, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 7, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [0, 1, 3, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [1, 1, 0, 0, 0, 2, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 1, 0, 0, 0, 0, 0, 2, 6, 2, 5, 1, 0, 0, 2, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 14, 0, 0, 0, 0, 2, 0, 0], [4, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 6, 1, 0, 1, 0, 0, 1], [0, 1, 0, 0, 0, 0, 0, 0, 3, 1, 2, 1, 6, 0, 1, 0, 4, 7], [0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 10, 4, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 6, 0, 0, 2], [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 11, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 8]]}",
                "lineage": "69201"
            }
        ],
        "693": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom scipy.signal import butter, filtfilt\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyq = 0.5 * fs\n    normal_cutoff = cutoff / nyq\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff=30.0, fs=1000.0, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    return filtfilt(b, a, data, axis=0)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    train_data_filtered = lowpass_filter(train_data_reshaped)\n    val_data_filtered = lowpass_filter(val_data_reshaped)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_filtered.reshape(-1, 16)).reshape(train_data_filtered.shape)\n    val_data_scaled = scaler.transform(val_data_filtered.reshape(-1, 16)).reshape(val_data_filtered.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.5872534142640364,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.5872534142640364, 'f1_score': 0.4764659181588446, 'precision': 0.4037686082894613, 'recall': 0.5872534142640364, 'confusion_matrix': [[384, 0, 2, 6, 6, 0, 0, 0, 8, 3, 0, 0, 0, 0, 0, 0, 2, 0], [15, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [8, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [17, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [12, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [12, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0], [8, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [18, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [12, 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0], [24, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0], [17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [11, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [15, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0], [10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]]}",
                "lineage": "69301"
            }
        ],
        "694": [],
        "695": [],
        "696": [],
        "697": [],
        "698": [],
        "699": [],
        "700": [],
        "701": [],
        "702": [],
        "703": [],
        "704": [],
        "705": [],
        "706": [],
        "707": [],
        "708": [],
        "709": [],
        "710": [],
        "711": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=3, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    frozen_layers = [name for name, param in contrastive_model.named_parameters() if not param.requires_grad]\n    trainable_layers = [name for name, param in contrastive_model.named_parameters() if param.requires_grad]\n    print(\"Frozen Layers:\", frozen_layers)\n    print(\"Trainable Layers:\", trainable_layers)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXXX.py",
                "accuracy": 0.7905918057663126,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.7905918057663126, 'f1_score': 0.7824013087540075, 'precision': 0.809218382601877, 'recall': 0.7905918057663126, 'confusion_matrix': [[403, 3, 0, 0, 1, 1, 0, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0], [1, 11, 3, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 7, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 0, 4, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 10, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 3, 0, 0, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 1, 0, 1, 2, 1, 0, 0, 0, 1, 2, 0, 0, 0], [4, 1, 0, 0, 0, 0, 0, 0, 0, 9, 0, 2, 0, 0, 4, 0, 0, 0], [0, 0, 0, 0, 1, 0, 0, 0, 0, 2, 12, 2, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 1, 0, 0, 3, 1, 1, 2, 0, 0, 3, 0, 0, 2], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 1, 1, 0, 7, 0, 6, 7], [0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 1, 0, 5, 7, 0, 1, 0], [1, 0, 2, 0, 0, 1, 0, 0, 1, 0, 3, 1, 0, 0, 3, 0, 0, 0], [1, 1, 3, 2, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0], [0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 12, 3], [0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 0, 3, 3]]}\nFrozen Layers: []\nTrainable Layers: ['base_model.tcn.weight', 'base_model.tcn.bias', 'base_model.lstm.weight_ih_l0', 'base_model.lstm.weight_hh_l0', 'base_model.lstm.bias_ih_l0', 'base_model.lstm.bias_hh_l0', 'base_model.lstm.weight_ih_l1', 'base_model.lstm.weight_hh_l1', 'base_model.lstm.bias_ih_l1', 'base_model.lstm.bias_hh_l1', 'base_model.lstm.weight_ih_l2', 'base_model.lstm.weight_hh_l2', 'base_model.lstm.bias_ih_l2', 'base_model.lstm.bias_hh_l2', 'base_model.fc.weight', 'base_model.fc.bias']",
                "lineage": "71101"
            }
        ],
        "712": [],
        "713": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            jittered_inputs = inputs.clone()\n            jittered_inputs[:, :, :] += torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(jittered_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.866464339908953,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.866464339908953, 'f1_score': 0.8681968678849481, 'precision': 0.8780553885667649, 'recall': 0.866464339908953, 'confusion_matrix': [[404, 0, 0, 0, 3, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1], [1, 12, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 5, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 8, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 4, 1, 0, 1, 0, 2, 0, 0, 0, 0], [1, 0, 0, 0, 0, 1, 0, 0, 0, 13, 1, 2, 0, 0, 0, 0, 2, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, 2], [2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 6, 3, 0, 3, 0, 0, 0], [0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 1, 0, 19, 0, 0, 0, 2, 1], [0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 0, 0, 10, 4, 0, 0, 0], [0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 1, 0, 8, 0, 0, 0], [2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 11, 4], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 0, 0, 6]]}",
                "lineage": "71301"
            }
        ],
        "714": [],
        "715": [],
        "716": [],
        "717": [],
        "718": [],
        "719": [],
        "720": [],
        "721": [],
        "722": [],
        "723": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.834597875569044,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.834597875569044, 'f1_score': 0.8266690347474566, 'precision': 0.8365801526773448, 'recall': 0.834597875569044, 'confusion_matrix': [[404, 1, 0, 0, 1, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 1, 0, 0], [1, 12, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 2, 0, 0, 3, 0, 0, 1, 0, 1, 0, 0, 0, 0], [3, 0, 1, 0, 1, 0, 0, 0, 0, 9, 2, 4, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 14, 0, 0, 0, 1, 0, 0, 0], [4, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 6, 1, 0, 0, 0, 0, 2], [0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 2, 5, 1, 0, 0, 12, 0], [0, 0, 0, 0, 1, 1, 0, 0, 1, 1, 0, 0, 0, 5, 8, 0, 1, 0], [0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 2, 1, 1, 0, 5, 0, 0, 1], [3, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 3, 1, 1, 0, 0, 0, 11, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 9]]}",
                "lineage": "72301"
            }
        ],
        "724": [],
        "725": [],
        "726": [],
        "727": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            noise = torch.randn_like(inputs) * 0.01\n            inputs = inputs + noise\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8755690440060698,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8755690440060698, 'f1_score': 0.8763885035881327, 'precision': 0.8843115419492823, 'recall': 0.8755690440060698, 'confusion_matrix': [[401, 1, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 4, 0, 0], [0, 13, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 2, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 4, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 0, 0, 0, 0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 6, 1, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 14, 1, 2, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 13, 0, 0, 0, 0, 2, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 8, 2, 0, 3, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 2, 18, 1, 0, 0, 2, 0], [1, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 8, 5, 0, 1, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 11, 0, 0, 0], [2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 14, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 1, 0, 0, 6]]}",
                "lineage": "72701"
            }
        ],
        "728": [],
        "729": [],
        "730": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8512898330804249, 'f1_score': 0.8523963018395967, 'precision': 0.8695797111273229, 'recall': 0.8512898330804249, 'confusion_matrix': [[401, 2, 0, 0, 2, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 3, 0, 1], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 3, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 1, 0, 0, 0, 0], [1, 0, 0, 0, 0, 1, 0, 0, 1, 9, 3, 2, 0, 0, 0, 0, 1, 2], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, 1], [3, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 6, 3, 0, 2, 0, 0, 1], [0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 3, 0, 13, 1, 1, 0, 4, 2], [0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 8, 4, 0, 1, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 9, 0, 0, 1], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 2, 0, 11, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 6]]}",
                "lineage": "73001"
            }
        ],
        "731": [],
        "732": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    print(\"Class balance before resampling:\", Counter(train_label))\n    \n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    print(\"Class balance after resampling:\", Counter(predicted.cpu().numpy()))\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Class balance before resampling: Counter({0.0: 1656, 17.0: 76, 16.0: 71, 11.0: 71, 1.0: 64, 4.0: 60, 10.0: 60, 14.0: 59, 12.0: 59, 2.0: 57, 8.0: 56, 7.0: 55, 9.0: 53, 3.0: 51, 13.0: 50, 15.0: 49, 5.0: 48, 6.0: 43})\nClass balance after resampling: Counter({0: 405, 14: 21, 12: 20, 16: 19, 10: 18, 4: 18, 3: 17, 1: 16, 9: 16, 15: 16, 13: 14, 8: 14, 17: 13, 6: 13, 7: 13, 2: 12, 11: 8, 5: 6})\nFinal Evaluation Metrics:\n {'accuracy': 0.8634294385432474, 'f1_score': 0.8641811199727978, 'precision': 0.8759238702686064, 'recall': 0.8634294385432474, 'confusion_matrix': [[398, 2, 1, 0, 2, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 4, 1, 0], [0, 12, 2, 1, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 2, 1, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 3, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 1, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 2, 12, 0, 2, 0, 0, 0, 1, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 5, 3, 1, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 16, 1, 1, 1, 3, 2], [0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 10, 5, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 10, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 7, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0, 12, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 2, 6]]}",
                "lineage": "73201"
            }
        ],
        "733": [],
        "734": [],
        "735": [],
        "736": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom scipy.signal import butter, filtfilt\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef butter_lowpass(cutoff, fs, order=5):\n    nyquist = 0.5 * fs\n    normal_cutoff = cutoff / nyquist\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return b, a\n\ndef lowpass_filter(data, cutoff, fs, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = filtfilt(b, a, data, axis=0)\n    return y\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    fs = 1000\n    cutoff = 50\n    train_data_filtered = lowpass_filter(train_data, cutoff, fs)\n    val_data_filtered = lowpass_filter(val_data, cutoff, fs)\n\n    train_data_reshaped = train_data_filtered.reshape(-1, 52, 16)\n    val_data_reshaped = val_data_filtered.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.5371775417298937,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.5371775417298937, 'f1_score': 0.4673620827774141, 'precision': 0.42349536294145107, 'recall': 0.5371775417298937, 'confusion_matrix': [[350, 0, 2, 1, 8, 4, 1, 4, 1, 5, 9, 10, 1, 0, 6, 5, 0, 4], [14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0], [7, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0], [16, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0], [11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0], [6, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 1, 0, 0], [9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 1, 0, 0], [6, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [5, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0], [16, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0], [15, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [14, 0, 0, 0, 0, 0, 0, 1, 0, 0, 4, 1, 1, 0, 1, 0, 0, 4], [17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0], [7, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [13, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 0, 0], [7, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0]]}",
                "lineage": "73601"
            }
        ],
        "737": [],
        "738": [],
        "739": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn1 = nn.Conv1d(in_channels=16, out_channels=64, kernel_size=3, padding=1)\n        self.tcn2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn1(x)\n        x = self.tcn2(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8694992412746586, 'f1_score': 0.8689148396091239, 'precision': 0.8784938032996588, 'recall': 0.8694992412746586, 'confusion_matrix': [[402, 3, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 4, 0, 0], [0, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [0, 0, 0, 0, 10, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 4, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 1, 0, 0, 1, 0, 0, 0, 10, 1, 5, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 0, 1, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 8, 1, 0, 1, 0, 0, 1], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 4, 12, 1, 0, 0, 5, 2], [0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 0, 0, 0, 7, 4, 0, 2, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 9, 0, 0, 0], [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 1, 0, 12, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 8]]}",
                "lineage": "73901"
            }
        ],
        "740": [],
        "741": [],
        "742": [],
        "743": [],
        "744": [],
        "745": [],
        "746": [],
        "747": [],
        "748": [],
        "749": [],
        "750": [],
        "751": [],
        "752": [],
        "753": [],
        "754": [],
        "755": [],
        "756": [],
        "757": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass GestureClassifierWithHeads(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifierWithHeads, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.heads = nn.ModuleList([nn.Linear(128, 1) for _ in range(18)])\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        outputs = [head(x) for head in self.heads]\n        return torch.cat(outputs, dim=1).view(x.size(0), -1)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = GestureClassifierWithHeads(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.874051593323217,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.874051593323217, 'f1_score': 0.8733892208434837, 'precision': 0.8819610473390945, 'recall': 0.874051593323217, 'confusion_matrix': [[399, 3, 0, 0, 0, 0, 1, 2, 0, 0, 0, 1, 1, 1, 0, 3, 0, 0], [0, 15, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 17, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 10, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 3, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 0, 0, 0, 0, 0, 0, 0, 7, 1, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 12, 3, 3, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 16, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 4, 1, 0, 5, 2, 0, 1, 0, 0, 1], [0, 0, 0, 0, 0, 0, 1, 0, 3, 0, 2, 0, 16, 0, 0, 0, 3, 1], [2, 0, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 0, 9, 2, 0, 1, 1], [0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 10, 0, 0, 1], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 12, 3], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 7]]}",
                "lineage": "75701"
            }
        ],
        "758": [],
        "759": [],
        "760": [],
        "761": [],
        "762": [],
        "763": [],
        "764": [],
        "765": [],
        "766": [],
        "767": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            random_indices = torch.randint(0, inputs.size(0), (inputs.size(0),))\n            mixed_inputs = inputs[random_indices] + inputs\n            optimizer.zero_grad()\n            outputs = contrastive_model(mixed_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.7708649468892261,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.7708649468892261, 'f1_score': 0.7269637627708095, 'precision': 0.7708548061295637, 'recall': 0.7708649468892261, 'confusion_matrix': [[406, 0, 2, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [5, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [7, 0, 2, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [6, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [4, 0, 0, 0, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 1, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [5, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 1, 0, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0], [16, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0], [12, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 1], [15, 0, 0, 0, 0, 0, 0, 0, 1, 0, 4, 0, 1, 0, 1, 0, 4, 0], [10, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 4, 2, 0, 1, 0], [4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 6, 0, 0, 1], [5, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0], [9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 1], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 7]]}",
                "lineage": "76701"
            }
        ],
        "768": [],
        "769": [],
        "770": [],
        "771": [],
        "772": [],
        "773": [],
        "774": [],
        "775": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nimport time\nimport tracemalloc\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.4).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    tracemalloc.start()\n    start_time = time.time()\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist(),\n        \"execution_time\": time.time() - start_time,\n        \"memory_usage\": tracemalloc.get_traced_memory()\n    }\n    tracemalloc.stop()\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXXX.py",
                "accuracy": 0.8391502276176024,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8391502276176024, 'f1_score': 0.835471733366076, 'precision': 0.8462807242619591, 'recall': 0.8391502276176024, 'confusion_matrix': [[401, 4, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0], [1, 13, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 15, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 0, 0, 0, 5, 1, 0, 0, 0, 1, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 8, 1, 8, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 5, 1, 0, 1, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 3, 9, 0, 0, 0, 5, 3], [0, 0, 0, 0, 1, 1, 0, 0, 2, 0, 1, 0, 0, 6, 6, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 0, 7, 0, 0, 2], [1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 1, 1, 0, 0, 0, 10, 3], [0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 5]], 'execution_time': 11.191352128982544, 'memory_usage': (388081, 410198)}",
                "lineage": "77501"
            }
        ],
        "776": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8619119878603946,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8619119878603946, 'f1_score': 0.8627342006354071, 'precision': 0.8726273169102117, 'recall': 0.8619119878603946, 'confusion_matrix': [[398, 4, 0, 0, 0, 0, 1, 2, 0, 0, 0, 0, 1, 1, 1, 2, 0, 1], [1, 13, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 8, 3, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0], [1, 0, 0, 0, 0, 1, 0, 0, 3, 2, 0, 1, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 1, 1, 0, 0, 1, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, 0, 1, 0, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 6, 2, 0, 2, 1, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 16, 0, 1, 0, 5, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 10, 5, 0, 0, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 9, 0, 0, 2], [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 6, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 9, 6], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 8]]}",
                "lineage": "77601"
            }
        ],
        "777": [],
        "778": [],
        "779": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            time_shift = torch.randint(0, inputs.size(1), (1,)).item()\n            inputs = torch.roll(inputs, shifts=time_shift, dims=1)\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8512898330804249, 'f1_score': 0.8510876211895662, 'precision': 0.8723690348924993, 'recall': 0.8512898330804249, 'confusion_matrix': [[396, 4, 0, 0, 1, 0, 0, 2, 0, 0, 2, 0, 1, 1, 0, 3, 1, 0], [2, 10, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 2, 16, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0], [1, 1, 0, 0, 0, 0, 0, 0, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 1, 12, 4, 1, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 0, 0, 1, 1, 0], [2, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0, 4, 3, 0, 1, 1, 1, 1], [0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 15, 0, 0, 0, 7, 1], [1, 0, 0, 0, 0, 4, 0, 0, 1, 2, 0, 0, 0, 5, 3, 0, 2, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, 0, 8, 0, 1, 0], [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 14, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 8]]}",
                "lineage": "77901"
            }
        ],
        "780": [],
        "781": [],
        "782": [],
        "783": [],
        "784": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom sklearn.model_selection import StratifiedKFold\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    kf = StratifiedKFold(n_splits=5)\n    metrics_list = []\n\n    for train_index, val_index in kf.split(train_tensor.cpu(), train_label):\n        train_subset = train_tensor[train_index]\n        label_subset = train_label_tensor[train_index]\n        \n        train_dataset = TensorDataset(train_subset, label_subset)\n        train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n        model = GestureClassifier(dropout_rate=0.5).to(device)\n        criterion = nn.CrossEntropyLoss()\n        optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n        model.train()\n        for epoch in range(50):\n            for inputs, labels in train_loader:\n                inputs = inputs + torch.randn_like(inputs) * 0.01\n                optimizer.zero_grad()\n                outputs = model(inputs)\n                loss = criterion(outputs, labels)\n                loss.backward()\n                optimizer.step()\n\n        model.eval()\n        with torch.no_grad():\n            val_outputs = model(val_tensor)\n            _, predicted = torch.max(val_outputs, 1)\n\n        cm = confusion_matrix(val_label, predicted.cpu().numpy())\n        report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n        metrics = {\n            \"accuracy\": report[\"accuracy\"],\n            \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n            \"precision\": report[\"weighted avg\"][\"precision\"],\n            \"recall\": report[\"weighted avg\"][\"recall\"],\n            \"confusion_matrix\": cm.tolist()\n        }\n        metrics_list.append(metrics)\n\n    avg_metrics = {key: np.mean([m[key] for m in metrics_list]) for key in metrics_list[0].keys()}\n    print(\"Final Evaluation Metrics:\\n\", avg_metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8710166919575114,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8634294385432474, 'f1_score': 0.8639828661833875, 'precision': 0.8760732122993561, 'recall': 0.8634294385432474, 'confusion_matrix': 2.0339506172839505}",
                "lineage": "78401"
            }
        ],
        "785": [],
        "786": [],
        "787": [],
        "788": [],
        "789": [],
        "790": [],
        "791": [],
        "792": [],
        "793": [],
        "794": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        for param in self.lstm.parameters():\n            param.requires_grad = False\n        print(\"Frozen layers: LSTM parameters\")\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.802731411229135,
                "model_info": "Frozen layers: LSTM parameters\nFinal Evaluation Metrics:\n {'accuracy': 0.802731411229135, 'f1_score': 0.7899059188931322, 'precision': 0.8122900593525604, 'recall': 0.802731411229135, 'confusion_matrix': [[403, 2, 1, 0, 1, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [2, 9, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 7, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [2, 0, 1, 15, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 0, 0, 0, 11, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 3, 4, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [1, 0, 0, 0, 0, 0, 0, 7, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 1, 0, 0, 5, 0, 0, 0, 0, 0, 1, 0, 0, 0], [3, 0, 0, 0, 0, 1, 0, 1, 0, 7, 4, 3, 0, 0, 1, 0, 0, 0], [2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 13, 0, 0, 0, 1, 0, 0, 0], [6, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 4, 1, 0, 0, 0, 0, 2], [0, 4, 0, 0, 0, 0, 0, 0, 3, 0, 2, 1, 4, 0, 1, 0, 6, 5], [0, 0, 0, 0, 0, 3, 0, 0, 1, 3, 0, 2, 0, 3, 5, 0, 1, 0], [1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 6, 0, 0, 2], [1, 2, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 1, 0, 0, 1, 0, 8, 2], [0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 0, 7]]}",
                "lineage": "79401"
            }
        ],
        "795": [],
        "796": [],
        "797": [],
        "798": [],
        "799": [],
        "800": [],
        "801": [],
        "802": [],
        "803": [],
        "804": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\nfrom collections import Counter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    class_counts = Counter(train_label)\n    class_weights = 1. / torch.tensor([class_counts[i] for i in range(18)], dtype=torch.float)\n    sample_weights = class_weights[train_label]\n    sampler = WeightedRandomSampler(weights=sample_weights, num_samples=len(sample_weights), replacement=True)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, sampler=sampler)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8694992412746586,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8694992412746586, 'f1_score': 0.873956778893668, 'precision': 0.884204994007878, 'recall': 0.8694992412746586, 'confusion_matrix': [[392, 4, 0, 0, 2, 1, 0, 3, 0, 0, 0, 4, 0, 0, 1, 2, 0, 2], [0, 13, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 8, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 1, 3, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 12, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 0, 0, 0, 0, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0], [0, 2, 0, 0, 0, 0, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 2, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 13, 0, 0, 0, 0, 0, 1, 1], [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 9, 2, 0, 1, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 2, 2, 20, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 3, 0, 0, 1, 0, 0, 0, 0, 9, 3, 0, 2, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 7, 0, 1, 2], [1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 13, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 8]]}",
                "lineage": "80401"
            }
        ],
        "805": [],
        "806": [],
        "807": [],
        "808": [],
        "809": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(base_model.parameters(), lr=0.001)\n    scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=20, gamma=0.1)\n\n    base_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = base_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    base_model.eval()\n    with torch.no_grad():\n        val_outputs = base_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8786039453717754,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8786039453717754, 'f1_score': 0.8787071157985525, 'precision': 0.8863110009454055, 'recall': 0.8786039453717754, 'confusion_matrix': [[402, 3, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 1, 2, 0, 1], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [0, 0, 0, 0, 11, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 4, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0, 1, 0, 0, 1, 10, 0, 4, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, 1, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 9, 1, 0, 0, 1, 0, 1], [0, 1, 0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 17, 0, 1, 0, 2, 0], [0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 0, 0, 9, 4, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 6, 0, 1, 1], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0], [0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 14, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 8]]}",
                "lineage": "80901"
            }
        ],
        "810": [],
        "811": [],
        "812": [],
        "813": [],
        "814": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=4)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        attn_output, _ = self.attention(lstm_out, lstm_out, lstm_out)\n        x = attn_output[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8391502276176024,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8391502276176024, 'f1_score': 0.8418889657401475, 'precision': 0.8513406671140199, 'recall': 0.8391502276176024, 'confusion_matrix': [[396, 5, 0, 0, 1, 1, 1, 0, 2, 2, 0, 0, 2, 1, 0, 0, 0, 0], [0, 12, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [0, 0, 9, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 4, 14, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 1, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [0, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 1, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 1, 0, 0, 0, 1, 11, 1, 3, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 12, 0, 0, 1, 0, 0, 1, 1], [2, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 7, 2, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 2, 0, 17, 0, 0, 0, 4, 0], [0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 0, 0, 0, 9, 1, 0, 4, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 3, 1, 1, 4, 0, 0, 1], [2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 5, 0, 0], [0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 6, 0, 0, 0, 8, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 6]]}",
                "lineage": "81401"
            }
        ],
        "815": [],
        "816": [],
        "817": [],
        "818": [],
        "819": [],
        "820": [],
        "821": [],
        "822": [],
        "823": [],
        "824": [],
        "825": [],
        "826": [],
        "827": [],
        "828": [],
        "829": [],
        "830": [],
        "831": [],
        "832": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            blended_inputs = inputs.clone()\n            for i in range(len(blended_inputs)):\n                if np.random.rand() > 0.5:\n                    idx = np.random.randint(len(train_loader.dataset))\n                    blended_inputs[i] = (inputs[i] + train_loader.dataset[idx][0]) / 2\n            optimizer.zero_grad()\n            outputs = contrastive_model(blended_inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8315629742033384,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8315629742033384, 'f1_score': 0.8128859154508505, 'precision': 0.8214165450775246, 'recall': 0.8315629742033384, 'confusion_matrix': [[408, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0], [2, 13, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [11, 0, 1, 6, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0], [3, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 0, 0, 0, 2, 5, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 1, 0, 0, 0, 0, 0, 0, 3, 1, 0, 0, 0, 2, 0, 0, 0, 0], [5, 0, 1, 0, 0, 0, 0, 0, 0, 13, 0, 1, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 1, 0], [10, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 2, 1, 0, 0, 0, 0, 1], [2, 0, 0, 0, 0, 0, 0, 0, 1, 0, 4, 0, 13, 3, 0, 0, 3, 0], [6, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 5, 4, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 7, 1, 0, 2], [2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0, 0], [3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 9, 4], [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 7]]}",
                "lineage": "83201"
            }
        ],
        "833": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n\n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n\n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8634294385432474,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8634294385432474, 'f1_score': 0.8644017036408519, 'precision': 0.871719046759329, 'recall': 0.8634294385432474, 'confusion_matrix': [[402, 1, 1, 0, 0, 2, 2, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0], [0, 14, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 8, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 3, 15, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0], [0, 0, 0, 0, 9, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 4, 3, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 2, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 1, 0, 0, 0, 1, 10, 2, 3, 0, 0, 0, 0, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 15, 0, 0, 0, 0, 1, 0, 0], [2, 0, 0, 0, 0, 0, 0, 0, 1, 2, 1, 6, 3, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 3, 2, 17, 1, 0, 0, 1, 0], [0, 0, 0, 0, 0, 3, 0, 0, 1, 0, 1, 0, 0, 8, 2, 0, 3, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 8, 0, 0, 0], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 1, 0, 0, 0, 12, 2], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 2, 7]]}",
                "lineage": "83301"
            }
        ],
        "834": [],
        "835": [],
        "836": [],
        "837": [],
        "838": [],
        "839": [],
        "840": [],
        "841": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import confusion_matrix, classification_report\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.tcn = nn.Conv1d(in_channels=16, out_channels=128, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=128, hidden_size=128, num_layers=2, batch_first=True, dropout=dropout_rate)\n        self.fc = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = x.view(-1, 52, 16).permute(0, 2, 1)\n        x = self.tcn(x)\n        x = x.permute(0, 2, 1)\n        lstm_out, _ = self.lstm(x)\n        x = lstm_out[:, -1, :]\n        x = self.fc(x)\n        return x\n\nclass ContrastiveLearningModel(nn.Module):\n    def __init__(self, base_model):\n        super(ContrastiveLearningModel, self).__init__()\n        self.base_model = base_model\n    \n    def forward(self, x):\n        return self.base_model(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 16)).reshape(train_data_reshaped.shape)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 16)).reshape(val_data_reshaped.shape)\n\n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n\n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    base_model = GestureClassifier(dropout_rate=0.5).to(device)\n    contrastive_model = ContrastiveLearningModel(base_model).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(contrastive_model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.1)\n\n    contrastive_model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            inputs = inputs + torch.randn_like(inputs) * 0.01\n            optimizer.zero_grad()\n            outputs = contrastive_model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    contrastive_model.eval()\n    with torch.no_grad():\n        val_outputs = contrastive_model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n\n    cm = confusion_matrix(val_label, predicted.cpu().numpy())\n    report = classification_report(val_label, predicted.cpu().numpy(), output_dict=True)\n    metrics = {\n        \"accuracy\": report[\"accuracy\"],\n        \"f1_score\": report[\"weighted avg\"][\"f1-score\"],\n        \"precision\": report[\"weighted avg\"][\"precision\"],\n        \"recall\": report[\"weighted avg\"][\"recall\"],\n        \"confusion_matrix\": cm.tolist()\n    }\n    print(\"Final Evaluation Metrics:\\n\", metrics)\n\n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXXXXXXXXX.py",
                "accuracy": 0.8512898330804249,
                "model_info": "Final Evaluation Metrics:\n {'accuracy': 0.8512898330804249, 'f1_score': 0.8475444968430107, 'precision': 0.8634548501626857, 'recall': 0.8512898330804249, 'confusion_matrix': [[404, 2, 0, 0, 2, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, 0, 0], [1, 13, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0], [1, 0, 7, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [0, 0, 4, 15, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 13, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 2, 5, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0], [0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0], [1, 1, 0, 0, 0, 1, 0, 0, 4, 1, 0, 1, 0, 0, 0, 0, 0, 0], [4, 0, 0, 0, 0, 0, 0, 0, 1, 8, 1, 5, 0, 0, 0, 0, 0, 1], [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, 0, 0, 0, 0, 0], [2, 0, 0, 0, 1, 0, 0, 0, 3, 1, 0, 6, 0, 0, 2, 0, 0, 1], [0, 1, 0, 0, 0, 0, 0, 0, 2, 3, 2, 1, 11, 0, 0, 0, 3, 3], [0, 0, 0, 0, 1, 0, 0, 0, 1, 2, 0, 0, 0, 5, 7, 1, 1, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 8, 0, 0, 0], [3, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 0, 0, 0, 13, 1], [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 2, 0, 1, 5]]}",
                "lineage": "84101"
            }
        ],
        "842": [],
        "843": []
    },
    "1": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass LSTMModel(nn.Module):\n    def __init__(self):\n        super(LSTMModel, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=64, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(64, 18)\n    \n    def forward(self, x):\n        x, _ = self.lstm(x)\n        x = self.fc(x[:, -1, :])\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    model = LSTMModel().to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(train_data, dtype=torch.float32), torch.tensor(train_label, dtype=torch.long))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for data, labels in train_loader:\n            data, labels = data.to(device), labels.to(device)\n            optimizer.zero_grad()\n            outputs = model(data)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    val_data_tensor = torch.tensor(val_data, dtype=torch.float32).to(device)\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8261_Recurrent_Neural_Net.py",
                "accuracy": 0.6555386949924128,
                "model_info": "",
                "lineage": "ninapro_initial_8261_Recurrent_Neural_Net"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\n\nclass LSTMModel(nn.Module):\n    def __init__(self):\n        super(LSTMModel, self).__init__()\n        self.lstm = nn.LSTM(input_size=16, hidden_size=64, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(64, 18)\n    \n    def forward(self, x):\n        x, _ = self.lstm(x)\n        x = self.fc(x[:, -1, :])\n        return x\n\ndef add_frequency_domain_transformations(data):\n    transformed_data = np.fft.fft(data, axis=1)\n    return np.abs(transformed_data)\n\ndef add_gaussian_noise(data, noise_level=0.1):\n    noise = np.random.normal(0, noise_level, data.shape)\n    return data + noise\n\ndef add_temporal_jittering(data, jitter_strength=0.1):\n    jitter = np.random.uniform(-jitter_strength, jitter_strength, data.shape)\n    return data + jitter\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = add_frequency_domain_transformations(train_data)\n    val_data = add_frequency_domain_transformations(val_data)\n\n    model = LSTMModel().to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(train_data, dtype=torch.float32), torch.tensor(train_label, dtype=torch.long))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for data, labels in train_loader:\n            data, labels = data.to(device), labels.to(device)\n            optimizer.zero_grad()\n            outputs = model(data)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    val_data_tensor = torch.tensor(val_data, dtype=torch.float32).to(device)\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8261_Recurrent_Neural_NetX.py",
                "accuracy": 0.6752655538694993,
                "model_info": "",
                "lineage": "111"
            }
        ],
        "2": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import StandardScaler\nfrom torchvision import models\nimport random\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, num_classes):\n        super(GestureClassifier, self).__init__()\n        self.backbone = models.resnet18(pretrained=True)\n        self.backbone.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n        self.backbone.fc = nn.Linear(self.backbone.fc.in_features, num_classes)\n\n    def forward(self, x):\n        return self.backbone(x)\n\ndef temporal_jittering(data):\n    jittered_data = []\n    for sample in data:\n        jitter = np.random.normal(0, 0.01, sample.shape)\n        jittered_data.append(sample + jitter)\n    return np.array(jittered_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = temporal_jittering(train_data)\n    train_data_reshaped = train_data.reshape(-1, 1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n\n    train_tensor = torch.tensor(train_data_scaled, dtype=torch.float32).to(device)\n    train_labels_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_scaled, dtype=torch.float32).to(device)\n\n    model = GestureClassifier(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(train_tensor), batch_size):\n            batch_data = train_tensor[i:i + batch_size]\n            batch_labels = train_labels_tensor[i:i + batch_size]\n\n            optimizer.zero_grad()\n            outputs = model(batch_data)\n            loss = criterion(outputs, batch_labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXX.py",
                "accuracy": 0.7996965098634294,
                "model_info": "",
                "lineage": "211"
            }
        ],
        "3": [
            {
                "code": "import numpy as np\nfrom sklearn.svm import SVC\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.decomposition import PCA\nfrom scipy.fft import fft\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    fft_train = np.abs(fft(train_data_scaled, axis=1))[:, :train_data_scaled.shape[1] // 2]\n    fft_val = np.abs(fft(val_data_scaled, axis=1))[:, :val_data_scaled.shape[1] // 2]\n    \n    pca = PCA(n_components=50)\n    train_data_features = pca.fit_transform(np.hstack((train_data_scaled, fft_train)))\n    val_data_features = pca.transform(np.hstack((val_data_scaled, fft_val)))\n    \n    svm_model = SVC(kernel='rbf')\n    svm_model.fit(train_data_features, train_label)\n    \n    y_pred_labels = svm_model.predict(val_data_features)\n    \n    return y_pred_labels.tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiX.py",
                "accuracy": 0.7374810318664643,
                "model_info": "",
                "lineage": "311"
            }
        ],
        "4": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import StandardScaler\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, dropout_rate=0.5):\n        super(GestureClassifier, self).__init__()\n        self.fc1 = nn.Linear(52 * 16, 128)\n        self.dropout = nn.Dropout(dropout_rate)\n        self.fc2 = nn.Linear(128, 18)\n    \n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    train_tensor = torch.FloatTensor(train_data_scaled).to(device)\n    train_label_tensor = torch.LongTensor(train_label).to(device)\n    val_tensor = torch.FloatTensor(val_data_scaled).to(device)\n    \n    train_dataset = TensorDataset(train_tensor, train_label_tensor)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    \n    model = GestureClassifier(dropout_rate=0.5).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(50):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, predicted = torch.max(val_outputs, 1)\n    \n    return predicted.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiX.py",
                "accuracy": 0.858877086494689,
                "model_info": "",
                "lineage": "411"
            }
        ]
    },
    "2": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass TCN(nn.Module):\n    def __init__(self, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(16, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 26, num_classes)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool1d(2)\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.pool(x)\n        x = self.relu(self.conv2(x))\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = torch.tensor(train_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n\n    train_dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, y_pred = torch.max(val_outputs, 1)\n    \n    return y_pred.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8262_Temporal_Convolution.py",
                "accuracy": 0.7830045523520486,
                "model_info": "",
                "lineage": "ninapro_initial_8262_Temporal_Convolution"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass TCN(nn.Module):\n    def __init__(self, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(16, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 13, num_classes)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool1d(2)\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.pool(x)\n        x = self.relu(self.conv2(x))\n        x = self.pool(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = torch.tensor(train_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).permute(0, 2, 1).to(device)\n\n    train_dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, 'min', patience=3)\n\n    model.train()\n    for epoch in range(20):\n        total_loss = 0\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n            optimizer.step()\n            total_loss += loss.item()\n        scheduler.step(total_loss / len(train_loader))\n        print(f\"Epoch {epoch+1}, Loss: {total_loss / len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, y_pred = torch.max(val_outputs, 1)\n    \n    return y_pred.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8262_Temporal_ConvolutionXX.py",
                "accuracy": 0.7921092564491654,
                "model_info": "Epoch 1, Loss: 2.143032797745296\nEpoch 2, Loss: 1.251443027030854\nEpoch 3, Loss: 1.0965345814114524\nEpoch 4, Loss: 1.0610685376893907\nEpoch 5, Loss: 1.007700230394091\nEpoch 6, Loss: 0.948633306083225\nEpoch 7, Loss: 0.8957252147651854\nEpoch 8, Loss: 0.8435943793682825\nEpoch 9, Loss: 0.7939980434519904\nEpoch 10, Loss: 0.7559687381698972\nEpoch 11, Loss: 0.7085159513212386\nEpoch 12, Loss: 0.6719678626174018\nEpoch 13, Loss: 0.6614543405317125\nEpoch 14, Loss: 0.6326111384800502\nEpoch 15, Loss: 0.600910308105605\nEpoch 16, Loss: 0.5764363301651818\nEpoch 17, Loss: 0.5623304400415647\nEpoch 18, Loss: 0.5445091735039439\nEpoch 19, Loss: 0.5366320780345372\nEpoch 20, Loss: 0.5245762488671711",
                "lineage": "121"
            }
        ],
        "2": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\n\nclass CombinedModel(nn.Module):\n    def __init__(self):\n        super(CombinedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=16, out_channels=32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=3, padding=1)\n        self.lstm = nn.LSTM(input_size=64, hidden_size=64, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(64, 18)\n    \n    def forward(self, x):\n        x = x.permute(0, 2, 1)\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.relu(self.conv2(x))\n        x = x.permute(0, 2, 1)\n        x, _ = self.lstm(x)\n        x = self.fc(x[:, -1, :])\n        return x\n\ndef add_frequency_domain_transformations(data):\n    transformed_data = np.fft.fft(data, axis=1)\n    return np.abs(transformed_data)\n\ndef add_gaussian_noise(data, noise_level=0.1):\n    noise = np.random.normal(0, noise_level, data.shape)\n    return data + noise\n\ndef add_temporal_jittering(data, jitter_strength=0.1):\n    jitter = np.random.uniform(-jitter_strength, jitter_strength, data.shape)\n    return data + jitter\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = add_frequency_domain_transformations(train_data)\n    val_data = add_frequency_domain_transformations(val_data)\n\n    model = CombinedModel().to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(train_data, dtype=torch.float32), torch.tensor(train_label, dtype=torch.long))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for data, labels in train_loader:\n            data, labels = data.to(device), labels.to(device)\n            optimizer.zero_grad()\n            outputs = model(data)\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    val_data_tensor = torch.tensor(val_data, dtype=torch.float32).to(device)\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8261_Recurrent_Neural_NetXX.py",
                "accuracy": 0.6646433990895296,
                "model_info": "",
                "lineage": "221"
            }
        ],
        "3": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import StandardScaler\nfrom torchvision import models\nimport random\nfrom scipy.signal import butter, lfilter\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, num_classes):\n        super(GestureClassifier, self).__init__()\n        self.backbone = models.resnet18(pretrained=True)\n        self.backbone.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n        self.backbone.fc = nn.Linear(self.backbone.fc.in_features, num_classes)\n\n    def forward(self, x):\n        return self.backbone(x)\n\ndef low_pass_filter(data, cutoff=10, fs=100, order=5):\n    nyquist = 0.5 * fs\n    normal_cutoff = cutoff / nyquist\n    b, a = butter(order, normal_cutoff, btype='low', analog=False)\n    return lfilter(b, a, data)\n\ndef filter_data(data):\n    filtered_data = []\n    for sample in data:\n        filtered_sample = low_pass_filter(sample, cutoff=10, fs=100)\n        filtered_data.append(filtered_sample)\n    return np.array(filtered_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = filter_data(train_data)\n    train_data_reshaped = train_data.reshape(-1, 1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n\n    train_tensor = torch.tensor(train_data_scaled, dtype=torch.float32).to(device)\n    train_labels_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_scaled, dtype=torch.float32).to(device)\n\n    model = GestureClassifier(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(train_tensor), batch_size):\n            batch_data = train_tensor[i:i + batch_size]\n            batch_labels = train_labels_tensor[i:i + batch_size]\n\n            optimizer.zero_grad()\n            outputs = model(batch_data)\n            loss = criterion(outputs, batch_labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXX.py",
                "accuracy": 0.015174506828528073,
                "model_info": "",
                "lineage": "321"
            }
        ],
        "4": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import StandardScaler\nfrom torchvision import models\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, num_classes):\n        super(GestureClassifier, self).__init__()\n        self.backbone = models.resnet18(weights='DEFAULT')\n        self.backbone.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n        self.backbone.fc = nn.Linear(self.backbone.fc.in_features, num_classes)\n\n    def forward(self, x):\n        x = self.backbone(x)\n        return x\n\ndef temporal_jittering(data):\n    jittered_data = []\n    for sample in data:\n        jitter = np.random.normal(0, 0.01, sample.shape)\n        jittered_data.append(sample + jitter)\n    return np.array(jittered_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data = temporal_jittering(train_data)\n    train_data_reshaped = train_data.reshape(-1, 1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n\n    train_tensor = torch.tensor(train_data_scaled, dtype=torch.float32).to(device)\n    train_labels_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_scaled, dtype=torch.float32).to(device)\n\n    model = GestureClassifier(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=5, gamma=0.1)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(train_tensor), batch_size):\n            batch_data = train_tensor[i:i + batch_size]\n            batch_labels = train_labels_tensor[i:i + batch_size]\n\n            optimizer.zero_grad()\n            outputs = model(batch_data)\n            loss = criterion(outputs, batch_labels)\n            loss.backward()\n            optimizer.step()\n        scheduler.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiXXXX.py",
                "accuracy": 0.8163884673748103,
                "model_info": "",
                "lineage": "421"
            }
        ]
    },
    "4": {
        "0": [
            {
                "code": "import numpy as np\nfrom sklearn.svm import SVC\nfrom sklearn.preprocessing import StandardScaler\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    svm_model = SVC(kernel='rbf')\n    svm_model.fit(train_data_scaled, train_label)\n    \n    y_pred_labels = svm_model.predict(val_data_scaled)\n    \n    return y_pred_labels.tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_Machi.py",
                "accuracy": 0.8209408194233687,
                "model_info": "",
                "lineage": "ninapro_initial_8264_Support_Vector_Machi"
            }
        ],
        "1": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import StandardScaler\nfrom torchvision import models\n\nclass GestureClassifier(nn.Module):\n    def __init__(self, num_classes):\n        super(GestureClassifier, self).__init__()\n        self.backbone = models.resnet18(pretrained=True)\n        self.backbone.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n        self.backbone.fc = nn.Linear(self.backbone.fc.in_features, num_classes)\n\n    def forward(self, x):\n        return self.backbone(x)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data_reshaped = train_data.reshape(-1, 1, 52, 16)\n    val_data_reshaped = val_data.reshape(-1, 1, 52, 16)\n\n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n    val_data_scaled = scaler.transform(val_data_reshaped.reshape(-1, 52 * 16)).reshape(-1, 1, 52, 16)\n\n    train_tensor = torch.tensor(train_data_scaled, dtype=torch.float32).to(device)\n    train_labels_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_scaled, dtype=torch.float32).to(device)\n\n    model = GestureClassifier(num_classes=18).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(train_tensor), batch_size):\n            batch_data = train_tensor[i:i + batch_size]\n            batch_labels = train_labels_tensor[i:i + batch_size]\n\n            optimizer.zero_grad()\n            outputs = model(batch_data)\n            loss = criterion(outputs, batch_labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_tensor)\n        _, y_pred_labels = torch.max(val_outputs, 1)\n\n    return y_pred_labels.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiX.py",
                "accuracy": 0.7738998482549317,
                "model_info": "",
                "lineage": "141"
            }
        ]
    },
    "3": {
        "2": [
            {
                "code": "import numpy as np\nfrom sklearn.svm import SVC\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import accuracy_score\n\ndef augment_data_with_interpolation(train_data, train_label):\n    # Implement synthetic gesture generation through interpolation\n    # This is a placeholder for actual interpolation logic\n    return train_data, train_label\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=64):\n    train_data, train_label = augment_data_with_interpolation(train_data, train_label)\n    \n    train_data_reshaped = train_data.reshape(-1, 52 * 16)\n    val_data_reshaped = val_data.reshape(-1, 52 * 16)\n    \n    scaler = StandardScaler()\n    train_data_scaled = scaler.fit_transform(train_data_reshaped)\n    val_data_scaled = scaler.transform(val_data_reshaped)\n    \n    svm_model = SVC(kernel='rbf')\n    svm_model.fit(train_data_scaled, train_label)\n    \n    y_pred_labels = svm_model.predict(val_data_scaled)\n    \n    return y_pred_labels.tolist()",
                "file": "/projects/users/tusoml/ninapro_initial_8264_Support_Vector_MachiX.py",
                "accuracy": 0.8209408194233687,
                "model_info": "",
                "lineage": "231"
            }
        ]
    }
}