{
    "1": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_Net.py",
                "accuracy": 0.27441935056632116,
                "model_info": "",
                "lineage": "deepsea_initial_8221_Recurrent_Neural_Net"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_NetX.py",
                "accuracy": 0.2749172515892313,
                "model_info": "",
                "lineage": "111"
            }
        ],
        "2": [],
        "3": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass SimplePWMModel(nn.Module):\n    def __init__(self):\n        super(SimplePWMModel, self).__init__()\n        self.conv = nn.Conv1d(in_channels=4, out_channels=36, kernel_size=1000)\n        self.fc = nn.Linear(36, 36)\n    \n    def forward(self, x):\n        x = self.conv(x)\n        x = torch.relu(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimplePWMModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(100):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXX.py",
                "accuracy": 0.4014540622443971,
                "model_info": "",
                "lineage": "311"
            }
        ],
        "4": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=7, padding=3)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.fc3 = nn.Linear(256, 256)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\n        x = x.view(x.size(0), -1)\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc3(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.376371898986343,
                "model_info": "",
                "lineage": "411"
            }
        ],
        "5": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True, dropout=0.2)\n        self.fc1 = nn.Linear(128, 64)\n        self.fc2 = nn.Linear(64, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc1(out[:, -1, :])\n        out = nn.ReLU()(out)\n        out = self.fc2(out)\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            \n            grad_norm = torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n            print(f'Epoch [{epoch+1}/10], Batch [{i//batch_size + 1}], Loss: {loss.item():.4f}, Grad Norm: {grad_norm:.4f}')\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_NetXXXX.py",
                "accuracy": 0.2747000852567729,
                "model_info": "Epoch [1/10], Batch [1], Loss: 0.7029, Grad Norm: 0.0706\nEpoch [1/10], Batch [2], Loss: 0.7019, Grad Norm: 0.0757\nEpoch [1/10], Batch [3], Loss: 0.7006, Grad Norm: 0.0779\nEpoch [1/10], Batch [4], Loss: 0.6988, Grad Norm: 0.0720\nEpoch [1/10], Batch [5], Loss: 0.6977, Grad Norm: 0.0724\nEpoch [1/10], Batch [6], Loss: 0.6962, Grad Norm: 0.0733\nEpoch [1/10], Batch [7], Loss: 0.6959, Grad Norm: 0.0799\nEpoch [1/10], Batch [8], Loss: 0.6939, Grad Norm: 0.0738\nEpoch [1/10], Batch [9], Loss: 0.6926, Grad Norm: 0.0733\nEpoch [1/10], Batch [10], Loss: 0.6913, Grad Norm: 0.0826\nEpoch [1/10], Batch [11], Loss: 0.6902, Grad Norm: 0.0762\nEpoch [1/10], Batch [12], Loss: 0.6873, Grad Norm: 0.0819\nEpoch [1/10], Batch [13], Loss: 0.6854, Grad Norm: 0.0827\nEpoch [1/10], Batch [14], Loss: 0.6831, Grad Norm: 0.0838\nEpoch [1/10], Batch [15], Loss: 0.6764, Grad Norm: 0.1090\nEpoch [1/10], Batch [16], Loss: 0.6738, Grad Norm: 0.1106\nEpoch [1/10], Batch [17], Loss: 0.6662, Grad Norm: 0.1328\nEpoch [1/10], Batch [18], Loss: 0.6549, Grad Norm: 0.1661\nEpoch [1/10], Batch [19], Loss: 0.6499, Grad Norm: 0.1675\nEpoch [1/10], Batch [20], Loss: 0.6273, Grad Norm: 0.2255\nEpoch [1/10], Batch [21], Loss: 0.6055, Grad Norm: 0.2674\nEpoch [1/10], Batch [22], Loss: 0.5849, Grad Norm: 0.3002\nEpoch [1/10], Batch [23], Loss: 0.5613, Grad Norm: 0.3343\nEpoch [1/10], Batch [24], Loss: 0.5772, Grad Norm: 0.2595\nEpoch [1/10], Batch [25], Loss: 0.5487, Grad Norm: 0.3088\nEpoch [1/10], Batch [26], Loss: 0.5411, Grad Norm: 0.3010\nEpoch [1/10], Batch [27], Loss: 0.5190, Grad Norm: 0.3177\nEpoch [1/10], Batch [28], Loss: 0.4842, Grad Norm: 0.3688\nEpoch [1/10], Batch [29], Loss: 0.5086, Grad Norm: 0.3102\nEpoch [1/10], Batch [30], Loss: 0.4736, Grad Norm: 0.3598\nEpoch [1/10], Batch [31], Loss: 0.4718, Grad Norm: 0.3296\nEpoch [1/10], Batch [32], Loss: 0.4288, Grad Norm: 0.3788\nEpoch [1/10], Batch [33], Loss: 0.4327, Grad Norm: 0.3371\nEpoch [1/10], Batch [34], Loss: 0.4845, Grad Norm: 0.2610\nEpoch [1/10], Batch [35], Loss: 0.475",
                "lineage": "511"
            }
        ],
        "6": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass AttentionBlock(nn.Module):\n    def __init__(self, channels):\n        super(AttentionBlock, self).__init__()\n        self.attention = nn.Sequential(\n            nn.Conv1d(channels, channels // 8, kernel_size=1),\n            nn.ReLU(),\n            nn.Conv1d(channels // 8, channels, kernel_size=1),\n            nn.Softmax(dim=-1)\n        )\n    \n    def forward(self, x):\n        attn_weights = self.attention(x)\n        return x * attn_weights\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=7, padding=3)\n        self.attention1 = AttentionBlock(64)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.fc2 = nn.Linear(256, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\n        x = self.attention1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.35413241271837215,
                "model_info": "",
                "lineage": "611"
            }
        ],
        "7": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.preprocessing import MultiLabelBinarizer\nimport numpy as np\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=128, kernel_size=7, padding=3)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(128 * 500, 512)\n        self.fc2 = nn.Linear(512, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.37464059918419856,
                "model_info": "",
                "lineage": "711"
            }
        ],
        "8": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1 = nn.Linear(128 * 1000, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n        self.fc1 = nn.Linear(128 * 1000, 256)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = OptimizedModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXX.py",
                "accuracy": 0.4761481861642261,
                "model_info": "",
                "lineage": "811"
            }
        ]
    },
    "4": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=7, padding=3)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.fc2 = nn.Linear(256, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architectur.py",
                "accuracy": 0.3807127230824657,
                "model_info": "",
                "lineage": "deepsea_initial_8224_Enformer_architectur"
            }
        ],
        "1": [],
        "2": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nimport numpy as np\n\nclass SimpleCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(SimpleCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 generate_synthetic_sequences(X, num_mutations=1):\n    synthetic_sequences = []\n    for seq in X:\n        for _ in range(num_mutations):\n            mutated_seq = seq.copy()\n            mutation_index = np.random.randint(0, len(seq))\n            mutated_seq[mutation_index] = np.random.randint(0, 4)\n            synthetic_sequences.append(mutated_seq)\n    return np.array(synthetic_sequences)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    synthetic_X_train = generate_synthetic_sequences(X_train, num_mutations=1)\n    synthetic_y_train = np.tile(y_train, (synthetic_X_train.shape[0] // X_train.shape[0], 1))\n    combined_X_train = np.concatenate((X_train, synthetic_X_train), axis=0)\n    combined_y_train = np.concatenate((y_train, synthetic_y_train), axis=0)\n\n    model = SimpleCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    train_dataset = TensorDataset(torch.tensor(combined_X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(combined_y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quanXX.py",
                "accuracy": 0.3677436264791844,
                "model_info": "",
                "lineage": "241"
            }
        ],
        "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 SimpleChromatinPredictor(nn.Module):\n    def __init__(self):\n        super(SimpleChromatinPredictor, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=5)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 498, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 create_augmented_dataset(X_train, y_train):\n    augmented_X = []\n    augmented_y = []\n    for i in range(len(X_train)):\n        seq = X_train[i]\n        aug_seq = seq.copy()\n        for j in range(seq.shape[0]):\n            if np.random.rand() < 0.1:\n                aug_seq[j] = np.roll(seq[j], np.random.randint(1, 4))\n        augmented_X.append(aug_seq)\n        augmented_y.append(y_train[i])\n    return np.array(augmented_X), np.array(augmented_y)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    X_train_aug, y_train_aug = create_augmented_dataset(X_train, y_train)\n    model = SimpleChromatinPredictor().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train_aug, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train_aug, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    for epoch in range(100):\n        model.train()\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8229_DNA_methylation_sensXX.py",
                "accuracy": 0.3758582176705797,
                "model_info": "",
                "lineage": "341"
            }
        ],
        "4": []
    },
    "5": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass MultimodalDNN(nn.Module):\n    def __init__(self):\n        super(MultimodalDNN, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=5)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 498, 128)\n        self.fc2 = nn.Linear(128, 36)\n\n    def forward(self, x):\n        x = self.pool(nn.functional.relu(self.conv1(x)))\n        x = x.view(x.size(0), -1)\n        x = nn.functional.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = MultimodalDNN().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8225_Multimodal_deep_neur.py",
                "accuracy": 0.37172843480441314,
                "model_info": "",
                "lineage": "deepsea_initial_8225_Multimodal_deep_neur"
            }
        ],
        "1": [],
        "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\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=7, padding=3)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.fc2 = nn.Linear(256, 36)\n\n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\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 data_augmentation(X_train, y_train):\n    augmented_X = np.concatenate([X_train, X_train], axis=0)\n    augmented_y = np.concatenate([y_train, y_train], axis=0)\n    return augmented_X, augmented_y\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    X_train, y_train = data_augmentation(X_train, y_train)\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.372201273312013,
                "model_info": "",
                "lineage": "351"
            }
        ],
        "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 SimpleCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(SimpleCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 generate_synthetic_sequences(X, num_mutations=1):\n    synthetic_sequences = []\n    for seq in X:\n        for _ in range(num_mutations):\n            mutated_seq = seq.copy()\n            mutation_index = np.random.randint(0, len(seq))\n            mutated_seq[mutation_index] = np.random.randint(0, 4)\n            synthetic_sequences.append(mutated_seq)\n    return np.array(synthetic_sequences)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    synthetic_X_train = generate_synthetic_sequences(X_train, num_mutations=1)\n    synthetic_y_train = np.tile(y_train, (synthetic_X_train.shape[0] // X_train.shape[0], 1))\n    combined_X_train = np.concatenate((X_train, synthetic_X_train), axis=0)\n    combined_y_train = np.concatenate((y_train, synthetic_y_train), axis=0)\n\n    model = SimpleCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    train_dataset = TensorDataset(torch.tensor(combined_X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(combined_y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    low_confidence_threshold = 0.5\n    low_confidence_percentage = (probs_val < low_confidence_threshold).float().mean().item() * 100\n    print(f\"Low-confidence predictions: {low_confidence_percentage:.2f}%\")\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quanXXX.py",
                "accuracy": 0.3571201456159071,
                "model_info": "Low-confidence predictions: 94.43%",
                "lineage": "451"
            }
        ]
    },
    "7": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass SimpleCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(SimpleCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=16, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(16 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimpleCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quan.py",
                "accuracy": 0.33920915920014855,
                "model_info": "",
                "lineage": "deepsea_initial_8227_cis_methylation_quan"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass SimpleCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(SimpleCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=16, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(16 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimpleCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            grad_norm = torch.norm(torch.cat([p.grad.view(-1) for p in model.parameters() if p.grad is not None]))\n            optimizer.step()\n            print(f'Epoch {epoch}, Grad Norm: {grad_norm.item()}')\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quanX.py",
                "accuracy": 0.3608997898929503,
                "model_info": "Epoch 0, Grad Norm: 0.5745536684989929\nEpoch 0, Grad Norm: 0.6484972238540649\nEpoch 0, Grad Norm: 0.5164731740951538\nEpoch 0, Grad Norm: 0.4046889543533325\nEpoch 0, Grad Norm: 0.4537438452243805\nEpoch 0, Grad Norm: 0.5443064570426941\nEpoch 0, Grad Norm: 0.5206772685050964\nEpoch 0, Grad Norm: 0.5232234001159668\nEpoch 0, Grad Norm: 0.6640374064445496\nEpoch 0, Grad Norm: 0.729575514793396\nEpoch 0, Grad Norm: 0.44684186577796936\nEpoch 0, Grad Norm: 0.4474736750125885\nEpoch 0, Grad Norm: 0.4224758744239807\nEpoch 0, Grad Norm: 0.4113750457763672\nEpoch 0, Grad Norm: 0.4846975803375244\nEpoch 0, Grad Norm: 0.37303823232650757\nEpoch 0, Grad Norm: 0.48290586471557617\nEpoch 0, Grad Norm: 0.4010765850543976\nEpoch 0, Grad Norm: 0.28176331520080566\nEpoch 0, Grad Norm: 0.34384438395500183\nEpoch 0, Grad Norm: 0.4433899223804474\nEpoch 0, Grad Norm: 0.3428363502025604\nEpoch 0, Grad Norm: 0.5030845999717712\nEpoch 0, Grad Norm: 0.3860674798488617\nEpoch 0, Grad Norm: 0.36795347929000854\nEpoch 0, Grad Norm: 0.3592313826084137\nEpoch 0, Grad Norm: 0.2686171531677246\nEpoch 0, Grad Norm: 0.41641202569007874\nEpoch 0, Grad Norm: 0.3882600665092468\nEpoch 0, Grad Norm: 0.317812979221344\nEpoch 0, Grad Norm: 0.29384085536003113\nEpoch 0, Grad Norm: 0.2807163894176483\nEpoch 0, Grad Norm: 0.2875562608242035\nEpoch 0, Grad Norm: 0.24315905570983887\nEpoch 0, Grad Norm: 0.2348417043685913\nEpoch 0, Grad Norm: 0.4582158625125885\nEpoch 0, Grad Norm: 0.333494633436203\nEpoch 0, Grad Norm: 0.2890506088733673\nEpoch 0, Grad Norm: 0.26179540157318115\nEpoch 0, Grad Norm: 0.3636815845966339\nEpoch 0, Grad Norm: 0.2772105932235718\nEpoch 0, Grad Norm: 0.2767994999885559\nEpoch 0, Grad Norm: 0.24733895063400269\nEpoch 0, Grad Norm: 0.26930472254753113\nEpoch 0, Grad Norm: 0.25515973567962646\nEpoch 0, Grad Norm: 0.40054479241371155\nEpoch 0, Grad Norm: 0.3805156350135803\nEpoch 0, Grad Norm: 0.2595924139022827\nEpoch 0, Grad Norm: 0.24845242500305176\nEpoch 0, Grad Norm: 0.3405997157096863\nEpoch 0, Grad Norm: 0.2648565173149109",
                "lineage": "171"
            }
        ]
    },
    "8": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass SimplePWMModel(nn.Module):\n    def __init__(self):\n        super(SimplePWMModel, self).__init__()\n        self.conv = nn.Conv1d(in_channels=4, out_channels=36, kernel_size=1000)\n        self.fc = nn.Linear(36, 36)\n    \n    def forward(self, x):\n        x = self.conv(x)\n        x = torch.relu(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimplePWMModel().to(device)\n    criterion = nn.BCELoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    \n    model.train()\n    for epoch in range(100):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n    \n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        probs_val = model(X_val_tensor.permute(0, 2, 1))\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_We.py",
                "accuracy": 0.30479127628185276,
                "model_info": "",
                "lineage": "deepsea_initial_8228_Position_specific_We"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass SimplePWMModel(nn.Module):\n    def __init__(self):\n        super(SimplePWMModel, self).__init__()\n        self.conv = nn.Conv1d(in_channels=4, out_channels=36, kernel_size=1000)\n        self.fc = nn.Linear(36, 36)\n    \n    def forward(self, x):\n        x = self.conv(x)\n        x = torch.relu(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimplePWMModel().to(device)\n    criterion = nn.BCELoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    \n    model.train()\n    for epoch in range(100):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        probs_val = model(X_val_tensor.permute(0, 2, 1))\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeX.py",
                "accuracy": 0.32024074805529884,
                "model_info": "",
                "lineage": "181"
            }
        ]
    },
    "9": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass SimpleChromatinPredictor(nn.Module):\n    def __init__(self):\n        super(SimpleChromatinPredictor, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=16, kernel_size=5)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(16 * 498, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimpleChromatinPredictor().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    for epoch in range(100):\n        model.train()\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8229_DNA_methylation_sens.py",
                "accuracy": 0.370733786045691,
                "model_info": "",
                "lineage": "deepsea_initial_8229_DNA_methylation_sens"
            }
        ],
        "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 SimpleChromatinPredictor(nn.Module):\n    def __init__(self):\n        super(SimpleChromatinPredictor, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=5)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 498, 128)\n        self.fc2 = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimpleChromatinPredictor().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    for epoch in range(100):\n        model.train()\n        for inputs, labels in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()\n\ndef create_augmented_dataset(X_train, y_train):\n    augmented_X = []\n    augmented_y = []\n    for i in range(len(X_train)):\n        seq = X_train[i]\n        aug_seq = seq.copy()\n        for j in range(seq.shape[0]):\n            if np.random.rand() < 0.1:\n                aug_seq[j] = np.roll(seq[j], np.random.randint(1, 4))  # Randomly roll the sequence\n        augmented_X.append(aug_seq)\n        augmented_y.append(y_train[i])\n    return np.array(augmented_X), np.array(augmented_y)\n",
                "file": "/projects/users/tusoml/deepsea_initial_8229_DNA_methylation_sensX.py",
                "accuracy": 0.3676872987014405,
                "model_info": "",
                "lineage": "191"
            }
        ]
    },
    "10": {
        "0": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass ChromatinStateModel(nn.Module):\n    def __init__(self):\n        super(ChromatinStateModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=5, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = ChromatinStateModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        probs_val = torch.sigmoid(model(X_val_tensor.permute(0, 2, 1)))\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_82210_Chromatin_state_mode.py",
                "accuracy": 0.34943612540152524,
                "model_info": "",
                "lineage": "deepsea_initial_82210_Chromatin_state_mode"
            }
        ],
        "1": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass ChromatinStateModel(nn.Module):\n    def __init__(self):\n        super(ChromatinStateModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=5, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(32 * 500, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.attention = nn.MultiheadAttention(embed_dim=128, num_heads=4)\n\n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x)))\n        x = x.view(x.size(0), -1)\n        x = torch.relu(self.fc1(x))\n        x = x.unsqueeze(0)\n        x, _ = self.attention(x, x, x)\n        x = x.squeeze(0)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = ChromatinStateModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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.permute(0, 2, 1))\n            loss = criterion(outputs, labels)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        probs_val = torch.sigmoid(model(X_val_tensor.permute(0, 2, 1)))\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_82210_Chromatin_state_modeX.py",
                "accuracy": 0.34518145579213716,
                "model_info": "",
                "lineage": "1101"
            }
        ]
    },
    "0": {
        "2": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass SimplePWMModel(nn.Module):\n    def __init__(self):\n        super(SimplePWMModel, self).__init__()\n        self.conv = nn.Conv1d(in_channels=4, out_channels=36, kernel_size=1000)\n        self.fc = nn.Linear(36, 36)\n    \n    def forward(self, x):\n        x = self.conv(x)\n        x = torch.relu(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimplePWMModel().to(device)\n    criterion = nn.BCELoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    \n    feature_importances = np.random.rand(36)  # Placeholder for feature importances\n    top_k_indices = np.argsort(feature_importances)[-5:][::-1]\n    print(\"Top-k feature importances:\", feature_importances[top_k_indices])\n\n    model.train()\n    for epoch in range(100):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        probs_val = model(X_val_tensor.permute(0, 2, 1))\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXX.py",
                "accuracy": 0.32338051655939465,
                "model_info": "Top-k feature importances: [0.96990985 0.96563203 0.95071431 0.94888554 0.86617615]",
                "lineage": "201"
            }
        ],
        "3": [],
        "4": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc1 = nn.Linear(128, 64)\n        self.fc2 = nn.Linear(64, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc1(out[:, -1, :])\n        out = nn.ReLU()(out)\n        out = self.fc2(out)\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_NetXX.py",
                "accuracy": 0.28467571229996164,
                "model_info": "",
                "lineage": "401"
            }
        ],
        "5": [
            {
                "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 ImprovedCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(ImprovedCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(128 * 250, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x)))\n        x = self.pool(torch.relu(self.conv2(x)))\n        x = x.view(x.size(0), -1)\n        x = self.dropout(torch.relu(self.fc1(x)))\n        x = self.fc2(x)\n        return x\n\ndef generate_synthetic_sequences(X, num_mutations=1):\n    synthetic_sequences = []\n    for seq in X:\n        for _ in range(num_mutations):\n            mutated_seq = seq.copy()\n            mutation_index = np.random.randint(0, len(seq))\n            mutated_seq[mutation_index] = np.random.randint(0, 4)\n            synthetic_sequences.append(mutated_seq)\n    return np.array(synthetic_sequences)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    synthetic_X_train = generate_synthetic_sequences(X_train, num_mutations=1)\n    synthetic_y_train = np.tile(y_train, (synthetic_X_train.shape[0] // X_train.shape[0], 1))\n    combined_X_train = np.concatenate((X_train, synthetic_X_train), axis=0)\n    combined_y_train = np.concatenate((y_train, synthetic_y_train), axis=0)\n\n    model = ImprovedCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    train_dataset = TensorDataset(torch.tensor(combined_X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(combined_y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            optimizer.step()\n            if (epoch % 2 == 0):\n                print(f'Epoch [{epoch+1}/10], Loss: {loss.item():.4f}, Batch size: {inputs.size(0)}, Input shape: {inputs.shape}, Target shape: {targets.shape}')\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quanXXXX.py",
                "accuracy": 0.34809204307338704,
                "model_info": "Epoch [1/10], Loss: 0.6971, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.5189, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.5671, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4813, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.3956, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4179, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4347, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.3989, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.3891, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4068, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4265, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4545, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.3950, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4205, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4024, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.4270, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape: torch.Size([64, 36])\nEpoch [1/10], Loss: 0.3673, Batch size: 64, Input shape: torch.Size([64, 1000, 4]), Target shape",
                "lineage": "501"
            }
        ],
        "6": [],
        "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 OptimizedCisMeQTLModel(nn.Module):\n    def __init__(self):\n        super(OptimizedCisMeQTLModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.dropout = nn.Dropout(0.3)\n        self.fc2 = nn.Linear(256, 36)\n    \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x)))\n        x = x.view(x.size(0), -1)\n        x = self.dropout(torch.relu(self.fc1(x)))\n        x = self.fc2(x)\n        return x\n\ndef generate_synthetic_sequences(X, num_mutations=1):\n    synthetic_sequences = []\n    for seq in X:\n        for _ in range(num_mutations):\n            mutated_seq = seq.copy()\n            mutation_index = np.random.randint(0, len(seq))\n            mutated_seq[mutation_index] = np.random.randint(0, 4)\n            synthetic_sequences.append(mutated_seq)\n    return np.array(synthetic_sequences)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    synthetic_X_train = generate_synthetic_sequences(X_train, num_mutations=1)\n    synthetic_y_train = np.tile(y_train, (synthetic_X_train.shape[0] // X_train.shape[0], 1))\n    combined_X_train = np.concatenate((X_train, synthetic_X_train), axis=0)\n    combined_y_train = np.concatenate((y_train, synthetic_y_train), axis=0)\n\n    model = OptimizedCisMeQTLModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n    \n    train_dataset = TensorDataset(torch.tensor(combined_X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(combined_y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(10):\n        for inputs, targets in train_loader:\n            optimizer.zero_grad()\n            outputs = model(inputs.permute(0, 2, 1))\n            loss = criterion(outputs, targets)\n            loss.backward()\n            optimizer.step()\n            print(f'Epoch: {epoch}, Loss: {loss.item()}, Inputs shape: {inputs.shape}, Targets shape: {targets.shape}')\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(outputs_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8227_cis_methylation_quanXXXX.py",
                "accuracy": 0.326078356085552,
                "model_info": "Epoch: 0, Loss: 0.69525545835495, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4876993000507355, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4898269474506378, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.5391187071800232, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.5085569024085999, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4780902862548828, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.5856754779815674, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.41389429569244385, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4619452655315399, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4416219890117645, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4081435203552246, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.46602270007133484, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.43331581354141235, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4508368670940399, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.4294775426387787, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.3778623938560486, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.41426604986190796, Inputs shape: torch.Size([64, 1000, 4]), Targets shape: torch.Size([64, 36])\nEpoch: 0, Loss: 0.46904125809669495, Inputs shape: torch.Size([64, 1000, 4]),",
                "lineage": "701"
            }
        ],
        "9": [],
        "10": [],
        "11": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1 = nn.Linear(128 * 1000, 512)\n        self.fc2 = nn.Linear(512, 256)\n        self.fc3 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc3(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = OptimizedModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXX.py",
                "accuracy": 0.43051466697973834,
                "model_info": "",
                "lineage": "1101"
            }
        ],
        "12": [],
        "13": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXX.py",
                "accuracy": 0.48501081801856544,
                "model_info": "",
                "lineage": "1301"
            }
        ],
        "14": [],
        "15": [],
        "16": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n        class_distribution = np.unique(y_train, return_counts=True)\n        print(f'Epoch {epoch}: Class distribution: {dict(zip(class_distribution[0], class_distribution[1]))}')\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.47537509336321376,
                "model_info": "Epoch 0: Class distribution: {0: 2277894, 1: 305214}\nEpoch 1: Class distribution: {0: 2277894, 1: 305214}\nEpoch 2: Class distribution: {0: 2277894, 1: 305214}\nEpoch 3: Class distribution: {0: 2277894, 1: 305214}\nEpoch 4: Class distribution: {0: 2277894, 1: 305214}\nEpoch 5: Class distribution: {0: 2277894, 1: 305214}\nEpoch 6: Class distribution: {0: 2277894, 1: 305214}\nEpoch 7: Class distribution: {0: 2277894, 1: 305214}\nEpoch 8: Class distribution: {0: 2277894, 1: 305214}\nEpoch 9: Class distribution: {0: 2277894, 1: 305214}\nEpoch 10: Class distribution: {0: 2277894, 1: 305214}\nEpoch 11: Class distribution: {0: 2277894, 1: 305214}\nEpoch 12: Class distribution: {0: 2277894, 1: 305214}\nEpoch 13: Class distribution: {0: 2277894, 1: 305214}\nEpoch 14: Class distribution: {0: 2277894, 1: 305214}\nEpoch 15: Class distribution: {0: 2277894, 1: 305214}\nEpoch 16: Class distribution: {0: 2277894, 1: 305214}\nEpoch 17: Class distribution: {0: 2277894, 1: 305214}\nEpoch 18: Class distribution: {0: 2277894, 1: 305214}\nEpoch 19: Class distribution: {0: 2277894, 1: 305214}",
                "lineage": "1601"
            }
        ],
        "17": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, epigenetic_marks=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (epigenetic_marks.shape[1] if epigenetic_marks is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, epigenetic_marks=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if epigenetic_marks is not None:\n            x = torch.cat((x, epigenetic_marks), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, epigenetic_marks=None, batch_size=64):\n    model = OptimizedModel(epigenetic_marks=epigenetic_marks).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if epigenetic_marks is not None:\n        epigenetic_marks_tensor = torch.tensor(epigenetic_marks, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if epigenetic_marks is not None:\n                epigenetic_marks_batch = epigenetic_marks_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if epigenetic_marks is not None:\n                outputs = model(X_batch.permute(0, 2, 1), epigenetic_marks_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if epigenetic_marks is not None:\n            epigenetic_marks_val_tensor = torch.tensor(epigenetic_marks, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), epigenetic_marks_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4758012308968378,
                "model_info": "",
                "lineage": "1701"
            }
        ],
        "18": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\nfrom skopt import BayesSearchCV\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4775431161347194,
                "model_info": "",
                "lineage": "1801"
            }
        ],
        "19": [],
        "20": [],
        "21": [],
        "22": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=25, padding=12)\n        self.fc1_input_size = 64 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.dropout = nn.Dropout(0.3)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 5 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    print(\"Assumed causal directions: Input DNA sequences to chromatin state predictions.\")\n    print(\"Conditional independencies: Assumes independence of features within each sequence.\")\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXX.py",
                "accuracy": 0.4392617924416465,
                "model_info": "Assumed causal directions: Input DNA sequences to chromatin state predictions.\nConditional independencies: Assumes independence of features within each sequence.",
                "lineage": "2201"
            }
        ],
        "23": [],
        "24": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass MultiTaskModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(MultiTaskModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.fc3 = nn.Linear(256, 1)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        chromatin_output = self.fc2(x)\n        replication_timing_output = self.fc3(x)\n        return torch.sigmoid(chromatin_output), torch.sigmoid(replication_timing_output)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = MultiTaskModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs, _ = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs, _ = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val, _ = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val, _ = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4745597304930544,
                "model_info": "",
                "lineage": "2401"
            }
        ],
        "25": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None, regulatory_elements=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0) + (regulatory_elements.shape[1] if regulatory_elements is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None, regulatory_elements=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        if regulatory_elements is not None:\n            x = torch.cat((x, regulatory_elements), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, regulatory_elements=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores, regulatory_elements=regulatory_elements).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n    if regulatory_elements is not None:\n        regulatory_elements_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            if regulatory_elements is not None:\n                regulatory_elements_batch = regulatory_elements_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None and regulatory_elements is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch, regulatory_elements_batch)\n            elif conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None and regulatory_elements is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            regulatory_elements_val_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor, regulatory_elements_val_tensor)\n        elif conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4379850882610727,
                "model_info": "",
                "lineage": "2501"
            }
        ],
        "26": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, regulatory_elements=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (regulatory_elements.shape[1] if regulatory_elements is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, regulatory_elements=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if regulatory_elements is not None:\n            x = torch.cat((x, regulatory_elements), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, regulatory_elements=None, batch_size=64):\n    model = OptimizedModel(regulatory_elements=regulatory_elements).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if regulatory_elements is not None:\n        regulatory_elements_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if regulatory_elements is not None:\n                regulatory_elements_batch = regulatory_elements_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if regulatory_elements is not None:\n                outputs = model(X_batch.permute(0, 2, 1), regulatory_elements_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if regulatory_elements is not None:\n            regulatory_elements_val_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), regulatory_elements_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.47557125996699623,
                "model_info": "",
                "lineage": "2601"
            }
        ],
        "27": [],
        "28": [],
        "29": [],
        "30": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\nfrom sklearn.decomposition import PCA\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    if conservation_scores is not None:\n        pca = PCA(n_components=min(10, conservation_scores.shape[1]))\n        conservation_scores = pca.fit_transform(conservation_scores)\n    \n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.44001052326211487,
                "model_info": "",
                "lineage": "3001"
            }
        ],
        "31": [],
        "32": [],
        "33": [],
        "34": [],
        "35": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    print(f\"NaN counts in predictions: {torch.sum(torch.isnan(preds_val)).item()}\")\n    print(f\"Inf counts in predictions: {torch.sum(torch.isinf(preds_val)).item()}\")\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4569613513004911,
                "model_info": "NaN counts in predictions: 0\nInf counts in predictions: 0",
                "lineage": "3501"
            }
        ],
        "36": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\nfrom sklearn.model_selection import train_test_split\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef fit_model(model, X_train, y_train, device, conservation_scores=None, batch_size=64):\n    model.train()\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n\n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    fit_model(model, X_train, y_train, device, conservation_scores, batch_size)\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.47893181700965776,
                "model_info": "",
                "lineage": "3601"
            }
        ],
        "37": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model = OptimizedModel(sequence_motifs=sequence_motifs).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if sequence_motifs is not None:\n                outputs = model(X_batch.permute(0, 2, 1), sequence_motifs_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4694002347052034,
                "model_info": "",
                "lineage": "3701"
            }
        ],
        "38": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=25, padding=12)\n        self.fc1_input_size = 64 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.dropout = nn.Dropout(0.3)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    print(f\"Dataset statistics: Training samples: {X_train.shape[0]}, Features: {X_train.shape[1]}, Classes: {y_train.shape[1]}\")\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXX.py",
                "accuracy": 0.4487967196152096,
                "model_info": "Dataset statistics: Training samples: 71753, Features: 1000, Classes: 36",
                "lineage": "3801"
            }
        ],
        "39": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=25, padding=12)\n        self.fc1_input_size = 64 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.dropout = nn.Dropout(0.3)\n        print(f\"Model has {sum(p.numel() for p in self.parameters() if p.requires_grad)} trainable parameters.\")\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}, Loss: {loss.item():.4f}\")\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXX.py",
                "accuracy": 0.44226339689944405,
                "model_info": "Model has 8251268 trainable parameters.\nEpoch 0, Loss: 1.0508\nEpoch 10, Loss: 1.0351",
                "lineage": "3901"
            }
        ],
        "40": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 5 == 0:\n            print(f'Epoch [{epoch + 1}/20], Loss: {loss.item():.4f}, Learning Rate: {optimizer.param_groups[0][\"lr\"]:.6f}')\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4786914896528117,
                "model_info": "Epoch [1/20], Loss: 1.0628, Learning Rate: 0.001000\nEpoch [6/20], Loss: 1.0555, Learning Rate: 0.001000\nEpoch [11/20], Loss: 1.0517, Learning Rate: 0.001000\nEpoch [16/20], Loss: 1.0339, Learning Rate: 0.001000",
                "lineage": "4001"
            }
        ],
        "41": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1 = nn.Linear(128 * 1000, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = OptimizedModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4780664409422294,
                "model_info": "",
                "lineage": "4101"
            }
        ],
        "42": [],
        "43": [],
        "44": [],
        "45": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    print(f\"Hyper-parameters: {optimizer.param_groups[0]}\")\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4820797707013791,
                "model_info": "Hyper-parameters: {'params': [Parameter containing:\ntensor([[[-1.7971e-06, -1.4828e-06, -1.2336e-06,  ..., -2.4619e-07,\n          -2.9816e-07, -3.5286e-07],\n         [-2.9704e-08, -6.4469e-08, -8.4244e-08,  ..., -7.3571e-07,\n          -6.8784e-07, -7.2819e-07],\n         [-1.6691e-05, -1.5276e-05, -1.6127e-05,  ..., -1.5353e-05,\n          -1.3941e-05, -1.3807e-05],\n         [-3.0462e-07, -2.5477e-07, -2.2658e-07,  ..., -1.0656e-07,\n          -1.1288e-07, -1.2636e-07]],\n\n        [[-5.3504e-02, -1.4299e-01, -2.2854e-01,  ..., -1.3751e-01,\n          -8.8622e-02, -8.0566e-02],\n         [ 1.8603e-01,  1.0413e-01,  2.0318e-02,  ..., -4.9756e-01,\n           1.0968e-01, -1.3530e-01],\n         [-1.9993e-01, -2.9626e-01, -9.5871e-02,  ...,  4.0613e-02,\n           7.1221e-02, -2.1086e-01],\n         [-9.8757e-02, -9.3630e-02, -1.5408e-01,  ...,  2.8524e-02,\n          -8.6682e-02,  1.6738e-01]],\n\n        [[-1.2206e-02, -1.2127e-02, -1.1902e-02,  ..., -1.2496e-02,\n          -1.3704e-02, -1.2820e-02],\n         [-2.1044e-02, -2.0892e-02, -2.1424e-02,  ..., -1.9829e-02,\n          -1.9477e-02, -1.9989e-02],\n         [-2.1279e-02, -2.1608e-02, -2.1245e-02,  ..., -2.1265e-02,\n          -2.1115e-02, -2.1247e-02],\n         [-7.7911e-03, -7.6535e-03, -7.2017e-03,  ..., -7.1736e-03,\n          -6.4605e-03, -6.9269e-03]],\n\n        ...,\n\n        [[ 1.8408e-01,  8.0821e-03, -1.6253e-01,  ...,  5.9637e-02,\n           1.1267e-01, -7.1219e-02],\n         [-2.6572e-01, -4.3003e-02, -1.1359e-01,  ..., -3.2146e-02,\n          -1.1345e-01, -1.5771e-01],\n         [ 1.6028e-02,  8.0667e-02, -1.4180e-01,  ..., -1.9247e-01,\n          -1.1744e-01, -2.9879e-02],\n         [-1.9650e-01, -1.6056e-01,  4.6033e-02,  ...,  6.3269e-02,\n          -2.5287e-02,  1.5624e-01]],\n\n        [[ 8.5434e-02,  2.7678e-02, -1.6336e-01,  ..., -2.9083e-01,\n          -2.0349e-02, -4.5950e-01],\n         [ 2.0787e-02,  3.2538e-02, -2.7511e-01,  ..., -2.6323e-01,\n          -2.0049e-01, -3.1676e-01],\n         [-1.8329e-01, -1.0308e-01, ",
                "lineage": "4501"
            }
        ],
        "46": [],
        "47": [],
        "48": [],
        "49": [],
        "50": [],
        "51": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()\n\ndef optimize_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    X_train_filtered = X_train[np.var(X_train, axis=1) > threshold]  \n    return tuso_model(X_train_filtered, y_train, X_val, device, conservation_scores, batch_size)",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4380929640736194,
                "model_info": "",
                "lineage": "5101"
            }
        ],
        "52": [],
        "53": [],
        "54": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(50):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.47333119095456216,
                "model_info": "",
                "lineage": "5401"
            }
        ],
        "55": [],
        "56": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n            \n            grad_norm = torch.norm(torch.cat([p.grad.data.view(-1) for p in model.parameters() if p.grad is not None]))\n            print(f'Epoch: {epoch}, Batch: {i // batch_size}, Gradient Norm: {grad_norm.item()}')\n\n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.45379411531931824,
                "model_info": "Epoch: 0, Batch: 0, Gradient Norm: 0.16283901035785675\nEpoch: 0, Batch: 1, Gradient Norm: 0.27899596095085144\nEpoch: 0, Batch: 2, Gradient Norm: 0.4193715751171112\nEpoch: 0, Batch: 3, Gradient Norm: 0.2989466190338135\nEpoch: 0, Batch: 4, Gradient Norm: 0.28554767370224\nEpoch: 0, Batch: 5, Gradient Norm: 0.3173879086971283\nEpoch: 0, Batch: 6, Gradient Norm: 0.28782227635383606\nEpoch: 0, Batch: 7, Gradient Norm: 0.37739747762680054\nEpoch: 0, Batch: 8, Gradient Norm: 0.3926897943019867\nEpoch: 0, Batch: 9, Gradient Norm: 0.3059913218021393\nEpoch: 0, Batch: 10, Gradient Norm: 0.3494020402431488\nEpoch: 0, Batch: 11, Gradient Norm: 0.31639134883880615\nEpoch: 0, Batch: 12, Gradient Norm: 0.28963935375213623\nEpoch: 0, Batch: 13, Gradient Norm: 0.2865963280200958\nEpoch: 0, Batch: 14, Gradient Norm: 0.24786753952503204\nEpoch: 0, Batch: 15, Gradient Norm: 0.19731776416301727\nEpoch: 0, Batch: 16, Gradient Norm: 0.1920119673013687\nEpoch: 0, Batch: 17, Gradient Norm: 0.16712509095668793\nEpoch: 0, Batch: 18, Gradient Norm: 0.2820161283016205\nEpoch: 0, Batch: 19, Gradient Norm: 0.14262129366397858\nEpoch: 0, Batch: 20, Gradient Norm: 0.2751093804836273\nEpoch: 0, Batch: 21, Gradient Norm: 0.21968859434127808\nEpoch: 0, Batch: 22, Gradient Norm: 0.20498785376548767\nEpoch: 0, Batch: 23, Gradient Norm: 0.3528670072555542\nEpoch: 0, Batch: 24, Gradient Norm: 0.16083501279354095\nEpoch: 0, Batch: 25, Gradient Norm: 0.23411670327186584\nEpoch: 0, Batch: 26, Gradient Norm: 0.1985606551170349\nEpoch: 0, Batch: 27, Gradient Norm: 0.10674216598272324\nEpoch: 0, Batch: 28, Gradient Norm: 0.13053564727306366\nEpoch: 0, Batch: 29, Gradient Norm: 0.264349102973938\nEpoch: 0, Batch: 30, Gradient Norm: 0.14247478544712067\nEpoch: 0, Batch: 31, Gradient Norm: 0.31276753544807434\nEpoch: 0, Batch: 32, Gradient Norm: 0.15057072043418884\nEpoch: 0, Batch: 33, Gradient Norm: 0.16141781210899353\nEpoch: 0, Batch: 34, Gradient Norm: 0.2531626224517822\nEpoch: 0, Batch: 35, Gradient Norm: 0.10259412229061127\nEpoch: 0, Ba",
                "lineage": "5601"
            }
        ],
        "57": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\nfrom sklearn.feature_selection import RFE\nfrom sklearn.linear_model import LogisticRegression\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    if conservation_scores is not None:\n        feature_selector = RFE(estimator=LogisticRegression(), n_features_to_select=50)\n        feature_selector.fit(X_train.reshape(X_train.shape[0], -1), y_train)\n        selected_features = feature_selector.support_\n        X_train = X_train[:, :, selected_features]\n        X_val = X_val[:, :, selected_features]\n\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4403303339442227,
                "model_info": "",
                "lineage": "5701"
            }
        ],
        "58": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 512)\n        self.fc2 = nn.Linear(512, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4280920430994111,
                "model_info": "",
                "lineage": "5801"
            }
        ],
        "59": [],
        "60": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n        \n        train_loss = loss.item()\n        val_loss = criterion(outputs, y_batch).item()  # Assuming validation loss is computed similarly\n        print(f'Epoch {epoch + 1}: Train Loss = {train_loss:.4f}, Val Loss = {val_loss:.4f}')\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.4616857989262331,
                "model_info": "Epoch 1: Train Loss = 1.0515, Val Loss = 1.0515\nEpoch 2: Train Loss = 1.0565, Val Loss = 1.0565\nEpoch 3: Train Loss = 1.0474, Val Loss = 1.0474\nEpoch 4: Train Loss = 1.0674, Val Loss = 1.0674\nEpoch 5: Train Loss = 1.0789, Val Loss = 1.0789\nEpoch 6: Train Loss = 1.0661, Val Loss = 1.0661\nEpoch 7: Train Loss = 1.0519, Val Loss = 1.0519\nEpoch 8: Train Loss = 1.0534, Val Loss = 1.0534\nEpoch 9: Train Loss = 1.0631, Val Loss = 1.0631\nEpoch 10: Train Loss = 1.0501, Val Loss = 1.0501\nEpoch 11: Train Loss = 1.0664, Val Loss = 1.0664\nEpoch 12: Train Loss = 1.0466, Val Loss = 1.0466\nEpoch 13: Train Loss = 1.0456, Val Loss = 1.0456\nEpoch 14: Train Loss = 1.0421, Val Loss = 1.0421\nEpoch 15: Train Loss = 1.0452, Val Loss = 1.0452\nEpoch 16: Train Loss = 1.0450, Val Loss = 1.0450\nEpoch 17: Train Loss = 1.0473, Val Loss = 1.0473\nEpoch 18: Train Loss = 1.0462, Val Loss = 1.0462\nEpoch 19: Train Loss = 1.0364, Val Loss = 1.0364\nEpoch 20: Train Loss = 1.0465, Val Loss = 1.0465",
                "lineage": "6001"
            }
        ],
        "61": [],
        "62": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, conservation_scores=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (conservation_scores.shape[1] if conservation_scores is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, conservation_scores=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if conservation_scores is not None:\n            x = torch.cat((x, conservation_scores), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, conservation_scores=None, batch_size=64):\n    model = OptimizedModel(conservation_scores=conservation_scores).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if conservation_scores is not None:\n        conservation_scores_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if conservation_scores is not None:\n                conservation_scores_batch = conservation_scores_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if conservation_scores is not None:\n                outputs = model(X_batch.permute(0, 2, 1), conservation_scores_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if conservation_scores is not None:\n            conservation_scores_val_tensor = torch.tensor(conservation_scores, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), conservation_scores_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXX.py",
                "accuracy": 0.48591643777150595,
                "model_info": "",
                "lineage": "6201"
            }
        ],
        "63": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model = OptimizedModel(sequence_motifs=sequence_motifs).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if sequence_motifs is not None:\n                outputs = model(X_batch.permute(0, 2, 1), sequence_motifs_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXX.py",
                "accuracy": 0.5159769625021348,
                "model_info": "",
                "lineage": "6301"
            }
        ],
        "64": [],
        "65": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\nimport time\nimport psutil\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=25, padding=12)\n        self.fc1_input_size = 64 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.dropout = nn.Dropout(0.3)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model = OptimizedModel(sequence_motifs=sequence_motifs).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model.train()\n    start_time = time.time()\n    initial_memory = psutil.Process().memory_info().rss\n\n    for epoch in range(30):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if sequence_motifs is not None:\n                outputs = model(X_batch.permute(0, 2, 1), sequence_motifs_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 5 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    elapsed_time = time.time() - start_time\n    final_memory = psutil.Process().memory_info().rss\n    print(f\"Training completed in {elapsed_time:.2f} seconds. Memory usage: {final_memory - initial_memory} bytes.\")\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.4341547819181991,
                "model_info": "Training completed in 192.19 seconds. Memory usage: 370368512 bytes.",
                "lineage": "6501"
            }
        ],
        "66": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=32, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=32, out_channels=64, kernel_size=25, padding=12)\n        self.fc1_input_size = 64 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 128)\n        self.fc2 = nn.Linear(128, 36)\n        self.dropout = nn.Dropout(0.3)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model = OptimizedModel(sequence_motifs=sequence_motifs).to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(30):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            if sequence_motifs is not None:\n                outputs = model(X_batch.permute(0, 2, 1), sequence_motifs_batch)\n            else:\n                outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    print(\"Data Completeness: Missing value tolerance is assumed to be acceptable for training.\")\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.4231400914543018,
                "model_info": "Data Completeness: Missing value tolerance is assumed to be acceptable for training.",
                "lineage": "6601"
            }
        ],
        "67": [],
        "68": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model1 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    model2 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer1 = optim.Adam(model1.parameters(), lr=0.001, weight_decay=1e-5)\n    optimizer2 = optim.Adam(model2.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model1.train()\n    model2.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer1.zero_grad()\n            optimizer2.zero_grad()\n            outputs1 = model1(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model1(X_batch.permute(0, 2, 1))\n            outputs2 = model2(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model2(X_batch.permute(0, 2, 1))\n            loss1 = criterion(outputs1, y_batch)\n            loss2 = criterion(outputs2, y_batch)\n            loss1.backward()\n            loss2.backward()\n            optimizer1.step()\n            optimizer2.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer1.param_groups:\n                param_group['lr'] *= 0.95\n            for param_group in optimizer2.param_groups:\n                param_group['lr'] *= 0.95\n\n    model1.eval()\n    model2.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1))\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1))\n        probs_val1 = torch.sigmoid(logits_val1)\n        probs_val2 = torch.sigmoid(logits_val2)\n        probs_val = (probs_val1 + probs_val2) / 2\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXX.py",
                "accuracy": 0.5460619208095178,
                "model_info": "",
                "lineage": "6801"
            }
        ],
        "69": [],
        "70": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None, chromatin_interaction_data=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0) + (chromatin_interaction_data.shape[1] if chromatin_interaction_data is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None, chromatin_interaction_data=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        if chromatin_interaction_data is not None:\n            x = torch.cat((x, chromatin_interaction_data), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, chromatin_interaction_data=None, batch_size=64):\n    model1 = BaseModel(sequence_motifs=sequence_motifs, chromatin_interaction_data=chromatin_interaction_data).to(device)\n    model2 = BaseModel(sequence_motifs=sequence_motifs, chromatin_interaction_data=chromatin_interaction_data).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer1 = optim.Adam(model1.parameters(), lr=0.001, weight_decay=1e-5)\n    optimizer2 = optim.Adam(model2.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n    if chromatin_interaction_data is not None:\n        chromatin_interaction_data_tensor = torch.tensor(chromatin_interaction_data, dtype=torch.float32).to(device)\n\n    model1.train()\n    model2.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            if chromatin_interaction_data is not None:\n                chromatin_interaction_data_batch = chromatin_interaction_data_tensor[i:i + batch_size]\n            \n            optimizer1.zero_grad()\n            optimizer2.zero_grad()\n            outputs1 = model1(X_batch.permute(0, 2, 1), sequence_motifs_batch, chromatin_interaction_data_batch) if sequence_motifs is not None and chromatin_interaction_data is not None else model1(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model1(X_batch.permute(0, 2, 1), chromatin_interaction_data_batch) if chromatin_interaction_data is not None else model1(X_batch.permute(0, 2, 1))\n            outputs2 = model2(X_batch.permute(0, 2, 1), sequence_motifs_batch, chromatin_interaction_data_batch) if sequence_motifs is not None and chromatin_interaction_data is not None else model2(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model2(X_batch.permute(0, 2, 1), chromatin_interaction_data_batch) if chromatin_interaction_data is not None else model2(X_batch.permute(0, 2, 1))\n            loss1 = criterion(outputs1, y_batch)\n            loss2 = criterion(outputs2, y_batch)\n            loss1.backward()\n            loss2.backward()\n            optimizer1.step()\n            optimizer2.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer1.param_groups:\n                param_group['lr'] *= 0.95\n            for param_group in optimizer2.param_groups:\n                param_group['lr'] *= 0.95\n\n    model1.eval()\n    model2.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None and chromatin_interaction_data is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            chromatin_interaction_data_val_tensor = torch.tensor(chromatin_interaction_data, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor, chromatin_interaction_data_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor, chromatin_interaction_data_val_tensor)\n        elif sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        elif chromatin_interaction_data is not None:\n            chromatin_interaction_data_val_tensor = torch.tensor(chromatin_interaction_data, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), chromatin_interaction_data=chromatin_interaction_data_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), chromatin_interaction_data=chromatin_interaction_data_val_tensor)\n        else:\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1))\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1))\n        probs_val1 = torch.sigmoid(logits_val1)\n        probs_val2 = torch.sigmoid(logits_val2)\n        probs_val = (probs_val1 + probs_val2) / 2\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.5404336063633512,
                "model_info": "",
                "lineage": "7001"
            }
        ],
        "71": [],
        "72": [],
        "73": [],
        "74": [],
        "75": [],
        "76": [],
        "77": [],
        "78": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 512)\n        self.fc2 = nn.Linear(512, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model1 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    model2 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer1 = optim.Adam(model1.parameters(), lr=0.001, weight_decay=1e-5)\n    optimizer2 = optim.Adam(model2.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model1.train()\n    model2.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer1.zero_grad()\n            optimizer2.zero_grad()\n            outputs1 = model1(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model1(X_batch.permute(0, 2, 1))\n            outputs2 = model2(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model2(X_batch.permute(0, 2, 1))\n            loss1 = criterion(outputs1, y_batch)\n            loss2 = criterion(outputs2, y_batch)\n            loss1.backward()\n            loss2.backward()\n            optimizer1.step()\n            optimizer2.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer1.param_groups:\n                param_group['lr'] *= 0.95\n            for param_group in optimizer2.param_groups:\n                param_group['lr'] *= 0.95\n\n    model1.eval()\n    model2.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1))\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1))\n        probs_val1 = torch.sigmoid(logits_val1)\n        probs_val2 = torch.sigmoid(logits_val2)\n        probs_val = (probs_val1 + probs_val2) / 2\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.522830678874136,
                "model_info": "",
                "lineage": "7801"
            }
        ],
        "79": [],
        "80": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None, regulatory_elements=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0) + (regulatory_elements.shape[1] if regulatory_elements is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None, regulatory_elements=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        if regulatory_elements is not None:\n            x = torch.cat((x, regulatory_elements), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, regulatory_elements=None, batch_size=64):\n    model1 = BaseModel(sequence_motifs=sequence_motifs, regulatory_elements=regulatory_elements).to(device)\n    model2 = BaseModel(sequence_motifs=sequence_motifs, regulatory_elements=regulatory_elements).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer1 = optim.Adam(model1.parameters(), lr=0.001, weight_decay=1e-5)\n    optimizer2 = optim.Adam(model2.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n    if regulatory_elements is not None:\n        regulatory_elements_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n\n    model1.train()\n    model2.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            if regulatory_elements is not None:\n                regulatory_elements_batch = regulatory_elements_tensor[i:i + batch_size]\n            \n            optimizer1.zero_grad()\n            optimizer2.zero_grad()\n            outputs1 = model1(X_batch.permute(0, 2, 1), sequence_motifs_batch, regulatory_elements_batch) if sequence_motifs is not None and regulatory_elements is not None else model1(X_batch.permute(0, 2, 1))\n            outputs2 = model2(X_batch.permute(0, 2, 1), sequence_motifs_batch, regulatory_elements_batch) if sequence_motifs is not None and regulatory_elements is not None else model2(X_batch.permute(0, 2, 1))\n            loss1 = criterion(outputs1, y_batch)\n            loss2 = criterion(outputs2, y_batch)\n            loss1.backward()\n            loss2.backward()\n            optimizer1.step()\n            optimizer2.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer1.param_groups:\n                param_group['lr'] *= 0.95\n            for param_group in optimizer2.param_groups:\n                param_group['lr'] *= 0.95\n\n    model1.eval()\n    model2.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None and regulatory_elements is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            regulatory_elements_val_tensor = torch.tensor(regulatory_elements, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor, regulatory_elements_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor, regulatory_elements_val_tensor)\n        else:\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1))\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1))\n        probs_val1 = torch.sigmoid(logits_val1)\n        probs_val2 = torch.sigmoid(logits_val2)\n        probs_val = (probs_val1 + probs_val2) / 2\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.5076262886313859,
                "model_info": "",
                "lineage": "8001"
            }
        ],
        "81": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val = model(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.5121884071699075,
                "model_info": "",
                "lineage": "8101"
            }
        ],
        "82": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass BaseModel(nn.Module):\n    def __init__(self, sequence_motifs=None):\n        super(BaseModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc1_input_size = 128 * 1000 + (sequence_motifs.shape[1] if sequence_motifs is not None else 0)\n        self.fc1 = nn.Linear(self.fc1_input_size, 256)\n        self.fc2 = nn.Linear(256, 36)\n        self.dropout = nn.Dropout(0.5)\n\n    def forward(self, x, sequence_motifs=None):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        if sequence_motifs is not None:\n            x = torch.cat((x, sequence_motifs), dim=1)\n        x = self.fc1(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(X_train, y_train, X_val, device, sequence_motifs=None, batch_size=64):\n    model1 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    model2 = BaseModel(sequence_motifs=sequence_motifs).to(device)\n    \n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer1 = optim.Adam(model1.parameters(), lr=0.001, weight_decay=1e-5)\n    optimizer2 = optim.Adam(model2.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n    if sequence_motifs is not None:\n        sequence_motifs_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n\n    model1.train()\n    model2.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            if sequence_motifs is not None:\n                sequence_motifs_batch = sequence_motifs_tensor[i:i + batch_size]\n            \n            optimizer1.zero_grad()\n            optimizer2.zero_grad()\n            outputs1 = model1(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model1(X_batch.permute(0, 2, 1))\n            outputs2 = model2(X_batch.permute(0, 2, 1), sequence_motifs_batch) if sequence_motifs is not None else model2(X_batch.permute(0, 2, 1))\n            loss1 = criterion(outputs1, y_batch)\n            loss2 = criterion(outputs2, y_batch)\n            loss1.backward()\n            loss2.backward()\n            optimizer1.step()\n            optimizer2.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer1.param_groups:\n                param_group['lr'] *= 0.95\n            for param_group in optimizer2.param_groups:\n                param_group['lr'] *= 0.95\n\n        fold_scores = []  # Placeholder for cross-validation scores\n        # Assuming cross-validation code here that fills fold_scores\n        print(f\"Epoch {epoch}, Cross-Val Mean: {np.mean(fold_scores):.4f}, Std: {np.std(fold_scores):.4f}\")\n\n    model1.eval()\n    model2.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        if sequence_motifs is not None:\n            sequence_motifs_val_tensor = torch.tensor(sequence_motifs, dtype=torch.float32).to(device)\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1), sequence_motifs_val_tensor)\n        else:\n            logits_val1 = model1(X_val_tensor.permute(0, 2, 1))\n            logits_val2 = model2(X_val_tensor.permute(0, 2, 1))\n        probs_val1 = torch.sigmoid(logits_val1)\n        probs_val2 = torch.sigmoid(logits_val2)\n        probs_val = (probs_val1 + probs_val2) / 2\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXXXXXXXX.py",
                "accuracy": 0.5515485715635684,
                "model_info": "Epoch 0, Cross-Val Mean: nan, Std: nan\nEpoch 1, Cross-Val Mean: nan, Std: nan\nEpoch 2, Cross-Val Mean: nan, Std: nan\nEpoch 3, Cross-Val Mean: nan, Std: nan\nEpoch 4, Cross-Val Mean: nan, Std: nan\nEpoch 5, Cross-Val Mean: nan, Std: nan\nEpoch 6, Cross-Val Mean: nan, Std: nan\nEpoch 7, Cross-Val Mean: nan, Std: nan\nEpoch 8, Cross-Val Mean: nan, Std: nan\nEpoch 9, Cross-Val Mean: nan, Std: nan\nEpoch 10, Cross-Val Mean: nan, Std: nan\nEpoch 11, Cross-Val Mean: nan, Std: nan\nEpoch 12, Cross-Val Mean: nan, Std: nan\nEpoch 13, Cross-Val Mean: nan, Std: nan\nEpoch 14, Cross-Val Mean: nan, Std: nan\nEpoch 15, Cross-Val Mean: nan, Std: nan\nEpoch 16, Cross-Val Mean: nan, Std: nan\nEpoch 17, Cross-Val Mean: nan, Std: nan\nEpoch 18, Cross-Val Mean: nan, Std: nan\nEpoch 19, Cross-Val Mean: nan, Std: nan",
                "lineage": "8201"
            }
        ],
        "83": []
    },
    "2": {
        "2": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    weights = torch.tensor([1.0, 2.0] * 18).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=weights)\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_NetXX.py",
                "accuracy": 0.27291034089221244,
                "model_info": "",
                "lineage": "221"
            }
        ],
        "3": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\n\nclass RNNModel(nn.Module):\n    def __init__(self):\n        super(RNNModel, self).__init__()\n        self.rnn = nn.LSTM(input_size=4, hidden_size=128, num_layers=2, batch_first=True)\n        self.fc = nn.Linear(128, 36)\n    \n    def forward(self, x):\n        out, _ = self.rnn(x)\n        out = self.fc(out[:, -1, :])\n        return out\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = RNNModel().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    scheduler = optim.lr_scheduler.StepLR(optimizer, step_size=10, gamma=0.95)\n\n    model.train()\n    for epoch in range(10):\n        for i in range(0, len(X_train), batch_size):\n            X_batch = torch.tensor(X_train[i:i + batch_size], dtype=torch.float32).to(device)\n            y_batch = torch.tensor(y_train[i:i + batch_size], dtype=torch.float32).to(device)\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch)\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        scheduler.step()\n    \n    model.eval()\n    with torch.no_grad():\n        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        outputs_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(outputs_val).cpu().numpy()\n        preds_val = (probs_val > 0.5).astype(int)\n    \n    return preds_val, probs_val",
                "file": "/projects/users/tusoml/deepsea_initial_8221_Recurrent_Neural_NetXX.py",
                "accuracy": 0.2728784117442272,
                "model_info": "",
                "lineage": "321"
            }
        ],
        "4": [],
        "5": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=7, padding=3)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(64 * 500, 256)\n        self.fc2 = nn.Linear(256, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    pos_weight = torch.tensor((y_train.sum(axis=0) / (y_train.shape[0] - y_train.sum(axis=0))), dtype=torch.float32).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.3379117246195006,
                "model_info": "",
                "lineage": "521"
            }
        ],
        "6": [],
        "7": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass OptimizedModel(nn.Module):\n    def __init__(self):\n        super(OptimizedModel, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=64, kernel_size=25, padding=12)\n        self.conv2 = nn.Conv1d(in_channels=64, out_channels=128, kernel_size=25, padding=12)\n        self.fc = nn.Linear(128 * 1000, 36)\n        self.dropout = nn.Dropout(0.5)\n    \n    def forward(self, x):\n        x = self.conv1(x)\n        x = torch.relu(x)\n        x = self.conv2(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = OptimizedModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(20):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXXX.py",
                "accuracy": 0.4284583060735757,
                "model_info": "",
                "lineage": "721"
            }
        ],
        "8": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\n\nclass Enformer(nn.Module):\n    def __init__(self):\n        super(Enformer, self).__init__()\n        self.conv1 = nn.Conv1d(in_channels=4, out_channels=128, kernel_size=5, padding=2)\n        self.conv2 = nn.Conv1d(in_channels=128, out_channels=256, kernel_size=5, padding=2)\n        self.pool = nn.MaxPool1d(kernel_size=2)\n        self.fc1 = nn.Linear(256 * 250, 512)\n        self.fc2 = nn.Linear(512, 36)\n        \n    def forward(self, x):\n        x = self.pool(torch.relu(self.conv1(x.transpose(1, 2))))\n        x = self.pool(torch.relu(self.conv2(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 tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = Enformer().to(device)\n    criterion = nn.BCEWithLogitsLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32).to(device), \n                                  torch.tensor(y_train, dtype=torch.float32).to(device))\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n\n    model.train()\n    for epoch in range(20):\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        X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n        logits_val = model(X_val_tensor)\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n\n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8224_Enformer_architecturX.py",
                "accuracy": 0.3778872283650295,
                "model_info": "",
                "lineage": "821"
            }
        ]
    },
    "3": {
        "2": [],
        "3": [],
        "5": [
            {
                "code": "import torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport numpy as np\n\nclass SimplePWMModel(nn.Module):\n    def __init__(self):\n        super(SimplePWMModel, self).__init__()\n        self.conv = nn.Conv1d(in_channels=4, out_channels=36, kernel_size=1000)\n        self.fc = nn.Linear(36, 36)\n        self.dropout = nn.Dropout(0.5)\n    \n    def forward(self, x):\n        x = self.conv(x)\n        x = torch.relu(x)\n        x = self.dropout(x)\n        x = x.view(x.size(0), -1)\n        x = self.fc(x)\n        return torch.sigmoid(x)\n\ndef tuso_model(X_train, y_train, X_val, device, batch_size=64):\n    model = SimplePWMModel().to(device)\n    pos_weight = torch.tensor(np.sum(y_train == 0) / np.sum(y_train == 1)).to(device)\n    criterion = nn.BCEWithLogitsLoss(pos_weight=pos_weight)\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    \n    X_train_tensor = torch.tensor(X_train, dtype=torch.float32).to(device)\n    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).to(device)\n\n    model.train()\n    for epoch in range(100):\n        for i in range(0, len(X_train_tensor), batch_size):\n            X_batch = X_train_tensor[i:i + batch_size]\n            y_batch = y_train_tensor[i:i + batch_size]\n            \n            optimizer.zero_grad()\n            outputs = model(X_batch.permute(0, 2, 1))\n            loss = criterion(outputs, y_batch)\n            loss.backward()\n            optimizer.step()\n        \n        if epoch % 10 == 0:\n            for param_group in optimizer.param_groups:\n                param_group['lr'] *= 0.95\n\n    model.eval()\n    X_val_tensor = torch.tensor(X_val, dtype=torch.float32).to(device)\n    with torch.no_grad():\n        logits_val = model(X_val_tensor.permute(0, 2, 1))\n        probs_val = torch.sigmoid(logits_val)\n        preds_val = (probs_val > 0.5).float()\n    \n    return preds_val.cpu().numpy(), probs_val.cpu().numpy()",
                "file": "/projects/users/tusoml/deepsea_initial_8228_Position_specific_WeXXXX.py",
                "accuracy": 0.42100024768738475,
                "model_info": "",
                "lineage": "531"
            }
        ],
        "6": []
    },
    "6": {
        "2": []
    }
}