{
    "1": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass RNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.RNN(input_size, hidden_size, batch_first=True)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 64\n    num_classes = 4\n\n    model = RNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_Net.py",
                "accuracy": 0.4495,
                "model_info": "",
                "lineage": "ecg_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\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 16, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn = nn.RNN(16 * 500, hidden_size, batch_first=True)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, 16 * 500)\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 64\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetX.py",
                "accuracy": 0.4968,
                "model_info": "",
                "lineage": "111"
            }
        ],
        "2": [
            {
                "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, input_size, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(input_size, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 1000 // 4, num_classes)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool1d(2)\n        self.dropout = nn.Dropout(p=0.5)\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.pool(x)\n        x = self.dropout(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=1024):\n    train_data_tensor = torch.tensor(train_data, dtype=torch.float32).unsqueeze(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).unsqueeze(1).to(device)\n\n    dataset = TensorDataset(train_data_tensor, train_label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(input_size=1, num_classes=4).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        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8263_Temporal_ConvolutionX.py",
                "accuracy": 0.4405,
                "model_info": "",
                "lineage": "211"
            }
        ],
        "3": [
            {
                "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 CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 32, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 64 * (input_size // 4)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\nclass FocalLoss(nn.Module):\n    def __init__(self, alpha=1, gamma=2, reduction='mean'):\n        super(FocalLoss, self).__init__()\n        self.alpha = alpha\n        self.gamma = gamma\n        self.reduction = reduction\n\n    def forward(self, inputs, targets):\n        BCE_loss = nn.CrossEntropyLoss(reduction='none')(inputs, targets)\n        pt = torch.exp(-BCE_loss)\n        F_loss = self.alpha * (1 - pt) ** self.gamma * BCE_loss\n        if self.reduction == 'mean':\n            return F_loss.mean()\n        return F_loss\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 128\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = FocalLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXX.py",
                "accuracy": 0.5934,
                "model_info": "Epoch 1, Loss: 0.6149693074354267\nEpoch 2, Loss: 0.49259255649486267\nEpoch 3, Loss: 0.4262517019249927\nEpoch 4, Loss: 0.38292793387197444\nEpoch 5, Loss: 0.3555606282762184\nEpoch 6, Loss: 0.33419004094098265\nEpoch 7, Loss: 0.31569439446789094\nEpoch 8, Loss: 0.29933203397126035\nEpoch 9, Loss: 0.28611637001065005\nEpoch 10, Loss: 0.27342657116866204\nEpoch 11, Loss: 0.2610309256447686\nEpoch 12, Loss: 0.24951138504391887\nEpoch 13, Loss: 0.23988319282559142\nEpoch 14, Loss: 0.22935358523409027\nEpoch 15, Loss: 0.22052694320450342\nEpoch 16, Loss: 0.21104366820434045\nEpoch 17, Loss: 0.20208443278782212\nEpoch 18, Loss: 0.19324957901947343\nEpoch 19, Loss: 0.18876357650619813\nEpoch 20, Loss: 0.17898316612873955",
                "lineage": "311"
            }
        ],
        "4": [
            {
                "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 AttentionLayer(nn.Module):\n    def __init__(self, input_dim):\n        super(AttentionLayer, self).__init__()\n        self.W = nn.Linear(input_dim, input_dim)\n        self.V = nn.Linear(input_dim, 1)\n\n    def forward(self, x):\n        scores = self.V(torch.tanh(self.W(x)))\n        weights = torch.softmax(scores, dim=1)\n        context = torch.bmm(weights.transpose(1, 2), x).squeeze(1)\n        return context\n\nclass WaveletTransformModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.attention = AttentionLayer(input_dim)\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = self.attention(x.unsqueeze(1))\n        x = torch.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=1024):\n    def dummy_transform(data):\n        return data\n\n    train_data_transformed = np.array([dummy_transform(seq) for seq in train_data])\n    val_data_transformed = np.array([dummy_transform(seq) for seq in val_data])\n\n    train_tensor = torch.tensor(train_data_transformed, dtype=torch.float32).to(device)\n    label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_transformed, dtype=torch.float32).to(device)\n\n    dataset = TensorDataset(train_tensor, label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = WaveletTransformModel(input_dim=train_data_transformed.shape[1], num_classes=4).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 data, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(data)\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        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8264_Transformer_based_moXX.py",
                "accuracy": 0.5015,
                "model_info": "",
                "lineage": "411"
            }
        ]
    },
    "3": {
        "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, input_size, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(input_size, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 1000 // 4, 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=1024):\n    train_data_tensor = torch.tensor(train_data, dtype=torch.float32).unsqueeze(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).unsqueeze(1).to(device)\n\n    dataset = TensorDataset(train_data_tensor, train_label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(input_size=1, num_classes=4).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        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8263_Temporal_Convolution.py",
                "accuracy": 0.5118,
                "model_info": "",
                "lineage": "ecg_initial_8263_Temporal_Convolution"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.datasets import make_classification\nfrom sklearn.model_selection import train_test_split\nfrom sklearn.preprocessing import StandardScaler\n\nclass TCN(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(TCN, self).__init__()\n        self.conv1 = nn.Conv1d(input_size, 64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=3, padding=1)\n        self.fc = nn.Linear(128 * 1000 // 4, 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=1024):\n    train_data_tensor = torch.tensor(train_data, dtype=torch.float32).unsqueeze(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).unsqueeze(1).to(device)\n\n    dataset = TensorDataset(train_data_tensor, train_label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = TCN(input_size=1, num_classes=4).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        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8263_Temporal_ConvolutionX.py",
                "accuracy": 0.5067,
                "model_info": "",
                "lineage": "131"
            }
        ]
    },
    "4": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass TransformerModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(TransformerModel, self).__init__()\n        self.transformer = nn.Transformer(d_model=input_dim, nhead=8, num_encoder_layers=6)\n        self.fc = nn.Linear(input_dim, num_classes)\n\n    def forward(self, x):\n        x = x.permute(1, 0, 2)\n        x = self.transformer(x, x)\n        x = self.fc(x[-1, :, :])\n        return x\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_tensor = torch.tensor(train_data, dtype=torch.float32).to(device)\n    label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    dataset = TensorDataset(train_tensor, label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = TransformerModel(input_dim=1000, num_classes=4).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 data, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(data.unsqueeze(1))\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.unsqueeze(1))\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8264_Transformer_based_mo.py",
                "accuracy": 0.1054,
                "model_info": "",
                "lineage": "ecg_initial_8264_Transformer_based_mo"
            }
        ],
        "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 WaveletTransformModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = torch.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=1024):\n    def dummy_transform(data):\n        return data\n\n    train_data_transformed = np.array([dummy_transform(seq) for seq in train_data])\n    val_data_transformed = np.array([dummy_transform(seq) for seq in val_data])\n\n    train_tensor = torch.tensor(train_data_transformed, dtype=torch.float32).to(device)\n    label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_transformed, dtype=torch.float32).to(device)\n\n    dataset = TensorDataset(train_tensor, label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = WaveletTransformModel(input_dim=train_data_transformed.shape[1], num_classes=4).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 data, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(data)\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        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8264_Transformer_based_moX.py",
                "accuracy": 0.5053,
                "model_info": "",
                "lineage": "141"
            }
        ]
    },
    "0": {
        "2": [],
        "3": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nimport matplotlib.pyplot as plt\n\nclass WaveletTransformModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = torch.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=1024):\n    def dummy_transform(data):\n        return data\n\n    train_data_transformed = np.array([dummy_transform(seq) for seq in train_data])\n    val_data_transformed = np.array([dummy_transform(seq) for seq in val_data])\n\n    train_tensor = torch.tensor(train_data_transformed, dtype=torch.float32).to(device)\n    label_tensor = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_tensor = torch.tensor(val_data_transformed, dtype=torch.float32).to(device)\n\n    dataset = TensorDataset(train_tensor, label_tensor)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model = WaveletTransformModel(input_dim=train_data_transformed.shape[1], num_classes=4).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 data, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(data)\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        _, val_preds = torch.max(val_outputs, 1)\n\n    feature_importances = torch.mean(torch.abs(model.fc1.weight.data), axis=1)\n    top_k_indices = torch.topk(feature_importances, k=5).indices.cpu().numpy().tolist()\n    print(f\"Top-K feature importances (indices): {top_k_indices}\")\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8264_Transformer_based_moXX.py",
                "accuracy": 0.5053,
                "model_info": "Top-K feature importances (indices): [67, 119, 127, 29, 105]",
                "lineage": "301"
            }
        ],
        "4": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 32, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 64 * (input_size // 4)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True)\n        self.attention = nn.Linear(hidden_size, 1)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 128\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXX.py",
                "accuracy": 0.6032,
                "model_info": "Epoch 1, Loss: 1.1866521136514072\nEpoch 2, Loss: 1.0261129469707095\nEpoch 3, Loss: 0.9293490687092602\nEpoch 4, Loss: 0.8613312723992885\nEpoch 5, Loss: 0.8144292975294178\nEpoch 6, Loss: 0.7764517027756264\nEpoch 7, Loss: 0.7466279003355238\nEpoch 8, Loss: 0.7189372172757583\nEpoch 9, Loss: 0.6942091974718817\nEpoch 10, Loss: 0.6708337436233901\nEpoch 11, Loss: 0.6512788520462212\nEpoch 12, Loss: 0.629122582431954\nEpoch 13, Loss: 0.6089812521733543\nEpoch 14, Loss: 0.5882233842579341\nEpoch 15, Loss: 0.5703095599609317\nEpoch 16, Loss: 0.5534713969376809\nEpoch 17, Loss: 0.5363957079205933\nEpoch 18, Loss: 0.5200440963566075\nEpoch 19, Loss: 0.5039312442143759\nEpoch 20, Loss: 0.48851793079540645",
                "lineage": "401"
            }
        ],
        "5": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom scipy.stats import skew, kurtosis\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 128 * (input_size // 4)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0003)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(30):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    class_balance_before = torch.bincount(train_label).float() / len(train_label)\n    print(f\"Class balance before resampling: {class_balance_before.tolist()}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    class_balance_after = torch.bincount(val_preds).float() / len(val_preds)\n    print(f\"Class balance after resampling: {class_balance_after.tolist()}\")\n\n    for i in range(train_data.shape[1]):\n        skewness = skew(train_data[:, i].cpu().numpy())\n        kurt = kurtosis(train_data[:, i].cpu().numpy())\n        print(f\"Feature {i} - Skewness: {skewness}, Kurtosis: {kurt}\")\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXX.py",
                "accuracy": 0.6003,
                "model_info": "Epoch 1, Loss: 1.1125312558520093\nEpoch 2, Loss: 0.9281678049898422\nEpoch 3, Loss: 0.818374691448834\nEpoch 4, Loss: 0.7483358997529848\nEpoch 5, Loss: 0.6947437444712516\nEpoch 6, Loss: 0.646184846215422\nEpoch 7, Loss: 0.6043336238719222\nEpoch 8, Loss: 0.5645177975268373\nEpoch 9, Loss: 0.5279902486334378\nEpoch 10, Loss: 0.4951587412041574\nEpoch 11, Loss: 0.4614978033956319\nEpoch 12, Loss: 0.43204836733281726\nEpoch 13, Loss: 0.4021897500741962\nEpoch 14, Loss: 0.3777648064660019\nEpoch 15, Loss: 0.35498461670701653\nEpoch 16, Loss: 0.3341233914507099\nEpoch 17, Loss: 0.3114910829890941\nEpoch 18, Loss: 0.2903911480805238\nEpoch 19, Loss: 0.27221078724527087\nEpoch 20, Loss: 0.25278303879465114\nEpoch 21, Loss: 0.2383130908641614\nEpoch 22, Loss: 0.22432443490984802\nEpoch 23, Loss: 0.2099407042971957\nEpoch 24, Loss: 0.19286195746481763\nEpoch 25, Loss: 0.1838237447038493\nEpoch 26, Loss: 0.1747647248165621\nEpoch 27, Loss: 0.1651339931216899\nEpoch 28, Loss: 0.1594753758320424\nEpoch 29, Loss: 0.15223283279193797\nEpoch 30, Loss: 0.14647174104619162\nClass balance before resampling: [0.26714181900024414, 0.24496789276599884, 0.27502354979515076, 0.21286673843860626]\nClass balance after resampling: [0.274784654378891, 0.24053367972373962, 0.26150986552238464, 0.22317175567150116]\nFeature 0 - Skewness: [0.7677025  0.7371021  0.6986309  0.65345633 0.6146276  0.58625\n 0.5879016  0.6107784  0.635724   0.64716524 0.6294165  0.60377336\n 0.5916256  0.6013343  0.63349676 0.67278546 0.6956065  0.6958473\n 0.6797321  0.65630656 0.6305599  0.6034981  0.57505566 0.5554268\n 0.55479413 0.5701813  0.5860682  0.5928555  0.59699273 0.6051698\n 0.60830337 0.60578334 0.597345   0.60792154 0.6201352  0.63160205\n 0.6411563  0.65040225 0.6556063  0.66432405 0.6846563  0.7105274\n 0.73830694 0.7520125  0.74251163 0.7368124  0.74104184 0.7503559\n 0.75383943 0.7421261  0.73023653 0.71769136 0.7051789  0.7082283\n 0.72608805 0.74779177 0.7634665  0.77158445 0.77564865 0.7609751\n 0.7440748  0.753204   0.7660045  0.77",
                "lineage": "501"
            }
        ],
        "6": [
            {
                "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 WaveletTransformModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.fc1 = nn.Linear(input_size, hidden_size)\n        self.fc2 = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = x.view(x.size(0), -1)\n        x = torch.relu(self.fc1(x))\n        out = self.fc2(x)\n        return out\n\ndef dummy_wavelet_transform(data):\n    return torch.tensor(data, dtype=torch.float32)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = dummy_wavelet_transform(train_data).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = dummy_wavelet_transform(val_data).to(device)\n\n    input_size = train_data.shape[1]\n    hidden_size = 128\n    num_classes = 4\n\n    model = WaveletTransformModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXX.py",
                "accuracy": 0.5085,
                "model_info": "Epoch 1, Loss: 1.2736568021591597\nEpoch 2, Loss: 1.201273333523922\nEpoch 3, Loss: 1.1709510339174234\nEpoch 4, Loss: 1.1505709808905007\nEpoch 5, Loss: 1.1364860580342027\nEpoch 6, Loss: 1.1255553325930774\nEpoch 7, Loss: 1.116730737503461\nEpoch 8, Loss: 1.109167709204429\nEpoch 9, Loss: 1.1020197064483759\nEpoch 10, Loss: 1.0966973131187117\nEpoch 11, Loss: 1.0926608874880035\nEpoch 12, Loss: 1.086561957995097\nEpoch 13, Loss: 1.082659682551563\nEpoch 14, Loss: 1.0783832762889936\nEpoch 15, Loss: 1.0749407330692042\nEpoch 16, Loss: 1.071827371458441\nEpoch 17, Loss: 1.0684990015066447\nEpoch 18, Loss: 1.0657432947122274\nEpoch 19, Loss: 1.0626986296240855\nEpoch 20, Loss: 1.0607851156786483",
                "lineage": "601"
            }
        ],
        "7": [
            {
                "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 WaveletTransformModel(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.fc1 = nn.Linear(input_size, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = x.view(x.size(0), -1)\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef dummy_wavelet_transform(data):\n    transformed_data = []\n    for signal in data:\n        coeffs_flat = np.random.rand(64)  # Placeholder for wavelet coefficients\n        transformed_data.append(coeffs_flat)\n    return np.array(transformed_data)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = dummy_wavelet_transform(train_data)\n    val_data = dummy_wavelet_transform(val_data)\n    \n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    input_size = train_data.shape[1]\n    num_classes = 4\n\n    model = WaveletTransformModel(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXX.py",
                "accuracy": 0.2072,
                "model_info": "Epoch 1, Loss: 1.3825764272404812\nEpoch 2, Loss: 1.3818899886361484\nEpoch 3, Loss: 1.3815803619180145\nEpoch 4, Loss: 1.3814296809192819\nEpoch 5, Loss: 1.381266428593018\nEpoch 6, Loss: 1.3811124809857072\nEpoch 7, Loss: 1.3810116660092526\nEpoch 8, Loss: 1.380797694926061\nEpoch 9, Loss: 1.380719462117016\nEpoch 10, Loss: 1.3803917448182672\nEpoch 11, Loss: 1.3803929994846214\nEpoch 12, Loss: 1.380022744566088\nEpoch 13, Loss: 1.3797567562125195\nEpoch 14, Loss: 1.3795384451804034\nEpoch 15, Loss: 1.3791999542850188\nEpoch 16, Loss: 1.378830735254105\nEpoch 17, Loss: 1.378372946004758\nEpoch 18, Loss: 1.3780903519341772\nEpoch 19, Loss: 1.3777795888454978\nEpoch 20, Loss: 1.3773508195219368",
                "lineage": "701"
            }
        ],
        "8": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 32, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 64 * (input_size // 4)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True)\n        self.attention = nn.Linear(hidden_size, 1)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 128\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXX.py",
                "accuracy": 0.6602,
                "model_info": "Epoch 1, Loss: 1.1832760197906202\nEpoch 2, Loss: 1.0508080296132756\nEpoch 3, Loss: 0.9949582365280824\nEpoch 4, Loss: 0.9646001766467917\nEpoch 5, Loss: 0.9393603013849806\nEpoch 6, Loss: 0.9212460543004032\nEpoch 7, Loss: 0.902403289787614\nEpoch 8, Loss: 0.8877303506679461\nEpoch 9, Loss: 0.8751057290482795\nEpoch 10, Loss: 0.8635499121128828\nEpoch 11, Loss: 0.853214588658563\nEpoch 12, Loss: 0.8429037745885009\nEpoch 13, Loss: 0.8352517321191985\nEpoch 14, Loss: 0.8268963475336973\nEpoch 15, Loss: 0.8204967171753047\nEpoch 16, Loss: 0.8127595428306024\nEpoch 17, Loss: 0.8072052766993585\nEpoch 18, Loss: 0.800018632548979\nEpoch 19, Loss: 0.7952949402432788\nEpoch 20, Loss: 0.7903170880229994",
                "lineage": "801"
            }
        ],
        "9": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\n\nclass SimpleNNModel(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(SimpleNNModel, self).__init__()\n        self.fc1 = nn.Linear(input_size, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    input_size = train_data.shape[1]\n    num_classes = 4\n\n    model = SimpleNNModel(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXX.py",
                "accuracy": 0.539,
                "model_info": "Epoch 1, Loss: 1.290559005920001\nEpoch 2, Loss: 1.2037343129344371\nEpoch 3, Loss: 1.1630019520434383\nEpoch 4, Loss: 1.1383686558953647\nEpoch 5, Loss: 1.1228903696454804\nEpoch 6, Loss: 1.1110802025630557\nEpoch 7, Loss: 1.1017826772740975\nEpoch 8, Loss: 1.0931016512757517\nEpoch 9, Loss: 1.08606374720504\nEpoch 10, Loss: 1.0795840079756989\nEpoch 11, Loss: 1.0738666692456067\nEpoch 12, Loss: 1.0684329189103225\nEpoch 13, Loss: 1.0638271526815335\nEpoch 14, Loss: 1.0586865505496204\nEpoch 15, Loss: 1.0544784000550194\nEpoch 16, Loss: 1.0502724277562108\nEpoch 17, Loss: 1.0462945430214834\nEpoch 18, Loss: 1.0421704506051952\nEpoch 19, Loss: 1.0383824404628796\nEpoch 20, Loss: 1.0347409892356259",
                "lineage": "901"
            }
        ],
        "10": [],
        "11": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 128 * (input_size // 4)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    frozen_layers = [name for name, param in model.named_parameters() if not param.requires_grad]\n    trainable_layers = [name for name, param in model.named_parameters() if param.requires_grad]\n    \n    print(f\"Frozen Layers: {frozen_layers}\")\n    print(f\"Trainable Layers: {trainable_layers}\")\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXX.py",
                "accuracy": 0.6934,
                "model_info": "Epoch 1, Loss: 1.1954324217995846\nEpoch 2, Loss: 1.0565711080227154\nEpoch 3, Loss: 1.007573014257508\nEpoch 4, Loss: 0.9789163256332193\nEpoch 5, Loss: 0.9596835615081202\nEpoch 6, Loss: 0.9414763917392137\nEpoch 7, Loss: 0.9274469778771135\nEpoch 8, Loss: 0.9142165498632845\nEpoch 9, Loss: 0.9025212208277433\nEpoch 10, Loss: 0.8913410249918756\nEpoch 11, Loss: 0.8812864798044289\nEpoch 12, Loss: 0.8705532087474318\nEpoch 13, Loss: 0.8623827072343075\nEpoch 14, Loss: 0.8530234171653206\nEpoch 15, Loss: 0.8446825819372444\nEpoch 16, Loss: 0.8375901137112198\nEpoch 17, Loss: 0.8302773490061915\nEpoch 18, Loss: 0.8227117492919234\nEpoch 19, Loss: 0.8168261087787357\nEpoch 20, Loss: 0.8096697738898235\nEpoch 21, Loss: 0.8034733278737645\nEpoch 22, Loss: 0.7969610095024109\nEpoch 23, Loss: 0.7913000696908947\nEpoch 24, Loss: 0.7853843300905429\nEpoch 25, Loss: 0.7797935377384559\nEpoch 26, Loss: 0.7744789648650933\nEpoch 27, Loss: 0.7691771020816064\nEpoch 28, Loss: 0.7632062301297106\nEpoch 29, Loss: 0.7582626046466279\nEpoch 30, Loss: 0.7540263224700591\nEpoch 31, Loss: 0.7490516539498621\nEpoch 32, Loss: 0.7434778636796918\nEpoch 33, Loss: 0.738353948789915\nEpoch 34, Loss: 0.7343330455375495\nEpoch 35, Loss: 0.7300492013713449\nEpoch 36, Loss: 0.7254798657148218\nEpoch 37, Loss: 0.720720774839112\nEpoch 38, Loss: 0.7165476091763795\nEpoch 39, Loss: 0.7124953554825224\nEpoch 40, Loss: 0.7082546532954913\nFrozen Layers: []\nTrainable Layers: ['conv1.weight', 'conv1.bias', 'conv2.weight', 'conv2.bias', 'rnn.weight_ih_l0', 'rnn.weight_hh_l0', 'rnn.bias_ih_l0', 'rnn.bias_hh_l0', 'rnn.weight_ih_l0_reverse', 'rnn.weight_hh_l0_reverse', 'rnn.bias_ih_l0_reverse', 'rnn.bias_hh_l0_reverse', 'attention.weight', 'attention.bias', 'fc.weight', 'fc.bias']",
                "lineage": "1101"
            }
        ],
        "12": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXX.py",
                "accuracy": 0.7094,
                "model_info": "Epoch 1, Loss: 1.1916938301697801\nEpoch 2, Loss: 1.0385009232272113\nEpoch 3, Loss: 0.9925192673467171\nEpoch 4, Loss: 0.9626269035055632\nEpoch 5, Loss: 0.9409999774193352\nEpoch 6, Loss: 0.9223359330144358\nEpoch 7, Loss: 0.9079295663366849\nEpoch 8, Loss: 0.893593604756866\nEpoch 9, Loss: 0.8813902222034798\nEpoch 10, Loss: 0.8720784162147946\nEpoch 11, Loss: 0.8583075875512927\nEpoch 12, Loss: 0.848963022003247\nEpoch 13, Loss: 0.840691929700965\nEpoch 14, Loss: 0.8319161240290314\nEpoch 15, Loss: 0.8233264907765526\nEpoch 16, Loss: 0.8140211084753904\nEpoch 17, Loss: 0.806703263189422\nEpoch 18, Loss: 0.7994312124609261\nEpoch 19, Loss: 0.7922223736594597\nEpoch 20, Loss: 0.7852316499900451\nEpoch 21, Loss: 0.7788299836947684\nEpoch 22, Loss: 0.7718047877190896\nEpoch 23, Loss: 0.7651341193697045\nEpoch 24, Loss: 0.7599421741866333\nEpoch 25, Loss: 0.7533169304111869\nEpoch 26, Loss: 0.7464594695709946\nEpoch 27, Loss: 0.7416557772603465\nEpoch 28, Loss: 0.73598633343336\nEpoch 29, Loss: 0.7316228184498661\nEpoch 30, Loss: 0.7241137767936355\nEpoch 31, Loss: 0.720015510602098\nEpoch 32, Loss: 0.7147350424539562\nEpoch 33, Loss: 0.7102677904484139\nEpoch 34, Loss: 0.7051813425120832\nEpoch 35, Loss: 0.7003153826819729\nEpoch 36, Loss: 0.6947502136916894\nEpoch 37, Loss: 0.6910860475560296\nEpoch 38, Loss: 0.6866921749316341\nEpoch 39, Loss: 0.6819205793217825\nEpoch 40, Loss: 0.6773751485599437",
                "lineage": "1201"
            }
        ],
        "13": [],
        "14": [],
        "15": [],
        "16": [],
        "17": [],
        "18": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.pipeline import make_pipeline\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXX.py",
                "accuracy": 0.7113,
                "model_info": "Epoch 1, Loss: 1.1916963150313629\nEpoch 2, Loss: 1.0383927203185728\nEpoch 3, Loss: 0.9924728659887918\nEpoch 4, Loss: 0.9620088647743562\nEpoch 5, Loss: 0.9405464225675689\nEpoch 6, Loss: 0.9221571998495516\nEpoch 7, Loss: 0.907715702354336\nEpoch 8, Loss: 0.8934190600481234\nEpoch 9, Loss: 0.8810030406130024\nEpoch 10, Loss: 0.8710568238357207\nEpoch 11, Loss: 0.8586271958936885\nEpoch 12, Loss: 0.8488984645671441\nEpoch 13, Loss: 0.8406156193958363\nEpoch 14, Loss: 0.8311804204664395\nEpoch 15, Loss: 0.8230095830622652\nEpoch 16, Loss: 0.8138824822577772\nEpoch 17, Loss: 0.8064579297851006\nEpoch 18, Loss: 0.7989985512680375\nEpoch 19, Loss: 0.7918116481198917\nEpoch 20, Loss: 0.7846165251365779\nEpoch 21, Loss: 0.7785996240983769\nEpoch 22, Loss: 0.7710364067394307\nEpoch 23, Loss: 0.7646845822828516\nEpoch 24, Loss: 0.758731421376373\nEpoch 25, Loss: 0.7525082336963939\nEpoch 26, Loss: 0.7462849234894003\nEpoch 27, Loss: 0.7404108459340862\nEpoch 28, Loss: 0.7350830640536581\nEpoch 29, Loss: 0.7309049389641482\nEpoch 30, Loss: 0.7238366895582306\nEpoch 31, Loss: 0.7192108239871298\nEpoch 32, Loss: 0.7141525080702813\nEpoch 33, Loss: 0.7095600399769657\nEpoch 34, Loss: 0.70380692518604\nEpoch 35, Loss: 0.6991455751737569\nEpoch 36, Loss: 0.6940399725240389\nEpoch 37, Loss: 0.6898401105014925\nEpoch 38, Loss: 0.6864215786534856\nEpoch 39, Loss: 0.6815596044406781\nEpoch 40, Loss: 0.6768454467724014",
                "lineage": "1801"
            }
        ],
        "19": [],
        "20": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.pipeline import make_pipeline\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.metrics import f1_score\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss(weight=torch.tensor([1.0, 1.0, 1.0, 1.0])).to(device)\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXX.py",
                "accuracy": 0.7093,
                "model_info": "Epoch 1, Loss: 1.1916995231569842\nEpoch 2, Loss: 1.038421516340662\nEpoch 3, Loss: 0.9919599315255251\nEpoch 4, Loss: 0.9616476320259402\nEpoch 5, Loss: 0.9406284709351992\nEpoch 6, Loss: 0.9220418909460936\nEpoch 7, Loss: 0.9076657226584466\nEpoch 8, Loss: 0.8937239715554206\nEpoch 9, Loss: 0.8810834019746981\nEpoch 10, Loss: 0.8714300820786298\nEpoch 11, Loss: 0.8584878078577843\nEpoch 12, Loss: 0.8490768803744765\nEpoch 13, Loss: 0.8407977178778621\nEpoch 14, Loss: 0.8322103898722013\nEpoch 15, Loss: 0.8229029407428002\nEpoch 16, Loss: 0.8143655730987007\nEpoch 17, Loss: 0.8067108378986937\nEpoch 18, Loss: 0.7995281562695348\nEpoch 19, Loss: 0.7921882743112414\nEpoch 20, Loss: 0.7849629767339198\nEpoch 21, Loss: 0.7785498940326888\nEpoch 22, Loss: 0.7718397772472331\nEpoch 23, Loss: 0.7640835630230163\nEpoch 24, Loss: 0.7583599083711914\nEpoch 25, Loss: 0.7525675150345932\nEpoch 26, Loss: 0.7458148316092317\nEpoch 27, Loss: 0.7407625089908974\nEpoch 28, Loss: 0.7350671887397766\nEpoch 29, Loss: 0.7307161893588339\nEpoch 30, Loss: 0.7234364055855032\nEpoch 31, Loss: 0.7188556685099904\nEpoch 32, Loss: 0.7133274315186059\nEpoch 33, Loss: 0.7095543948107627\nEpoch 34, Loss: 0.7034778569801755\nEpoch 35, Loss: 0.698720897914352\nEpoch 36, Loss: 0.6934331534233752\nEpoch 37, Loss: 0.6895455555586348\nEpoch 38, Loss: 0.6854721423302869\nEpoch 39, Loss: 0.6809000065139068\nEpoch 40, Loss: 0.6754360546763708",
                "lineage": "2001"
            }
        ],
        "21": [],
        "22": [],
        "23": [],
        "24": [],
        "25": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\n\nclass TemporalConvNet(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(TemporalConvNet, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.fc = nn.Linear(128 * (input_size // 8), num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1)\n        out = self.fc(x)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    num_classes = 4\n\n    model = TemporalConvNet(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXX.py",
                "accuracy": 0.5956,
                "model_info": "Epoch 1, Loss: 1.2675651286705443\nEpoch 2, Loss: 1.1567390276237093\nEpoch 3, Loss: 1.1066989852919917\nEpoch 4, Loss: 1.0824437406836454\nEpoch 5, Loss: 1.0648409320388326\nEpoch 6, Loss: 1.0505309095767088\nEpoch 7, Loss: 1.039016898442596\nEpoch 8, Loss: 1.0298260512141486\nEpoch 9, Loss: 1.0222175790572579\nEpoch 10, Loss: 1.015703157362691\nEpoch 11, Loss: 1.0100808355263693\nEpoch 12, Loss: 1.0052083350875327\nEpoch 13, Loss: 0.9995331819135259\nEpoch 14, Loss: 0.9953943142048914\nEpoch 15, Loss: 0.9909379707645775\nEpoch 16, Loss: 0.9872836730301723\nEpoch 17, Loss: 0.9831735707976768\nEpoch 18, Loss: 0.9799344286808812\nEpoch 19, Loss: 0.976317650182691\nEpoch 20, Loss: 0.9724583693291999\nEpoch 21, Loss: 0.9700840664687861\nEpoch 22, Loss: 0.9670551273964646\nEpoch 23, Loss: 0.9639043706163564\nEpoch 24, Loss: 0.9609286028913253\nEpoch 25, Loss: 0.9587438532120893\nEpoch 26, Loss: 0.9558770023929867\nEpoch 27, Loss: 0.9539941444049184\nEpoch 28, Loss: 0.9520067235100979\nEpoch 29, Loss: 0.9494597296339536\nEpoch 30, Loss: 0.9473208628323165\nEpoch 31, Loss: 0.9459686190061515\nEpoch 32, Loss: 0.9433179709366782\nEpoch 33, Loss: 0.9425357331927587\nEpoch 34, Loss: 0.9405209347748711\nEpoch 35, Loss: 0.9387844156852839\nEpoch 36, Loss: 0.937323586611281\nEpoch 37, Loss: 0.9352924956469985\nEpoch 38, Loss: 0.9344748631548744\nEpoch 39, Loss: 0.9328162420734105\nEpoch 40, Loss: 0.9315220564889817",
                "lineage": "2501"
            }
        ],
        "26": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.pipeline import make_pipeline\nfrom sklearn.preprocessing import StandardScaler\nfrom scipy.ndimage import gaussian_filter1d\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef apply_smoothing(data):\n    return gaussian_filter1d(data, sigma=2, axis=1)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = apply_smoothing(time_frequency_features(train_data))\n    val_data = apply_smoothing(time_frequency_features(val_data))\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXX.py",
                "accuracy": 0.6629,
                "model_info": "Epoch 1, Loss: 1.2285871517177736\nEpoch 2, Loss: 1.130100948110423\nEpoch 3, Loss: 1.076428684643729\nEpoch 4, Loss: 1.042924696676104\nEpoch 5, Loss: 1.0205440221500945\nEpoch 6, Loss: 1.0014353132522495\nEpoch 7, Loss: 0.9852155857717694\nEpoch 8, Loss: 0.9689354476681598\nEpoch 9, Loss: 0.9529169778448606\nEpoch 10, Loss: 0.9405442006070874\nEpoch 11, Loss: 0.9268299446453746\nEpoch 12, Loss: 0.9164238848979094\nEpoch 13, Loss: 0.9071908553136288\nEpoch 14, Loss: 0.8990644279459845\nEpoch 15, Loss: 0.8903632049597157\nEpoch 16, Loss: 0.8821779045628495\nEpoch 17, Loss: 0.8762096855324656\nEpoch 18, Loss: 0.86922138609035\nEpoch 19, Loss: 0.8631582923676826\nEpoch 20, Loss: 0.8563806103424467\nEpoch 21, Loss: 0.8511932597508128\nEpoch 22, Loss: 0.8446468688018491\nEpoch 23, Loss: 0.8398931668266911\nEpoch 24, Loss: 0.8350252347807051\nEpoch 25, Loss: 0.8297930523438555\nEpoch 26, Loss: 0.8247861206645929\nEpoch 27, Loss: 0.8197387774937899\nEpoch 28, Loss: 0.8157194701815292\nEpoch 29, Loss: 0.8121571299439428\nEpoch 30, Loss: 0.8061085925678831\nEpoch 31, Loss: 0.8024945951240305\nEpoch 32, Loss: 0.7981160181268849\nEpoch 33, Loss: 0.7942783228495299\nEpoch 34, Loss: 0.7912737449162752\nEpoch 35, Loss: 0.7864111950209869\nEpoch 36, Loss: 0.7818350132962335\nEpoch 37, Loss: 0.7798925171429274\nEpoch 38, Loss: 0.7764490739855336\nEpoch 39, Loss: 0.7723854972396382\nEpoch 40, Loss: 0.7687105170367089",
                "lineage": "2601"
            }
        ],
        "27": [],
        "28": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXX.py",
                "accuracy": 0.8037,
                "model_info": "Epoch 1, Loss: 0.9747175700147412\nEpoch 2, Loss: 0.865118386191736\nEpoch 3, Loss: 0.8114440248932353\nEpoch 4, Loss: 0.768856677578873\nEpoch 5, Loss: 0.7345292138046586\nEpoch 6, Loss: 0.702361360621315\nEpoch 7, Loss: 0.6751605636098792\nEpoch 8, Loss: 0.6503642461121425\nEpoch 9, Loss: 0.6263316239367978\nEpoch 10, Loss: 0.6036642007315227\nEpoch 11, Loss: 0.5814906868962089\nEpoch 12, Loss: 0.5616934906383851\nEpoch 13, Loss: 0.5431829326555505\nEpoch 14, Loss: 0.522138619434353\nEpoch 15, Loss: 0.5042176913620185\nEpoch 16, Loss: 0.4851944622746356\nEpoch 17, Loss: 0.4681521130157295\nEpoch 18, Loss: 0.4514673551305013\nEpoch 19, Loss: 0.43449606438973587\nEpoch 20, Loss: 0.4193126520932064\nEpoch 21, Loss: 0.40237821063702484\nEpoch 22, Loss: 0.38694692367326733\nEpoch 23, Loss: 0.37213442999433416\nEpoch 24, Loss: 0.3575305660718233\nEpoch 25, Loss: 0.34319416603749175\nEpoch 26, Loss: 0.3293753828059689\nEpoch 27, Loss: 0.3161814186486081\nEpoch 28, Loss: 0.3032990755538336\nEpoch 29, Loss: 0.290774537339778\nEpoch 30, Loss: 0.27798415099819423\nEpoch 31, Loss: 0.2667821029383482\nEpoch 32, Loss: 0.2548765164876854\nEpoch 33, Loss: 0.2438757734484041\nEpoch 34, Loss: 0.23417316417204442\nEpoch 35, Loss: 0.2242040147650951\nEpoch 36, Loss: 0.21257653168890617\nEpoch 37, Loss: 0.20322578550529113\nEpoch 38, Loss: 0.1954771338062872\nEpoch 39, Loss: 0.18632489431384885\nEpoch 40, Loss: 0.17874552203689106",
                "lineage": "2801"
            }
        ],
        "29": [],
        "30": [],
        "31": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass SimpleNNModel(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(SimpleNNModel, self).__init__()\n        self.fc1 = nn.Linear(input_size, 512)\n        self.fc2 = nn.Linear(512, 256)\n        self.fc3 = nn.Linear(256, num_classes)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.fc1(x))\n        x = self.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    input_size = train_data.shape[1]\n    num_classes = 4\n\n    model = SimpleNNModel(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6795,
                "model_info": "Epoch 1, Loss: 1.1176421055409365\nEpoch 2, Loss: 0.9992792305470428\nEpoch 3, Loss: 0.9585191798530476\nEpoch 4, Loss: 0.9300581244269168\nEpoch 5, Loss: 0.907248192121795\nEpoch 6, Loss: 0.887955620398677\nEpoch 7, Loss: 0.8704711940146682\nEpoch 8, Loss: 0.8551172983623512\nEpoch 9, Loss: 0.8419449034213105\nEpoch 10, Loss: 0.8294533730239648\nEpoch 11, Loss: 0.8192433070770381\nEpoch 12, Loss: 0.8082044598237109\nEpoch 13, Loss: 0.7981657922382318\nEpoch 14, Loss: 0.7904822916764902\nEpoch 15, Loss: 0.7809108694775777\nEpoch 16, Loss: 0.7735971398866108\nEpoch 17, Loss: 0.766222844540272\nEpoch 18, Loss: 0.757889489637913\nEpoch 19, Loss: 0.7518782274736782\nEpoch 20, Loss: 0.7454047753348689\nEpoch 21, Loss: 0.7380098087316282\nEpoch 22, Loss: 0.7321533945151345\nEpoch 23, Loss: 0.7272195649009748\nEpoch 24, Loss: 0.7215832009654127\nEpoch 25, Loss: 0.7156901039226041\nEpoch 26, Loss: 0.7102619834001143\nEpoch 27, Loss: 0.7059202993899985\nEpoch 28, Loss: 0.7011768305370308\nEpoch 29, Loss: 0.6946660711531905\nEpoch 30, Loss: 0.6905172016478774\nEpoch 31, Loss: 0.6873720315733707\nEpoch 32, Loss: 0.6820991284101343\nEpoch 33, Loss: 0.6777157794948732\nEpoch 34, Loss: 0.6731935780702764\nEpoch 35, Loss: 0.6691854661348456\nEpoch 36, Loss: 0.6655264554005438\nEpoch 37, Loss: 0.6629239228087515\nEpoch 38, Loss: 0.6568500994491944\nEpoch 39, Loss: 0.6532227820260968\nEpoch 40, Loss: 0.6508732974643671",
                "lineage": "3101"
            }
        ],
        "32": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    print(f\"Validation Predictions Count: {np.bincount(val_preds.cpu().numpy())}\")\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.7999,
                "model_info": "Epoch 1, Loss: 0.974724053306909\nEpoch 2, Loss: 0.8652829260148838\nEpoch 3, Loss: 0.8117345348429542\nEpoch 4, Loss: 0.7688893259372455\nEpoch 5, Loss: 0.734307972346066\nEpoch 6, Loss: 0.7021682535846951\nEpoch 7, Loss: 0.674779724251057\nEpoch 8, Loss: 0.6500987849857894\nEpoch 9, Loss: 0.625990140575365\nEpoch 10, Loss: 0.6031542746439548\nEpoch 11, Loss: 0.5815072015013667\nEpoch 12, Loss: 0.5618025613037043\nEpoch 13, Loss: 0.5423605069661095\nEpoch 14, Loss: 0.5217280226568343\nEpoch 15, Loss: 0.504163005130076\nEpoch 16, Loss: 0.4847373570567587\nEpoch 17, Loss: 0.4681188386369804\nEpoch 18, Loss: 0.4514792010674321\nEpoch 19, Loss: 0.4345360621380943\nEpoch 20, Loss: 0.41891062568565707\nEpoch 21, Loss: 0.40224830511664245\nEpoch 22, Loss: 0.38643575418247145\nEpoch 23, Loss: 0.3715862941261445\nEpoch 24, Loss: 0.3563819087741471\nEpoch 25, Loss: 0.34234376769377034\nEpoch 26, Loss: 0.32848219278906676\nEpoch 27, Loss: 0.31496948959044896\nEpoch 28, Loss: 0.3028557753608689\nEpoch 29, Loss: 0.2899990105812014\nEpoch 30, Loss: 0.2771046943891071\nEpoch 31, Loss: 0.26563079460683114\nEpoch 32, Loss: 0.2548507816102821\nEpoch 33, Loss: 0.24385652841281524\nEpoch 34, Loss: 0.23330820055817916\nEpoch 35, Loss: 0.2238030750268709\nEpoch 36, Loss: 0.21302153796472384\nEpoch 37, Loss: 0.20360873459396803\nEpoch 38, Loss: 0.19440167721882892\nEpoch 39, Loss: 0.1854167050054572\nEpoch 40, Loss: 0.17778606346724357\nValidation Predictions Count: [7841 7400 7541 6823]",
                "lineage": "3201"
            }
        ],
        "33": [],
        "34": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    print(\"Hyper-parameters: Learning Rate: 0.0001, Hidden Size: 256, Batch Size: 512\")\n    \n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8009,
                "model_info": "Hyper-parameters: Learning Rate: 0.0001, Hidden Size: 256, Batch Size: 512\nEpoch 1, Loss: 0.9747492510846847\nEpoch 2, Loss: 0.865134458509837\nEpoch 3, Loss: 0.8115446408513411\nEpoch 4, Loss: 0.7687869403732944\nEpoch 5, Loss: 0.7344624103831696\nEpoch 6, Loss: 0.7021609033366769\nEpoch 7, Loss: 0.6745789532698048\nEpoch 8, Loss: 0.6497186948607842\nEpoch 9, Loss: 0.6260877743563588\nEpoch 10, Loss: 0.6031947833791576\nEpoch 11, Loss: 0.5815111841441574\nEpoch 12, Loss: 0.561898360668812\nEpoch 13, Loss: 0.5431025989796974\nEpoch 14, Loss: 0.5219676756012234\nEpoch 15, Loss: 0.5046368388891678\nEpoch 16, Loss: 0.4859928537925237\nEpoch 17, Loss: 0.4692239674977286\nEpoch 18, Loss: 0.4523231327076105\nEpoch 19, Loss: 0.43422280140435626\nEpoch 20, Loss: 0.4192593322491234\nEpoch 21, Loss: 0.40276441961927284\nEpoch 22, Loss: 0.38640959134715075\nEpoch 23, Loss: 0.3714042772715929\nEpoch 24, Loss: 0.357591909547685\nEpoch 25, Loss: 0.34334005263853895\nEpoch 26, Loss: 0.3293526891096997\nEpoch 27, Loss: 0.31559567971444635\nEpoch 28, Loss: 0.3037696154698758\nEpoch 29, Loss: 0.2909872177809534\nEpoch 30, Loss: 0.2787267472487722\nEpoch 31, Loss: 0.2670031487941742\nEpoch 32, Loss: 0.25560785841461336\nEpoch 33, Loss: 0.2445685357827829\nEpoch 34, Loss: 0.23507525799027332\nEpoch 35, Loss: 0.22471822063204422\nEpoch 36, Loss: 0.21417094195072114\nEpoch 37, Loss: 0.20507907750167223\nEpoch 38, Loss: 0.19581409370716155\nEpoch 39, Loss: 0.187345981454895\nEpoch 40, Loss: 0.17989547376211681",
                "lineage": "3401"
            }
        ],
        "35": [],
        "36": [],
        "37": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass WaveletTransformModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(WaveletTransformModel, self).__init__()\n        self.fc1 = nn.Linear(input_size, hidden_size)\n        self.fc2 = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    input_size = train_data.shape[1]\n    hidden_size = 256\n    num_classes = 4\n\n    model = WaveletTransformModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6245,
                "model_info": "Epoch 1, Loss: 1.177252717988276\nEpoch 2, Loss: 1.078993737239984\nEpoch 3, Loss: 1.0440355319665626\nEpoch 4, Loss: 1.0198067689811428\nEpoch 5, Loss: 1.000536416748435\nEpoch 6, Loss: 0.9851574794802236\nEpoch 7, Loss: 0.9723984893132538\nEpoch 8, Loss: 0.9614813729348429\nEpoch 9, Loss: 0.9522683046143252\nEpoch 10, Loss: 0.9440504869664241\nEpoch 11, Loss: 0.9364014605414158\nEpoch 12, Loss: 0.929579615020935\nEpoch 13, Loss: 0.9234525635695503\nEpoch 14, Loss: 0.917528688793219\nEpoch 15, Loss: 0.9117407627160627\nEpoch 16, Loss: 0.906531824489015\nEpoch 17, Loss: 0.9016651341873945\nEpoch 18, Loss: 0.8968521680346835\nEpoch 19, Loss: 0.8922836552883522\nEpoch 20, Loss: 0.8880005901010847\nEpoch 21, Loss: 0.8838116774861048\nEpoch 22, Loss: 0.8802113091419388\nEpoch 23, Loss: 0.876333402809392\nEpoch 24, Loss: 0.8729180366430082\nEpoch 25, Loss: 0.8693697295811263\nEpoch 26, Loss: 0.8663480137680405\nEpoch 27, Loss: 0.8625789011279819\nEpoch 28, Loss: 0.8594436098655217\nEpoch 29, Loss: 0.8566293607746571\nEpoch 30, Loss: 0.8534334767574083\nEpoch 31, Loss: 0.8507693780589699\nEpoch 32, Loss: 0.8480125467745219\nEpoch 33, Loss: 0.8449329336865621\nEpoch 34, Loss: 0.8426099388704648\nEpoch 35, Loss: 0.8398453173390277\nEpoch 36, Loss: 0.8375742496089605\nEpoch 37, Loss: 0.8347838682313798\nEpoch 38, Loss: 0.8326393966482606\nEpoch 39, Loss: 0.8306070249277433\nEpoch 40, Loss: 0.8283168750166207",
                "lineage": "3701"
            }
        ],
        "38": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    class_counts = np.bincount(train_label.cpu().numpy())\n    class_weights = 1.0 / class_counts\n    sample_weights = class_weights[train_label.cpu().numpy()]\n    sampler = WeightedRandomSampler(sample_weights, len(sample_weights), replacement=True)\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, sampler=sampler)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.7993,
                "model_info": "Epoch 1, Loss: 0.9522012655199603\nEpoch 2, Loss: 0.8419098039506264\nEpoch 3, Loss: 0.7876922614057325\nEpoch 4, Loss: 0.7406667199793795\nEpoch 5, Loss: 0.7079245874840558\nEpoch 6, Loss: 0.6757296680717688\nEpoch 7, Loss: 0.6474144032042681\nEpoch 8, Loss: 0.6284770208219649\nEpoch 9, Loss: 0.6014765043977126\nEpoch 10, Loss: 0.5797723133024008\nEpoch 11, Loss: 0.5564409528721317\nEpoch 12, Loss: 0.53831438871812\nEpoch 13, Loss: 0.5205530654674757\nEpoch 14, Loss: 0.5003596818264067\nEpoch 15, Loss: 0.48421568530763637\nEpoch 16, Loss: 0.4648432540001201\nEpoch 17, Loss: 0.44969396913806675\nEpoch 18, Loss: 0.4348179106520142\nEpoch 19, Loss: 0.4189007326302739\nEpoch 20, Loss: 0.4038573570992805\nEpoch 21, Loss: 0.3879091115007016\nEpoch 22, Loss: 0.37299600260729066\nEpoch 23, Loss: 0.36026615596549755\nEpoch 24, Loss: 0.34648117388736266\nEpoch 25, Loss: 0.33458841682166834\nEpoch 26, Loss: 0.3214397918354298\nEpoch 27, Loss: 0.30884835718918213\nEpoch 28, Loss: 0.2950092515766964\nEpoch 29, Loss: 0.2822578321148475\nEpoch 30, Loss: 0.27540008677974087\nEpoch 31, Loss: 0.26277593561875384\nEpoch 32, Loss: 0.25465285563537576\nEpoch 33, Loss: 0.24495027481708784\nEpoch 34, Loss: 0.235529225984599\nEpoch 35, Loss: 0.22535188318786145\nEpoch 36, Loss: 0.21536808459520798\nEpoch 37, Loss: 0.20774330836568822\nEpoch 38, Loss: 0.1993987796517114\nEpoch 39, Loss: 0.19076222152719113\nEpoch 40, Loss: 0.18345769906627468",
                "lineage": "3801"
            }
        ],
        "39": [],
        "40": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    print(f\"Train data distribution before scaling: mean={np.mean(train_data)}, std={np.std(train_data)}, min={np.min(train_data)}, max={np.max(train_data)}\")\n    print(f\"Validation data distribution before scaling: mean={np.mean(val_data)}, std={np.std(val_data)}, min={np.min(val_data)}, max={np.max(val_data)}\")\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8009,
                "model_info": "Train data distribution before scaling: mean=-1.044166753061404e-09, std=0.9999999403953552, min=-0.8197185397148132, max=285.8739013671875\nValidation data distribution before scaling: mean=0.0017377687618136406, std=0.9903039932250977, min=-0.8197184801101685, max=283.1389465332031\nEpoch 1, Loss: 0.9747249909646223\nEpoch 2, Loss: 0.865180133514807\nEpoch 3, Loss: 0.8113710819645258\nEpoch 4, Loss: 0.7686605941997608\nEpoch 5, Loss: 0.7341648402003547\nEpoch 6, Loss: 0.702278887127274\nEpoch 7, Loss: 0.6746219299347525\nEpoch 8, Loss: 0.6499559123090499\nEpoch 9, Loss: 0.6255861296534767\nEpoch 10, Loss: 0.602122438274281\nEpoch 11, Loss: 0.5802844756509887\nEpoch 12, Loss: 0.560514198269359\nEpoch 13, Loss: 0.5413372459429926\nEpoch 14, Loss: 0.5201948377770335\nEpoch 15, Loss: 0.5018966440504663\nEpoch 16, Loss: 0.48319240392055257\nEpoch 17, Loss: 0.4661819191788986\nEpoch 18, Loss: 0.450382133820693\nEpoch 19, Loss: 0.4325948528616534\nEpoch 20, Loss: 0.41718518550931377\nEpoch 21, Loss: 0.4004850354968014\nEpoch 22, Loss: 0.3849388917554134\nEpoch 23, Loss: 0.3697461323408614\nEpoch 24, Loss: 0.35610260724334936\nEpoch 25, Loss: 0.3413464791372047\nEpoch 26, Loss: 0.32644373950711136\nEpoch 27, Loss: 0.31443857317236246\nEpoch 28, Loss: 0.3016238949063186\nEpoch 29, Loss: 0.2891858765522944\nEpoch 30, Loss: 0.27572699766355835\nEpoch 31, Loss: 0.26473524548728267\nEpoch 32, Loss: 0.2539701415744258\nEpoch 33, Loss: 0.24276524908025526\nEpoch 34, Loss: 0.23274458029563047\nEpoch 35, Loss: 0.22251390386909076\nEpoch 36, Loss: 0.2129503143611659\nEpoch 37, Loss: 0.20239408368570105\nEpoch 38, Loss: 0.19400582987378975\nEpoch 39, Loss: 0.18580104676638362\nEpoch 40, Loss: 0.17799206927504513",
                "lineage": "4001"
            }
        ],
        "41": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.utils import class_weight\nfrom sklearn.metrics import confusion_matrix\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n\n    class_weights = class_weight.compute_class_weight('balanced', classes=np.unique(train_label.cpu().numpy()), y=train_label.cpu().numpy())\n    class_weights = torch.tensor(class_weights, dtype=torch.float32).to(device)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8007,
                "model_info": "Epoch 1, Loss: 0.9547817298638386\nEpoch 2, Loss: 0.8441800674184041\nEpoch 3, Loss: 0.7893773021029877\nEpoch 4, Loss: 0.7469117474418684\nEpoch 5, Loss: 0.7126350021865684\nEpoch 6, Loss: 0.6813079425332185\nEpoch 7, Loss: 0.6547083839802733\nEpoch 8, Loss: 0.6303131245148159\nEpoch 9, Loss: 0.6076049980870135\nEpoch 10, Loss: 0.5854182384636489\nEpoch 11, Loss: 0.564472578423037\nEpoch 12, Loss: 0.5460354135498662\nEpoch 13, Loss: 0.528201230656849\nEpoch 14, Loss: 0.5075993394325424\nEpoch 15, Loss: 0.49058775606631316\nEpoch 16, Loss: 0.4720997709687978\nEpoch 17, Loss: 0.45663609511563963\nEpoch 18, Loss: 0.4405283407949898\nEpoch 19, Loss: 0.42446752667655874\nEpoch 20, Loss: 0.4098775096223359\nEpoch 21, Loss: 0.39393803442966\nEpoch 22, Loss: 0.37863625108394877\nEpoch 23, Loss: 0.3643186251970719\nEpoch 24, Loss: 0.3513804063229552\nEpoch 25, Loss: 0.33726467555406686\nEpoch 26, Loss: 0.32342852291699337\nEpoch 27, Loss: 0.310992226176207\nEpoch 28, Loss: 0.2993018946354769\nEpoch 29, Loss: 0.2867879912743413\nEpoch 30, Loss: 0.2757809340038592\nEpoch 31, Loss: 0.26368210663493447\nEpoch 32, Loss: 0.25282467026513733\nEpoch 33, Loss: 0.24267874131847939\nEpoch 34, Loss: 0.23217845083198255\nEpoch 35, Loss: 0.22264619434749325\nEpoch 36, Loss: 0.2127962303767964\nEpoch 37, Loss: 0.2034024857056118\nEpoch 38, Loss: 0.19506548668281132\nEpoch 39, Loss: 0.1875597988746903\nEpoch 40, Loss: 0.17918824546053405",
                "lineage": "4101"
            }
        ],
        "42": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    print(\"Model Assumptions: No multicollinearity, input features normalized.\")\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8036,
                "model_info": "Epoch 1, Loss: 0.9747206424568527\nEpoch 2, Loss: 0.8651701484211576\nEpoch 3, Loss: 0.8117526879466198\nEpoch 4, Loss: 0.7690454562428817\nEpoch 5, Loss: 0.7348690855525963\nEpoch 6, Loss: 0.703046522648458\nEpoch 7, Loss: 0.6755802017027037\nEpoch 8, Loss: 0.6508419092694537\nEpoch 9, Loss: 0.6263918314922794\nEpoch 10, Loss: 0.6034855612637672\nEpoch 11, Loss: 0.5823466098239921\nEpoch 12, Loss: 0.5620345345156664\nEpoch 13, Loss: 0.5432283062051674\nEpoch 14, Loss: 0.5224089768363052\nEpoch 15, Loss: 0.5050660550823138\nEpoch 16, Loss: 0.4862494869104045\nEpoch 17, Loss: 0.4696112969557749\nEpoch 18, Loss: 0.45296872663177595\nEpoch 19, Loss: 0.43578642412247903\nEpoch 20, Loss: 0.4200954958367485\nEpoch 21, Loss: 0.4039828329992386\nEpoch 22, Loss: 0.38851701612664735\nEpoch 23, Loss: 0.3731968756943884\nEpoch 24, Loss: 0.35924183664532405\nEpoch 25, Loss: 0.3455119943550132\nEpoch 26, Loss: 0.3304308346846282\nEpoch 27, Loss: 0.31762929784130456\nEpoch 28, Loss: 0.3053922053433654\nEpoch 29, Loss: 0.29228094560514256\nEpoch 30, Loss: 0.27988567001645714\nEpoch 31, Loss: 0.26777557756987735\nEpoch 32, Loss: 0.2566801506360982\nEpoch 33, Loss: 0.24556974051323596\nEpoch 34, Loss: 0.23577385751848715\nEpoch 35, Loss: 0.2247344372997815\nEpoch 36, Loss: 0.21443619440361542\nEpoch 37, Loss: 0.20493920519232978\nEpoch 38, Loss: 0.19621605999524672\nEpoch 39, Loss: 0.1869600667491298\nEpoch 40, Loss: 0.17999650286278204\nModel Assumptions: No multicollinearity, input features normalized.",
                "lineage": "4201"
            }
        ],
        "43": [],
        "44": [],
        "45": [],
        "46": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    total_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    print(f\"Total trainable parameters: {total_params}\")\n\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8023,
                "model_info": "Total trainable parameters: 17398917\nEpoch 1, Loss: 0.9746677099857587\nEpoch 2, Loss: 0.8650449601336313\nEpoch 3, Loss: 0.811468491627479\nEpoch 4, Loss: 0.7687317517348305\nEpoch 5, Loss: 0.7342553472793492\nEpoch 6, Loss: 0.7024138932493507\nEpoch 7, Loss: 0.6745902246110956\nEpoch 8, Loss: 0.6496578570519665\nEpoch 9, Loss: 0.6261975228672064\nEpoch 10, Loss: 0.6026457214080898\nEpoch 11, Loss: 0.5808339011417469\nEpoch 12, Loss: 0.5616004101488732\nEpoch 13, Loss: 0.5423122013484677\nEpoch 14, Loss: 0.5224795187617904\nEpoch 15, Loss: 0.5033832367459552\nEpoch 16, Loss: 0.48502010558937425\nEpoch 17, Loss: 0.46833666587058964\nEpoch 18, Loss: 0.45198515927036526\nEpoch 19, Loss: 0.4341237333937478\nEpoch 20, Loss: 0.4193907213645796\nEpoch 21, Loss: 0.4029801077783222\nEpoch 22, Loss: 0.38608958653662345\nEpoch 23, Loss: 0.3722182335528668\nEpoch 24, Loss: 0.35826911481236773\nEpoch 25, Loss: 0.34389060283805495\nEpoch 26, Loss: 0.32939924130970594\nEpoch 27, Loss: 0.3163371076968261\nEpoch 28, Loss: 0.30441640203035725\nEpoch 29, Loss: 0.29058743183878244\nEpoch 30, Loss: 0.2780727098290156\nEpoch 31, Loss: 0.2667487292566592\nEpoch 32, Loss: 0.25528419080714115\nEpoch 33, Loss: 0.24440123192293858\nEpoch 34, Loss: 0.2339518467489909\nEpoch 35, Loss: 0.224398987707387\nEpoch 36, Loss: 0.21389265747422678\nEpoch 37, Loss: 0.20409880149501758\nEpoch 38, Loss: 0.1949205410286012\nEpoch 39, Loss: 0.1875581437303558\nEpoch 40, Loss: 0.17972495914535194",
                "lineage": "4601"
            }
        ],
        "47": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.utils.class_weight import compute_class_weight\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    \n    class_weights = compute_class_weight('balanced', classes=np.unique(train_label.cpu().numpy()), y=train_label.cpu().numpy())\n    class_weights = torch.tensor(class_weights, dtype=torch.float32).to(device)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8014,
                "model_info": "Epoch 1, Loss: 0.9547315024826211\nEpoch 2, Loss: 0.8441485069306021\nEpoch 3, Loss: 0.7893995283432519\nEpoch 4, Loss: 0.7466992144392457\nEpoch 5, Loss: 0.7128998517074878\nEpoch 6, Loss: 0.6814279872030305\nEpoch 7, Loss: 0.6548771964611338\nEpoch 8, Loss: 0.6309064240007163\nEpoch 9, Loss: 0.6079644982965803\nEpoch 10, Loss: 0.585408712531692\nEpoch 11, Loss: 0.5644691496687063\nEpoch 12, Loss: 0.54595412150912\nEpoch 13, Loss: 0.5273203485414758\nEpoch 14, Loss: 0.507178952449114\nEpoch 15, Loss: 0.49003432745439307\nEpoch 16, Loss: 0.4717391861491835\nEpoch 17, Loss: 0.45559960998408855\nEpoch 18, Loss: 0.43937286030994493\nEpoch 19, Loss: 0.42264968145374143\nEpoch 20, Loss: 0.4083584854790437\nEpoch 21, Loss: 0.3921922790798253\nEpoch 22, Loss: 0.37710160983729957\nEpoch 23, Loss: 0.3629265062639672\nEpoch 24, Loss: 0.3487351569928043\nEpoch 25, Loss: 0.3345933856868012\nEpoch 26, Loss: 0.32158675520982943\nEpoch 27, Loss: 0.30836658397128164\nEpoch 28, Loss: 0.29701281454764494\nEpoch 29, Loss: 0.28528150132430036\nEpoch 30, Loss: 0.27268425691265064\nEpoch 31, Loss: 0.260634818598771\nEpoch 32, Loss: 0.25062637265607174\nEpoch 33, Loss: 0.24054832956726857\nEpoch 34, Loss: 0.23004944671138464\nEpoch 35, Loss: 0.22147187493355397\nEpoch 36, Loss: 0.2114842374471236\nEpoch 37, Loss: 0.20039230058838448\nEpoch 38, Loss: 0.19323782539871054\nEpoch 39, Loss: 0.18485250894602337\nEpoch 40, Loss: 0.1770420845404925",
                "lineage": "4701"
            }
        ],
        "48": [],
        "49": [],
        "50": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    print(f\"Training set statistics: mean={train_data.mean().item()}, std={train_data.std().item()}, min={train_data.min().item()}, max={train_data.max().item()}\")\n    print(f\"Validation set statistics: mean={val_data.mean().item()}, std={val_data.std().item()}, min={val_data.min().item()}, max={val_data.max().item()}\")\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8017,
                "model_info": "Epoch 1, Loss: 0.974726226531155\nEpoch 2, Loss: 0.8652956816376742\nEpoch 3, Loss: 0.8114586705896081\nEpoch 4, Loss: 0.7687705828452522\nEpoch 5, Loss: 0.7341919099758316\nEpoch 6, Loss: 0.7015425335194008\nEpoch 7, Loss: 0.6736699445691539\nEpoch 8, Loss: 0.649004274961358\nEpoch 9, Loss: 0.6249702151814716\nEpoch 10, Loss: 0.6020283139598576\nEpoch 11, Loss: 0.5805939927897389\nEpoch 12, Loss: 0.5609947599170304\nEpoch 13, Loss: 0.5428167601578981\nEpoch 14, Loss: 0.5220218733839705\nEpoch 15, Loss: 0.5043199079508058\nEpoch 16, Loss: 0.48558729028976355\nEpoch 17, Loss: 0.4682351075069918\nEpoch 18, Loss: 0.4521921230140437\nEpoch 19, Loss: 0.4346702120583254\nEpoch 20, Loss: 0.41900173784903966\nEpoch 21, Loss: 0.40325482552888986\nEpoch 22, Loss: 0.3872357854001124\nEpoch 23, Loss: 0.37202704570572576\nEpoch 24, Loss: 0.3584216910337532\nEpoch 25, Loss: 0.34365580132277596\nEpoch 26, Loss: 0.33012734156194895\nEpoch 27, Loss: 0.31657314815356496\nEpoch 28, Loss: 0.3041966844943572\nEpoch 29, Loss: 0.2916863257219146\nEpoch 30, Loss: 0.2783468712886327\nEpoch 31, Loss: 0.2676803245711464\nEpoch 32, Loss: 0.25625482613431744\nEpoch 33, Loss: 0.24522383991564534\nEpoch 34, Loss: 0.23563221268598955\nEpoch 35, Loss: 0.22424895529440406\nEpoch 36, Loss: 0.21390465290898783\nEpoch 37, Loss: 0.2042482105475241\nEpoch 38, Loss: 0.19562496253487702\nEpoch 39, Loss: 0.18686316466949265\nEpoch 40, Loss: 0.18002247838964847\nTraining set statistics: mean=-2.557143108372628e-10, std=1.0, min=-0.8197185397148132, max=285.8739013671875\nValidation set statistics: mean=0.0017377696931362152, std=0.9903038144111633, min=-0.8197184801101685, max=283.1389465332031",
                "lineage": "5001"
            }
        ],
        "51": [],
        "52": [],
        "53": [],
        "54": [],
        "55": [],
        "56": [],
        "57": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.utils import resample\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef augment_data(train_data, train_label):\n    unique_labels = np.unique(train_label)\n    augmented_data = []\n    augmented_labels = []\n    for label in unique_labels:\n        class_data = train_data[train_label == label]\n        if len(class_data) < 100:\n            class_data_resampled = resample(class_data, n_samples=100, replace=True)\n            augmented_data.append(class_data_resampled)\n            augmented_labels.extend([label] * len(class_data_resampled))\n    if len(augmented_data) == 0:\n        return train_data, train_label\n    return np.vstack(augmented_data), np.array(augmented_labels)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data, train_label = augment_data(train_data, train_label)\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8042,
                "model_info": "Epoch 1, Loss: 0.9747219227554702\nEpoch 2, Loss: 0.8652428274191273\nEpoch 3, Loss: 0.8115385578598491\nEpoch 4, Loss: 0.7687422016531859\nEpoch 5, Loss: 0.7342871797061927\nEpoch 6, Loss: 0.7024769335699173\nEpoch 7, Loss: 0.6749273779982569\nEpoch 8, Loss: 0.650096918937112\nEpoch 9, Loss: 0.6260663004388278\nEpoch 10, Loss: 0.6033228961840243\nEpoch 11, Loss: 0.5813125322739131\nEpoch 12, Loss: 0.5616370433237182\nEpoch 13, Loss: 0.5423884138951146\nEpoch 14, Loss: 0.5223000875018151\nEpoch 15, Loss: 0.5040087587201892\nEpoch 16, Loss: 0.4848653198203748\nEpoch 17, Loss: 0.46847835022977585\nEpoch 18, Loss: 0.45132608005272906\nEpoch 19, Loss: 0.434115857972751\nEpoch 20, Loss: 0.4183463225437904\nEpoch 21, Loss: 0.40273794039883676\nEpoch 22, Loss: 0.38654545264143403\nEpoch 23, Loss: 0.37155969220708746\nEpoch 24, Loss: 0.357019952528765\nEpoch 25, Loss: 0.3429441652233907\nEpoch 26, Loss: 0.32856539669741597\nEpoch 27, Loss: 0.31625591593145636\nEpoch 28, Loss: 0.30372695867937494\nEpoch 29, Loss: 0.29069475517849547\nEpoch 30, Loss: 0.27843335196518854\nEpoch 31, Loss: 0.2673230257864877\nEpoch 32, Loss: 0.25575592936572555\nEpoch 33, Loss: 0.243816948554795\nEpoch 34, Loss: 0.23378171418541452\nEpoch 35, Loss: 0.22448927392886375\nEpoch 36, Loss: 0.21463940568597212\nEpoch 37, Loss: 0.20510861369103708\nEpoch 38, Loss: 0.19577213641320446\nEpoch 39, Loss: 0.18758846985287034\nEpoch 40, Loss: 0.17970796547215181",
                "lineage": "5701"
            }
        ],
        "58": [],
        "59": [],
        "60": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNTemporalModel(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(CNNTemporalModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.fc = nn.Linear(128 * (input_size // 8), num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1)\n        out = self.fc(x)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    num_classes = 4\n\n    model = CNNTemporalModel(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6326,
                "model_info": "Epoch 1, Loss: 1.081326661206024\nEpoch 2, Loss: 1.0118243115419618\nEpoch 3, Loss: 0.9921293734588916\nEpoch 4, Loss: 0.978499667200612\nEpoch 5, Loss: 0.9652302721640428\nEpoch 6, Loss: 0.9559450960662681\nEpoch 7, Loss: 0.9458685112319843\nEpoch 8, Loss: 0.9380276506326936\nEpoch 9, Loss: 0.9313324699017457\nEpoch 10, Loss: 0.9236508508332631\nEpoch 11, Loss: 0.9185464906143365\nEpoch 12, Loss: 0.9135592203451438\nEpoch 13, Loss: 0.9083909965522459\nEpoch 14, Loss: 0.9037073341532541\nEpoch 15, Loss: 0.899988664317726\nEpoch 16, Loss: 0.8955703512720778\nEpoch 17, Loss: 0.8915272557575277\nEpoch 18, Loss: 0.8872633050133308\nEpoch 19, Loss: 0.8836021530879894\nEpoch 20, Loss: 0.8783399895148176\nEpoch 21, Loss: 0.878527120527974\nEpoch 22, Loss: 0.8745685514927826\nEpoch 23, Loss: 0.8701170068555968\nEpoch 24, Loss: 0.8674085680216608\nEpoch 25, Loss: 0.8656488014045466\nEpoch 26, Loss: 0.8618226857880942\nEpoch 27, Loss: 0.858576782033448\nEpoch 28, Loss: 0.8563013049325192\nEpoch 29, Loss: 0.8550693690204804\nEpoch 30, Loss: 0.8510288863859341\nEpoch 31, Loss: 0.850096476970387\nEpoch 32, Loss: 0.8455822118870814\nEpoch 33, Loss: 0.8431726483603128\nEpoch 34, Loss: 0.8413807756612488\nEpoch 35, Loss: 0.8398396981426026\nEpoch 36, Loss: 0.8366613822797896\nEpoch 37, Loss: 0.8342889181254235\nEpoch 38, Loss: 0.8326721118187492\nEpoch 39, Loss: 0.8308970308120787\nEpoch 40, Loss: 0.8275313843005907",
                "lineage": "6001"
            }
        ],
        "61": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset, WeightedRandomSampler\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.utils.class_weight import compute_class_weight\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    class_weights = compute_class_weight('balanced', classes=np.unique(train_label.cpu().numpy()), y=train_label.cpu().numpy())\n    class_weights = torch.tensor(class_weights, dtype=torch.float32).to(device)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    class_sample_count = np.bincount(train_label.cpu().numpy())\n    weights = 1. / class_sample_count\n    samples_weights = weights[train_label.cpu().numpy()]\n    weighted_sampler = WeightedRandomSampler(weights=samples_weights, num_samples=len(samples_weights), replacement=True)\n    train_loader = DataLoader(dataset, batch_size=batch_size, sampler=weighted_sampler)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.7984,
                "model_info": "Epoch 1, Loss: 0.9257095156384063\nEpoch 2, Loss: 0.8142149644026143\nEpoch 3, Loss: 0.7587998666140946\nEpoch 4, Loss: 0.7111208799246863\nEpoch 5, Loss: 0.6794609273006271\nEpoch 6, Loss: 0.647727163419156\nEpoch 7, Loss: 0.6198458930123562\nEpoch 8, Loss: 0.6024270157781992\nEpoch 9, Loss: 0.5769236442452429\nEpoch 10, Loss: 0.5557918666992444\nEpoch 11, Loss: 0.5337280990866919\nEpoch 12, Loss: 0.5168387366462349\nEpoch 13, Loss: 0.49989373326988\nEpoch 14, Loss: 0.48001957969336045\nEpoch 15, Loss: 0.46609460157762334\nEpoch 16, Loss: 0.4469565117084591\nEpoch 17, Loss: 0.4332004860472542\nEpoch 18, Loss: 0.4172703707286813\nEpoch 19, Loss: 0.4034869672011963\nEpoch 20, Loss: 0.38937159365976154\nEpoch 21, Loss: 0.3741840509672769\nEpoch 22, Loss: 0.3596204969452805\nEpoch 23, Loss: 0.34765087065220796\nEpoch 24, Loss: 0.3336623582180997\nEpoch 25, Loss: 0.3224143193687908\nEpoch 26, Loss: 0.3107849616350002\nEpoch 27, Loss: 0.2981819179831448\nEpoch 28, Loss: 0.2848535262748971\nEpoch 29, Loss: 0.2754490393823488\nEpoch 30, Loss: 0.2679100358383212\nEpoch 31, Loss: 0.2545538591274602\nEpoch 32, Loss: 0.2481575978637428\nEpoch 33, Loss: 0.23727087559260698\nEpoch 34, Loss: 0.22784822921835302\nEpoch 35, Loss: 0.21691198072140597\nEpoch 36, Loss: 0.2096574060232763\nEpoch 37, Loss: 0.2019628060413185\nEpoch 38, Loss: 0.19327684762152966\nEpoch 39, Loss: 0.18587560445470683\nEpoch 40, Loss: 0.17722005052438394",
                "lineage": "6101"
            }
        ],
        "62": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.pipeline import make_pipeline\nfrom sklearn.model_selection import train_test_split\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.802,
                "model_info": "Epoch 1, Loss: 0.9747524095588362\nEpoch 2, Loss: 0.8651627114546734\nEpoch 3, Loss: 0.8117539698468975\nEpoch 4, Loss: 0.7690270381788374\nEpoch 5, Loss: 0.7347839152057889\nEpoch 6, Loss: 0.7024842448060663\nEpoch 7, Loss: 0.6751295362461551\nEpoch 8, Loss: 0.6500133508226464\nEpoch 9, Loss: 0.6264018013701558\nEpoch 10, Loss: 0.6034612105354924\nEpoch 11, Loss: 0.5815509317474951\nEpoch 12, Loss: 0.5619699680416231\nEpoch 13, Loss: 0.5427418461001537\nEpoch 14, Loss: 0.5217207552375354\nEpoch 15, Loss: 0.5038576561407027\nEpoch 16, Loss: 0.4850125301936766\nEpoch 17, Loss: 0.467779539768618\nEpoch 18, Loss: 0.4512620316585973\nEpoch 19, Loss: 0.4334361435355701\nEpoch 20, Loss: 0.4183893847259587\nEpoch 21, Loss: 0.4016973649128385\nEpoch 22, Loss: 0.3859105228004895\nEpoch 23, Loss: 0.37066267307797685\nEpoch 24, Loss: 0.35625260170270295\nEpoch 25, Loss: 0.3417448936863275\nEpoch 26, Loss: 0.32779843879295173\nEpoch 27, Loss: 0.31491167297061257\nEpoch 28, Loss: 0.3024064182319934\nEpoch 29, Loss: 0.28921023997944745\nEpoch 30, Loss: 0.27629195565568737\nEpoch 31, Loss: 0.2647371110211407\nEpoch 32, Loss: 0.2535486972663773\nEpoch 33, Loss: 0.24206800510009283\nEpoch 34, Loss: 0.23240771337685795\nEpoch 35, Loss: 0.2226622096350463\nEpoch 36, Loss: 0.21132752694003643\nEpoch 37, Loss: 0.20249160257616794\nEpoch 38, Loss: 0.19433877761556181\nEpoch 39, Loss: 0.18574034898843966\nEpoch 40, Loss: 0.17826587027528693",
                "lineage": "6201"
            }
        ],
        "63": [],
        "64": [],
        "65": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef morphological_features(data):\n    features = []\n    for signal in data:\n        # Extract morphological features here\n        # This is a placeholder for the actual feature extraction\n        features.append(signal)  # Replace with actual feature extraction logic\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = morphological_features(train_data)\n    val_data = morphological_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6346,
                "model_info": "Epoch 1, Loss: 1.0665305293452945\nEpoch 2, Loss: 0.8276171001271414\nEpoch 3, Loss: 0.744924939754142\nEpoch 4, Loss: 0.691453480217141\nEpoch 5, Loss: 0.6481341774541448\nEpoch 6, Loss: 0.6104888624284638\nEpoch 7, Loss: 0.5747712378652906\nEpoch 8, Loss: 0.5426549395535591\nEpoch 9, Loss: 0.511257046930163\nEpoch 10, Loss: 0.4841099583942465\nEpoch 11, Loss: 0.45727060589360186\nEpoch 12, Loss: 0.43095638930454366\nEpoch 13, Loss: 0.4081026483863421\nEpoch 14, Loss: 0.3862028407959014\nEpoch 15, Loss: 0.36605655986837143\nEpoch 16, Loss: 0.34411209392684894\nEpoch 17, Loss: 0.32530017139929956\nEpoch 18, Loss: 0.30655098971043804\nEpoch 19, Loss: 0.28971872434391854\nEpoch 20, Loss: 0.27267154590754045\nEpoch 21, Loss: 0.2575943723120753\nEpoch 22, Loss: 0.24300116989868845\nEpoch 23, Loss: 0.22803483168360367\nEpoch 24, Loss: 0.21473644719586032\nEpoch 25, Loss: 0.2015294345978812\nEpoch 26, Loss: 0.19153085880110224\nEpoch 27, Loss: 0.18035899049775844\nEpoch 28, Loss: 0.16958723979467621\nEpoch 29, Loss: 0.15930117293477286\nEpoch 30, Loss: 0.1506675067795673\nEpoch 31, Loss: 0.1435685158919922\nEpoch 32, Loss: 0.13427553749187437\nEpoch 33, Loss: 0.12567567473524133\nEpoch 34, Loss: 0.118467757946699\nEpoch 35, Loss: 0.11294637375909856\nEpoch 36, Loss: 0.10804963706779847\nEpoch 37, Loss: 0.1038033170428935\nEpoch 38, Loss: 0.09897056294894722\nEpoch 39, Loss: 0.09326935981377073\nEpoch 40, Loss: 0.08575441019749001",
                "lineage": "6501"
            }
        ],
        "66": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8014,
                "model_info": "Epoch 1, Loss: 0.9747177640444487\nEpoch 2, Loss: 0.865280825551778\nEpoch 3, Loss: 0.8116514794885998\nEpoch 4, Loss: 0.7687714527756148\nEpoch 5, Loss: 0.7346353953035688\nEpoch 6, Loss: 0.7025714545240787\nEpoch 7, Loss: 0.6752459705447967\nEpoch 8, Loss: 0.6504158190024334\nEpoch 9, Loss: 0.6264563819497194\nEpoch 10, Loss: 0.6036182299914149\nEpoch 11, Loss: 0.5825668269064056\nEpoch 12, Loss: 0.5625601545862868\nEpoch 13, Loss: 0.5435011098000458\nEpoch 14, Loss: 0.5227735684380193\nEpoch 15, Loss: 0.5045826805187049\nEpoch 16, Loss: 0.4858939179188917\nEpoch 17, Loss: 0.46938909129766954\nEpoch 18, Loss: 0.45245694685119586\nEpoch 19, Loss: 0.4345838998993162\nEpoch 20, Loss: 0.4196595420878588\nEpoch 21, Loss: 0.40321990687421555\nEpoch 22, Loss: 0.3874062069203712\nEpoch 23, Loss: 0.372196429350097\nEpoch 24, Loss: 0.35821339579552924\nEpoch 25, Loss: 0.34337929268716166\nEpoch 26, Loss: 0.3284980373853914\nEpoch 27, Loss: 0.31675935975649533\nEpoch 28, Loss: 0.30363558355768905\nEpoch 29, Loss: 0.29077150471036584\nEpoch 30, Loss: 0.2781602946501547\nEpoch 31, Loss: 0.26686786381159544\nEpoch 32, Loss: 0.2560604673715562\nEpoch 33, Loss: 0.24459351133018903\nEpoch 34, Loss: 0.2352249964985875\nEpoch 35, Loss: 0.22381206514624855\nEpoch 36, Loss: 0.21340101848637075\nEpoch 37, Loss: 0.20380932141288458\nEpoch 38, Loss: 0.1954590326421778\nEpoch 39, Loss: 0.1867249795662922\nEpoch 40, Loss: 0.17912072134910298",
                "lineage": "6601"
            }
        ],
        "67": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNModel(nn.Module):\n    def __init__(self, input_size, num_classes):\n        super(CNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.fc = nn.Linear(128 * (input_size // 8), num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1)\n        out = self.fc(x)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    num_classes = 4\n\n    model = CNNModel(input_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6325,
                "model_info": "Epoch 1, Loss: 1.0813324444582275\nEpoch 2, Loss: 1.011833513194906\nEpoch 3, Loss: 0.9921335696945264\nEpoch 4, Loss: 0.9784821277616578\nEpoch 5, Loss: 0.9652266103109334\nEpoch 6, Loss: 0.9559018298440154\nEpoch 7, Loss: 0.9458960848440364\nEpoch 8, Loss: 0.9378883069856611\nEpoch 9, Loss: 0.9313709015123217\nEpoch 10, Loss: 0.9235496995773974\nEpoch 11, Loss: 0.9184611265810346\nEpoch 12, Loss: 0.913298980745839\nEpoch 13, Loss: 0.9083599276597578\nEpoch 14, Loss: 0.9037808179855347\nEpoch 15, Loss: 0.8999352316709947\nEpoch 16, Loss: 0.8953428311906254\nEpoch 17, Loss: 0.8917673203858213\nEpoch 18, Loss: 0.8870100588350058\nEpoch 19, Loss: 0.8838101394345802\nEpoch 20, Loss: 0.8784886710703259\nEpoch 21, Loss: 0.8782081026262147\nEpoch 22, Loss: 0.8741192711291982\nEpoch 23, Loss: 0.8700952555076175\nEpoch 24, Loss: 0.8671123161196937\nEpoch 25, Loss: 0.8652576051380722\nEpoch 26, Loss: 0.8618993095610283\nEpoch 27, Loss: 0.8587292017497394\nEpoch 28, Loss: 0.8560475957599574\nEpoch 29, Loss: 0.8546682800990377\nEpoch 30, Loss: 0.8504873193843351\nEpoch 31, Loss: 0.8495333317145276\nEpoch 32, Loss: 0.8455463564327262\nEpoch 33, Loss: 0.8431867338187864\nEpoch 34, Loss: 0.8410060859916306\nEpoch 35, Loss: 0.8399691963836465\nEpoch 36, Loss: 0.8365341505025032\nEpoch 37, Loss: 0.8340092794451284\nEpoch 38, Loss: 0.8327483068043349\nEpoch 39, Loss: 0.8311698529404551\nEpoch 40, Loss: 0.8277065677285881",
                "lineage": "6701"
            }
        ],
        "68": [],
        "69": [],
        "70": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom scipy.signal import butter, filtfilt\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\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=0.5, fs=250, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    y = filtfilt(b, a, data)\n    return y\n\ndef preprocess_data(data):\n    return np.array([lowpass_filter(signal) for signal in data])\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = preprocess_data(train_data)\n    val_data = preprocess_data(val_data)\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.3173,
                "model_info": "Epoch 1, Loss: 1.3597745854200192\nEpoch 2, Loss: 1.3546046894937467\nEpoch 3, Loss: 1.3527341312272994\nEpoch 4, Loss: 1.3514739300147585\nEpoch 5, Loss: 1.3506863339162376\nEpoch 6, Loss: 1.3497463878880536\nEpoch 7, Loss: 1.3487824640896406\nEpoch 8, Loss: 1.348038496989435\nEpoch 9, Loss: 1.3473896264114673\nEpoch 10, Loss: 1.346853792324176\nEpoch 11, Loss: 1.3461672529835618\nEpoch 12, Loss: 1.3456355841283376\nEpoch 13, Loss: 1.3449485878569152\nEpoch 14, Loss: 1.344463695033727\nEpoch 15, Loss: 1.3438923198751205\nEpoch 16, Loss: 1.3433121241443218\nEpoch 17, Loss: 1.3431737553364027\nEpoch 18, Loss: 1.3423078165402111\nEpoch 19, Loss: 1.3417910749303632\nEpoch 20, Loss: 1.3413630334978597\nEpoch 21, Loss: 1.3409696897481087\nEpoch 22, Loss: 1.3404844475341622\nEpoch 23, Loss: 1.339822649726941\nEpoch 24, Loss: 1.3392476555024364\nEpoch 25, Loss: 1.3386347076485574\nEpoch 26, Loss: 1.3383254085072172\nEpoch 27, Loss: 1.3375576997672756\nEpoch 28, Loss: 1.3370354530220983\nEpoch 29, Loss: 1.336601981045875\nEpoch 30, Loss: 1.335929723481528\nEpoch 31, Loss: 1.3352930522926023\nEpoch 32, Loss: 1.3346450770427536\nEpoch 33, Loss: 1.3338818572990725\nEpoch 34, Loss: 1.3334986712790726\nEpoch 35, Loss: 1.3326004393498865\nEpoch 36, Loss: 1.3320183136184018\nEpoch 37, Loss: 1.3313765390820786\nEpoch 38, Loss: 1.330631017456128\nEpoch 39, Loss: 1.3300436444566255\nEpoch 40, Loss: 1.3288865405172396",
                "lineage": "7001"
            }
        ],
        "71": [],
        "72": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef morphological_features(data):\n    features = []\n    for signal in data:\n        features.append(signal)  # Placeholder for actual morphological feature extraction\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = morphological_features(train_data)\n    val_data = morphological_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.6383,
                "model_info": "Epoch 1, Loss: 1.066617604180627\nEpoch 2, Loss: 0.8273066858870054\nEpoch 3, Loss: 0.7450515961921604\nEpoch 4, Loss: 0.6919603310024899\nEpoch 5, Loss: 0.6491217026326112\nEpoch 6, Loss: 0.6095868829573413\nEpoch 7, Loss: 0.5756520312601225\nEpoch 8, Loss: 0.5429168999080695\nEpoch 9, Loss: 0.5129388523879755\nEpoch 10, Loss: 0.48511403776176143\nEpoch 11, Loss: 0.4581326357805798\nEpoch 12, Loss: 0.43398838337231965\nEpoch 13, Loss: 0.4113575355677138\nEpoch 14, Loss: 0.387699554039741\nEpoch 15, Loss: 0.3671666856805102\nEpoch 16, Loss: 0.34676870303282126\nEpoch 17, Loss: 0.3270545213728171\nEpoch 18, Loss: 0.30681582667548457\nEpoch 19, Loss: 0.2918862772537056\nEpoch 20, Loss: 0.27424683300295627\nEpoch 21, Loss: 0.2587163139728118\nEpoch 22, Loss: 0.24311159253692444\nEpoch 23, Loss: 0.22995478664158403\nEpoch 24, Loss: 0.21627977573368234\nEpoch 25, Loss: 0.20405448732929815\nEpoch 26, Loss: 0.19207280270769592\nEpoch 27, Loss: 0.1795366995908935\nEpoch 28, Loss: 0.17053787194321116\nEpoch 29, Loss: 0.15978412664783206\nEpoch 30, Loss: 0.14983947407776013\nEpoch 31, Loss: 0.143531661688023\nEpoch 32, Loss: 0.13518283264479117\nEpoch 33, Loss: 0.1276554243492531\nEpoch 34, Loss: 0.11960075222198885\nEpoch 35, Loss: 0.11147863136143236\nEpoch 36, Loss: 0.10526492801314352\nEpoch 37, Loss: 0.09969408990325489\nEpoch 38, Loss: 0.09631922487133752\nEpoch 39, Loss: 0.09320818017917952\nEpoch 40, Loss: 0.08863514420824865",
                "lineage": "7201"
            }
        ],
        "73": [],
        "74": [],
        "75": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, sampler=torch.utils.data.WeightedRandomSampler(weights=train_label.float(), num_samples=len(train_label), replacement=True))\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.592,
                "model_info": "Epoch 1, Loss: 0.6030581989924418\nEpoch 2, Loss: 0.5030011401981859\nEpoch 3, Loss: 0.4524225143576309\nEpoch 4, Loss: 0.41590881805273483\nEpoch 5, Loss: 0.38779517144479586\nEpoch 6, Loss: 0.36519107216836855\nEpoch 7, Loss: 0.3428412733059698\nEpoch 8, Loss: 0.32449728050296\nEpoch 9, Loss: 0.30376949431571304\nEpoch 10, Loss: 0.28802004553763744\nEpoch 11, Loss: 0.27479332379439053\nEpoch 12, Loss: 0.25591849399848543\nEpoch 13, Loss: 0.2463674159745566\nEpoch 14, Loss: 0.23311521450411565\nEpoch 15, Loss: 0.21839202271198815\nEpoch 16, Loss: 0.20661276513120722\nEpoch 17, Loss: 0.19728011865304665\nEpoch 18, Loss: 0.18505310134214997\nEpoch 19, Loss: 0.17542077735381026\nEpoch 20, Loss: 0.1655303066070844\nEpoch 21, Loss: 0.15751290947713686\nEpoch 22, Loss: 0.14716423797687506\nEpoch 23, Loss: 0.14091530086154444\nEpoch 24, Loss: 0.1326073423714418\nEpoch 25, Loss: 0.1255202003524079\nEpoch 26, Loss: 0.11768633398922758\nEpoch 27, Loss: 0.11131527696712919\nEpoch 28, Loss: 0.10561485165969653\nEpoch 29, Loss: 0.1001527185003039\nEpoch 30, Loss: 0.09473401385282601\nEpoch 31, Loss: 0.09040872438054624\nEpoch 32, Loss: 0.0855331453146152\nEpoch 33, Loss: 0.07991237685284551\nEpoch 34, Loss: 0.07507649903505641\nEpoch 35, Loss: 0.07236884685229661\nEpoch 36, Loss: 0.06830269010333548\nEpoch 37, Loss: 0.06537679956793327\nEpoch 38, Loss: 0.06274505147635365\nEpoch 39, Loss: 0.05969731752794672\nEpoch 40, Loss: 0.055537787081956176",
                "lineage": "7501"
            }
        ],
        "76": [],
        "77": [],
        "78": [],
        "79": [],
        "80": [],
        "81": [],
        "82": [],
        "83": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    feature_importance = np.abs(model.fc.weight.detach().cpu().numpy()).mean(axis=0)\n    top_features = np.argsort(feature_importance)[-10:]\n\n    print(\"Top feature importances:\", feature_importance[top_features])\n    \n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8016,
                "model_info": "Epoch 1, Loss: 0.9747548806919017\nEpoch 2, Loss: 0.865277413672083\nEpoch 3, Loss: 0.8115163110268093\nEpoch 4, Loss: 0.7689923979270481\nEpoch 5, Loss: 0.734823224755029\nEpoch 6, Loss: 0.7024715935200052\nEpoch 7, Loss: 0.6750845910262695\nEpoch 8, Loss: 0.6506506148546991\nEpoch 9, Loss: 0.6265480093901079\nEpoch 10, Loss: 0.6032846308029087\nEpoch 11, Loss: 0.5820796269487282\nEpoch 12, Loss: 0.5620901820870141\nEpoch 13, Loss: 0.5433875082664893\nEpoch 14, Loss: 0.5223411805570239\nEpoch 15, Loss: 0.5047743932528139\nEpoch 16, Loss: 0.4862039603450248\nEpoch 17, Loss: 0.46922830319221553\nEpoch 18, Loss: 0.45229815778942806\nEpoch 19, Loss: 0.43559355533283184\nEpoch 20, Loss: 0.420216567571241\nEpoch 21, Loss: 0.40322110091198426\nEpoch 22, Loss: 0.3878196422403925\nEpoch 23, Loss: 0.3728089910322325\nEpoch 24, Loss: 0.3585344772650047\nEpoch 25, Loss: 0.3440777206947158\nEpoch 26, Loss: 0.3298465633575381\nEpoch 27, Loss: 0.3162231821702675\nEpoch 28, Loss: 0.30425436500166747\nEpoch 29, Loss: 0.2917142645697218\nEpoch 30, Loss: 0.279087683690029\nEpoch 31, Loss: 0.26744048017114685\nEpoch 32, Loss: 0.256068105117602\nEpoch 33, Loss: 0.2450141482584307\nEpoch 34, Loss: 0.23447345737761133\nEpoch 35, Loss: 0.22392048467944542\nEpoch 36, Loss: 0.21480784457956303\nEpoch 37, Loss: 0.20543378914729649\nEpoch 38, Loss: 0.19688535571784754\nEpoch 39, Loss: 0.18848278537936036\nEpoch 40, Loss: 0.17986543110487785\nTop feature importances: [0.2762577  0.2811082  0.2854956  0.29562888 0.3009228  0.31318992\n 0.32150298 0.33343947 0.34344923 0.35201868]",
                "lineage": "8301"
            }
        ],
        "84": [],
        "85": [],
        "86": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n            grad_norm = torch.norm(torch.cat([p.grad.view(-1) for p in model.parameters() if p.grad is not None]))\n            print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}, Grad Norm: {grad_norm.item()}\")\n    \n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8022,
                "model_info": "Epoch 1, Loss: 0.002657487616657982, Grad Norm: 0.37477976083755493\nEpoch 1, Loss: 0.005274505395578103, Grad Norm: 0.2909097671508789\nEpoch 1, Loss: 0.00789343738738955, Grad Norm: 0.36793118715286255\nEpoch 1, Loss: 0.010463351022716677, Grad Norm: 0.290721595287323\nEpoch 1, Loss: 0.013017311206019542, Grad Norm: 0.3249775469303131\nEpoch 1, Loss: 0.015546361681595873, Grad Norm: 0.3123044967651367\nEpoch 1, Loss: 0.018051737100743974, Grad Norm: 0.29110226035118103\nEpoch 1, Loss: 0.0205107984524542, Grad Norm: 0.377404123544693\nEpoch 1, Loss: 0.022959590644616768, Grad Norm: 0.3914981484413147\nEpoch 1, Loss: 0.025351395991393105, Grad Norm: 0.4179922938346863\nEpoch 1, Loss: 0.02774963177554667, Grad Norm: 0.3359147012233734\nEpoch 1, Loss: 0.030148065479154093, Grad Norm: 0.4145452082157135\nEpoch 1, Loss: 0.03251550819960757, Grad Norm: 0.38782069087028503\nEpoch 1, Loss: 0.03488993850642111, Grad Norm: 0.3550678789615631\nEpoch 1, Loss: 0.0371988128563264, Grad Norm: 0.32064586877822876\nEpoch 1, Loss: 0.03950304056083401, Grad Norm: 0.31924882531166077\nEpoch 1, Loss: 0.04176704462567584, Grad Norm: 0.3797956705093384\nEpoch 1, Loss: 0.044060621975479566, Grad Norm: 0.3592117130756378\nEpoch 1, Loss: 0.046284020290264925, Grad Norm: 0.3319392204284668\nEpoch 1, Loss: 0.04850060811655993, Grad Norm: 0.3170747756958008\nEpoch 1, Loss: 0.05068279891462564, Grad Norm: 0.40528008341789246\nEpoch 1, Loss: 0.05290646836762236, Grad Norm: 0.3265136778354645\nEpoch 1, Loss: 0.05504203849470318, Grad Norm: 0.3662055730819702\nEpoch 1, Loss: 0.057232474182480356, Grad Norm: 0.2785479426383972\nEpoch 1, Loss: 0.05939350750533267, Grad Norm: 0.3377320170402527\nEpoch 1, Loss: 0.06152727324765841, Grad Norm: 0.6127323508262634\nEpoch 1, Loss: 0.06374459257510252, Grad Norm: 0.5403186082839966\nEpoch 1, Loss: 0.06585850184801215, Grad Norm: 0.7224463224411011\nEpoch 1, Loss: 0.06792288847024519, Grad Norm: 0.7635836601257324\nEpoch 1, Loss: 0.07007989521905236, Grad Norm: 0.6114699244499207\nEpoch",
                "lineage": "8601"
            }
        ],
        "87": [],
        "88": [],
        "89": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\nfrom scipy.signal import butter, filtfilt\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\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=40, fs=250, order=5):\n    b, a = butter_lowpass(cutoff, fs, order=order)\n    filtered_data = filtfilt(b, a, data)\n    return filtered_data\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        filtered_signal = lowpass_filter(signal)\n        f, t, Sxx = spectrogram(filtered_signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.7391,
                "model_info": "Epoch 1, Loss: 0.9860967692852936\nEpoch 2, Loss: 0.8865750999459836\nEpoch 3, Loss: 0.8401207390765082\nEpoch 4, Loss: 0.8052736610002572\nEpoch 5, Loss: 0.77569019977511\nEpoch 6, Loss: 0.7488744456800069\nEpoch 7, Loss: 0.7247741094248766\nEpoch 8, Loss: 0.703300178851825\nEpoch 9, Loss: 0.6815977135455082\nEpoch 10, Loss: 0.662938583949706\nEpoch 11, Loss: 0.6433191206770986\nEpoch 12, Loss: 0.624502949430938\nEpoch 13, Loss: 0.608789757437532\nEpoch 14, Loss: 0.5913839522112811\nEpoch 15, Loss: 0.5748137972405227\nEpoch 16, Loss: 0.5586581663755904\nEpoch 17, Loss: 0.5443750030706116\nEpoch 18, Loss: 0.5288989503301266\nEpoch 19, Loss: 0.5115433762604353\nEpoch 20, Loss: 0.49863057087341794\nEpoch 21, Loss: 0.48415661664704673\nEpoch 22, Loss: 0.4697995999266685\nEpoch 23, Loss: 0.45522647157969265\nEpoch 24, Loss: 0.44049860482710107\nEpoch 25, Loss: 0.4279935278155753\nEpoch 26, Loss: 0.41471556280945177\nEpoch 27, Loss: 0.40182766524248986\nEpoch 28, Loss: 0.3907509508494452\nEpoch 29, Loss: 0.37705249978576194\nEpoch 30, Loss: 0.36398911573378917\nEpoch 31, Loss: 0.35099568362428224\nEpoch 32, Loss: 0.3418919243304606\nEpoch 33, Loss: 0.3309496180109694\nEpoch 34, Loss: 0.3187734581916209\nEpoch 35, Loss: 0.30901755398271635\nEpoch 36, Loss: 0.29870653795990054\nEpoch 37, Loss: 0.2875973376340006\nEpoch 38, Loss: 0.27701813854892055\nEpoch 39, Loss: 0.2697070722616565\nEpoch 40, Loss: 0.26033702521315005",
                "lineage": "8901"
            }
        ],
        "90": [],
        "91": [],
        "92": [],
        "93": [],
        "94": [],
        "95": [],
        "96": [],
        "97": [],
        "98": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n        self.dropout = nn.Dropout(0.3)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        out = self.dropout(out)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.7988,
                "model_info": "Epoch 1, Loss: 0.9851916912878772\nEpoch 2, Loss: 0.8829375411635855\nEpoch 3, Loss: 0.8348687781939809\nEpoch 4, Loss: 0.7978136856359164\nEpoch 5, Loss: 0.7685314347098747\nEpoch 6, Loss: 0.7413620937351073\nEpoch 7, Loss: 0.7191098609263518\nEpoch 8, Loss: 0.6978479909805327\nEpoch 9, Loss: 0.677920609083377\nEpoch 10, Loss: 0.6600064944168428\nEpoch 11, Loss: 0.6424619486830743\nEpoch 12, Loss: 0.6273077948308494\nEpoch 13, Loss: 0.6130368050595392\nEpoch 14, Loss: 0.5974139685594189\nEpoch 15, Loss: 0.5822260423264897\nEpoch 16, Loss: 0.5703826710839189\nEpoch 17, Loss: 0.5578950527419055\nEpoch 18, Loss: 0.5459321666930779\nEpoch 19, Loss: 0.5333748057112813\nEpoch 20, Loss: 0.5234835888625564\nEpoch 21, Loss: 0.5105364920996888\nEpoch 22, Loss: 0.5009861794977866\nEpoch 23, Loss: 0.4907780905717165\nEpoch 24, Loss: 0.4806810226756186\nEpoch 25, Loss: 0.4705822795572299\nEpoch 26, Loss: 0.4606124350869038\nEpoch 27, Loss: 0.4510831120718921\nEpoch 28, Loss: 0.44333190875639156\nEpoch 29, Loss: 0.43449422854379594\nEpoch 30, Loss: 0.4261875424298123\nEpoch 31, Loss: 0.4177910396668366\nEpoch 32, Loss: 0.409297608196621\nEpoch 33, Loss: 0.4005581507756019\nEpoch 34, Loss: 0.3941976860480208\nEpoch 35, Loss: 0.38804032471953337\nEpoch 36, Loss: 0.3792448831496907\nEpoch 37, Loss: 0.37391584945731793\nEpoch 38, Loss: 0.36631742743292606\nEpoch 39, Loss: 0.36000532815644015\nEpoch 40, Loss: 0.3537720760434237",
                "lineage": "9801"
            }
        ],
        "99": [],
        "100": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\nfrom scipy.signal import spectrogram\nfrom sklearn.preprocessing import StandardScaler\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 64, kernel_size=5, stride=1, padding=2)\n        self.conv2 = nn.Conv1d(64, 128, kernel_size=5, stride=1, padding=2)\n        self.dilated_conv = nn.Conv1d(128, 128, kernel_size=3, stride=1, padding=2, dilation=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.rnn_input_size = 128 * (input_size // 8)\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True, bidirectional=True)\n        self.attention = nn.Linear(hidden_size * 2, 1)\n        self.fc = nn.Linear(hidden_size * 2, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = self.dilated_conv(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        attention_weights = torch.softmax(self.attention(out), dim=1)\n        out = torch.bmm(attention_weights.transpose(1, 2), out).squeeze(1)\n        out = self.fc(out)\n        return out\n\ndef time_frequency_features(data):\n    features = []\n    for signal in data:\n        f, t, Sxx = spectrogram(signal, fs=250, nperseg=256)\n        features.append(Sxx.flatten())\n    return np.array(features)\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=512):\n    train_data = time_frequency_features(train_data)\n    val_data = time_frequency_features(val_data)\n\n    scaler = StandardScaler()\n    train_data = scaler.fit_transform(train_data)\n    val_data = scaler.transform(val_data)\n\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 256\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0001)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    frozen_layers = [name for name, param in model.named_parameters() if not param.requires_grad]\n    trainable_layers = [name for name, param in model.named_parameters() if param.requires_grad]\n    print(f\"Frozen layers: {frozen_layers}, Trainable layers: {trainable_layers}\")\n\n    model.train()\n    for epoch in range(40):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXXXXXXXXXX.py",
                "accuracy": 0.8061,
                "model_info": "Frozen layers: [], Trainable layers: ['conv1.weight', 'conv1.bias', 'conv2.weight', 'conv2.bias', 'dilated_conv.weight', 'dilated_conv.bias', 'rnn.weight_ih_l0', 'rnn.weight_hh_l0', 'rnn.bias_ih_l0', 'rnn.bias_hh_l0', 'rnn.weight_ih_l0_reverse', 'rnn.weight_hh_l0_reverse', 'rnn.bias_ih_l0_reverse', 'rnn.bias_hh_l0_reverse', 'attention.weight', 'attention.bias', 'fc.weight', 'fc.bias']\nEpoch 1, Loss: 0.9747024661291126\nEpoch 2, Loss: 0.8650429215632565\nEpoch 3, Loss: 0.8114547191791938\nEpoch 4, Loss: 0.7686350747170695\nEpoch 5, Loss: 0.7341158098314179\nEpoch 6, Loss: 0.7020460350042113\nEpoch 7, Loss: 0.6742490802296293\nEpoch 8, Loss: 0.6496883709691537\nEpoch 9, Loss: 0.6258312502657841\nEpoch 10, Loss: 0.6026114210515013\nEpoch 11, Loss: 0.5810436057266485\nEpoch 12, Loss: 0.5615232079477548\nEpoch 13, Loss: 0.5421716843136442\nEpoch 14, Loss: 0.5217455687884406\nEpoch 15, Loss: 0.5033534887084119\nEpoch 16, Loss: 0.48440242580168535\nEpoch 17, Loss: 0.4675285370587845\nEpoch 18, Loss: 0.45109705881514156\nEpoch 19, Loss: 0.4341725948447229\nEpoch 20, Loss: 0.4181037850091645\nEpoch 21, Loss: 0.4015045164871582\nEpoch 22, Loss: 0.3857690845821732\nEpoch 23, Loss: 0.3705001686790854\nEpoch 24, Loss: 0.35678192057902436\nEpoch 25, Loss: 0.34192549799088096\nEpoch 26, Loss: 0.3280303933570115\nEpoch 27, Loss: 0.31479016472648064\nEpoch 28, Loss: 0.302761703529422\nEpoch 29, Loss: 0.28958655167335284\nEpoch 30, Loss: 0.2770399832508157\nEpoch 31, Loss: 0.2657368292392101\nEpoch 32, Loss: 0.2532464073338115\nEpoch 33, Loss: 0.242843042723048\nEpoch 34, Loss: 0.2320860647480227\nEpoch 35, Loss: 0.22237305105762153\nEpoch 36, Loss: 0.21170276337644647\nEpoch 37, Loss: 0.20288024230676055\nEpoch 38, Loss: 0.19437631810237715\nEpoch 39, Loss: 0.18438077979719342\nEpoch 40, Loss: 0.17718186416804446",
                "lineage": "10001"
            }
        ]
    },
    "2": {
        "2": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass CNNRNNModel(nn.Module):\n    def __init__(self, input_size, hidden_size, num_classes):\n        super(CNNRNNModel, self).__init__()\n        self.conv1 = nn.Conv1d(1, 32, kernel_size=5, stride=1, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2, stride=2)\n        self.conv2 = nn.Conv1d(32, 64, kernel_size=5, stride=1, padding=2)\n        self.rnn_input_size = 64 * (input_size // 4)  # Adjust input size for RNN\n        self.rnn = nn.LSTM(self.rnn_input_size, hidden_size, batch_first=True)\n        self.fc = nn.Linear(hidden_size, num_classes)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = self.pool(x)\n        x = self.conv2(x)\n        x = self.pool(x)\n        x = x.view(x.size(0), -1, self.rnn_input_size)\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(train_data, train_label, val_data, device, batch_size=1024):\n    train_data = torch.tensor(train_data, dtype=torch.float32).to(device)\n    train_label = torch.tensor(train_label, dtype=torch.long).to(device)\n    val_data = torch.tensor(val_data, dtype=torch.float32).to(device)\n\n    if train_data.dim() == 2:\n        train_data = train_data.unsqueeze(1)\n    if val_data.dim() == 2:\n        val_data = val_data.unsqueeze(1)\n\n    input_size = train_data.shape[2]\n    hidden_size = 128\n    num_classes = 4\n\n    model = CNNRNNModel(input_size, hidden_size, num_classes).to(device)\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    dataset = TensorDataset(train_data, train_label)\n    train_loader = DataLoader(dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\n        epoch_loss = 0\n        for x_batch, y_batch in train_loader:\n            optimizer.zero_grad()\n            outputs = model(x_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            epoch_loss += loss.item()\n        print(f\"Epoch {epoch+1}, Loss: {epoch_loss/len(train_loader)}\")\n\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(val_data)\n        _, val_preds = torch.max(val_outputs, 1)\n\n    return val_preds.cpu().numpy().tolist()",
                "file": "/projects/users/tusoml/ecg_initial_8261_Recurrent_Neural_NetXXX.py",
                "accuracy": 0.6021,
                "model_info": "Epoch 1, Loss: 1.1901250196142672\nEpoch 2, Loss: 1.018803264217815\nEpoch 3, Loss: 0.9186183033775096\nEpoch 4, Loss: 0.8511665116324736\nEpoch 5, Loss: 0.8054958243936414\nEpoch 6, Loss: 0.7693055799637718\nEpoch 7, Loss: 0.7378482603935447\nEpoch 8, Loss: 0.7116643192667614\nEpoch 9, Loss: 0.6866326827655806\nEpoch 10, Loss: 0.6620208945310893\nEpoch 11, Loss: 0.6423558894245104\nEpoch 12, Loss: 0.6219172820277598\nEpoch 13, Loss: 0.6020978805662571\nEpoch 14, Loss: 0.5821802802241168\nEpoch 15, Loss: 0.5621977826416265\nEpoch 16, Loss: 0.5458972812612395\nEpoch 17, Loss: 0.528782771921706\nEpoch 18, Loss: 0.5115592406627318\nEpoch 19, Loss: 0.49511217979635774\nEpoch 20, Loss: 0.47983198672875593",
                "lineage": "221"
            }
        ]
    }
}