{
    "0": {
        "0": [
            {
                "code": "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.neighbors import NearestNeighbors\n\nclass GCNLayer(nn.Module):\n    def __init__(self, in_features, out_features):\n        super(GCNLayer, self).__init__()\n        self.weight = nn.Parameter(torch.randn(in_features, out_features))\n    \n    def forward(self, x, adj):\n        return torch.relu(torch.matmul(adj, torch.matmul(x, self.weight)))\n\nclass GCN(nn.Module):\n    def __init__(self, in_features, hidden_features, out_features):\n        super(GCN, self).__init__()\n        self.layer1 = GCNLayer(in_features, hidden_features)\n        self.layer2 = GCNLayer(hidden_features, out_features)\n\n    def forward(self, x, adj):\n        x = self.layer1(x, adj)\n        x = self.layer2(x, adj)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    y_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    gene_expression = adata_sc.X\n    model = GCN(gene_expression.shape[1], 16, len(cell_types))\n    \n    nbrs = NearestNeighbors(n_neighbors=5).fit(adata_sp.X)\n    distances, indices = nbrs.kneighbors(adata_sp.X)\n    \n    adj = np.zeros((adata_sp.shape[0], adata_sp.shape[0]))\n    for i in range(adj.shape[0]):\n        for j in indices[i]:\n            adj[i, j] = 1\n    adj = torch.FloatTensor(adj)\n    \n    gene_expression_tensor = torch.FloatTensor(adata_sp.X.toarray())\n    model.train()\n    optimizer = optim.Adam(model.parameters(), lr=0.01)\n    \n    for epoch in range(100):\n        optimizer.zero_grad()\n        output = model(gene_expression_tensor, adj)\n        loss = nn.BCEWithLogitsLoss()(output, torch.FloatTensor(y_onehot[:gene_expression_tensor.shape[0]]))\n        loss.backward()\n        optimizer.step()\n    \n    with torch.no_grad():\n        model.eval()\n        predictions = model(gene_expression_tensor, adj)\n        adata_sp.obsm['proportions_pred'] = torch.sigmoid(predictions).numpy()\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round10_graph_convolutional_.py",
                "accuracy": -21.618459511082758,
                "model_info": "",
                "lineage": "spatial_decomp_tusoml_round10_graph_convolutional_"
            }
        ],
        "1": [
            {
                "code": "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.neighbors import NearestNeighbors\nimport umap\n\nclass GCNLayer(nn.Module):\n    def __init__(self, in_features, out_features):\n        super(GCNLayer, self).__init__()\n        self.weight = nn.Parameter(torch.randn(in_features, out_features))\n    \n    def forward(self, x, adj):\n        return torch.relu(torch.matmul(adj, torch.matmul(x, self.weight)))\n\nclass GCN(nn.Module):\n    def __init__(self, in_features, hidden_features, out_features):\n        super(GCN, self).__init__()\n        self.layer1 = GCNLayer(in_features, hidden_features)\n        self.layer2 = GCNLayer(hidden_features, out_features)\n\n    def forward(self, x, adj):\n        x = self.layer1(x, adj)\n        x = self.layer2(x, adj)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    y_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    gene_expression = adata_sc.X\n    model = GCN(gene_expression.shape[1], 16, len(cell_types))\n    \n    reducer = umap.UMAP(n_neighbors=5, min_dist=0.1, metric='euclidean')\n    adata_sp_embedded = reducer.fit_transform(adata_sp.X.toarray())\n    \n    nbrs = NearestNeighbors(n_neighbors=5).fit(adata_sp_embedded)\n    distances, indices = nbrs.kneighbors(adata_sp_embedded)\n    \n    adj = np.zeros((adata_sp.shape[0], adata_sp.shape[0]))\n    for i in range(adj.shape[0]):\n        for j in indices[i]:\n            adj[i, j] = 1\n    adj = torch.FloatTensor(adj)\n    \n    gene_expression_tensor = torch.FloatTensor(adata_sp.X.toarray())\n    model.train()\n    optimizer = optim.Adam(model.parameters(), lr=0.01)\n    \n    for epoch in range(100):\n        optimizer.zero_grad()\n        output = model(gene_expression_tensor, adj)\n        loss = nn.BCEWithLogitsLoss()(output, torch.FloatTensor(y_onehot[:gene_expression_tensor.shape[0]]))\n        loss.backward()\n        optimizer.step()\n    \n    with torch.no_grad():\n        model.eval()\n        predictions = model(gene_expression_tensor, adj)\n        adata_sp.obsm['proportions_pred'] = torch.sigmoid(predictions).numpy()\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round10_graph_convolutional_X.py",
                "accuracy": -21.618459511082758,
                "model_info": "",
                "lineage": "101"
            }
        ],
        "2": [],
        "3": [],
        "4": [],
        "5": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    fold_losses = []\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        fold_losses.append(loss.item())\n\n    mean_loss = np.mean(fold_losses)\n    std_loss = np.std(fold_losses)\n    print(f\"Cross-validation fold scores - Mean Loss: {mean_loss:.4f}, Std Loss: {std_loss:.4f}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.8310339929073192,
                "model_info": "Cross-validation fold scores - Mean Loss: 0.4113, Std Loss: 0.4987",
                "lineage": "501"
            }
        ],
        "6": [],
        "7": [],
        "8": [],
        "9": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n\n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.91700422309193,
                "model_info": "",
                "lineage": "901"
            }
        ],
        "10": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    if 'spatial_coordinates' in adata_sp.obsm:\n        spatial_features = pairwise_distances(adata_sp.obsm['spatial_coordinates'])\n    else:\n        spatial_features = np.zeros((proportions.shape[0], proportions.shape[0]))\n\n    spatial_autocorrelation = np.corrcoef(proportions.T)\n    \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.8766595653254868,
                "model_info": "",
                "lineage": "1001"
            }
        ],
        "11": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.feature_selection import VarianceThreshold\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    selector = VarianceThreshold(threshold=0.1)\n    adata_sc_filtered = selector.fit_transform(adata_sc.X.toarray())\n    adata_sp_filtered = selector.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_filtered.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_filtered, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_filtered, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.9298845932238986,
                "model_info": "",
                "lineage": "1101"
            }
        ],
        "12": [],
        "13": [],
        "14": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    noise = torch.randn_like(torch.tensor(refined_proportions, dtype=torch.float32)) * 0.1\n    augmented_proportions = refined_proportions + noise.numpy()\n    adata_sp.obsm[\"proportions_pred\"] = np.clip(augmented_proportions, 0, 1)\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -1.4773172389463054,
                "model_info": "",
                "lineage": "1401"
            }
        ],
        "15": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import silhouette_score\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        \n        if epoch % 10 == 0:\n            trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n            frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n            print(f'Epoch {epoch}: Trainable params = {trainable_params}, Frozen params = {frozen_params}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    silhouette_avg = silhouette_score(refined_proportions, adata_sp.obsm['cell_type_clusters'])\n    print(f'Silhouette Score: {silhouette_avg}')\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.180305484114172,
                "model_info": "Epoch 0: Trainable params = 4174349, Frozen params = 0\nEpoch 10: Trainable params = 4174349, Frozen params = 0\nEpoch 20: Trainable params = 4174349, Frozen params = 0\nEpoch 30: Trainable params = 4174349, Frozen params = 0\nEpoch 40: Trainable params = 4174349, Frozen params = 0\nEpoch 50: Trainable params = 4174349, Frozen params = 0\nEpoch 60: Trainable params = 4174349, Frozen params = 0\nEpoch 70: Trainable params = 4174349, Frozen params = 0\nEpoch 80: Trainable params = 4174349, Frozen params = 0\nEpoch 90: Trainable params = 4174349, Frozen params = 0\nSilhouette Score: 1.0",
                "lineage": "1501"
            }
        ],
        "16": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    refined_proportions += np.random.normal(0, 0.1, refined_proportions.shape)\n    refined_proportions = np.clip(refined_proportions, 0, 1)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -1.5905566061779208,
                "model_info": "",
                "lineage": "1601"
            }
        ],
        "17": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    print(\"Initial class balance:\", np.bincount(np.argmax(labels_onehot, axis=1)))\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    print(\"Final class balance:\", np.bincount(np.argmax(refined_proportions, axis=1)))\n    print(\"Number of trainable parameters:\", sum(p.numel() for p in model.parameters() if p.requires_grad))\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.281227954370989,
                "model_info": "Initial class balance: [ 276  180  106  193  343 3615 1495 1098  120  191  287 2473  115]\nFinal class balance: [ 5  0 16  0  3  6 13 25  3  6  2  0 21]\nNumber of trainable parameters: 2078989",
                "lineage": "1701"
            }
        ],
        "18": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport networkx as nx\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    G = nx.Graph()\n    G.add_nodes_from(range(len(adata_sp)))\n    for i in range(len(adata_sp)):\n        for j in range(len(adata_sp)):\n            if i != j:\n                distance = np.linalg.norm(adata_sp.obsm['spatial'][i] - adata_sp.obsm['spatial'][j])\n                G.add_edge(i, j, weight=1/distance)\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.828925148395836,
                "model_info": "",
                "lineage": "1801"
            }
        ],
        "19": [],
        "20": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.conv1 = nn.Linear(input_dim, 128)\n        self.conv2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.conv1(x))\n        return self.conv2(x)\n\ndef create_spatial_graph(adata_sp):\n    edge_index = torch.tensor([[0, 1], [1, 0]], dtype=torch.long)\n    return edge_index\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    edge_index = create_spatial_graph(adata_sp)\n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        data = torch.tensor(adata_sc.X.toarray(), dtype=torch.float32)\n        outputs = model(data)\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        data_sp = torch.tensor(adata_sp.X.toarray(), dtype=torch.float32)\n        spot_outputs = model(data_sp)\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -0.7914300794985322,
                "model_info": "",
                "lineage": "2001"
            }
        ],
        "21": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": 0.025914692826250568,
                "model_info": "",
                "lineage": "2101"
            }
        ],
        "22": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch: {epoch + 1}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -1.2881109108747677,
                "model_info": "Epoch: 1, Loss: 2.556165933609009\nEpoch: 2, Loss: 1.922408938407898\nEpoch: 3, Loss: 1.9683326482772827\nEpoch: 4, Loss: 1.7397868633270264\nEpoch: 5, Loss: 1.6551756858825684\nEpoch: 6, Loss: 1.4913853406906128\nEpoch: 7, Loss: 1.4264850616455078\nEpoch: 8, Loss: 1.345401406288147\nEpoch: 9, Loss: 1.2193238735198975\nEpoch: 10, Loss: 1.1548458337783813\nEpoch: 11, Loss: 1.0919098854064941\nEpoch: 12, Loss: 0.9995850920677185\nEpoch: 13, Loss: 0.94258713722229\nEpoch: 14, Loss: 0.8894063234329224\nEpoch: 15, Loss: 0.8204784393310547\nEpoch: 16, Loss: 0.7737143039703369\nEpoch: 17, Loss: 0.7249657511711121\nEpoch: 18, Loss: 0.6694529056549072\nEpoch: 19, Loss: 0.6298256516456604\nEpoch: 20, Loss: 0.5900124311447144\nEpoch: 21, Loss: 0.5500622391700745\nEpoch: 22, Loss: 0.5152079463005066\nEpoch: 23, Loss: 0.48210030794143677\nEpoch: 24, Loss: 0.4514061510562897\nEpoch: 25, Loss: 0.42350807785987854\nEpoch: 26, Loss: 0.39587336778640747\nEpoch: 27, Loss: 0.3707507252693176\nEpoch: 28, Loss: 0.35019832849502563\nEpoch: 29, Loss: 0.32821252942085266\nEpoch: 30, Loss: 0.31010523438453674\nEpoch: 31, Loss: 0.29069826006889343\nEpoch: 32, Loss: 0.27518999576568604\nEpoch: 33, Loss: 0.2586641311645508\nEpoch: 34, Loss: 0.24493449926376343\nEpoch: 35, Loss: 0.23036934435367584\nEpoch: 36, Loss: 0.2181621789932251\nEpoch: 37, Loss: 0.2052401453256607\nEpoch: 38, Loss: 0.19423028826713562\nEpoch: 39, Loss: 0.18305598199367523\nEpoch: 40, Loss: 0.17304234206676483\nEpoch: 41, Loss: 0.1632278710603714\nEpoch: 42, Loss: 0.1537119448184967\nEpoch: 43, Loss: 0.14512766897678375\nEpoch: 44, Loss: 0.1362558901309967\nEpoch: 45, Loss: 0.12857531011104584\nEpoch: 46, Loss: 0.12051843851804733\nEpoch: 47, Loss: 0.11339254677295685\nEpoch: 48, Loss: 0.10611335188150406\nEpoch: 49, Loss: 0.09960445016622543\nEpoch: 50, Loss: 0.0929984599351883\nEpoch: 51, Loss: 0.0871671736240387\nEpoch: 52, Loss: 0.08126514405012131\nEpoch: 53, Loss: 0.07590604573488235\nEpoch: 54, Loss: 0.0708332508802414\nEpoch: 55, Loss: 0.06593571603298187\nEpoch: 56, L",
                "lineage": "2201"
            }
        ],
        "23": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.decomposition import PCA\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    pca = PCA(n_components=0.95)\n    proportions_reduced = pca.fit_transform(proportions)\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions_reduced)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.01418299552079223,
                "model_info": "",
                "lineage": "2301"
            }
        ],
        "24": [],
        "25": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    if adata_sc.shape[0] == 0 or adata_sp.shape[0] == 0:\n        raise ValueError(\"Input data cannot be empty.\")\n    \n    if adata_sc.shape[1] != adata_sp.shape[1]:\n        raise ValueError(\"Mismatch in number of features between adata_sc and adata_sp.\")\n    \n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}: Loss = {loss.item():.4f}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -0.12132830915682392,
                "model_info": "Epoch 0: Loss = 2.5355\nEpoch 10: Loss = 1.2243\nEpoch 20: Loss = 0.9113\nEpoch 30: Loss = 0.7364\nEpoch 40: Loss = 0.6490\nEpoch 50: Loss = 0.5885\nEpoch 60: Loss = 0.5449\nEpoch 70: Loss = 0.5117\nEpoch 80: Loss = 0.4850\nEpoch 90: Loss = 0.4630",
                "lineage": "2501"
            }
        ],
        "26": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass MultiTaskModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(MultiTaskModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = MultiTaskModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.023369316804569686,
                "model_info": "",
                "lineage": "2601"
            }
        ],
        "27": [],
        "28": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport networkx as nx\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef create_spatial_graph(adata_sp):\n    G = nx.Graph()\n    for i in range(adata_sp.shape[0]):\n        G.add_node(i)\n    # Add edges based on spatial proximity\n    # This is a placeholder; actual implementation will depend on spatial coordinates\n    return G\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    G = create_spatial_graph(adata_sp)\n    spatial_features = np.array([list(nx.get_node_attributes(G, 'feature').values()) for _ in range(adata_sp.shape[0])])\n    \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.23904462145064131,
                "model_info": "",
                "lineage": "2801"
            }
        ],
        "29": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import r2_score\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.805602410264913,
                "model_info": "",
                "lineage": "2901"
            }
        ],
        "30": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nimport networkx as nx\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    if 'spatial_coords' in adata_sp.obsm.keys():\n        G = nx.from_numpy_array(adata_sp.obsm['spatial_coords']) \n        for i in range(proportions.shape[0]):\n            neighbors = list(G.neighbors(i))\n            if neighbors:\n                proportions[i] = np.mean(proportions[neighbors], axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.04503221672196567,
                "model_info": "",
                "lineage": "3001"
            }
        ],
        "31": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport networkx as nx\n\nclass EnhancedModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(EnhancedModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef create_spatial_graph(adata_sp):\n    G = nx.Graph()\n    for i in range(adata_sp.shape[0]):\n        G.add_node(i, pos=adata_sp.obsm['spatial'][i])\n    return G\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = EnhancedModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    G = create_spatial_graph(adata_sp)\n    spatial_features = np.array([G.degree(i) for i in range(len(G))])\n    proportions += spatial_features[:, np.newaxis] * 0.01\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.11890304017240402,
                "model_info": "",
                "lineage": "3101"
            }
        ],
        "32": [],
        "33": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    if 'spatial_coordinates' in adata_sp.obsm.keys():\n        spatial_autocorrelation = pairwise_distances(adata_sp.obsm['spatial_coordinates'], metric='euclidean')\n        proportions += spatial_autocorrelation @ proportions / np.max(spatial_autocorrelation)\n\n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.4388247069763378,
                "model_info": "",
                "lineage": "3301"
            }
        ],
        "34": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.054397519452198,
                "model_info": "",
                "lineage": "3401"
            }
        ],
        "35": [],
        "36": [],
        "37": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    if 'spatial_coordinates' in adata_sp.obsm:\n        spatial_features = pairwise_distances(adata_sp.obsm['spatial_coordinates'])\n        adata_sp.obsm['spatial_features'] = spatial_features\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.17398720982097451,
                "model_info": "",
                "lineage": "3701"
            }
        ],
        "38": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        \n        if epoch % 10 == 0:\n            print(f'Epoch: {epoch}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -1.1176552511923943,
                "model_info": "Epoch: 0, Loss: 2.5218019485473633\nEpoch: 10, Loss: 1.2368006706237793\nEpoch: 20, Loss: 0.6970317959785461\nEpoch: 30, Loss: 0.4102746844291687\nEpoch: 40, Loss: 0.24303917586803436\nEpoch: 50, Loss: 0.14458142220973969\nEpoch: 60, Loss: 0.0858689695596695\nEpoch: 70, Loss: 0.05103972554206848\nEpoch: 80, Loss: 0.03129640594124794\nEpoch: 90, Loss: 0.020298976451158524",
                "lineage": "3801"
            }
        ],
        "39": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f'Epoch {epoch}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -1.095952321338483,
                "model_info": "Epoch 0, Loss: 2.537003755569458\nEpoch 10, Loss: 1.3143675327301025\nEpoch 20, Loss: 0.7691046595573425\nEpoch 30, Loss: 0.47179901599884033\nEpoch 40, Loss: 0.30545637011528015\nEpoch 50, Loss: 0.19755178689956665\nEpoch 60, Loss: 0.12711872160434723\nEpoch 70, Loss: 0.08175992220640182\nEpoch 80, Loss: 0.05347829312086105\nEpoch 90, Loss: 0.03635672107338905",
                "lineage": "3901"
            }
        ],
        "40": [],
        "41": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import silhouette_score\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        cluster_proportions = proportions[cluster_indices]\n        if len(cluster_indices) > 1:\n            refined_proportions[cluster_indices] = cluster_proportions.mean(axis=0)\n        else:\n            refined_proportions[cluster_indices] = cluster_proportions\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    if len(np.unique(adata_sp.obsm['cell_type_clusters'])) > 1:\n        silhouette_avg = silhouette_score(refined_proportions, adata_sp.obsm['cell_type_clusters'])\n        print(f'Silhouette Score: {silhouette_avg}')\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.050992770110843195,
                "model_info": "Silhouette Score: 0.9800000190734863",
                "lineage": "4101"
            }
        ],
        "42": [],
        "43": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    print(f\"Model Configuration: Input Dim: {adata_sc.shape[1]}, Output Dim: {len(cell_types)}, Learning Rate: 0.001\")\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -1.288484505528376,
                "model_info": "Model Configuration: Input Dim: 16170, Output Dim: 13, Learning Rate: 0.001",
                "lineage": "4301"
            }
        ],
        "44": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.neighbors import NearestNeighbors\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    nbrs = NearestNeighbors(n_neighbors=5).fit(proportions)\n    distances, indices = nbrs.kneighbors(proportions)\n    \n    for i in range(proportions.shape[0]):\n        proportions[i] = np.mean(proportions[indices[i]], axis=0)\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": 0.01918917925154971,
                "model_info": "",
                "lineage": "4401"
            }
        ],
        "45": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}, Loss: {loss.item()}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n    print(f\"Assumptions: Single-cell data matched with spot data, cell types identified.\")\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.014048142066292133,
                "model_info": "Epoch 0, Loss: 2.5840680599212646\nEpoch 10, Loss: 2.0339713096618652\nEpoch 20, Loss: 1.8729430437088013\nEpoch 30, Loss: 1.8181054592132568\nEpoch 40, Loss: 1.7746540307998657\nEpoch 50, Loss: 1.7444522380828857\nEpoch 60, Loss: 1.7206604480743408\nEpoch 70, Loss: 1.700582504272461\nEpoch 80, Loss: 1.6831482648849487\nEpoch 90, Loss: 1.6682779788970947\nAssumptions: Single-cell data matched with spot data, cell types identified.",
                "lineage": "4501"
            }
        ],
        "46": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.8832859715068699,
                "model_info": "",
                "lineage": "4601"
            }
        ],
        "47": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.model_selection import cross_val_score\nfrom sklearn.base import BaseEstimator\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\nclass DummyEstimator(BaseEstimator):\n    def __init__(self):\n        pass\n\n    def fit(self, X, y):\n        return self\n\n    def predict(self, X):\n        return X\n\n    def score(self, X, y):\n        return np.mean(np.argmax(X, axis=1) == np.argmax(y, axis=1))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    def optimize_label_propagation(proportions):\n        best_proportions = proportions.copy()\n        best_score = -np.inf\n        for alpha in np.linspace(0, 1, 10):\n            smoothed_proportions = np.zeros_like(proportions)\n            for i in range(proportions.shape[0]):\n                neighbors = np.where(adata_sp.obsm['cell_type_clusters'] == adata_sp.obsm['cell_type_clusters'][i])[0]\n                smoothed_proportions[i] = alpha * proportions[i] + (1 - alpha) * proportions[neighbors].mean(axis=0)\n            dummy_estimator = DummyEstimator()\n            score = cross_val_score(dummy_estimator, smoothed_proportions, refined_proportions, cv=5).mean()\n            if score > best_score:\n                best_score = score\n                best_proportions = smoothed_proportions\n        return best_proportions\n\n    adata_sp.obsm[\"proportions_pred\"] = optimize_label_propagation(refined_proportions)\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.10041116850898849,
                "model_info": "",
                "lineage": "4701"
            }
        ],
        "48": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.neighbors import NearestNeighbors\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    nbrs = NearestNeighbors(n_neighbors=5).fit(proportions)\n    distances, indices = nbrs.kneighbors(proportions)\n    \n    refined_proportions = np.zeros_like(proportions)\n    for i in range(proportions.shape[0]):\n        refined_proportions[i] = proportions[indices[i]].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": 0.009518743019200757,
                "model_info": "",
                "lineage": "4801"
            }
        ],
        "49": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport time\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    start_time = time.time()\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        \n        if epoch % 10 == 0:\n            elapsed_time = time.time() - start_time\n            print(f\"Epoch {epoch}, Time elapsed: {elapsed_time:.2f} seconds\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": -1.7351614954999737,
                "model_info": "Epoch 0, Time elapsed: 2.02 seconds\nEpoch 10, Time elapsed: 7.19 seconds\nEpoch 20, Time elapsed: 12.19 seconds\nEpoch 30, Time elapsed: 16.27 seconds\nEpoch 40, Time elapsed: 20.22 seconds\nEpoch 50, Time elapsed: 24.16 seconds\nEpoch 60, Time elapsed: 28.14 seconds\nEpoch 70, Time elapsed: 32.08 seconds\nEpoch 80, Time elapsed: 36.04 seconds\nEpoch 90, Time elapsed: 40.01 seconds",
                "lineage": "4901"
            }
        ],
        "50": [],
        "51": [],
        "52": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass MultiTaskModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(MultiTaskModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = MultiTaskModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.8504410520286776,
                "model_info": "",
                "lineage": "5201"
            }
        ],
        "53": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    pretrain_data = adata_sc.X.toarray()\n    pretrain_labels = np.argmax(labels_onehot, axis=1)\n\n    pretrain_model = ContrastiveModel(input_dim=pretrain_data.shape[1], output_dim=len(cell_types))\n    pretrain_optimizer = optim.Adam(pretrain_model.parameters(), lr=0.001)\n    pretrain_criterion = nn.CrossEntropyLoss()\n\n    pretrain_model.train()\n    for epoch in range(50):\n        pretrain_optimizer.zero_grad()\n        pretrain_outputs = pretrain_model(torch.tensor(pretrain_data, dtype=torch.float32))\n        pretrain_loss = pretrain_criterion(pretrain_outputs, torch.tensor(pretrain_labels, dtype=torch.long))\n        pretrain_loss.backward()\n        pretrain_optimizer.step()\n\n    model.fc1.weight.data = pretrain_model.fc1.weight.data.clone()\n    model.fc1.bias.data = pretrain_model.fc1.bias.data.clone()\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.1046399973018899,
                "model_info": "",
                "lineage": "5301"
            }
        ],
        "54": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    spatial_embedding = np.mean(refined_proportions, axis=0).reshape(1, -1)\n    adata_sp.obsm[\"spatial_embedding\"] = np.tile(spatial_embedding, (adata_sp.shape[0], 1))\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.6988357893009293,
                "model_info": "",
                "lineage": "5401"
            }
        ],
        "55": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport networkx as nx\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef create_graph(adata_sp):\n    G = nx.Graph()\n    for i in range(adata_sp.shape[0]):\n        G.add_node(i)\n    for i in range(adata_sp.shape[0]):\n        for j in range(i + 1, adata_sp.shape[0]):\n            distance = np.linalg.norm(adata_sp.obsm['spatial'][i] - adata_sp.obsm['spatial'][j])\n            if distance < threshold:  # Define a threshold for edges\n                G.add_edge(i, j)\n    return G\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.1259162281674415,
                "model_info": "",
                "lineage": "5501"
            }
        ],
        "56": [],
        "57": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm['proportions_pred'] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.1043429579521074,
                "model_info": "",
                "lineage": "5701"
            }
        ],
        "58": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nimport networkx as nx\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp, threshold=1.0):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    spatial_graph = nx.Graph()\n    for i in range(adata_sp.shape[0]):\n        spatial_graph.add_node(i, pos=adata_sp.obsm['spatial'][i])\n\n    for i in range(adata_sp.shape[0]):\n        for j in range(i + 1, adata_sp.shape[0]):\n            distance = np.linalg.norm(adata_sp.obsm['spatial'][i] - adata_sp.obsm['spatial'][j])\n            if distance < threshold:\n                spatial_graph.add_edge(i, j)\n\n    adjacency_matrix = nx.to_numpy_array(spatial_graph)\n    enriched_proportions = np.dot(adjacency_matrix, proportions) / np.sum(adjacency_matrix, axis=1, keepdims=True)\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(enriched_proportions)\n\n    refined_proportions = np.zeros_like(enriched_proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = enriched_proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.16337158023104145,
                "model_info": "",
                "lineage": "5801"
            }
        ],
        "59": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    mixup_alpha = 0.2\n    for i in range(len(refined_proportions)):\n        if np.random.rand() < mixup_alpha:\n            j = np.random.randint(0, len(refined_proportions))\n            refined_proportions[i] = (refined_proportions[i] + refined_proportions[j]) / 2\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.2359406020199277,
                "model_info": "",
                "lineage": "5901"
            }
        ],
        "60": [],
        "61": [],
        "62": [],
        "63": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.11757070723163146,
                "model_info": "",
                "lineage": "6301"
            }
        ],
        "64": [],
        "65": [],
        "66": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    refined_proportions += np.random.uniform(-0.1, 0.1, refined_proportions.shape)\n    refined_proportions = np.clip(refined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.33652014106282374,
                "model_info": "",
                "lineage": "6601"
            }
        ],
        "67": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import confusion_matrix\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    pred_labels = np.argmax(refined_proportions, axis=1)\n    true_labels = np.argmax(labels_onehot, axis=1)[:len(pred_labels)]\n    cm = confusion_matrix(true_labels, pred_labels)\n    print(\"Confusion Matrix:\\n\", cm)\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": 0.023671588761614605,
                "model_info": "Confusion Matrix:\n [[ 0  0  4  0  0  0]\n [ 0  0  0  0  0  0]\n [ 0  7 27  0  0  1]\n [ 0  0 14  0  0  0]\n [ 0  5 15  0  0  0]\n [ 0  1 26  0  0  0]]",
                "lineage": "6701"
            }
        ],
        "68": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.decomposition import PCA\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    pca = PCA(n_components=min(50, adata_sc.shape[1]))\n    adata_sc_reduced = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_reduced = pca.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_reduced.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_reduced, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_reduced, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -1.374604674196325,
                "model_info": "",
                "lineage": "6801"
            }
        ],
        "69": [],
        "70": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f'Epoch {epoch}: Loss {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": 0.018988321453712466,
                "model_info": "Epoch 0: Loss 2.559518337249756\nEpoch 10: Loss 1.3385467529296875\nEpoch 20: Loss 1.0185177326202393\nEpoch 30: Loss 0.881971538066864\nEpoch 40: Loss 0.8079996109008789\nEpoch 50: Loss 0.7564134001731873\nEpoch 60: Loss 0.7160337567329407\nEpoch 70: Loss 0.6836792826652527\nEpoch 80: Loss 0.6571515798568726\nEpoch 90: Loss 0.635298490524292",
                "lineage": "7001"
            }
        ],
        "71": [],
        "72": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    print(\"Class balance before resampling:\", np.bincount(np.argmax(labels_onehot, axis=1)))\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    print(\"Class balance after resampling:\", np.bincount(np.argmax(refined_proportions, axis=1)))\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.20811856011247326,
                "model_info": "Class balance before resampling: [ 276  180  106  193  343 3615 1495 1098  120  191  287 2473  115]\nClass balance after resampling: [ 0  3  0  0  4 62 12  4  6  0  8  1]",
                "lineage": "7201"
            }
        ],
        "73": [],
        "74": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom scipy.stats import normaltest\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        \n        if epoch % 10 == 0:\n            print(f'Epoch {epoch}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n    \n    _, p_value = normaltest(proportions.flatten())\n    if p_value < 0.05:\n        print(\"Warning: Proportions may not meet i.i.d. assumptions.\")\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": -0.005326105428794543,
                "model_info": "Epoch 0, Loss: 2.5791842937469482\nEpoch 10, Loss: 1.8588114976882935\nEpoch 20, Loss: 1.7133234739303589\nEpoch 30, Loss: 1.6557117700576782\nEpoch 40, Loss: 1.6248531341552734\nEpoch 50, Loss: 1.6041444540023804\nEpoch 60, Loss: 1.590110182762146\nEpoch 70, Loss: 1.579415202140808\nEpoch 80, Loss: 1.5709619522094727\nEpoch 90, Loss: 1.5643682479858398\nWarning: Proportions may not meet i.i.d. assumptions.",
                "lineage": "7401"
            }
        ],
        "75": [],
        "76": [],
        "77": [],
        "78": [],
        "79": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXX.py",
                "accuracy": 0.10529272444447378,
                "model_info": "",
                "lineage": "7901"
            }
        ],
        "80": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXX.py",
                "accuracy": 0.2801542785318641,
                "model_info": "",
                "lineage": "8001"
            }
        ],
        "81": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.26910699666742244,
                "model_info": "",
                "lineage": "8101"
            }
        ],
        "82": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            val_loss = log_loss(np.argmax(labels_onehot, axis=1), torch.softmax(outputs, dim=1).detach().numpy())\n            print(f'Epoch {epoch}, Loss: {loss.item():.4f}, Validation Loss: {val_loss:.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.11035883952615656,
                "model_info": "Epoch 0, Loss: 2.5691, Validation Loss: 2.5192\nEpoch 10, Loss: 1.0423, Validation Loss: 0.8409\nEpoch 20, Loss: 0.5908, Validation Loss: 0.4166\nEpoch 30, Loss: 0.5002, Validation Loss: 0.3114\nEpoch 40, Loss: 0.4631, Validation Loss: 0.2428\nEpoch 50, Loss: 0.4444, Validation Loss: 0.1979\nEpoch 60, Loss: 0.4323, Validation Loss: 0.1673\nEpoch 70, Loss: 0.4238, Validation Loss: 0.1428\nEpoch 80, Loss: 0.4175, Validation Loss: 0.1253\nEpoch 90, Loss: 0.4129, Validation Loss: 0.1109",
                "lineage": "8201"
            }
        ],
        "83": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.016265187284726403,
                "model_info": "",
                "lineage": "8301"
            }
        ],
        "84": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.04268722169739048,
                "model_info": "",
                "lineage": "8401"
            }
        ],
        "85": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.20080182006101785,
                "model_info": "",
                "lineage": "8501"
            }
        ],
        "86": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    if adata_sc.shape[0] < 1000:\n        print(\"Warning: Insufficient training data volume for reliable model performance.\")\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": -0.03798901548428339,
                "model_info": "",
                "lineage": "8601"
            }
        ],
        "87": [],
        "88": [],
        "89": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXX.py",
                "accuracy": 0.33160475450840465,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5645\nEpoch 2, Loss: 2.1772\nEpoch 3, Loss: 1.9846\nEpoch 4, Loss: 1.5132\nEpoch 5, Loss: 1.3741\nEpoch 6, Loss: 1.2122\nEpoch 7, Loss: 1.0533\nEpoch 8, Loss: 0.9911\nEpoch 9, Loss: 0.8968\nEpoch 10, Loss: 0.8196\nEpoch 11, Loss: 0.7755\nEpoch 12, Loss: 0.7385\nEpoch 13, Loss: 0.7007\nEpoch 14, Loss: 0.6655\nEpoch 15, Loss: 0.6376\nEpoch 16, Loss: 0.6162\nEpoch 17, Loss: 0.5983\nEpoch 18, Loss: 0.5826\nEpoch 19, Loss: 0.5699\nEpoch 20, Loss: 0.5586\nEpoch 21, Loss: 0.5465\nEpoch 22, Loss: 0.5360\nEpoch 23, Loss: 0.5286\nEpoch 24, Loss: 0.5233\nEpoch 25, Loss: 0.5184\nEpoch 26, Loss: 0.5127\nEpoch 27, Loss: 0.5067\nEpoch 28, Loss: 0.5014\nEpoch 29, Loss: 0.4968\nEpoch 30, Loss: 0.4932\nEpoch 31, Loss: 0.4902\nEpoch 32, Loss: 0.4872\nEpoch 33, Loss: 0.4842\nEpoch 34, Loss: 0.4812\nEpoch 35, Loss: 0.4783\nEpoch 36, Loss: 0.4758\nEpoch 37, Loss: 0.4735\nEpoch 38, Loss: 0.4714\nEpoch 39, Loss: 0.4694\nEpoch 40, Loss: 0.4676\nEpoch 41, Loss: 0.4657\nEpoch 42, Loss: 0.4639\nEpoch 43, Loss: 0.4621\nEpoch 44, Loss: 0.4604\nEpoch 45, Loss: 0.4588\nEpoch 46, Loss: 0.4573\nEpoch 47, Loss: 0.4558\nEpoch 48, Loss: 0.4545\nEpoch 49, Loss: 0.4533\nEpoch 50, Loss: 0.4520\nEpoch 51, Loss: 0.4508\nEpoch 52, Loss: 0.4495\nEpoch 53, Loss: 0.4484\nEpoch 54, Loss: 0.4473\nEpoch 55, Loss: 0.4462\nEpoch 56, Loss: 0.4452\nEpoch 57, Loss: 0.4442\nEpoch 58, Loss: 0.4433\nEpoch 59, Loss: 0.4423\nEpoch 60, Loss: 0.4414\nEpoch 61, Loss: 0.4405\nEpoch 62, Loss: 0.4396\nEpoch 63, Loss: 0.4388\nEpoch 64, Loss: 0.4380\nEpoch 65, Loss: 0.4372\nEpoch 66, Loss: 0.4364\nEpoch 67, Loss: 0.4356\nEpoch 68, Loss: 0.4349\nEpoch 69, Loss: 0.4342\nEpoch 70, Loss: 0.4335\nEpoch 71, Loss: 0.4328\nEpoch 72, Loss: 0.4321\nEpoch 73, Loss: 0.4315\nEpoch 74, Loss: 0.4309\nEpoch 75, Loss: 0.4302\nEpoch 76, Loss: 0.4296\nEpoch 77, Loss: 0.4290\nEpoch 78, Loss: 0.4285\nEpoch 79, Loss: 0.4279\nEpoch 80, Loss: 0.4273\nEpoch 81, Loss: 0.4268\nEpoch 82, Loss: 0.4263\nEpoch 83, Loss: 0.4257\nEpoch 84, Loss: 0.4252\nEpoch 85, Loss: 0.4247\nEp",
                "lineage": "8901"
            }
        ],
        "90": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    local_density = np.mean(combined_proportions, axis=1, keepdims=True)\n    adaptive_weights = combined_proportions / (local_density + 1e-8)\n    adata_sp.obsm[\"proportions_pred\"] = adaptive_weights\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -230.70000012357303,
                "model_info": "",
                "lineage": "9001"
            }
        ],
        "91": [],
        "92": [],
        "93": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.07635924419250519,
                "model_info": "",
                "lineage": "9301"
            }
        ],
        "94": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.decomposition import PCA\nfrom sklearn.manifold import TSNE\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    pca = PCA(n_components=50)\n    adata_sc_pca = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_pca = pca.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_pca.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_pca, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_pca, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_pca)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.3384450224758742,
                "model_info": "Trainable parameters: 8387, Frozen parameters: 0\nEpoch 1, Loss: 2.5903\nEpoch 2, Loss: 2.5092\nEpoch 3, Loss: 2.4291\nEpoch 4, Loss: 2.3497\nEpoch 5, Loss: 2.2710\nEpoch 6, Loss: 2.1936\nEpoch 7, Loss: 2.1186\nEpoch 8, Loss: 2.0465\nEpoch 9, Loss: 1.9770\nEpoch 10, Loss: 1.9101\nEpoch 11, Loss: 1.8458\nEpoch 12, Loss: 1.7844\nEpoch 13, Loss: 1.7258\nEpoch 14, Loss: 1.6702\nEpoch 15, Loss: 1.6174\nEpoch 16, Loss: 1.5675\nEpoch 17, Loss: 1.5203\nEpoch 18, Loss: 1.4758\nEpoch 19, Loss: 1.4338\nEpoch 20, Loss: 1.3942\nEpoch 21, Loss: 1.3569\nEpoch 22, Loss: 1.3217\nEpoch 23, Loss: 1.2885\nEpoch 24, Loss: 1.2571\nEpoch 25, Loss: 1.2275\nEpoch 26, Loss: 1.1995\nEpoch 27, Loss: 1.1730\nEpoch 28, Loss: 1.1479\nEpoch 29, Loss: 1.1241\nEpoch 30, Loss: 1.1015\nEpoch 31, Loss: 1.0800\nEpoch 32, Loss: 1.0595\nEpoch 33, Loss: 1.0400\nEpoch 34, Loss: 1.0214\nEpoch 35, Loss: 1.0038\nEpoch 36, Loss: 0.9869\nEpoch 37, Loss: 0.9708\nEpoch 38, Loss: 0.9555\nEpoch 39, Loss: 0.9409\nEpoch 40, Loss: 0.9269\nEpoch 41, Loss: 0.9135\nEpoch 42, Loss: 0.9007\nEpoch 43, Loss: 0.8885\nEpoch 44, Loss: 0.8767\nEpoch 45, Loss: 0.8654\nEpoch 46, Loss: 0.8546\nEpoch 47, Loss: 0.8442\nEpoch 48, Loss: 0.8342\nEpoch 49, Loss: 0.8246\nEpoch 50, Loss: 0.8153\nEpoch 51, Loss: 0.8064\nEpoch 52, Loss: 0.7979\nEpoch 53, Loss: 0.7896\nEpoch 54, Loss: 0.7817\nEpoch 55, Loss: 0.7740\nEpoch 56, Loss: 0.7666\nEpoch 57, Loss: 0.7595\nEpoch 58, Loss: 0.7527\nEpoch 59, Loss: 0.7461\nEpoch 60, Loss: 0.7397\nEpoch 61, Loss: 0.7336\nEpoch 62, Loss: 0.7277\nEpoch 63, Loss: 0.7220\nEpoch 64, Loss: 0.7164\nEpoch 65, Loss: 0.7111\nEpoch 66, Loss: 0.7060\nEpoch 67, Loss: 0.7010\nEpoch 68, Loss: 0.6962\nEpoch 69, Loss: 0.6916\nEpoch 70, Loss: 0.6871\nEpoch 71, Loss: 0.6828\nEpoch 72, Loss: 0.6786\nEpoch 73, Loss: 0.6746\nEpoch 74, Loss: 0.6707\nEpoch 75, Loss: 0.6669\nEpoch 76, Loss: 0.6632\nEpoch 77, Loss: 0.6597\nEpoch 78, Loss: 0.6563\nEpoch 79, Loss: 0.6529\nEpoch 80, Loss: 0.6497\nEpoch 81, Loss: 0.6466\nEpoch 82, Loss: 0.6436\nEpoch 83, Loss: 0.6406\nEpoch 84, Loss: 0.6378\nEpoch 85, Loss: 0.6350\nEpoch",
                "lineage": "9401"
            }
        ],
        "95": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.manifold import TSNE\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    tsne = TSNE(n_components=2)\n    adata_sc_embedded = tsne.fit_transform(adata_sc.X.toarray())\n    adata_sp_embedded = tsne.fit_transform(adata_sp.X.toarray())\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_embedded, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_embedded)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.6308243287605271,
                "model_info": "",
                "lineage": "9501"
            }
        ],
        "96": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.08220633278514677,
                "model_info": "",
                "lineage": "9601"
            }
        ],
        "97": [],
        "98": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.07612148399384527,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5706\nEpoch 2, Loss: 2.4761\nEpoch 3, Loss: 2.3256\nEpoch 4, Loss: 2.1573\nEpoch 5, Loss: 2.0178\nEpoch 6, Loss: 1.8705\nEpoch 7, Loss: 1.7351\nEpoch 8, Loss: 1.6167\nEpoch 9, Loss: 1.4976\nEpoch 10, Loss: 1.3893\nEpoch 11, Loss: 1.2856\nEpoch 12, Loss: 1.1897\nEpoch 13, Loss: 1.0971\nEpoch 14, Loss: 1.0095\nEpoch 15, Loss: 0.9262\nEpoch 16, Loss: 0.8460\nEpoch 17, Loss: 0.7700\nEpoch 18, Loss: 0.7005\nEpoch 19, Loss: 0.6397\nEpoch 20, Loss: 0.5819\nEpoch 21, Loss: 0.5294\nEpoch 22, Loss: 0.4827\nEpoch 23, Loss: 0.4401\nEpoch 24, Loss: 0.4031\nEpoch 25, Loss: 0.3709\nEpoch 26, Loss: 0.3409\nEpoch 27, Loss: 0.3135\nEpoch 28, Loss: 0.2901\nEpoch 29, Loss: 0.2695\nEpoch 30, Loss: 0.2505\nEpoch 31, Loss: 0.2331\nEpoch 32, Loss: 0.2176\nEpoch 33, Loss: 0.2031\nEpoch 34, Loss: 0.1902\nEpoch 35, Loss: 0.1791\nEpoch 36, Loss: 0.1691\nEpoch 37, Loss: 0.1598\nEpoch 38, Loss: 0.1512\nEpoch 39, Loss: 0.1434\nEpoch 40, Loss: 0.1362\nEpoch 41, Loss: 0.1293\nEpoch 42, Loss: 0.1231\nEpoch 43, Loss: 0.1176\nEpoch 44, Loss: 0.1125\nEpoch 45, Loss: 0.1077\nEpoch 46, Loss: 0.1033\nEpoch 47, Loss: 0.0992\nEpoch 48, Loss: 0.0955\nEpoch 49, Loss: 0.0919\nEpoch 50, Loss: 0.0885\nEpoch 51, Loss: 0.0854\nEpoch 52, Loss: 0.0824\nEpoch 53, Loss: 0.0795\nEpoch 54, Loss: 0.0768\nEpoch 55, Loss: 0.0743\nEpoch 56, Loss: 0.0718\nEpoch 57, Loss: 0.0695\nEpoch 58, Loss: 0.0673\nEpoch 59, Loss: 0.0652\nEpoch 60, Loss: 0.0632\nEpoch 61, Loss: 0.0612\nEpoch 62, Loss: 0.0594\nEpoch 63, Loss: 0.0576\nEpoch 64, Loss: 0.0559\nEpoch 65, Loss: 0.0542\nEpoch 66, Loss: 0.0526\nEpoch 67, Loss: 0.0510\nEpoch 68, Loss: 0.0496\nEpoch 69, Loss: 0.0481\nEpoch 70, Loss: 0.0467\nEpoch 71, Loss: 0.0454\nEpoch 72, Loss: 0.0440\nEpoch 73, Loss: 0.0428\nEpoch 74, Loss: 0.0416\nEpoch 75, Loss: 0.0404\nEpoch 76, Loss: 0.0392\nEpoch 77, Loss: 0.0381\nEpoch 78, Loss: 0.0370\nEpoch 79, Loss: 0.0359\nEpoch 80, Loss: 0.0349\nEpoch 81, Loss: 0.0339\nEpoch 82, Loss: 0.0330\nEpoch 83, Loss: 0.0320\nEpoch 84, Loss: 0.0311\nEpoch 85, Loss: 0.0302\nEp",
                "lineage": "9801"
            }
        ],
        "99": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n    \n    print(f'Input shape: {adata_sc.X.shape}, Output shape: {len(cell_types)}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.023439768194603385,
                "model_info": "Trainable parameters: 4174349, Frozen parameters: 0\nInput shape: (10492, 16170), Output shape: 13\nEpoch 1, Loss: 2.5665\nEpoch 2, Loss: 2.3401\nEpoch 3, Loss: 1.9831\nEpoch 4, Loss: 1.6705\nEpoch 5, Loss: 1.3321\nEpoch 6, Loss: 1.0879\nEpoch 7, Loss: 0.8628\nEpoch 8, Loss: 0.7002\nEpoch 9, Loss: 0.5616\nEpoch 10, Loss: 0.4644\nEpoch 11, Loss: 0.3862\nEpoch 12, Loss: 0.3211\nEpoch 13, Loss: 0.2774\nEpoch 14, Loss: 0.2386\nEpoch 15, Loss: 0.2058\nEpoch 16, Loss: 0.1824\nEpoch 17, Loss: 0.1653\nEpoch 18, Loss: 0.1463\nEpoch 19, Loss: 0.1342\nEpoch 20, Loss: 0.1234\nEpoch 21, Loss: 0.1103\nEpoch 22, Loss: 0.1038\nEpoch 23, Loss: 0.0977\nEpoch 24, Loss: 0.0923\nEpoch 25, Loss: 0.0843\nEpoch 26, Loss: 0.0805\nEpoch 27, Loss: 0.0772\nEpoch 28, Loss: 0.0722\nEpoch 29, Loss: 0.0681\nEpoch 30, Loss: 0.0658\nEpoch 31, Loss: 0.0624\nEpoch 32, Loss: 0.0588\nEpoch 33, Loss: 0.0567\nEpoch 34, Loss: 0.0540\nEpoch 35, Loss: 0.0511\nEpoch 36, Loss: 0.0492\nEpoch 37, Loss: 0.0472\nEpoch 38, Loss: 0.0447\nEpoch 39, Loss: 0.0429\nEpoch 40, Loss: 0.0413\nEpoch 41, Loss: 0.0392\nEpoch 42, Loss: 0.0375\nEpoch 43, Loss: 0.0359\nEpoch 44, Loss: 0.0346\nEpoch 45, Loss: 0.0328\nEpoch 46, Loss: 0.0316\nEpoch 47, Loss: 0.0302\nEpoch 48, Loss: 0.0289\nEpoch 49, Loss: 0.0275\nEpoch 50, Loss: 0.0265\nEpoch 51, Loss: 0.0253\nEpoch 52, Loss: 0.0241\nEpoch 53, Loss: 0.0231\nEpoch 54, Loss: 0.0221\nEpoch 55, Loss: 0.0211\nEpoch 56, Loss: 0.0202\nEpoch 57, Loss: 0.0194\nEpoch 58, Loss: 0.0185\nEpoch 59, Loss: 0.0177\nEpoch 60, Loss: 0.0169\nEpoch 61, Loss: 0.0162\nEpoch 62, Loss: 0.0155\nEpoch 63, Loss: 0.0148\nEpoch 64, Loss: 0.0142\nEpoch 65, Loss: 0.0136\nEpoch 66, Loss: 0.0130\nEpoch 67, Loss: 0.0125\nEpoch 68, Loss: 0.0119\nEpoch 69, Loss: 0.0114\nEpoch 70, Loss: 0.0110\nEpoch 71, Loss: 0.0105\nEpoch 72, Loss: 0.0101\nEpoch 73, Loss: 0.0097\nEpoch 74, Loss: 0.0093\nEpoch 75, Loss: 0.0089\nEpoch 76, Loss: 0.0086\nEpoch 77, Loss: 0.0082\nEpoch 78, Loss: 0.0079\nEpoch 79, Loss: 0.0076\nEpoch 80, Loss: 0.0073\nEpoch 81, Loss: 0.0070\nEpoch 82, Loss: 0.0068\nEpoch 83, Loss: 0.0065\nEp",
                "lineage": "9901"
            }
        ],
        "100": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    if adata_sc.shape[0] < 1000:\n        print(\"Warning: Insufficient training data volume. Consider increasing sample size.\")\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.00614593570868889,
                "model_info": "Trainable parameters: 4174349, Frozen parameters: 0\nEpoch 1, Loss: 2.5664\nEpoch 2, Loss: 2.2840\nEpoch 3, Loss: 1.8970\nEpoch 4, Loss: 1.5089\nEpoch 5, Loss: 1.2192\nEpoch 6, Loss: 0.9653\nEpoch 7, Loss: 0.7664\nEpoch 8, Loss: 0.6317\nEpoch 9, Loss: 0.5205\nEpoch 10, Loss: 0.4288\nEpoch 11, Loss: 0.3574\nEpoch 12, Loss: 0.3063\nEpoch 13, Loss: 0.2616\nEpoch 14, Loss: 0.2268\nEpoch 15, Loss: 0.1961\nEpoch 16, Loss: 0.1740\nEpoch 17, Loss: 0.1569\nEpoch 18, Loss: 0.1403\nEpoch 19, Loss: 0.1265\nEpoch 20, Loss: 0.1180\nEpoch 21, Loss: 0.1089\nEpoch 22, Loss: 0.0996\nEpoch 23, Loss: 0.0938\nEpoch 24, Loss: 0.0891\nEpoch 25, Loss: 0.0828\nEpoch 26, Loss: 0.0780\nEpoch 27, Loss: 0.0747\nEpoch 28, Loss: 0.0706\nEpoch 29, Loss: 0.0672\nEpoch 30, Loss: 0.0643\nEpoch 31, Loss: 0.0610\nEpoch 32, Loss: 0.0583\nEpoch 33, Loss: 0.0563\nEpoch 34, Loss: 0.0535\nEpoch 35, Loss: 0.0512\nEpoch 36, Loss: 0.0494\nEpoch 37, Loss: 0.0471\nEpoch 38, Loss: 0.0451\nEpoch 39, Loss: 0.0434\nEpoch 40, Loss: 0.0415\nEpoch 41, Loss: 0.0398\nEpoch 42, Loss: 0.0383\nEpoch 43, Loss: 0.0366\nEpoch 44, Loss: 0.0351\nEpoch 45, Loss: 0.0338\nEpoch 46, Loss: 0.0324\nEpoch 47, Loss: 0.0311\nEpoch 48, Loss: 0.0298\nEpoch 49, Loss: 0.0286\nEpoch 50, Loss: 0.0275\nEpoch 51, Loss: 0.0263\nEpoch 52, Loss: 0.0253\nEpoch 53, Loss: 0.0243\nEpoch 54, Loss: 0.0233\nEpoch 55, Loss: 0.0223\nEpoch 56, Loss: 0.0215\nEpoch 57, Loss: 0.0206\nEpoch 58, Loss: 0.0198\nEpoch 59, Loss: 0.0190\nEpoch 60, Loss: 0.0183\nEpoch 61, Loss: 0.0175\nEpoch 62, Loss: 0.0169\nEpoch 63, Loss: 0.0162\nEpoch 64, Loss: 0.0156\nEpoch 65, Loss: 0.0150\nEpoch 66, Loss: 0.0144\nEpoch 67, Loss: 0.0139\nEpoch 68, Loss: 0.0133\nEpoch 69, Loss: 0.0128\nEpoch 70, Loss: 0.0123\nEpoch 71, Loss: 0.0119\nEpoch 72, Loss: 0.0114\nEpoch 73, Loss: 0.0110\nEpoch 74, Loss: 0.0106\nEpoch 75, Loss: 0.0102\nEpoch 76, Loss: 0.0098\nEpoch 77, Loss: 0.0095\nEpoch 78, Loss: 0.0092\nEpoch 79, Loss: 0.0088\nEpoch 80, Loss: 0.0085\nEpoch 81, Loss: 0.0082\nEpoch 82, Loss: 0.0079\nEpoch 83, Loss: 0.0077\nEpoch 84, Loss: 0.0074\nEpoch 85, Loss: 0.0071\nEp",
                "lineage": "10001"
            }
        ],
        "101": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.21247685685053405,
                "model_info": "Trainable parameters: 2078989, Frozen parameters: 0\nEpoch 1, Loss: 2.5664\nEpoch 2, Loss: 2.4037\nEpoch 3, Loss: 2.1416\nEpoch 4, Loss: 1.9314\nEpoch 5, Loss: 1.6750\nEpoch 6, Loss: 1.4697\nEpoch 7, Loss: 1.2635\nEpoch 8, Loss: 1.0818\nEpoch 9, Loss: 0.9215\nEpoch 10, Loss: 0.7908\nEpoch 11, Loss: 0.6834\nEpoch 12, Loss: 0.5881\nEpoch 13, Loss: 0.5034\nEpoch 14, Loss: 0.4372\nEpoch 15, Loss: 0.3821\nEpoch 16, Loss: 0.3385\nEpoch 17, Loss: 0.3022\nEpoch 18, Loss: 0.2717\nEpoch 19, Loss: 0.2446\nEpoch 20, Loss: 0.2214\nEpoch 21, Loss: 0.2031\nEpoch 22, Loss: 0.1852\nEpoch 23, Loss: 0.1707\nEpoch 24, Loss: 0.1579\nEpoch 25, Loss: 0.1474\nEpoch 26, Loss: 0.1375\nEpoch 27, Loss: 0.1283\nEpoch 28, Loss: 0.1208\nEpoch 29, Loss: 0.1142\nEpoch 30, Loss: 0.1080\nEpoch 31, Loss: 0.1026\nEpoch 32, Loss: 0.0976\nEpoch 33, Loss: 0.0930\nEpoch 34, Loss: 0.0890\nEpoch 35, Loss: 0.0848\nEpoch 36, Loss: 0.0812\nEpoch 37, Loss: 0.0779\nEpoch 38, Loss: 0.0746\nEpoch 39, Loss: 0.0715\nEpoch 40, Loss: 0.0687\nEpoch 41, Loss: 0.0659\nEpoch 42, Loss: 0.0634\nEpoch 43, Loss: 0.0609\nEpoch 44, Loss: 0.0585\nEpoch 45, Loss: 0.0563\nEpoch 46, Loss: 0.0541\nEpoch 47, Loss: 0.0520\nEpoch 48, Loss: 0.0501\nEpoch 49, Loss: 0.0482\nEpoch 50, Loss: 0.0464\nEpoch 51, Loss: 0.0448\nEpoch 52, Loss: 0.0431\nEpoch 53, Loss: 0.0416\nEpoch 54, Loss: 0.0401\nEpoch 55, Loss: 0.0386\nEpoch 56, Loss: 0.0372\nEpoch 57, Loss: 0.0359\nEpoch 58, Loss: 0.0346\nEpoch 59, Loss: 0.0334\nEpoch 60, Loss: 0.0322\nEpoch 61, Loss: 0.0311\nEpoch 62, Loss: 0.0300\nEpoch 63, Loss: 0.0289\nEpoch 64, Loss: 0.0279\nEpoch 65, Loss: 0.0269\nEpoch 66, Loss: 0.0259\nEpoch 67, Loss: 0.0249\nEpoch 68, Loss: 0.0240\nEpoch 69, Loss: 0.0232\nEpoch 70, Loss: 0.0223\nEpoch 71, Loss: 0.0215\nEpoch 72, Loss: 0.0208\nEpoch 73, Loss: 0.0200\nEpoch 74, Loss: 0.0193\nEpoch 75, Loss: 0.0186\nEpoch 76, Loss: 0.0179\nEpoch 77, Loss: 0.0173\nEpoch 78, Loss: 0.0167\nEpoch 79, Loss: 0.0161\nEpoch 80, Loss: 0.0155\nEpoch 81, Loss: 0.0149\nEpoch 82, Loss: 0.0144\nEpoch 83, Loss: 0.0139\nEpoch 84, Loss: 0.0134\nEpoch 85, Loss: 0.0129\nEp",
                "lineage": "10101"
            }
        ],
        "102": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.decomposition import PCA\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    pca = PCA(n_components=50)\n    adata_sc_pca = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_pca = pca.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_pca.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_pca, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_pca, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_pca)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.6216180622887584,
                "model_info": "Trainable parameters: 8387, Frozen parameters: 0\nEpoch 1, Loss: 2.6979\nEpoch 2, Loss: 2.6141\nEpoch 3, Loss: 2.5307\nEpoch 4, Loss: 2.4505\nEpoch 5, Loss: 2.3742\nEpoch 6, Loss: 2.3020\nEpoch 7, Loss: 2.2338\nEpoch 8, Loss: 2.1696\nEpoch 9, Loss: 2.1089\nEpoch 10, Loss: 2.0515\nEpoch 11, Loss: 1.9968\nEpoch 12, Loss: 1.9446\nEpoch 13, Loss: 1.8948\nEpoch 14, Loss: 1.8475\nEpoch 15, Loss: 1.8027\nEpoch 16, Loss: 1.7603\nEpoch 17, Loss: 1.7202\nEpoch 18, Loss: 1.6825\nEpoch 19, Loss: 1.6468\nEpoch 20, Loss: 1.6129\nEpoch 21, Loss: 1.5807\nEpoch 22, Loss: 1.5500\nEpoch 23, Loss: 1.5206\nEpoch 24, Loss: 1.4925\nEpoch 25, Loss: 1.4656\nEpoch 26, Loss: 1.4398\nEpoch 27, Loss: 1.4151\nEpoch 28, Loss: 1.3914\nEpoch 29, Loss: 1.3686\nEpoch 30, Loss: 1.3467\nEpoch 31, Loss: 1.3258\nEpoch 32, Loss: 1.3058\nEpoch 33, Loss: 1.2866\nEpoch 34, Loss: 1.2683\nEpoch 35, Loss: 1.2508\nEpoch 36, Loss: 1.2340\nEpoch 37, Loss: 1.2179\nEpoch 38, Loss: 1.2024\nEpoch 39, Loss: 1.1876\nEpoch 40, Loss: 1.1734\nEpoch 41, Loss: 1.1598\nEpoch 42, Loss: 1.1467\nEpoch 43, Loss: 1.1341\nEpoch 44, Loss: 1.1219\nEpoch 45, Loss: 1.1102\nEpoch 46, Loss: 1.0989\nEpoch 47, Loss: 1.0879\nEpoch 48, Loss: 1.0773\nEpoch 49, Loss: 1.0671\nEpoch 50, Loss: 1.0572\nEpoch 51, Loss: 1.0477\nEpoch 52, Loss: 1.0385\nEpoch 53, Loss: 1.0296\nEpoch 54, Loss: 1.0210\nEpoch 55, Loss: 1.0127\nEpoch 56, Loss: 1.0046\nEpoch 57, Loss: 0.9968\nEpoch 58, Loss: 0.9893\nEpoch 59, Loss: 0.9820\nEpoch 60, Loss: 0.9749\nEpoch 61, Loss: 0.9680\nEpoch 62, Loss: 0.9614\nEpoch 63, Loss: 0.9549\nEpoch 64, Loss: 0.9487\nEpoch 65, Loss: 0.9426\nEpoch 66, Loss: 0.9368\nEpoch 67, Loss: 0.9311\nEpoch 68, Loss: 0.9256\nEpoch 69, Loss: 0.9202\nEpoch 70, Loss: 0.9151\nEpoch 71, Loss: 0.9101\nEpoch 72, Loss: 0.9052\nEpoch 73, Loss: 0.9005\nEpoch 74, Loss: 0.8959\nEpoch 75, Loss: 0.8915\nEpoch 76, Loss: 0.8872\nEpoch 77, Loss: 0.8831\nEpoch 78, Loss: 0.8790\nEpoch 79, Loss: 0.8751\nEpoch 80, Loss: 0.8713\nEpoch 81, Loss: 0.8677\nEpoch 82, Loss: 0.8641\nEpoch 83, Loss: 0.8606\nEpoch 84, Loss: 0.8573\nEpoch 85, Loss: 0.8540\nEpoch",
                "lineage": "10201"
            }
        ],
        "103": [],
        "104": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.28403900835053064,
                "model_info": "",
                "lineage": "10401"
            }
        ],
        "105": [],
        "106": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.conv1 = nn.Linear(input_dim, 128)\n        self.conv2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.conv1(x))\n        x = self.conv2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.026327307987324685,
                "model_info": "Epoch 1, Loss: 2.5637\nEpoch 2, Loss: 2.3018\nEpoch 3, Loss: 2.0463\nEpoch 4, Loss: 1.8829\nEpoch 5, Loss: 1.6715\nEpoch 6, Loss: 1.4397\nEpoch 7, Loss: 1.2645\nEpoch 8, Loss: 1.0876\nEpoch 9, Loss: 1.0032\nEpoch 10, Loss: 0.9056\nEpoch 11, Loss: 0.8401\nEpoch 12, Loss: 0.7818\nEpoch 13, Loss: 0.7403\nEpoch 14, Loss: 0.6997\nEpoch 15, Loss: 0.6598\nEpoch 16, Loss: 0.6347\nEpoch 17, Loss: 0.6168\nEpoch 18, Loss: 0.6002\nEpoch 19, Loss: 0.5839\nEpoch 20, Loss: 0.5680\nEpoch 21, Loss: 0.5540\nEpoch 22, Loss: 0.5445\nEpoch 23, Loss: 0.5356\nEpoch 24, Loss: 0.5266\nEpoch 25, Loss: 0.5196\nEpoch 26, Loss: 0.5130\nEpoch 27, Loss: 0.5066\nEpoch 28, Loss: 0.5011\nEpoch 29, Loss: 0.4963\nEpoch 30, Loss: 0.4921\nEpoch 31, Loss: 0.4890\nEpoch 32, Loss: 0.4854\nEpoch 33, Loss: 0.4814\nEpoch 34, Loss: 0.4785\nEpoch 35, Loss: 0.4761\nEpoch 36, Loss: 0.4734\nEpoch 37, Loss: 0.4710\nEpoch 38, Loss: 0.4689\nEpoch 39, Loss: 0.4665\nEpoch 40, Loss: 0.4642\nEpoch 41, Loss: 0.4622\nEpoch 42, Loss: 0.4604\nEpoch 43, Loss: 0.4589\nEpoch 44, Loss: 0.4574\nEpoch 45, Loss: 0.4557\nEpoch 46, Loss: 0.4542\nEpoch 47, Loss: 0.4528\nEpoch 48, Loss: 0.4513\nEpoch 49, Loss: 0.4499\nEpoch 50, Loss: 0.4487\nEpoch 51, Loss: 0.4475\nEpoch 52, Loss: 0.4463\nEpoch 53, Loss: 0.4451\nEpoch 54, Loss: 0.4440\nEpoch 55, Loss: 0.4429\nEpoch 56, Loss: 0.4418\nEpoch 57, Loss: 0.4407\nEpoch 58, Loss: 0.4397\nEpoch 59, Loss: 0.4388\nEpoch 60, Loss: 0.4379\nEpoch 61, Loss: 0.4370\nEpoch 62, Loss: 0.4361\nEpoch 63, Loss: 0.4352\nEpoch 64, Loss: 0.4344\nEpoch 65, Loss: 0.4336\nEpoch 66, Loss: 0.4328\nEpoch 67, Loss: 0.4320\nEpoch 68, Loss: 0.4312\nEpoch 69, Loss: 0.4305\nEpoch 70, Loss: 0.4298\nEpoch 71, Loss: 0.4291\nEpoch 72, Loss: 0.4284\nEpoch 73, Loss: 0.4277\nEpoch 74, Loss: 0.4271\nEpoch 75, Loss: 0.4264\nEpoch 76, Loss: 0.4258\nEpoch 77, Loss: 0.4252\nEpoch 78, Loss: 0.4246\nEpoch 79, Loss: 0.4240\nEpoch 80, Loss: 0.4235\nEpoch 81, Loss: 0.4229\nEpoch 82, Loss: 0.4224\nEpoch 83, Loss: 0.4219\nEpoch 84, Loss: 0.4214\nEpoch 85, Loss: 0.4209\nEpoch 86, Loss: 0.4204\nEpoch 87, Loss: 0.4199\nEpoch 88",
                "lineage": "10601"
            }
        ],
        "107": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.decomposition import PCA\nfrom sklearn.manifold import TSNE\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    pca = PCA(n_components=50)\n    adata_sc_pca = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_pca = pca.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=50, output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_pca, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_pca, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_pca)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.24060365990747928,
                "model_info": "Trainable parameters: 8387, Frozen parameters: 0\nEpoch 1, Loss: 2.6180\nEpoch 2, Loss: 2.5008\nEpoch 3, Loss: 2.3896\nEpoch 4, Loss: 2.2863\nEpoch 5, Loss: 2.1913\nEpoch 6, Loss: 2.1042\nEpoch 7, Loss: 2.0246\nEpoch 8, Loss: 1.9516\nEpoch 9, Loss: 1.8844\nEpoch 10, Loss: 1.8219\nEpoch 11, Loss: 1.7631\nEpoch 12, Loss: 1.7076\nEpoch 13, Loss: 1.6549\nEpoch 14, Loss: 1.6047\nEpoch 15, Loss: 1.5571\nEpoch 16, Loss: 1.5120\nEpoch 17, Loss: 1.4694\nEpoch 18, Loss: 1.4292\nEpoch 19, Loss: 1.3914\nEpoch 20, Loss: 1.3559\nEpoch 21, Loss: 1.3228\nEpoch 22, Loss: 1.2919\nEpoch 23, Loss: 1.2630\nEpoch 24, Loss: 1.2361\nEpoch 25, Loss: 1.2109\nEpoch 26, Loss: 1.1873\nEpoch 27, Loss: 1.1651\nEpoch 28, Loss: 1.1441\nEpoch 29, Loss: 1.1242\nEpoch 30, Loss: 1.1053\nEpoch 31, Loss: 1.0873\nEpoch 32, Loss: 1.0701\nEpoch 33, Loss: 1.0535\nEpoch 34, Loss: 1.0374\nEpoch 35, Loss: 1.0218\nEpoch 36, Loss: 1.0066\nEpoch 37, Loss: 0.9917\nEpoch 38, Loss: 0.9771\nEpoch 39, Loss: 0.9626\nEpoch 40, Loss: 0.9481\nEpoch 41, Loss: 0.9336\nEpoch 42, Loss: 0.9188\nEpoch 43, Loss: 0.9037\nEpoch 44, Loss: 0.8879\nEpoch 45, Loss: 0.8712\nEpoch 46, Loss: 0.8536\nEpoch 47, Loss: 0.8353\nEpoch 48, Loss: 0.8163\nEpoch 49, Loss: 0.7970\nEpoch 50, Loss: 0.7776\nEpoch 51, Loss: 0.7583\nEpoch 52, Loss: 0.7395\nEpoch 53, Loss: 0.7211\nEpoch 54, Loss: 0.7034\nEpoch 55, Loss: 0.6865\nEpoch 56, Loss: 0.6704\nEpoch 57, Loss: 0.6552\nEpoch 58, Loss: 0.6409\nEpoch 59, Loss: 0.6274\nEpoch 60, Loss: 0.6148\nEpoch 61, Loss: 0.6031\nEpoch 62, Loss: 0.5921\nEpoch 63, Loss: 0.5818\nEpoch 64, Loss: 0.5721\nEpoch 65, Loss: 0.5629\nEpoch 66, Loss: 0.5543\nEpoch 67, Loss: 0.5461\nEpoch 68, Loss: 0.5384\nEpoch 69, Loss: 0.5310\nEpoch 70, Loss: 0.5240\nEpoch 71, Loss: 0.5174\nEpoch 72, Loss: 0.5110\nEpoch 73, Loss: 0.5050\nEpoch 74, Loss: 0.4992\nEpoch 75, Loss: 0.4938\nEpoch 76, Loss: 0.4886\nEpoch 77, Loss: 0.4836\nEpoch 78, Loss: 0.4789\nEpoch 79, Loss: 0.4744\nEpoch 80, Loss: 0.4700\nEpoch 81, Loss: 0.4659\nEpoch 82, Loss: 0.4620\nEpoch 83, Loss: 0.4582\nEpoch 84, Loss: 0.4545\nEpoch 85, Loss: 0.4510\nEpoch",
                "lineage": "10701"
            }
        ],
        "108": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.004612065551306093,
                "model_info": "Trainable parameters: 2088077, Frozen parameters: 0\nEpoch 1, Loss: 2.5624\nEpoch 2, Loss: 2.3710\nEpoch 3, Loss: 2.1142\nEpoch 4, Loss: 1.8098\nEpoch 5, Loss: 1.5569\nEpoch 6, Loss: 1.3248\nEpoch 7, Loss: 1.1119\nEpoch 8, Loss: 0.9199\nEpoch 9, Loss: 0.7630\nEpoch 10, Loss: 0.6422\nEpoch 11, Loss: 0.5387\nEpoch 12, Loss: 0.4570\nEpoch 13, Loss: 0.3925\nEpoch 14, Loss: 0.3366\nEpoch 15, Loss: 0.2943\nEpoch 16, Loss: 0.2589\nEpoch 17, Loss: 0.2288\nEpoch 18, Loss: 0.2044\nEpoch 19, Loss: 0.1836\nEpoch 20, Loss: 0.1661\nEpoch 21, Loss: 0.1513\nEpoch 22, Loss: 0.1385\nEpoch 23, Loss: 0.1279\nEpoch 24, Loss: 0.1187\nEpoch 25, Loss: 0.1106\nEpoch 26, Loss: 0.1038\nEpoch 27, Loss: 0.0975\nEpoch 28, Loss: 0.0916\nEpoch 29, Loss: 0.0865\nEpoch 30, Loss: 0.0821\nEpoch 31, Loss: 0.0778\nEpoch 32, Loss: 0.0740\nEpoch 33, Loss: 0.0705\nEpoch 34, Loss: 0.0671\nEpoch 35, Loss: 0.0640\nEpoch 36, Loss: 0.0611\nEpoch 37, Loss: 0.0584\nEpoch 38, Loss: 0.0558\nEpoch 39, Loss: 0.0533\nEpoch 40, Loss: 0.0511\nEpoch 41, Loss: 0.0489\nEpoch 42, Loss: 0.0467\nEpoch 43, Loss: 0.0448\nEpoch 44, Loss: 0.0428\nEpoch 45, Loss: 0.0410\nEpoch 46, Loss: 0.0392\nEpoch 47, Loss: 0.0375\nEpoch 48, Loss: 0.0359\nEpoch 49, Loss: 0.0344\nEpoch 50, Loss: 0.0329\nEpoch 51, Loss: 0.0314\nEpoch 52, Loss: 0.0300\nEpoch 53, Loss: 0.0287\nEpoch 54, Loss: 0.0274\nEpoch 55, Loss: 0.0262\nEpoch 56, Loss: 0.0250\nEpoch 57, Loss: 0.0239\nEpoch 58, Loss: 0.0228\nEpoch 59, Loss: 0.0218\nEpoch 60, Loss: 0.0208\nEpoch 61, Loss: 0.0198\nEpoch 62, Loss: 0.0189\nEpoch 63, Loss: 0.0181\nEpoch 64, Loss: 0.0172\nEpoch 65, Loss: 0.0164\nEpoch 66, Loss: 0.0157\nEpoch 67, Loss: 0.0150\nEpoch 68, Loss: 0.0143\nEpoch 69, Loss: 0.0137\nEpoch 70, Loss: 0.0130\nEpoch 71, Loss: 0.0125\nEpoch 72, Loss: 0.0119\nEpoch 73, Loss: 0.0114\nEpoch 74, Loss: 0.0109\nEpoch 75, Loss: 0.0104\nEpoch 76, Loss: 0.0100\nEpoch 77, Loss: 0.0096\nEpoch 78, Loss: 0.0092\nEpoch 79, Loss: 0.0088\nEpoch 80, Loss: 0.0084\nEpoch 81, Loss: 0.0081\nEpoch 82, Loss: 0.0078\nEpoch 83, Loss: 0.0075\nEpoch 84, Loss: 0.0072\nEpoch 85, Loss: 0.0069\nEp",
                "lineage": "10801"
            }
        ],
        "109": [],
        "110": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.05282653298674862,
                "model_info": "Trainable parameters: 2088077, Frozen parameters: 0\nEpoch 1, Loss: 2.5614\nEpoch 2, Loss: 2.3732\nEpoch 3, Loss: 2.1426\nEpoch 4, Loss: 1.8521\nEpoch 5, Loss: 1.6252\nEpoch 6, Loss: 1.3755\nEpoch 7, Loss: 1.1698\nEpoch 8, Loss: 0.9874\nEpoch 9, Loss: 0.8277\nEpoch 10, Loss: 0.6965\nEpoch 11, Loss: 0.5977\nEpoch 12, Loss: 0.5116\nEpoch 13, Loss: 0.4453\nEpoch 14, Loss: 0.3881\nEpoch 15, Loss: 0.3396\nEpoch 16, Loss: 0.3008\nEpoch 17, Loss: 0.2655\nEpoch 18, Loss: 0.2365\nEpoch 19, Loss: 0.2117\nEpoch 20, Loss: 0.1910\nEpoch 21, Loss: 0.1733\nEpoch 22, Loss: 0.1576\nEpoch 23, Loss: 0.1443\nEpoch 24, Loss: 0.1335\nEpoch 25, Loss: 0.1238\nEpoch 26, Loss: 0.1151\nEpoch 27, Loss: 0.1076\nEpoch 28, Loss: 0.1012\nEpoch 29, Loss: 0.0952\nEpoch 30, Loss: 0.0899\nEpoch 31, Loss: 0.0850\nEpoch 32, Loss: 0.0807\nEpoch 33, Loss: 0.0766\nEpoch 34, Loss: 0.0731\nEpoch 35, Loss: 0.0697\nEpoch 36, Loss: 0.0666\nEpoch 37, Loss: 0.0637\nEpoch 38, Loss: 0.0610\nEpoch 39, Loss: 0.0584\nEpoch 40, Loss: 0.0560\nEpoch 41, Loss: 0.0537\nEpoch 42, Loss: 0.0515\nEpoch 43, Loss: 0.0494\nEpoch 44, Loss: 0.0475\nEpoch 45, Loss: 0.0456\nEpoch 46, Loss: 0.0438\nEpoch 47, Loss: 0.0421\nEpoch 48, Loss: 0.0404\nEpoch 49, Loss: 0.0389\nEpoch 50, Loss: 0.0374\nEpoch 51, Loss: 0.0359\nEpoch 52, Loss: 0.0345\nEpoch 53, Loss: 0.0332\nEpoch 54, Loss: 0.0320\nEpoch 55, Loss: 0.0307\nEpoch 56, Loss: 0.0296\nEpoch 57, Loss: 0.0284\nEpoch 58, Loss: 0.0274\nEpoch 59, Loss: 0.0263\nEpoch 60, Loss: 0.0253\nEpoch 61, Loss: 0.0243\nEpoch 62, Loss: 0.0234\nEpoch 63, Loss: 0.0225\nEpoch 64, Loss: 0.0216\nEpoch 65, Loss: 0.0208\nEpoch 66, Loss: 0.0200\nEpoch 67, Loss: 0.0193\nEpoch 68, Loss: 0.0185\nEpoch 69, Loss: 0.0179\nEpoch 70, Loss: 0.0172\nEpoch 71, Loss: 0.0165\nEpoch 72, Loss: 0.0159\nEpoch 73, Loss: 0.0153\nEpoch 74, Loss: 0.0148\nEpoch 75, Loss: 0.0142\nEpoch 76, Loss: 0.0137\nEpoch 77, Loss: 0.0132\nEpoch 78, Loss: 0.0127\nEpoch 79, Loss: 0.0123\nEpoch 80, Loss: 0.0119\nEpoch 81, Loss: 0.0114\nEpoch 82, Loss: 0.0110\nEpoch 83, Loss: 0.0107\nEpoch 84, Loss: 0.0103\nEpoch 85, Loss: 0.0100\nEp",
                "lineage": "11001"
            }
        ],
        "111": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    \n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.26435146613042515,
                "model_info": "",
                "lineage": "11101"
            }
        ],
        "112": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nimport networkx as nx\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef create_spatial_graph(adata_sp):\n    coords = adata_sp.obsm['spatial_coords']\n    G = nx.Graph()\n    for i in range(len(coords)):\n        G.add_node(i, pos=coords[i])\n    for i in range(len(coords)):\n        for j in range(i + 1, len(coords)):\n            distance = np.linalg.norm(coords[i] - coords[j])\n            if distance < threshold:  # Define a suitable threshold\n                G.add_edge(i, j)\n    return G\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.1777731817252975,
                "model_info": "",
                "lineage": "11201"
            }
        ],
        "113": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        memory_consumption = torch.cuda.memory_allocated() / (1024 ** 2) if torch.cuda.is_available() else 0\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Memory Consumption: {memory_consumption:.2f} MB')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.0986067452006077,
                "model_info": "Trainable parameters: 4174349, Frozen parameters: 0\nEpoch 1, Loss: 2.5675, Memory Consumption: 0.00 MB\nEpoch 2, Loss: 2.3280, Memory Consumption: 0.00 MB\nEpoch 3, Loss: 1.9714, Memory Consumption: 0.00 MB\nEpoch 4, Loss: 1.6180, Memory Consumption: 0.00 MB\nEpoch 5, Loss: 1.2898, Memory Consumption: 0.00 MB\nEpoch 6, Loss: 1.0142, Memory Consumption: 0.00 MB\nEpoch 7, Loss: 0.7796, Memory Consumption: 0.00 MB\nEpoch 8, Loss: 0.6215, Memory Consumption: 0.00 MB\nEpoch 9, Loss: 0.4884, Memory Consumption: 0.00 MB\nEpoch 10, Loss: 0.3993, Memory Consumption: 0.00 MB\nEpoch 11, Loss: 0.3282, Memory Consumption: 0.00 MB\nEpoch 12, Loss: 0.2778, Memory Consumption: 0.00 MB\nEpoch 13, Loss: 0.2359, Memory Consumption: 0.00 MB\nEpoch 14, Loss: 0.2014, Memory Consumption: 0.00 MB\nEpoch 15, Loss: 0.1791, Memory Consumption: 0.00 MB\nEpoch 16, Loss: 0.1553, Memory Consumption: 0.00 MB\nEpoch 17, Loss: 0.1402, Memory Consumption: 0.00 MB\nEpoch 18, Loss: 0.1286, Memory Consumption: 0.00 MB\nEpoch 19, Loss: 0.1165, Memory Consumption: 0.00 MB\nEpoch 20, Loss: 0.1071, Memory Consumption: 0.00 MB\nEpoch 21, Loss: 0.0976, Memory Consumption: 0.00 MB\nEpoch 22, Loss: 0.0910, Memory Consumption: 0.00 MB\nEpoch 23, Loss: 0.0856, Memory Consumption: 0.00 MB\nEpoch 24, Loss: 0.0798, Memory Consumption: 0.00 MB\nEpoch 25, Loss: 0.0753, Memory Consumption: 0.00 MB\nEpoch 26, Loss: 0.0705, Memory Consumption: 0.00 MB\nEpoch 27, Loss: 0.0678, Memory Consumption: 0.00 MB\nEpoch 28, Loss: 0.0637, Memory Consumption: 0.00 MB\nEpoch 29, Loss: 0.0603, Memory Consumption: 0.00 MB\nEpoch 30, Loss: 0.0570, Memory Consumption: 0.00 MB\nEpoch 31, Loss: 0.0546, Memory Consumption: 0.00 MB\nEpoch 32, Loss: 0.0520, Memory Consumption: 0.00 MB\nEpoch 33, Loss: 0.0493, Memory Consumption: 0.00 MB\nEpoch 34, Loss: 0.0469, Memory Consumption: 0.00 MB\nEpoch 35, Loss: 0.0448, Memory Consumption: 0.00 MB\nEpoch 36, Loss: 0.0429, Memory Consumption: 0.00 MB\nEpoch 37, Loss: 0.0407, Memory Consumption: 0.00 MB\nEpoch 38, Loss: 0.0388, Memory Co",
                "lineage": "11301"
            }
        ],
        "114": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.05037688908900173,
                "model_info": "Trainable parameters: 4143117, Frozen parameters: 0\nEpoch 1, Loss: 2.5727\nEpoch 2, Loss: 2.0357\nEpoch 3, Loss: 1.3922\nEpoch 4, Loss: 1.0734\nEpoch 5, Loss: 0.7719\nEpoch 6, Loss: 0.5886\nEpoch 7, Loss: 0.4480\nEpoch 8, Loss: 0.3662\nEpoch 9, Loss: 0.3067\nEpoch 10, Loss: 0.2587\nEpoch 11, Loss: 0.2270\nEpoch 12, Loss: 0.1957\nEpoch 13, Loss: 0.1744\nEpoch 14, Loss: 0.1559\nEpoch 15, Loss: 0.1410\nEpoch 16, Loss: 0.1333\nEpoch 17, Loss: 0.1194\nEpoch 18, Loss: 0.1085\nEpoch 19, Loss: 0.1042\nEpoch 20, Loss: 0.0987\nEpoch 21, Loss: 0.0913\nEpoch 22, Loss: 0.0855\nEpoch 23, Loss: 0.0807\nEpoch 24, Loss: 0.0772\nEpoch 25, Loss: 0.0749\nEpoch 26, Loss: 0.0716\nEpoch 27, Loss: 0.0674\nEpoch 28, Loss: 0.0644\nEpoch 29, Loss: 0.0626\nEpoch 30, Loss: 0.0601\nEpoch 31, Loss: 0.0574\nEpoch 32, Loss: 0.0553\nEpoch 33, Loss: 0.0533\nEpoch 34, Loss: 0.0512\nEpoch 35, Loss: 0.0496\nEpoch 36, Loss: 0.0481\nEpoch 37, Loss: 0.0462\nEpoch 38, Loss: 0.0444\nEpoch 39, Loss: 0.0430\nEpoch 40, Loss: 0.0417\nEpoch 41, Loss: 0.0402\nEpoch 42, Loss: 0.0389\nEpoch 43, Loss: 0.0377\nEpoch 44, Loss: 0.0365\nEpoch 45, Loss: 0.0353\nEpoch 46, Loss: 0.0343\nEpoch 47, Loss: 0.0333\nEpoch 48, Loss: 0.0322\nEpoch 49, Loss: 0.0312\nEpoch 50, Loss: 0.0303\nEpoch 51, Loss: 0.0294\nEpoch 52, Loss: 0.0286\nEpoch 53, Loss: 0.0278\nEpoch 54, Loss: 0.0270\nEpoch 55, Loss: 0.0262\nEpoch 56, Loss: 0.0254\nEpoch 57, Loss: 0.0247\nEpoch 58, Loss: 0.0240\nEpoch 59, Loss: 0.0233\nEpoch 60, Loss: 0.0227\nEpoch 61, Loss: 0.0221\nEpoch 62, Loss: 0.0215\nEpoch 63, Loss: 0.0209\nEpoch 64, Loss: 0.0203\nEpoch 65, Loss: 0.0198\nEpoch 66, Loss: 0.0193\nEpoch 67, Loss: 0.0188\nEpoch 68, Loss: 0.0183\nEpoch 69, Loss: 0.0178\nEpoch 70, Loss: 0.0173\nEpoch 71, Loss: 0.0169\nEpoch 72, Loss: 0.0164\nEpoch 73, Loss: 0.0160\nEpoch 74, Loss: 0.0156\nEpoch 75, Loss: 0.0152\nEpoch 76, Loss: 0.0148\nEpoch 77, Loss: 0.0144\nEpoch 78, Loss: 0.0141\nEpoch 79, Loss: 0.0137\nEpoch 80, Loss: 0.0134\nEpoch 81, Loss: 0.0131\nEpoch 82, Loss: 0.0128\nEpoch 83, Loss: 0.0124\nEpoch 84, Loss: 0.0121\nEpoch 85, Loss: 0.0119\nEp",
                "lineage": "11401"
            }
        ],
        "115": [],
        "116": [],
        "117": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.10864460004111812,
                "model_info": "Epoch 1, Loss: 2.5770\nEpoch 2, Loss: 2.0173\nEpoch 3, Loss: 1.5365\nEpoch 4, Loss: 1.1205\nEpoch 5, Loss: 0.8280\nEpoch 6, Loss: 0.6093\nEpoch 7, Loss: 0.4760\nEpoch 8, Loss: 0.3879\nEpoch 9, Loss: 0.3263\nEpoch 10, Loss: 0.2781\nEpoch 11, Loss: 0.2340\nEpoch 12, Loss: 0.2040\nEpoch 13, Loss: 0.1887\nEpoch 14, Loss: 0.1661\nEpoch 15, Loss: 0.1506\nEpoch 16, Loss: 0.1331\nEpoch 17, Loss: 0.1227\nEpoch 18, Loss: 0.1172\nEpoch 19, Loss: 0.1113\nEpoch 20, Loss: 0.1018\nEpoch 21, Loss: 0.0970\nEpoch 22, Loss: 0.0901\nEpoch 23, Loss: 0.0848\nEpoch 24, Loss: 0.0817\nEpoch 25, Loss: 0.0793\nEpoch 26, Loss: 0.0751\nEpoch 27, Loss: 0.0719\nEpoch 28, Loss: 0.0699\nEpoch 29, Loss: 0.0663\nEpoch 30, Loss: 0.0634\nEpoch 31, Loss: 0.0611\nEpoch 32, Loss: 0.0591\nEpoch 33, Loss: 0.0567\nEpoch 34, Loss: 0.0550\nEpoch 35, Loss: 0.0537\nEpoch 36, Loss: 0.0516\nEpoch 37, Loss: 0.0499\nEpoch 38, Loss: 0.0483\nEpoch 39, Loss: 0.0469\nEpoch 40, Loss: 0.0451\nEpoch 41, Loss: 0.0437\nEpoch 42, Loss: 0.0425\nEpoch 43, Loss: 0.0411\nEpoch 44, Loss: 0.0398\nEpoch 45, Loss: 0.0387\nEpoch 46, Loss: 0.0377\nEpoch 47, Loss: 0.0365\nEpoch 48, Loss: 0.0355\nEpoch 49, Loss: 0.0345\nEpoch 50, Loss: 0.0335\nEpoch 51, Loss: 0.0325\nEpoch 52, Loss: 0.0316\nEpoch 53, Loss: 0.0308\nEpoch 54, Loss: 0.0299\nEpoch 55, Loss: 0.0290\nEpoch 56, Loss: 0.0282\nEpoch 57, Loss: 0.0275\nEpoch 58, Loss: 0.0267\nEpoch 59, Loss: 0.0260\nEpoch 60, Loss: 0.0254\nEpoch 61, Loss: 0.0247\nEpoch 62, Loss: 0.0240\nEpoch 63, Loss: 0.0234\nEpoch 64, Loss: 0.0228\nEpoch 65, Loss: 0.0223\nEpoch 66, Loss: 0.0217\nEpoch 67, Loss: 0.0212\nEpoch 68, Loss: 0.0206\nEpoch 69, Loss: 0.0201\nEpoch 70, Loss: 0.0196\nEpoch 71, Loss: 0.0191\nEpoch 72, Loss: 0.0187\nEpoch 73, Loss: 0.0182\nEpoch 74, Loss: 0.0178\nEpoch 75, Loss: 0.0174\nEpoch 76, Loss: 0.0170\nEpoch 77, Loss: 0.0166\nEpoch 78, Loss: 0.0162\nEpoch 79, Loss: 0.0158\nEpoch 80, Loss: 0.0154\nEpoch 81, Loss: 0.0151\nEpoch 82, Loss: 0.0148\nEpoch 83, Loss: 0.0144\nEpoch 84, Loss: 0.0141\nEpoch 85, Loss: 0.0138\nEpoch 86, Loss: 0.0135\nEpoch 87, Loss: 0.0132\nEpoch 88",
                "lineage": "11701"
            }
        ],
        "118": [],
        "119": [],
        "120": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.2997098101062645,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5639\nEpoch 2, Loss: 2.2357\nEpoch 3, Loss: 2.0113\nEpoch 4, Loss: 1.7592\nEpoch 5, Loss: 1.6380\nEpoch 6, Loss: 1.4191\nEpoch 7, Loss: 1.3284\nEpoch 8, Loss: 1.2523\nEpoch 9, Loss: 1.1498\nEpoch 10, Loss: 1.0467\nEpoch 11, Loss: 1.0040\nEpoch 12, Loss: 0.9606\nEpoch 13, Loss: 0.9207\nEpoch 14, Loss: 0.8788\nEpoch 15, Loss: 0.8440\nEpoch 16, Loss: 0.8233\nEpoch 17, Loss: 0.8095\nEpoch 18, Loss: 0.7920\nEpoch 19, Loss: 0.7753\nEpoch 20, Loss: 0.7638\nEpoch 21, Loss: 0.7527\nEpoch 22, Loss: 0.7418\nEpoch 23, Loss: 0.7347\nEpoch 24, Loss: 0.7303\nEpoch 25, Loss: 0.7242\nEpoch 26, Loss: 0.7183\nEpoch 27, Loss: 0.7145\nEpoch 28, Loss: 0.7097\nEpoch 29, Loss: 0.7052\nEpoch 30, Loss: 0.7018\nEpoch 31, Loss: 0.6979\nEpoch 32, Loss: 0.6942\nEpoch 33, Loss: 0.6916\nEpoch 34, Loss: 0.6886\nEpoch 35, Loss: 0.6857\nEpoch 36, Loss: 0.6836\nEpoch 37, Loss: 0.6810\nEpoch 38, Loss: 0.6786\nEpoch 39, Loss: 0.6767\nEpoch 40, Loss: 0.6745\nEpoch 41, Loss: 0.6725\nEpoch 42, Loss: 0.6707\nEpoch 43, Loss: 0.6688\nEpoch 44, Loss: 0.6670\nEpoch 45, Loss: 0.6655\nEpoch 46, Loss: 0.6637\nEpoch 47, Loss: 0.6621\nEpoch 48, Loss: 0.6607\nEpoch 49, Loss: 0.6591\nEpoch 50, Loss: 0.6578\nEpoch 51, Loss: 0.6564\nEpoch 52, Loss: 0.6550\nEpoch 53, Loss: 0.6538\nEpoch 54, Loss: 0.6525\nEpoch 55, Loss: 0.6513\nEpoch 56, Loss: 0.6501\nEpoch 57, Loss: 0.6489\nEpoch 58, Loss: 0.6478\nEpoch 59, Loss: 0.6467\nEpoch 60, Loss: 0.6456\nEpoch 61, Loss: 0.6446\nEpoch 62, Loss: 0.6435\nEpoch 63, Loss: 0.6425\nEpoch 64, Loss: 0.6415\nEpoch 65, Loss: 0.6406\nEpoch 66, Loss: 0.6396\nEpoch 67, Loss: 0.6387\nEpoch 68, Loss: 0.6378\nEpoch 69, Loss: 0.6369\nEpoch 70, Loss: 0.6361\nEpoch 71, Loss: 0.6352\nEpoch 72, Loss: 0.6344\nEpoch 73, Loss: 0.6336\nEpoch 74, Loss: 0.6328\nEpoch 75, Loss: 0.6320\nEpoch 76, Loss: 0.6313\nEpoch 77, Loss: 0.6305\nEpoch 78, Loss: 0.6298\nEpoch 79, Loss: 0.6291\nEpoch 80, Loss: 0.6284\nEpoch 81, Loss: 0.6277\nEpoch 82, Loss: 0.6270\nEpoch 83, Loss: 0.6263\nEpoch 84, Loss: 0.6257\nEpoch 85, Loss: 0.6251\nEp",
                "lineage": "12001"
            }
        ],
        "121": [],
        "122": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=150)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.071774043859396,
                "model_info": "Trainable parameters: 4174349, Frozen parameters: 0\nEpoch 1, Loss: 2.5677\nEpoch 2, Loss: 2.4106\nEpoch 3, Loss: 2.1669\nEpoch 4, Loss: 1.9065\nEpoch 5, Loss: 1.6840\nEpoch 6, Loss: 1.4758\nEpoch 7, Loss: 1.2946\nEpoch 8, Loss: 1.1289\nEpoch 9, Loss: 0.9831\nEpoch 10, Loss: 0.8554\nEpoch 11, Loss: 0.7500\nEpoch 12, Loss: 0.6599\nEpoch 13, Loss: 0.5815\nEpoch 14, Loss: 0.5144\nEpoch 15, Loss: 0.4570\nEpoch 16, Loss: 0.4063\nEpoch 17, Loss: 0.3626\nEpoch 18, Loss: 0.3241\nEpoch 19, Loss: 0.2908\nEpoch 20, Loss: 0.2612\nEpoch 21, Loss: 0.2361\nEpoch 22, Loss: 0.2140\nEpoch 23, Loss: 0.1949\nEpoch 24, Loss: 0.1785\nEpoch 25, Loss: 0.1639\nEpoch 26, Loss: 0.1513\nEpoch 27, Loss: 0.1403\nEpoch 28, Loss: 0.1305\nEpoch 29, Loss: 0.1217\nEpoch 30, Loss: 0.1141\nEpoch 31, Loss: 0.1075\nEpoch 32, Loss: 0.1015\nEpoch 33, Loss: 0.0961\nEpoch 34, Loss: 0.0912\nEpoch 35, Loss: 0.0868\nEpoch 36, Loss: 0.0827\nEpoch 37, Loss: 0.0790\nEpoch 38, Loss: 0.0755\nEpoch 39, Loss: 0.0723\nEpoch 40, Loss: 0.0693\nEpoch 41, Loss: 0.0665\nEpoch 42, Loss: 0.0638\nEpoch 43, Loss: 0.0613\nEpoch 44, Loss: 0.0589\nEpoch 45, Loss: 0.0566\nEpoch 46, Loss: 0.0545\nEpoch 47, Loss: 0.0524\nEpoch 48, Loss: 0.0504\nEpoch 49, Loss: 0.0485\nEpoch 50, Loss: 0.0467\nEpoch 51, Loss: 0.0449\nEpoch 52, Loss: 0.0432\nEpoch 53, Loss: 0.0416\nEpoch 54, Loss: 0.0400\nEpoch 55, Loss: 0.0385\nEpoch 56, Loss: 0.0370\nEpoch 57, Loss: 0.0356\nEpoch 58, Loss: 0.0343\nEpoch 59, Loss: 0.0330\nEpoch 60, Loss: 0.0317\nEpoch 61, Loss: 0.0305\nEpoch 62, Loss: 0.0293\nEpoch 63, Loss: 0.0282\nEpoch 64, Loss: 0.0271\nEpoch 65, Loss: 0.0261\nEpoch 66, Loss: 0.0251\nEpoch 67, Loss: 0.0242\nEpoch 68, Loss: 0.0232\nEpoch 69, Loss: 0.0224\nEpoch 70, Loss: 0.0215\nEpoch 71, Loss: 0.0207\nEpoch 72, Loss: 0.0199\nEpoch 73, Loss: 0.0192\nEpoch 74, Loss: 0.0184\nEpoch 75, Loss: 0.0178\nEpoch 76, Loss: 0.0171\nEpoch 77, Loss: 0.0165\nEpoch 78, Loss: 0.0159\nEpoch 79, Loss: 0.0153\nEpoch 80, Loss: 0.0147\nEpoch 81, Loss: 0.0142\nEpoch 82, Loss: 0.0137\nEpoch 83, Loss: 0.0132\nEpoch 84, Loss: 0.0128\nEpoch 85, Loss: 0.0123\nEp",
                "lineage": "12201"
            }
        ],
        "123": [],
        "124": [],
        "125": [],
        "126": [],
        "127": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.8101023486777357,
                "model_info": "",
                "lineage": "12701"
            }
        ],
        "128": [],
        "129": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005, weight_decay=1e-5)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=200, max_depth=10)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.2610663919297936,
                "model_info": "Trainable parameters: 4174349, Frozen parameters: 0\nEpoch 1, Loss: 2.5694\nEpoch 2, Loss: 2.4241\nEpoch 3, Loss: 2.1997\nEpoch 4, Loss: 1.9799\nEpoch 5, Loss: 1.7444\nEpoch 6, Loss: 1.5261\nEpoch 7, Loss: 1.3263\nEpoch 8, Loss: 1.1451\nEpoch 9, Loss: 0.9851\nEpoch 10, Loss: 0.8459\nEpoch 11, Loss: 0.7276\nEpoch 12, Loss: 0.6279\nEpoch 13, Loss: 0.5428\nEpoch 14, Loss: 0.4709\nEpoch 15, Loss: 0.4111\nEpoch 16, Loss: 0.3614\nEpoch 17, Loss: 0.3192\nEpoch 18, Loss: 0.2840\nEpoch 19, Loss: 0.2542\nEpoch 20, Loss: 0.2288\nEpoch 21, Loss: 0.2074\nEpoch 22, Loss: 0.1890\nEpoch 23, Loss: 0.1733\nEpoch 24, Loss: 0.1597\nEpoch 25, Loss: 0.1477\nEpoch 26, Loss: 0.1373\nEpoch 27, Loss: 0.1283\nEpoch 28, Loss: 0.1202\nEpoch 29, Loss: 0.1132\nEpoch 30, Loss: 0.1068\nEpoch 31, Loss: 0.1012\nEpoch 32, Loss: 0.0961\nEpoch 33, Loss: 0.0916\nEpoch 34, Loss: 0.0873\nEpoch 35, Loss: 0.0835\nEpoch 36, Loss: 0.0798\nEpoch 37, Loss: 0.0765\nEpoch 38, Loss: 0.0734\nEpoch 39, Loss: 0.0704\nEpoch 40, Loss: 0.0677\nEpoch 41, Loss: 0.0651\nEpoch 42, Loss: 0.0626\nEpoch 43, Loss: 0.0602\nEpoch 44, Loss: 0.0580\nEpoch 45, Loss: 0.0559\nEpoch 46, Loss: 0.0538\nEpoch 47, Loss: 0.0519\nEpoch 48, Loss: 0.0500\nEpoch 49, Loss: 0.0482\nEpoch 50, Loss: 0.0464\nEpoch 51, Loss: 0.0448\nEpoch 52, Loss: 0.0431\nEpoch 53, Loss: 0.0416\nEpoch 54, Loss: 0.0401\nEpoch 55, Loss: 0.0386\nEpoch 56, Loss: 0.0373\nEpoch 57, Loss: 0.0359\nEpoch 58, Loss: 0.0346\nEpoch 59, Loss: 0.0334\nEpoch 60, Loss: 0.0322\nEpoch 61, Loss: 0.0310\nEpoch 62, Loss: 0.0299\nEpoch 63, Loss: 0.0288\nEpoch 64, Loss: 0.0278\nEpoch 65, Loss: 0.0268\nEpoch 66, Loss: 0.0259\nEpoch 67, Loss: 0.0249\nEpoch 68, Loss: 0.0240\nEpoch 69, Loss: 0.0232\nEpoch 70, Loss: 0.0224\nEpoch 71, Loss: 0.0216\nEpoch 72, Loss: 0.0208\nEpoch 73, Loss: 0.0201\nEpoch 74, Loss: 0.0194\nEpoch 75, Loss: 0.0187\nEpoch 76, Loss: 0.0180\nEpoch 77, Loss: 0.0174\nEpoch 78, Loss: 0.0168\nEpoch 79, Loss: 0.0162\nEpoch 80, Loss: 0.0157\nEpoch 81, Loss: 0.0151\nEpoch 82, Loss: 0.0146\nEpoch 83, Loss: 0.0141\nEpoch 84, Loss: 0.0137\nEpoch 85, Loss: 0.0132\nEp",
                "lineage": "12901"
            }
        ],
        "130": [],
        "131": [],
        "132": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    combined_proportions = np.clip(combined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.24936767493522224,
                "model_info": "",
                "lineage": "13201"
            }
        ],
        "133": [],
        "134": [],
        "135": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.6721411283427104,
                "model_info": "",
                "lineage": "13501"
            }
        ],
        "136": [],
        "137": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Gradient Norm: {torch.norm(torch.cat([p.grad.flatten() for p in model.parameters() if p.grad is not None])).item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=50)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.0831617421742087,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5754, Gradient Norm: 0.8688\nEpoch 2, Loss: 2.5091, Gradient Norm: 1.2957\nEpoch 3, Loss: 2.4167, Gradient Norm: 1.7304\nEpoch 4, Loss: 2.3046, Gradient Norm: 1.4623\nEpoch 5, Loss: 2.1962, Gradient Norm: 1.4468\nEpoch 6, Loss: 2.0988, Gradient Norm: 1.6360\nEpoch 7, Loss: 1.9885, Gradient Norm: 1.5223\nEpoch 8, Loss: 1.8808, Gradient Norm: 1.4367\nEpoch 9, Loss: 1.7820, Gradient Norm: 1.5546\nEpoch 10, Loss: 1.6846, Gradient Norm: 1.6358\nEpoch 11, Loss: 1.5879, Gradient Norm: 1.5167\nEpoch 12, Loss: 1.4978, Gradient Norm: 1.4592\nEpoch 13, Loss: 1.4137, Gradient Norm: 1.4752\nEpoch 14, Loss: 1.3315, Gradient Norm: 1.4498\nEpoch 15, Loss: 1.2522, Gradient Norm: 1.4010\nEpoch 16, Loss: 1.1791, Gradient Norm: 1.3963\nEpoch 17, Loss: 1.1098, Gradient Norm: 1.4232\nEpoch 18, Loss: 1.0432, Gradient Norm: 1.3950\nEpoch 19, Loss: 0.9800, Gradient Norm: 1.3545\nEpoch 20, Loss: 0.9207, Gradient Norm: 1.3156\nEpoch 21, Loss: 0.8649, Gradient Norm: 1.2670\nEpoch 22, Loss: 0.8127, Gradient Norm: 1.2063\nEpoch 23, Loss: 0.7636, Gradient Norm: 1.1248\nEpoch 24, Loss: 0.7174, Gradient Norm: 1.0231\nEpoch 25, Loss: 0.6744, Gradient Norm: 0.9247\nEpoch 26, Loss: 0.6346, Gradient Norm: 0.8469\nEpoch 27, Loss: 0.5980, Gradient Norm: 0.7937\nEpoch 28, Loss: 0.5642, Gradient Norm: 0.7619\nEpoch 29, Loss: 0.5325, Gradient Norm: 0.7463\nEpoch 30, Loss: 0.5024, Gradient Norm: 0.7366\nEpoch 31, Loss: 0.4741, Gradient Norm: 0.6911\nEpoch 32, Loss: 0.4485, Gradient Norm: 0.6721\nEpoch 33, Loss: 0.4252, Gradient Norm: 0.6608\nEpoch 34, Loss: 0.4034, Gradient Norm: 0.6575\nEpoch 35, Loss: 0.3828, Gradient Norm: 0.6252\nEpoch 36, Loss: 0.3632, Gradient Norm: 0.5334\nEpoch 37, Loss: 0.3451, Gradient Norm: 0.5120\nEpoch 38, Loss: 0.3283, Gradient Norm: 0.5323\nEpoch 39, Loss: 0.3125, Gradient Norm: 0.4849\nEpoch 40, Loss: 0.2980, Gradient Norm: 0.4550\nEpoch 41, Loss: 0.2850, Gradient Norm: 0.4735\nEpoch 42, Loss: 0.2727, Gradient Norm: 0.4273\nEpoch 43, Loss: 0.2614, G",
                "lineage": "13701"
            }
        ],
        "138": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.3210585812952417,
                "model_info": "Trainable parameters: 4143117, Frozen parameters: 0\nEpoch 1, Loss: 2.5627\nEpoch 2, Loss: 2.3757\nEpoch 3, Loss: 1.9845\nEpoch 4, Loss: 1.6911\nEpoch 5, Loss: 1.5554\nEpoch 6, Loss: 1.3420\nEpoch 7, Loss: 1.1507\nEpoch 8, Loss: 1.1368\nEpoch 9, Loss: 1.0459\nEpoch 10, Loss: 0.9517\nEpoch 11, Loss: 0.9346\nEpoch 12, Loss: 0.9244\nEpoch 13, Loss: 0.8880\nEpoch 14, Loss: 0.8636\nEpoch 15, Loss: 0.8549\nEpoch 16, Loss: 0.8518\nEpoch 17, Loss: 0.8468\nEpoch 18, Loss: 0.8368\nEpoch 19, Loss: 0.8267\nEpoch 20, Loss: 0.8207\nEpoch 21, Loss: 0.8180\nEpoch 22, Loss: 0.8164\nEpoch 23, Loss: 0.8149\nEpoch 24, Loss: 0.8128\nEpoch 25, Loss: 0.8103\nEpoch 26, Loss: 0.8077\nEpoch 27, Loss: 0.8056\nEpoch 28, Loss: 0.8041\nEpoch 29, Loss: 0.8032\nEpoch 30, Loss: 0.8026\nEpoch 31, Loss: 0.8021\nEpoch 32, Loss: 0.8016\nEpoch 33, Loss: 0.8009\nEpoch 34, Loss: 0.8001\nEpoch 35, Loss: 0.7993\nEpoch 36, Loss: 0.7986\nEpoch 37, Loss: 0.7980\nEpoch 38, Loss: 0.7977\nEpoch 39, Loss: 0.7974\nEpoch 40, Loss: 0.7972\nEpoch 41, Loss: 0.7969\nEpoch 42, Loss: 0.7966\nEpoch 43, Loss: 0.7963\nEpoch 44, Loss: 0.7959\nEpoch 45, Loss: 0.7956\nEpoch 46, Loss: 0.7954\nEpoch 47, Loss: 0.7952\nEpoch 48, Loss: 0.7950\nEpoch 49, Loss: 0.7949\nEpoch 50, Loss: 0.7947\nEpoch 51, Loss: 0.7946\nEpoch 52, Loss: 0.7944\nEpoch 53, Loss: 0.7942\nEpoch 54, Loss: 0.7941\nEpoch 55, Loss: 0.7939\nEpoch 56, Loss: 0.7938\nEpoch 57, Loss: 0.7937\nEpoch 58, Loss: 0.7936\nEpoch 59, Loss: 0.7935\nEpoch 60, Loss: 0.7934\nEpoch 61, Loss: 0.7933\nEpoch 62, Loss: 0.7932\nEpoch 63, Loss: 0.7931\nEpoch 64, Loss: 0.7930\nEpoch 65, Loss: 0.7929\nEpoch 66, Loss: 0.7928\nEpoch 67, Loss: 0.7928\nEpoch 68, Loss: 0.7927\nEpoch 69, Loss: 0.7926\nEpoch 70, Loss: 0.7926\nEpoch 71, Loss: 0.7925\nEpoch 72, Loss: 0.7924\nEpoch 73, Loss: 0.7924\nEpoch 74, Loss: 0.7923\nEpoch 75, Loss: 0.7922\nEpoch 76, Loss: 0.7922\nEpoch 77, Loss: 0.7921\nEpoch 78, Loss: 0.7921\nEpoch 79, Loss: 0.7920\nEpoch 80, Loss: 0.7920\nEpoch 81, Loss: 0.7919\nEpoch 82, Loss: 0.7919\nEpoch 83, Loss: 0.7918\nEpoch 84, Loss: 0.7918\nEpoch 85, Loss: 0.7917\nEp",
                "lineage": "13801"
            }
        ],
        "139": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    smoothed_proportions = np.zeros_like(combined_proportions)\n    for i in range(combined_proportions.shape[0]):\n        neighbors = np.argsort(np.linalg.norm(adata_sp.X.toarray() - adata_sp.X.toarray()[i], axis=1))[:5]\n        smoothed_proportions[i] = np.mean(combined_proportions[neighbors], axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = smoothed_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.008809896543677458,
                "model_info": "",
                "lineage": "13901"
            }
        ],
        "140": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.13127166580023777,
                "model_info": "",
                "lineage": "14001"
            }
        ],
        "141": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=50, max_depth=10)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.24353433382376144,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5670\nEpoch 2, Loss: 2.4804\nEpoch 3, Loss: 2.3661\nEpoch 4, Loss: 2.2282\nEpoch 5, Loss: 2.1021\nEpoch 6, Loss: 1.9897\nEpoch 7, Loss: 1.8755\nEpoch 8, Loss: 1.7639\nEpoch 9, Loss: 1.6635\nEpoch 10, Loss: 1.5673\nEpoch 11, Loss: 1.4749\nEpoch 12, Loss: 1.3846\nEpoch 13, Loss: 1.2976\nEpoch 14, Loss: 1.2145\nEpoch 15, Loss: 1.1349\nEpoch 16, Loss: 1.0589\nEpoch 17, Loss: 0.9872\nEpoch 18, Loss: 0.9198\nEpoch 19, Loss: 0.8563\nEpoch 20, Loss: 0.7968\nEpoch 21, Loss: 0.7417\nEpoch 22, Loss: 0.6908\nEpoch 23, Loss: 0.6437\nEpoch 24, Loss: 0.6007\nEpoch 25, Loss: 0.5615\nEpoch 26, Loss: 0.5257\nEpoch 27, Loss: 0.4929\nEpoch 28, Loss: 0.4630\nEpoch 29, Loss: 0.4358\nEpoch 30, Loss: 0.4108\nEpoch 31, Loss: 0.3878\nEpoch 32, Loss: 0.3667\nEpoch 33, Loss: 0.3473\nEpoch 34, Loss: 0.3294\nEpoch 35, Loss: 0.3128\nEpoch 36, Loss: 0.2976\nEpoch 37, Loss: 0.2835\nEpoch 38, Loss: 0.2705\nEpoch 39, Loss: 0.2584\nEpoch 40, Loss: 0.2472\nEpoch 41, Loss: 0.2368\nEpoch 42, Loss: 0.2271\nEpoch 43, Loss: 0.2180\nEpoch 44, Loss: 0.2095\nEpoch 45, Loss: 0.2017\nEpoch 46, Loss: 0.1943\nEpoch 47, Loss: 0.1873\nEpoch 48, Loss: 0.1808\nEpoch 49, Loss: 0.1747\nEpoch 50, Loss: 0.1689\nEpoch 51, Loss: 0.1634\nEpoch 52, Loss: 0.1583\nEpoch 53, Loss: 0.1534\nEpoch 54, Loss: 0.1487\nEpoch 55, Loss: 0.1442\nEpoch 56, Loss: 0.1399\nEpoch 57, Loss: 0.1358\nEpoch 58, Loss: 0.1319\nEpoch 59, Loss: 0.1283\nEpoch 60, Loss: 0.1250\nEpoch 61, Loss: 0.1218\nEpoch 62, Loss: 0.1187\nEpoch 63, Loss: 0.1158\nEpoch 64, Loss: 0.1130\nEpoch 65, Loss: 0.1104\nEpoch 66, Loss: 0.1078\nEpoch 67, Loss: 0.1053\nEpoch 68, Loss: 0.1030\nEpoch 69, Loss: 0.1007\nEpoch 70, Loss: 0.0985\nEpoch 71, Loss: 0.0963\nEpoch 72, Loss: 0.0943\nEpoch 73, Loss: 0.0923\nEpoch 74, Loss: 0.0904\nEpoch 75, Loss: 0.0885\nEpoch 76, Loss: 0.0868\nEpoch 77, Loss: 0.0850\nEpoch 78, Loss: 0.0833\nEpoch 79, Loss: 0.0817\nEpoch 80, Loss: 0.0801\nEpoch 81, Loss: 0.0786\nEpoch 82, Loss: 0.0771\nEpoch 83, Loss: 0.0756\nEpoch 84, Loss: 0.0742\nEpoch 85, Loss: 0.0728\nEp",
                "lineage": "14101"
            }
        ],
        "142": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.cluster import KMeans\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    kmeans = KMeans(n_clusters=len(cell_types))\n    kmeans.fit(proportions)\n    clustered_proportions = np.array([np.mean(proportions[kmeans.labels_ == i], axis=0) for i in range(len(cell_types))])\n\n    adata_sp.obsm[\"proportions_pred\"] = np.tile(clustered_proportions, (proportions.shape[0], 1))[:proportions.shape[0]]\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -2.988741967571788,
                "model_info": "",
                "lineage": "14201"
            }
        ],
        "143": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.2800117237165691,
                "model_info": "",
                "lineage": "14301"
            }
        ],
        "144": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.neighbors import NearestNeighbors\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n\n    if 'coordinates' in adata_sp.obsm:\n        nbrs = NearestNeighbors(n_neighbors=5).fit(adata_sp.obsm['coordinates'])\n        distances, indices = nbrs.kneighbors(adata_sp.obsm['coordinates'])\n        smoothed_proportions = np.zeros_like(combined_proportions)\n\n        for i in range(combined_proportions.shape[0]):\n            smoothed_proportions[i] = np.mean(combined_proportions[indices[i]], axis=0)\n\n        adata_sp.obsm[\"proportions_pred\"] = smoothed_proportions\n\n    else:\n        adata_sp.obsm[\"proportions_pred\"] = np.zeros((adata_sp.shape[0], len(cell_types)))\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.6679591250045576,
                "model_info": "",
                "lineage": "14401"
            }
        ],
        "145": [],
        "146": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.8651622299856181,
                "model_info": "",
                "lineage": "14601"
            }
        ],
        "147": [],
        "148": [],
        "149": [],
        "150": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.20999938089570216,
                "model_info": "Trainable parameters: 2078989, Frozen parameters: 0\nEpoch 1, Loss: 2.5657\nEpoch 2, Loss: 2.3532\nEpoch 3, Loss: 2.0928\nEpoch 4, Loss: 1.8076\nEpoch 5, Loss: 1.5480\nEpoch 6, Loss: 1.3401\nEpoch 7, Loss: 1.1462\nEpoch 8, Loss: 0.9731\nEpoch 9, Loss: 0.8209\nEpoch 10, Loss: 0.7007\nEpoch 11, Loss: 0.5982\nEpoch 12, Loss: 0.5162\nEpoch 13, Loss: 0.4518\nEpoch 14, Loss: 0.3924\nEpoch 15, Loss: 0.3465\nEpoch 16, Loss: 0.3041\nEpoch 17, Loss: 0.2702\nEpoch 18, Loss: 0.2419\nEpoch 19, Loss: 0.2168\nEpoch 20, Loss: 0.1956\nEpoch 21, Loss: 0.1763\nEpoch 22, Loss: 0.1608\nEpoch 23, Loss: 0.1473\nEpoch 24, Loss: 0.1354\nEpoch 25, Loss: 0.1252\nEpoch 26, Loss: 0.1163\nEpoch 27, Loss: 0.1085\nEpoch 28, Loss: 0.1016\nEpoch 29, Loss: 0.0958\nEpoch 30, Loss: 0.0905\nEpoch 31, Loss: 0.0857\nEpoch 32, Loss: 0.0809\nEpoch 33, Loss: 0.0770\nEpoch 34, Loss: 0.0735\nEpoch 35, Loss: 0.0702\nEpoch 36, Loss: 0.0672\nEpoch 37, Loss: 0.0642\nEpoch 38, Loss: 0.0616\nEpoch 39, Loss: 0.0591\nEpoch 40, Loss: 0.0567\nEpoch 41, Loss: 0.0546\nEpoch 42, Loss: 0.0524\nEpoch 43, Loss: 0.0503\nEpoch 44, Loss: 0.0485\nEpoch 45, Loss: 0.0467\nEpoch 46, Loss: 0.0449\nEpoch 47, Loss: 0.0433\nEpoch 48, Loss: 0.0417\nEpoch 49, Loss: 0.0401\nEpoch 50, Loss: 0.0387\nEpoch 51, Loss: 0.0372\nEpoch 52, Loss: 0.0359\nEpoch 53, Loss: 0.0346\nEpoch 54, Loss: 0.0333\nEpoch 55, Loss: 0.0321\nEpoch 56, Loss: 0.0309\nEpoch 57, Loss: 0.0298\nEpoch 58, Loss: 0.0287\nEpoch 59, Loss: 0.0277\nEpoch 60, Loss: 0.0266\nEpoch 61, Loss: 0.0257\nEpoch 62, Loss: 0.0247\nEpoch 63, Loss: 0.0238\nEpoch 64, Loss: 0.0230\nEpoch 65, Loss: 0.0221\nEpoch 66, Loss: 0.0213\nEpoch 67, Loss: 0.0206\nEpoch 68, Loss: 0.0198\nEpoch 69, Loss: 0.0191\nEpoch 70, Loss: 0.0184\nEpoch 71, Loss: 0.0177\nEpoch 72, Loss: 0.0171\nEpoch 73, Loss: 0.0165\nEpoch 74, Loss: 0.0159\nEpoch 75, Loss: 0.0153\nEpoch 76, Loss: 0.0147\nEpoch 77, Loss: 0.0142\nEpoch 78, Loss: 0.0137\nEpoch 79, Loss: 0.0132\nEpoch 80, Loss: 0.0128\nEpoch 81, Loss: 0.0123\nEpoch 82, Loss: 0.0119\nEpoch 83, Loss: 0.0115\nEpoch 84, Loss: 0.0111\nEpoch 85, Loss: 0.0107\nEp",
                "lineage": "15001"
            }
        ],
        "151": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(150):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=50, max_depth=10)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.1918693470524686,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5714\nEpoch 2, Loss: 2.4858\nEpoch 3, Loss: 2.3976\nEpoch 4, Loss: 2.2834\nEpoch 5, Loss: 2.1833\nEpoch 6, Loss: 2.0781\nEpoch 7, Loss: 1.9714\nEpoch 8, Loss: 1.8673\nEpoch 9, Loss: 1.7716\nEpoch 10, Loss: 1.6726\nEpoch 11, Loss: 1.5845\nEpoch 12, Loss: 1.4977\nEpoch 13, Loss: 1.4100\nEpoch 14, Loss: 1.3275\nEpoch 15, Loss: 1.2494\nEpoch 16, Loss: 1.1751\nEpoch 17, Loss: 1.1035\nEpoch 18, Loss: 1.0350\nEpoch 19, Loss: 0.9710\nEpoch 20, Loss: 0.9110\nEpoch 21, Loss: 0.8540\nEpoch 22, Loss: 0.8001\nEpoch 23, Loss: 0.7494\nEpoch 24, Loss: 0.7020\nEpoch 25, Loss: 0.6578\nEpoch 26, Loss: 0.6166\nEpoch 27, Loss: 0.5782\nEpoch 28, Loss: 0.5425\nEpoch 29, Loss: 0.5094\nEpoch 30, Loss: 0.4790\nEpoch 31, Loss: 0.4513\nEpoch 32, Loss: 0.4259\nEpoch 33, Loss: 0.4025\nEpoch 34, Loss: 0.3810\nEpoch 35, Loss: 0.3612\nEpoch 36, Loss: 0.3431\nEpoch 37, Loss: 0.3264\nEpoch 38, Loss: 0.3110\nEpoch 39, Loss: 0.2969\nEpoch 40, Loss: 0.2838\nEpoch 41, Loss: 0.2716\nEpoch 42, Loss: 0.2603\nEpoch 43, Loss: 0.2499\nEpoch 44, Loss: 0.2402\nEpoch 45, Loss: 0.2311\nEpoch 46, Loss: 0.2227\nEpoch 47, Loss: 0.2148\nEpoch 48, Loss: 0.2075\nEpoch 49, Loss: 0.2006\nEpoch 50, Loss: 0.1941\nEpoch 51, Loss: 0.1881\nEpoch 52, Loss: 0.1824\nEpoch 53, Loss: 0.1771\nEpoch 54, Loss: 0.1720\nEpoch 55, Loss: 0.1672\nEpoch 56, Loss: 0.1627\nEpoch 57, Loss: 0.1584\nEpoch 58, Loss: 0.1543\nEpoch 59, Loss: 0.1504\nEpoch 60, Loss: 0.1467\nEpoch 61, Loss: 0.1432\nEpoch 62, Loss: 0.1398\nEpoch 63, Loss: 0.1366\nEpoch 64, Loss: 0.1335\nEpoch 65, Loss: 0.1305\nEpoch 66, Loss: 0.1276\nEpoch 67, Loss: 0.1249\nEpoch 68, Loss: 0.1222\nEpoch 69, Loss: 0.1197\nEpoch 70, Loss: 0.1172\nEpoch 71, Loss: 0.1149\nEpoch 72, Loss: 0.1126\nEpoch 73, Loss: 0.1104\nEpoch 74, Loss: 0.1082\nEpoch 75, Loss: 0.1061\nEpoch 76, Loss: 0.1041\nEpoch 77, Loss: 0.1021\nEpoch 78, Loss: 0.1002\nEpoch 79, Loss: 0.0984\nEpoch 80, Loss: 0.0966\nEpoch 81, Loss: 0.0949\nEpoch 82, Loss: 0.0932\nEpoch 83, Loss: 0.0915\nEpoch 84, Loss: 0.0899\nEpoch 85, Loss: 0.0883\nEp",
                "lineage": "15101"
            }
        ],
        "152": [],
        "153": [],
        "154": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attn_weights = torch.softmax(self.attention(x), dim=0)\n        x = x * attn_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = AttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.3069116274766947,
                "model_info": "Trainable parameters: 2071694, Frozen parameters: 0\nEpoch 1, Loss: 2.5662\nEpoch 2, Loss: 2.5661\nEpoch 3, Loss: 2.5657\nEpoch 4, Loss: 2.5648\nEpoch 5, Loss: 2.5636\nEpoch 6, Loss: 2.5617\nEpoch 7, Loss: 2.5588\nEpoch 8, Loss: 2.5559\nEpoch 9, Loss: 2.5530\nEpoch 10, Loss: 2.5499\nEpoch 11, Loss: 2.5466\nEpoch 12, Loss: 2.5430\nEpoch 13, Loss: 2.5390\nEpoch 14, Loss: 2.5352\nEpoch 15, Loss: 2.5311\nEpoch 16, Loss: 2.5268\nEpoch 17, Loss: 2.5225\nEpoch 18, Loss: 2.5181\nEpoch 19, Loss: 2.5136\nEpoch 20, Loss: 2.5091\nEpoch 21, Loss: 2.5043\nEpoch 22, Loss: 2.4995\nEpoch 23, Loss: 2.4948\nEpoch 24, Loss: 2.4900\nEpoch 25, Loss: 2.4848\nEpoch 26, Loss: 2.4798\nEpoch 27, Loss: 2.4750\nEpoch 28, Loss: 2.4698\nEpoch 29, Loss: 2.4649\nEpoch 30, Loss: 2.4600\nEpoch 31, Loss: 2.4545\nEpoch 32, Loss: 2.4495\nEpoch 33, Loss: 2.4446\nEpoch 34, Loss: 2.4386\nEpoch 35, Loss: 2.4330\nEpoch 36, Loss: 2.4273\nEpoch 37, Loss: 2.4213\nEpoch 38, Loss: 2.4166\nEpoch 39, Loss: 2.4117\nEpoch 40, Loss: 2.4066\nEpoch 41, Loss: 2.4024\nEpoch 42, Loss: 2.3987\nEpoch 43, Loss: 2.3950\nEpoch 44, Loss: 2.3916\nEpoch 45, Loss: 2.3882\nEpoch 46, Loss: 2.3852\nEpoch 47, Loss: 2.3829\nEpoch 48, Loss: 2.3811\nEpoch 49, Loss: 2.3787\nEpoch 50, Loss: 2.3770\nEpoch 51, Loss: 2.3754\nEpoch 52, Loss: 2.3740\nEpoch 53, Loss: 2.3725\nEpoch 54, Loss: 2.3709\nEpoch 55, Loss: 2.3699\nEpoch 56, Loss: 2.3692\nEpoch 57, Loss: 2.3685\nEpoch 58, Loss: 2.3677\nEpoch 59, Loss: 2.3668\nEpoch 60, Loss: 2.3658\nEpoch 61, Loss: 2.3648\nEpoch 62, Loss: 2.3639\nEpoch 63, Loss: 2.3635\nEpoch 64, Loss: 2.3633\nEpoch 65, Loss: 2.3630\nEpoch 66, Loss: 2.3627\nEpoch 67, Loss: 2.3622\nEpoch 68, Loss: 2.3618\nEpoch 69, Loss: 2.3614\nEpoch 70, Loss: 2.3610\nEpoch 71, Loss: 2.3606\nEpoch 72, Loss: 2.3603\nEpoch 73, Loss: 2.3601\nEpoch 74, Loss: 2.3599\nEpoch 75, Loss: 2.3597\nEpoch 76, Loss: 2.3594\nEpoch 77, Loss: 2.3591\nEpoch 78, Loss: 2.3589\nEpoch 79, Loss: 2.3586\nEpoch 80, Loss: 2.3584\nEpoch 81, Loss: 2.3582\nEpoch 82, Loss: 2.3580\nEpoch 83, Loss: 2.3578\nEpoch 84, Loss: 2.3575\nEpoch 85, Loss: 2.3573\nEp",
                "lineage": "15401"
            }
        ],
        "155": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.8636719617371894,
                "model_info": "",
                "lineage": "15501"
            }
        ],
        "156": [],
        "157": [],
        "158": [],
        "159": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = np.clip(combined_proportions, 0, 1)\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.13366135943466034,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5681\nEpoch 2, Loss: 2.3234\nEpoch 3, Loss: 2.3562\nEpoch 4, Loss: 2.3095\nEpoch 5, Loss: 2.2924\nEpoch 6, Loss: 2.2561\nEpoch 7, Loss: 2.1993\nEpoch 8, Loss: 2.1908\nEpoch 9, Loss: 2.1344\nEpoch 10, Loss: 2.1053\nEpoch 11, Loss: 2.0973\nEpoch 12, Loss: 2.0657\nEpoch 13, Loss: 2.0452\nEpoch 14, Loss: 2.0429\nEpoch 15, Loss: 2.0316\nEpoch 16, Loss: 2.0182\nEpoch 17, Loss: 2.0151\nEpoch 18, Loss: 2.0127\nEpoch 19, Loss: 2.0072\nEpoch 20, Loss: 2.0012\nEpoch 21, Loss: 1.9978\nEpoch 22, Loss: 1.9963\nEpoch 23, Loss: 1.9946\nEpoch 24, Loss: 1.9925\nEpoch 25, Loss: 1.9899\nEpoch 26, Loss: 1.9876\nEpoch 27, Loss: 1.9855\nEpoch 28, Loss: 1.9830\nEpoch 29, Loss: 1.9790\nEpoch 30, Loss: 1.9590\nEpoch 31, Loss: 1.8769\nEpoch 32, Loss: 1.8101\nEpoch 33, Loss: 1.9010\nEpoch 34, Loss: 1.8404\nEpoch 35, Loss: 1.7975\nEpoch 36, Loss: 1.8138\nEpoch 37, Loss: 1.8250\nEpoch 38, Loss: 1.8166\nEpoch 39, Loss: 1.7991\nEpoch 40, Loss: 1.7883\nEpoch 41, Loss: 1.7853\nEpoch 42, Loss: 1.7904\nEpoch 43, Loss: 1.7952\nEpoch 44, Loss: 1.7888\nEpoch 45, Loss: 1.7833\nEpoch 46, Loss: 1.7823\nEpoch 47, Loss: 1.7823\nEpoch 48, Loss: 1.7824\nEpoch 49, Loss: 1.7824\nEpoch 50, Loss: 1.7824\nEpoch 51, Loss: 1.7824\nEpoch 52, Loss: 1.7824\nEpoch 53, Loss: 1.7823\nEpoch 54, Loss: 1.7819\nEpoch 55, Loss: 1.7815\nEpoch 56, Loss: 1.7809\nEpoch 57, Loss: 1.7804\nEpoch 58, Loss: 1.7801\nEpoch 59, Loss: 1.7799\nEpoch 60, Loss: 1.7797\nEpoch 61, Loss: 1.7795\nEpoch 62, Loss: 1.7793\nEpoch 63, Loss: 1.7791\nEpoch 64, Loss: 1.7789\nEpoch 65, Loss: 1.7788\nEpoch 66, Loss: 1.7788\nEpoch 67, Loss: 1.7787\nEpoch 68, Loss: 1.7786\nEpoch 69, Loss: 1.7785\nEpoch 70, Loss: 1.7784\nEpoch 71, Loss: 1.7783\nEpoch 72, Loss: 1.7782\nEpoch 73, Loss: 1.7782\nEpoch 74, Loss: 1.7782\nEpoch 75, Loss: 1.7781\nEpoch 76, Loss: 1.7780\nEpoch 77, Loss: 1.7780\nEpoch 78, Loss: 1.7779\nEpoch 79, Loss: 1.7779\nEpoch 80, Loss: 1.7778\nEpoch 81, Loss: 1.7778\nEpoch 82, Loss: 1.7777\nEpoch 83, Loss: 1.7776\nEpoch 84, Loss: 1.7776\nEpoch 85, Loss: 1.7775\nEp",
                "lineage": "15901"
            }
        ],
        "160": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(150):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Learning Rate: {optimizer.param_groups[0][\"lr\"]:.6f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=50, max_depth=10)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.13739292358500715,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5707, Learning Rate: 0.000500\nEpoch 2, Loss: 2.4773, Learning Rate: 0.000500\nEpoch 3, Loss: 2.3398, Learning Rate: 0.000500\nEpoch 4, Loss: 2.2157, Learning Rate: 0.000500\nEpoch 5, Loss: 2.0919, Learning Rate: 0.000500\nEpoch 6, Loss: 1.9689, Learning Rate: 0.000500\nEpoch 7, Loss: 1.8522, Learning Rate: 0.000500\nEpoch 8, Loss: 1.7406, Learning Rate: 0.000500\nEpoch 9, Loss: 1.6323, Learning Rate: 0.000500\nEpoch 10, Loss: 1.5339, Learning Rate: 0.000500\nEpoch 11, Loss: 1.4437, Learning Rate: 0.000500\nEpoch 12, Loss: 1.3593, Learning Rate: 0.000500\nEpoch 13, Loss: 1.2794, Learning Rate: 0.000500\nEpoch 14, Loss: 1.2024, Learning Rate: 0.000500\nEpoch 15, Loss: 1.1282, Learning Rate: 0.000500\nEpoch 16, Loss: 1.0585, Learning Rate: 0.000500\nEpoch 17, Loss: 0.9927, Learning Rate: 0.000500\nEpoch 18, Loss: 0.9301, Learning Rate: 0.000500\nEpoch 19, Loss: 0.8706, Learning Rate: 0.000500\nEpoch 20, Loss: 0.8147, Learning Rate: 0.000500\nEpoch 21, Loss: 0.7625, Learning Rate: 0.000500\nEpoch 22, Loss: 0.7133, Learning Rate: 0.000500\nEpoch 23, Loss: 0.6668, Learning Rate: 0.000500\nEpoch 24, Loss: 0.6235, Learning Rate: 0.000500\nEpoch 25, Loss: 0.5835, Learning Rate: 0.000500\nEpoch 26, Loss: 0.5467, Learning Rate: 0.000500\nEpoch 27, Loss: 0.5126, Learning Rate: 0.000500\nEpoch 28, Loss: 0.4810, Learning Rate: 0.000500\nEpoch 29, Loss: 0.4520, Learning Rate: 0.000500\nEpoch 30, Loss: 0.4253, Learning Rate: 0.000500\nEpoch 31, Loss: 0.4005, Learning Rate: 0.000500\nEpoch 32, Loss: 0.3777, Learning Rate: 0.000500\nEpoch 33, Loss: 0.3566, Learning Rate: 0.000500\nEpoch 34, Loss: 0.3366, Learning Rate: 0.000500\nEpoch 35, Loss: 0.3182, Learning Rate: 0.000500\nEpoch 36, Loss: 0.3015, Learning Rate: 0.000500\nEpoch 37, Loss: 0.2860, Learning Rate: 0.000500\nEpoch 38, Loss: 0.2715, Learning Rate: 0.000500\nEpoch 39, Loss: 0.2581, Learning Rate: 0.000500\nEpoch 40, Loss: 0.2455, Learning Rate: 0.000500\nEpoch 41, Loss: 0.2339, Learning Rate",
                "lineage": "16001"
            }
        ],
        "161": [],
        "162": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if (epoch + 1) % 10 == 0:\n            print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.24473875662665456,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 10, Loss: 0.9805\nEpoch 20, Loss: 0.7488\nEpoch 30, Loss: 0.6827\nEpoch 40, Loss: 0.6575\nEpoch 50, Loss: 0.6431\nEpoch 60, Loss: 0.6329\nEpoch 70, Loss: 0.6250\nEpoch 80, Loss: 0.6188\nEpoch 90, Loss: 0.6138\nEpoch 100, Loss: 0.6098",
                "lineage": "16201"
            }
        ],
        "163": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.metrics import silhouette_score\nfrom sklearn.cluster import KMeans\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    kmeans = KMeans(n_clusters=len(cell_types))\n    kmeans.fit(combined_proportions)\n    silhouette_avg = silhouette_score(combined_proportions, kmeans.labels_)\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.22153921884355127,
                "model_info": "",
                "lineage": "16301"
            }
        ],
        "164": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attn_weights = torch.softmax(self.attention(x), dim=0)\n        x = x * attn_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = AttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.020830956127347363,
                "model_info": "",
                "lineage": "16401"
            }
        ],
        "165": [],
        "166": [],
        "167": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.16483884983531932,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5681\nEpoch 2, Loss: 2.4344\nEpoch 3, Loss: 2.0503\nEpoch 4, Loss: 1.8641\nEpoch 5, Loss: 1.5146\nEpoch 6, Loss: 1.3518\nEpoch 7, Loss: 1.2178\nEpoch 8, Loss: 1.0935\nEpoch 9, Loss: 0.9669\nEpoch 10, Loss: 0.8692\nEpoch 11, Loss: 0.7792\nEpoch 12, Loss: 0.6994\nEpoch 13, Loss: 0.6337\nEpoch 14, Loss: 0.6056\nEpoch 15, Loss: 0.5665\nEpoch 16, Loss: 0.5134\nEpoch 17, Loss: 0.4719\nEpoch 18, Loss: 0.4501\nEpoch 19, Loss: 0.4391\nEpoch 20, Loss: 0.4234\nEpoch 21, Loss: 0.4022\nEpoch 22, Loss: 0.3845\nEpoch 23, Loss: 0.3723\nEpoch 24, Loss: 0.3624\nEpoch 25, Loss: 0.3542\nEpoch 26, Loss: 0.3472\nEpoch 27, Loss: 0.3392\nEpoch 28, Loss: 0.3307\nEpoch 29, Loss: 0.3233\nEpoch 30, Loss: 0.3173\nEpoch 31, Loss: 0.3127\nEpoch 32, Loss: 0.3088\nEpoch 33, Loss: 0.3047\nEpoch 34, Loss: 0.3006\nEpoch 35, Loss: 0.2972\nEpoch 36, Loss: 0.2944\nEpoch 37, Loss: 0.2913\nEpoch 38, Loss: 0.2882\nEpoch 39, Loss: 0.2853\nEpoch 40, Loss: 0.2827\nEpoch 41, Loss: 0.2805\nEpoch 42, Loss: 0.2785\nEpoch 43, Loss: 0.2764\nEpoch 44, Loss: 0.2744\nEpoch 45, Loss: 0.2727\nEpoch 46, Loss: 0.2711\nEpoch 47, Loss: 0.2694\nEpoch 48, Loss: 0.2677\nEpoch 49, Loss: 0.2660\nEpoch 50, Loss: 0.2644\nEpoch 51, Loss: 0.2630\nEpoch 52, Loss: 0.2618\nEpoch 53, Loss: 0.2606\nEpoch 54, Loss: 0.2594\nEpoch 55, Loss: 0.2581\nEpoch 56, Loss: 0.2568\nEpoch 57, Loss: 0.2557\nEpoch 58, Loss: 0.2546\nEpoch 59, Loss: 0.2535\nEpoch 60, Loss: 0.2525\nEpoch 61, Loss: 0.2514\nEpoch 62, Loss: 0.2504\nEpoch 63, Loss: 0.2495\nEpoch 64, Loss: 0.2485\nEpoch 65, Loss: 0.2476\nEpoch 66, Loss: 0.2467\nEpoch 67, Loss: 0.2458\nEpoch 68, Loss: 0.2450\nEpoch 69, Loss: 0.2441\nEpoch 70, Loss: 0.2433\nEpoch 71, Loss: 0.2425\nEpoch 72, Loss: 0.2417\nEpoch 73, Loss: 0.2409\nEpoch 74, Loss: 0.2402\nEpoch 75, Loss: 0.2395\nEpoch 76, Loss: 0.2388\nEpoch 77, Loss: 0.2381\nEpoch 78, Loss: 0.2374\nEpoch 79, Loss: 0.2367\nEpoch 80, Loss: 0.2360\nEpoch 81, Loss: 0.2354\nEpoch 82, Loss: 0.2347\nEpoch 83, Loss: 0.2341\nEpoch 84, Loss: 0.2335\nEpoch 85, Loss: 0.2329\nEp",
                "lineage": "16701"
            }
        ],
        "168": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass MultiTaskModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(MultiTaskModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = MultiTaskModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.08963526773732844,
                "model_info": "",
                "lineage": "16801"
            }
        ],
        "169": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.manifold import TSNE\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    tsne_sc = TSNE(n_components=2).fit_transform(adata_sc.X.toarray())\n    tsne_sp = TSNE(n_components=2).fit_transform(adata_sp.X.toarray())\n\n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=tsne_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(tsne_sc, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(tsne_sp, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(tsne_sc, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(tsne_sp)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -1.2656694698498898,
                "model_info": "Epoch 1, Loss: 3.4061\nEpoch 2, Loss: 3.0287\nEpoch 3, Loss: 2.7375\nEpoch 4, Loss: 2.5599\nEpoch 5, Loss: 2.4416\nEpoch 6, Loss: 2.3370\nEpoch 7, Loss: 2.2539\nEpoch 8, Loss: 2.2051\nEpoch 9, Loss: 2.1786\nEpoch 10, Loss: 2.1511\nEpoch 11, Loss: 2.1127\nEpoch 12, Loss: 2.0652\nEpoch 13, Loss: 2.0145\nEpoch 14, Loss: 1.9677\nEpoch 15, Loss: 1.9283\nEpoch 16, Loss: 1.8955\nEpoch 17, Loss: 1.8671\nEpoch 18, Loss: 1.8417\nEpoch 19, Loss: 1.8179\nEpoch 20, Loss: 1.7947\nEpoch 21, Loss: 1.7712\nEpoch 22, Loss: 1.7479\nEpoch 23, Loss: 1.7256\nEpoch 24, Loss: 1.7052\nEpoch 25, Loss: 1.6874\nEpoch 26, Loss: 1.6729\nEpoch 27, Loss: 1.6617\nEpoch 28, Loss: 1.6526\nEpoch 29, Loss: 1.6442\nEpoch 30, Loss: 1.6354\nEpoch 31, Loss: 1.6260\nEpoch 32, Loss: 1.6170\nEpoch 33, Loss: 1.6093\nEpoch 34, Loss: 1.6033\nEpoch 35, Loss: 1.5988\nEpoch 36, Loss: 1.5953\nEpoch 37, Loss: 1.5922\nEpoch 38, Loss: 1.5891\nEpoch 39, Loss: 1.5860\nEpoch 40, Loss: 1.5827\nEpoch 41, Loss: 1.5790\nEpoch 42, Loss: 1.5753\nEpoch 43, Loss: 1.5717\nEpoch 44, Loss: 1.5684\nEpoch 45, Loss: 1.5654\nEpoch 46, Loss: 1.5624\nEpoch 47, Loss: 1.5592\nEpoch 48, Loss: 1.5558\nEpoch 49, Loss: 1.5524\nEpoch 50, Loss: 1.5493\nEpoch 51, Loss: 1.5466\nEpoch 52, Loss: 1.5444\nEpoch 53, Loss: 1.5426\nEpoch 54, Loss: 1.5409\nEpoch 55, Loss: 1.5391\nEpoch 56, Loss: 1.5372\nEpoch 57, Loss: 1.5353\nEpoch 58, Loss: 1.5333\nEpoch 59, Loss: 1.5314\nEpoch 60, Loss: 1.5295\nEpoch 61, Loss: 1.5276\nEpoch 62, Loss: 1.5258\nEpoch 63, Loss: 1.5239\nEpoch 64, Loss: 1.5221\nEpoch 65, Loss: 1.5203\nEpoch 66, Loss: 1.5185\nEpoch 67, Loss: 1.5169\nEpoch 68, Loss: 1.5153\nEpoch 69, Loss: 1.5138\nEpoch 70, Loss: 1.5123\nEpoch 71, Loss: 1.5109\nEpoch 72, Loss: 1.5094\nEpoch 73, Loss: 1.5080\nEpoch 74, Loss: 1.5066\nEpoch 75, Loss: 1.5052\nEpoch 76, Loss: 1.5038\nEpoch 77, Loss: 1.5025\nEpoch 78, Loss: 1.5011\nEpoch 79, Loss: 1.4997\nEpoch 80, Loss: 1.4984\nEpoch 81, Loss: 1.4970\nEpoch 82, Loss: 1.4957\nEpoch 83, Loss: 1.4944\nEpoch 84, Loss: 1.4931\nEpoch 85, Loss: 1.4919\nEpoch 86, Loss: 1.4906\nEpoch 87, Loss: 1.4894\nEpoch 88",
                "lineage": "16901"
            }
        ],
        "170": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nimport networkx as nx\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef create_spatial_graph(adata_sp):\n    coords = adata_sp.obsm['spatial']  \n    graph = nx.Graph()\n    for i in range(len(coords)):\n        graph.add_node(i, pos=coords[i])\n    for i in range(len(coords)):\n        for j in range(i + 1, len(coords)):\n            distance = np.linalg.norm(coords[i] - coords[j])\n            if distance < threshold:\n                graph.add_edge(i, j)\n    return graph\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.17545075531645823,
                "model_info": "",
                "lineage": "17001"
            }
        ],
        "171": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        attention_scores = self.attention(x)\n        attention_weights = torch.softmax(attention_scores, dim=1)\n        return torch.relu(x * attention_weights)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = AttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.13590004919440707,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5650\nEpoch 2, Loss: 2.5350\nEpoch 3, Loss: 2.4729\nEpoch 4, Loss: 2.3455\nEpoch 5, Loss: 2.2596\nEpoch 6, Loss: 2.1107\nEpoch 7, Loss: 2.0281\nEpoch 8, Loss: 1.9622\nEpoch 9, Loss: 1.8504\nEpoch 10, Loss: 1.7545\nEpoch 11, Loss: 1.6865\nEpoch 12, Loss: 1.6151\nEpoch 13, Loss: 1.5329\nEpoch 14, Loss: 1.4965\nEpoch 15, Loss: 1.4670\nEpoch 16, Loss: 1.4082\nEpoch 17, Loss: 1.3298\nEpoch 18, Loss: 1.2485\nEpoch 19, Loss: 1.1780\nEpoch 20, Loss: 1.1280\nEpoch 21, Loss: 1.0643\nEpoch 22, Loss: 1.0449\nEpoch 23, Loss: 1.0381\nEpoch 24, Loss: 1.0259\nEpoch 25, Loss: 1.0090\nEpoch 26, Loss: 0.9916\nEpoch 27, Loss: 0.9822\nEpoch 28, Loss: 0.9634\nEpoch 29, Loss: 0.9516\nEpoch 30, Loss: 0.9369\nEpoch 31, Loss: 0.9210\nEpoch 32, Loss: 0.9070\nEpoch 33, Loss: 0.8929\nEpoch 34, Loss: 0.8820\nEpoch 35, Loss: 0.8701\nEpoch 36, Loss: 0.8472\nEpoch 37, Loss: 0.8108\nEpoch 38, Loss: 0.7638\nEpoch 39, Loss: 0.7239\nEpoch 40, Loss: 0.7094\nEpoch 41, Loss: 0.7039\nEpoch 42, Loss: 0.6958\nEpoch 43, Loss: 0.6895\nEpoch 44, Loss: 0.6843\nEpoch 45, Loss: 0.6797\nEpoch 46, Loss: 0.6772\nEpoch 47, Loss: 0.6727\nEpoch 48, Loss: 0.6643\nEpoch 49, Loss: 0.6574\nEpoch 50, Loss: 0.6534\nEpoch 51, Loss: 0.6504\nEpoch 52, Loss: 0.6470\nEpoch 53, Loss: 0.6433\nEpoch 54, Loss: 0.6401\nEpoch 55, Loss: 0.6377\nEpoch 56, Loss: 0.6359\nEpoch 57, Loss: 0.6343\nEpoch 58, Loss: 0.6328\nEpoch 59, Loss: 0.6315\nEpoch 60, Loss: 0.6301\nEpoch 61, Loss: 0.6289\nEpoch 62, Loss: 0.6277\nEpoch 63, Loss: 0.6266\nEpoch 64, Loss: 0.6257\nEpoch 65, Loss: 0.6247\nEpoch 66, Loss: 0.6236\nEpoch 67, Loss: 0.6226\nEpoch 68, Loss: 0.6216\nEpoch 69, Loss: 0.6206\nEpoch 70, Loss: 0.6198\nEpoch 71, Loss: 0.6192\nEpoch 72, Loss: 0.6185\nEpoch 73, Loss: 0.6178\nEpoch 74, Loss: 0.6172\nEpoch 75, Loss: 0.6165\nEpoch 76, Loss: 0.6159\nEpoch 77, Loss: 0.6153\nEpoch 78, Loss: 0.6148\nEpoch 79, Loss: 0.6144\nEpoch 80, Loss: 0.6139\nEpoch 81, Loss: 0.6134\nEpoch 82, Loss: 0.6129\nEpoch 83, Loss: 0.6125\nEpoch 84, Loss: 0.6120\nEpoch 85, Loss: 0.6116\nEp",
                "lineage": "17101"
            }
        ],
        "172": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass GraphNeuralNetwork(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GraphNeuralNetwork, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = GraphNeuralNetwork(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.09442834671721258,
                "model_info": "",
                "lineage": "17201"
            }
        ],
        "173": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    combined_proportions = np.clip(combined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.19497057126653367,
                "model_info": "",
                "lineage": "17301"
            }
        ],
        "174": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, 32)\n        self.fc3 = nn.Linear(32, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(150):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        \n        grad_norm = torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Gradient Norm: {grad_norm:.4f}')\n        \n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=50, max_depth=10)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.1982930484617668,
                "model_info": "Trainable parameters: 1037453, Frozen parameters: 0\nEpoch 1, Loss: 2.5743, Gradient Norm: 0.9667\nEpoch 2, Loss: 2.4859, Gradient Norm: 1.6029\nEpoch 3, Loss: 2.3552, Gradient Norm: 1.6319\nEpoch 4, Loss: 2.2338, Gradient Norm: 1.4383\nEpoch 5, Loss: 2.1183, Gradient Norm: 1.5458\nEpoch 6, Loss: 1.9983, Gradient Norm: 1.4369\nEpoch 7, Loss: 1.8895, Gradient Norm: 1.3020\nEpoch 8, Loss: 1.7890, Gradient Norm: 1.3673\nEpoch 9, Loss: 1.6915, Gradient Norm: 1.3737\nEpoch 10, Loss: 1.5992, Gradient Norm: 1.4390\nEpoch 11, Loss: 1.5105, Gradient Norm: 1.4456\nEpoch 12, Loss: 1.4256, Gradient Norm: 1.4045\nEpoch 13, Loss: 1.3459, Gradient Norm: 1.4036\nEpoch 14, Loss: 1.2709, Gradient Norm: 1.4147\nEpoch 15, Loss: 1.2001, Gradient Norm: 1.4350\nEpoch 16, Loss: 1.1320, Gradient Norm: 1.4299\nEpoch 17, Loss: 1.0668, Gradient Norm: 1.4313\nEpoch 18, Loss: 1.0041, Gradient Norm: 1.4132\nEpoch 19, Loss: 0.9447, Gradient Norm: 1.3519\nEpoch 20, Loss: 0.8883, Gradient Norm: 1.3129\nEpoch 21, Loss: 0.8345, Gradient Norm: 1.3044\nEpoch 22, Loss: 0.7838, Gradient Norm: 1.2672\nEpoch 23, Loss: 0.7362, Gradient Norm: 1.2479\nEpoch 24, Loss: 0.6906, Gradient Norm: 1.1650\nEpoch 25, Loss: 0.6478, Gradient Norm: 1.0924\nEpoch 26, Loss: 0.6076, Gradient Norm: 1.0149\nEpoch 27, Loss: 0.5693, Gradient Norm: 0.9082\nEpoch 28, Loss: 0.5335, Gradient Norm: 0.8584\nEpoch 29, Loss: 0.4997, Gradient Norm: 0.7979\nEpoch 30, Loss: 0.4679, Gradient Norm: 0.7517\nEpoch 31, Loss: 0.4383, Gradient Norm: 0.7407\nEpoch 32, Loss: 0.4106, Gradient Norm: 0.6859\nEpoch 33, Loss: 0.3851, Gradient Norm: 0.6108\nEpoch 34, Loss: 0.3621, Gradient Norm: 0.5711\nEpoch 35, Loss: 0.3410, Gradient Norm: 0.5319\nEpoch 36, Loss: 0.3215, Gradient Norm: 0.4924\nEpoch 37, Loss: 0.3035, Gradient Norm: 0.4757\nEpoch 38, Loss: 0.2869, Gradient Norm: 0.4546\nEpoch 39, Loss: 0.2716, Gradient Norm: 0.4155\nEpoch 40, Loss: 0.2574, Gradient Norm: 0.3861\nEpoch 41, Loss: 0.2443, Gradient Norm: 0.3663\nEpoch 42, Loss: 0.2322, Gradient Norm: 0.3501\nEpoch 43, Loss: 0.2210, G",
                "lineage": "17401"
            }
        ],
        "175": [],
        "176": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass GCNModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GCNModel, self).__init__()\n        self.conv1 = nn.Linear(input_dim, 128)\n        self.conv2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.conv1(x))\n        return torch.relu(self.conv2(x))\n\ndef create_spatial_graph(adata_sp):\n    edge_index = ... \n    return edge_index\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    edge_index = create_spatial_graph(adata_sp)\n    \n    model = GCNModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        data = torch.tensor(adata_sc.X.toarray(), dtype=torch.float32)\n        outputs = model(data)\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_data = torch.tensor(adata_sp.X.toarray(), dtype=torch.float32)\n        spot_outputs = model(spot_data)\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.2628541511702026,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5615\nEpoch 2, Loss: 2.3745\nEpoch 3, Loss: 2.1211\nEpoch 4, Loss: 1.7929\nEpoch 5, Loss: 1.5701\nEpoch 6, Loss: 1.4021\nEpoch 7, Loss: 1.2628\nEpoch 8, Loss: 1.1850\nEpoch 9, Loss: 1.1065\nEpoch 10, Loss: 1.0456\nEpoch 11, Loss: 0.9939\nEpoch 12, Loss: 0.9542\nEpoch 13, Loss: 0.9184\nEpoch 14, Loss: 0.8840\nEpoch 15, Loss: 0.8568\nEpoch 16, Loss: 0.8356\nEpoch 17, Loss: 0.8159\nEpoch 18, Loss: 0.7959\nEpoch 19, Loss: 0.7777\nEpoch 20, Loss: 0.7640\nEpoch 21, Loss: 0.7544\nEpoch 22, Loss: 0.7461\nEpoch 23, Loss: 0.7376\nEpoch 24, Loss: 0.7284\nEpoch 25, Loss: 0.7199\nEpoch 26, Loss: 0.7133\nEpoch 27, Loss: 0.7076\nEpoch 28, Loss: 0.7025\nEpoch 29, Loss: 0.6984\nEpoch 30, Loss: 0.6946\nEpoch 31, Loss: 0.6907\nEpoch 32, Loss: 0.6866\nEpoch 33, Loss: 0.6826\nEpoch 34, Loss: 0.6792\nEpoch 35, Loss: 0.6765\nEpoch 36, Loss: 0.6741\nEpoch 37, Loss: 0.6716\nEpoch 38, Loss: 0.6693\nEpoch 39, Loss: 0.6672\nEpoch 40, Loss: 0.6650\nEpoch 41, Loss: 0.6630\nEpoch 42, Loss: 0.6608\nEpoch 43, Loss: 0.6588\nEpoch 44, Loss: 0.6572\nEpoch 45, Loss: 0.6557\nEpoch 46, Loss: 0.6542\nEpoch 47, Loss: 0.6527\nEpoch 48, Loss: 0.6512\nEpoch 49, Loss: 0.6498\nEpoch 50, Loss: 0.6485\nEpoch 51, Loss: 0.6471\nEpoch 52, Loss: 0.6459\nEpoch 53, Loss: 0.6447\nEpoch 54, Loss: 0.6435\nEpoch 55, Loss: 0.6425\nEpoch 56, Loss: 0.6414\nEpoch 57, Loss: 0.6403\nEpoch 58, Loss: 0.6393\nEpoch 59, Loss: 0.6383\nEpoch 60, Loss: 0.6373\nEpoch 61, Loss: 0.6364\nEpoch 62, Loss: 0.6355\nEpoch 63, Loss: 0.6346\nEpoch 64, Loss: 0.6337\nEpoch 65, Loss: 0.6329\nEpoch 66, Loss: 0.6321\nEpoch 67, Loss: 0.6313\nEpoch 68, Loss: 0.6305\nEpoch 69, Loss: 0.6297\nEpoch 70, Loss: 0.6290\nEpoch 71, Loss: 0.6283\nEpoch 72, Loss: 0.6276\nEpoch 73, Loss: 0.6269\nEpoch 74, Loss: 0.6262\nEpoch 75, Loss: 0.6255\nEpoch 76, Loss: 0.6249\nEpoch 77, Loss: 0.6242\nEpoch 78, Loss: 0.6236\nEpoch 79, Loss: 0.6230\nEpoch 80, Loss: 0.6224\nEpoch 81, Loss: 0.6218\nEpoch 82, Loss: 0.6213\nEpoch 83, Loss: 0.6207\nEpoch 84, Loss: 0.6202\nEpoch 85, Loss: 0.6196\nEp",
                "lineage": "17601"
            }
        ],
        "177": [],
        "178": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attn_weights = torch.softmax(self.attention(x), dim=0)\n        x = x * attn_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = AttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.4294591351544534,
                "model_info": "",
                "lineage": "17801"
            }
        ],
        "179": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.feature_selection import SelectKBest, f_classif\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    k_best_features = 50\n    selector = SelectKBest(f_classif, k=k_best_features)\n    adata_sc_selected = selector.fit_transform(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    adata_sp_selected = selector.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_selected.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_selected, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_selected, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_selected, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_selected)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.13724253466564182,
                "model_info": "Trainable parameters: 8387, Frozen parameters: 0\nEpoch 1, Loss: 2.6044\nEpoch 2, Loss: 2.5543\nEpoch 3, Loss: 2.5053\nEpoch 4, Loss: 2.4572\nEpoch 5, Loss: 2.4105\nEpoch 6, Loss: 2.3653\nEpoch 7, Loss: 2.3215\nEpoch 8, Loss: 2.2794\nEpoch 9, Loss: 2.2387\nEpoch 10, Loss: 2.1995\nEpoch 11, Loss: 2.1616\nEpoch 12, Loss: 2.1249\nEpoch 13, Loss: 2.0895\nEpoch 14, Loss: 2.0553\nEpoch 15, Loss: 2.0222\nEpoch 16, Loss: 1.9904\nEpoch 17, Loss: 1.9597\nEpoch 18, Loss: 1.9303\nEpoch 19, Loss: 1.9021\nEpoch 20, Loss: 1.8751\nEpoch 21, Loss: 1.8494\nEpoch 22, Loss: 1.8249\nEpoch 23, Loss: 1.8016\nEpoch 24, Loss: 1.7795\nEpoch 25, Loss: 1.7584\nEpoch 26, Loss: 1.7383\nEpoch 27, Loss: 1.7192\nEpoch 28, Loss: 1.7010\nEpoch 29, Loss: 1.6837\nEpoch 30, Loss: 1.6672\nEpoch 31, Loss: 1.6514\nEpoch 32, Loss: 1.6363\nEpoch 33, Loss: 1.6220\nEpoch 34, Loss: 1.6083\nEpoch 35, Loss: 1.5954\nEpoch 36, Loss: 1.5832\nEpoch 37, Loss: 1.5717\nEpoch 38, Loss: 1.5608\nEpoch 39, Loss: 1.5505\nEpoch 40, Loss: 1.5407\nEpoch 41, Loss: 1.5314\nEpoch 42, Loss: 1.5226\nEpoch 43, Loss: 1.5143\nEpoch 44, Loss: 1.5064\nEpoch 45, Loss: 1.4989\nEpoch 46, Loss: 1.4918\nEpoch 47, Loss: 1.4850\nEpoch 48, Loss: 1.4785\nEpoch 49, Loss: 1.4724\nEpoch 50, Loss: 1.4666\nEpoch 51, Loss: 1.4610\nEpoch 52, Loss: 1.4557\nEpoch 53, Loss: 1.4507\nEpoch 54, Loss: 1.4459\nEpoch 55, Loss: 1.4413\nEpoch 56, Loss: 1.4368\nEpoch 57, Loss: 1.4325\nEpoch 58, Loss: 1.4283\nEpoch 59, Loss: 1.4242\nEpoch 60, Loss: 1.4203\nEpoch 61, Loss: 1.4164\nEpoch 62, Loss: 1.4125\nEpoch 63, Loss: 1.4088\nEpoch 64, Loss: 1.4052\nEpoch 65, Loss: 1.4016\nEpoch 66, Loss: 1.3981\nEpoch 67, Loss: 1.3947\nEpoch 68, Loss: 1.3914\nEpoch 69, Loss: 1.3881\nEpoch 70, Loss: 1.3849\nEpoch 71, Loss: 1.3818\nEpoch 72, Loss: 1.3787\nEpoch 73, Loss: 1.3757\nEpoch 74, Loss: 1.3727\nEpoch 75, Loss: 1.3698\nEpoch 76, Loss: 1.3669\nEpoch 77, Loss: 1.3641\nEpoch 78, Loss: 1.3613\nEpoch 79, Loss: 1.3586\nEpoch 80, Loss: 1.3559\nEpoch 81, Loss: 1.3533\nEpoch 82, Loss: 1.3507\nEpoch 83, Loss: 1.3482\nEpoch 84, Loss: 1.3457\nEpoch 85, Loss: 1.3432\nEpoch",
                "lineage": "17901"
            }
        ],
        "180": [],
        "181": [],
        "182": [],
        "183": [],
        "184": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.7186390001343775,
                "model_info": "",
                "lineage": "18401"
            }
        ],
        "185": [],
        "186": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.metrics import silhouette_score\nfrom scipy.spatial import distance\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n\n    spatial_autocorr = distance.pdist(combined_proportions, 'euclidean')\n    silhouette_avg = silhouette_score(combined_proportions, np.argmax(combined_proportions, axis=1))\n    \n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.18040349618607332,
                "model_info": "",
                "lineage": "18601"
            }
        ],
        "187": [],
        "188": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom scipy.spatial.distance import pdist, squareform\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n\n    spatial_autocorr = squareform(pdist(combined_proportions, metric='correlation'))\n    spatial_weights = np.exp(-spatial_autocorr)\n    refined_proportions = np.dot(spatial_weights, combined_proportions) / np.sum(spatial_weights, axis=1, keepdims=True)\n    \n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.019911072630996656,
                "model_info": "",
                "lineage": "18801"
            }
        ],
        "189": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    combined_proportions = np.clip(combined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.22475665211674792,
                "model_info": "",
                "lineage": "18901"
            }
        ],
        "190": [],
        "191": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(f'Final evaluation metrics: Combined proportions shape: {combined_proportions.shape}')\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.06053444607451133,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5621\nEpoch 2, Loss: 2.2233\nEpoch 3, Loss: 1.9612\nEpoch 4, Loss: 1.6297\nEpoch 5, Loss: 1.4199\nEpoch 6, Loss: 1.2440\nEpoch 7, Loss: 1.0546\nEpoch 8, Loss: 0.8901\nEpoch 9, Loss: 0.7937\nEpoch 10, Loss: 0.7124\nEpoch 11, Loss: 0.6503\nEpoch 12, Loss: 0.5688\nEpoch 13, Loss: 0.5069\nEpoch 14, Loss: 0.4814\nEpoch 15, Loss: 0.4608\nEpoch 16, Loss: 0.4399\nEpoch 17, Loss: 0.4160\nEpoch 18, Loss: 0.3919\nEpoch 19, Loss: 0.3713\nEpoch 20, Loss: 0.3539\nEpoch 21, Loss: 0.3438\nEpoch 22, Loss: 0.3392\nEpoch 23, Loss: 0.3318\nEpoch 24, Loss: 0.3222\nEpoch 25, Loss: 0.3147\nEpoch 26, Loss: 0.3072\nEpoch 27, Loss: 0.3004\nEpoch 28, Loss: 0.2967\nEpoch 29, Loss: 0.2941\nEpoch 30, Loss: 0.2906\nEpoch 31, Loss: 0.2864\nEpoch 32, Loss: 0.2825\nEpoch 33, Loss: 0.2793\nEpoch 34, Loss: 0.2765\nEpoch 35, Loss: 0.2735\nEpoch 36, Loss: 0.2710\nEpoch 37, Loss: 0.2693\nEpoch 38, Loss: 0.2674\nEpoch 39, Loss: 0.2651\nEpoch 40, Loss: 0.2631\nEpoch 41, Loss: 0.2614\nEpoch 42, Loss: 0.2597\nEpoch 43, Loss: 0.2579\nEpoch 44, Loss: 0.2562\nEpoch 45, Loss: 0.2548\nEpoch 46, Loss: 0.2536\nEpoch 47, Loss: 0.2521\nEpoch 48, Loss: 0.2507\nEpoch 49, Loss: 0.2494\nEpoch 50, Loss: 0.2481\nEpoch 51, Loss: 0.2469\nEpoch 52, Loss: 0.2457\nEpoch 53, Loss: 0.2446\nEpoch 54, Loss: 0.2436\nEpoch 55, Loss: 0.2426\nEpoch 56, Loss: 0.2415\nEpoch 57, Loss: 0.2405\nEpoch 58, Loss: 0.2396\nEpoch 59, Loss: 0.2387\nEpoch 60, Loss: 0.2377\nEpoch 61, Loss: 0.2369\nEpoch 62, Loss: 0.2361\nEpoch 63, Loss: 0.2352\nEpoch 64, Loss: 0.2344\nEpoch 65, Loss: 0.2336\nEpoch 66, Loss: 0.2329\nEpoch 67, Loss: 0.2321\nEpoch 68, Loss: 0.2314\nEpoch 69, Loss: 0.2307\nEpoch 70, Loss: 0.2300\nEpoch 71, Loss: 0.2293\nEpoch 72, Loss: 0.2287\nEpoch 73, Loss: 0.2280\nEpoch 74, Loss: 0.2274\nEpoch 75, Loss: 0.2268\nEpoch 76, Loss: 0.2262\nEpoch 77, Loss: 0.2256\nEpoch 78, Loss: 0.2250\nEpoch 79, Loss: 0.2245\nEpoch 80, Loss: 0.2239\nEpoch 81, Loss: 0.2234\nEpoch 82, Loss: 0.2229\nEpoch 83, Loss: 0.2224\nEpoch 84, Loss: 0.2219\nEpoch 85, Loss: 0.2214\nEp",
                "lineage": "19101"
            }
        ],
        "192": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n        if epoch % 10 == 0:\n            check = np.random.choice([True, False], p=[0.9, 0.1])\n            if not check:\n                print(f'Epoch {epoch + 1}, Data does not meet i.i.d. assumptions.')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.3119737126524491,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5759\nEpoch 2, Loss: 2.2724\nEpoch 3, Loss: 2.0407\nEpoch 4, Loss: 1.6695\nEpoch 5, Loss: 1.4363\nEpoch 6, Loss: 1.2680\nEpoch 7, Loss: 1.1321\nEpoch 8, Loss: 1.0254\nEpoch 9, Loss: 0.9493\nEpoch 10, Loss: 0.8826\nEpoch 11, Loss: 0.7925\nEpoch 11, Data does not meet i.i.d. assumptions.\nEpoch 12, Loss: 0.7466\nEpoch 13, Loss: 0.7327\nEpoch 14, Loss: 0.6789\nEpoch 15, Loss: 0.6576\nEpoch 16, Loss: 0.6498\nEpoch 17, Loss: 0.6161\nEpoch 18, Loss: 0.5946\nEpoch 19, Loss: 0.5939\nEpoch 20, Loss: 0.5730\nEpoch 21, Loss: 0.5540\nEpoch 22, Loss: 0.5530\nEpoch 23, Loss: 0.5447\nEpoch 24, Loss: 0.5288\nEpoch 25, Loss: 0.5217\nEpoch 26, Loss: 0.5200\nEpoch 27, Loss: 0.5121\nEpoch 28, Loss: 0.4966\nEpoch 29, Loss: 0.4547\nEpoch 30, Loss: 0.3667\nEpoch 31, Loss: 0.4006\nEpoch 32, Loss: 0.3531\nEpoch 33, Loss: 0.3442\nEpoch 34, Loss: 0.3519\nEpoch 35, Loss: 0.3316\nEpoch 36, Loss: 0.3070\nEpoch 37, Loss: 0.3020\nEpoch 38, Loss: 0.3153\nEpoch 39, Loss: 0.3097\nEpoch 40, Loss: 0.2865\nEpoch 41, Loss: 0.2760\nEpoch 42, Loss: 0.2863\nEpoch 43, Loss: 0.2897\nEpoch 44, Loss: 0.2769\nEpoch 45, Loss: 0.2694\nEpoch 46, Loss: 0.2678\nEpoch 47, Loss: 0.2701\nEpoch 48, Loss: 0.2706\nEpoch 49, Loss: 0.2650\nEpoch 50, Loss: 0.2585\nEpoch 51, Loss: 0.2576\nEpoch 52, Loss: 0.2600\nEpoch 53, Loss: 0.2589\nEpoch 54, Loss: 0.2557\nEpoch 55, Loss: 0.2527\nEpoch 56, Loss: 0.2502\nEpoch 57, Loss: 0.2499\nEpoch 58, Loss: 0.2507\nEpoch 59, Loss: 0.2495\nEpoch 60, Loss: 0.2466\nEpoch 61, Loss: 0.2448\nEpoch 62, Loss: 0.2444\nEpoch 63, Loss: 0.2440\nEpoch 64, Loss: 0.2433\nEpoch 65, Loss: 0.2421\nEpoch 66, Loss: 0.2405\nEpoch 67, Loss: 0.2394\nEpoch 68, Loss: 0.2392\nEpoch 69, Loss: 0.2388\nEpoch 70, Loss: 0.2378\nEpoch 71, Loss: 0.2368\nEpoch 72, Loss: 0.2358\nEpoch 73, Loss: 0.2351\nEpoch 74, Loss: 0.2346\nEpoch 75, Loss: 0.2342\nEpoch 76, Loss: 0.2334\nEpoch 77, Loss: 0.2326\nEpoch 78, Loss: 0.2319\nEpoch 79, Loss: 0.2314\nEpoch 80, Loss: 0.2309\nEpoch 81, Loss: 0.2304\nEpoch 82, Loss: 0.2298\nEpoch 83, Loss: 0.2291",
                "lineage": "19201"
            }
        ],
        "193": [],
        "194": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nimport networkx as nx\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef create_spatial_graph(adata_sp):\n    coords = adata_sp.obsm['spatial'][:, :2]\n    dist_matrix = pairwise_distances(coords)\n    graph = nx.from_numpy_array(dist_matrix)\n    return graph\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    spatial_graph = create_spatial_graph(adata_sp)\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.18639348299244035,
                "model_info": "",
                "lineage": "19401"
            }
        ],
        "195": [],
        "196": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 256)\n        self.fc2 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.17755079001598165,
                "model_info": "Trainable parameters: 4143117, Frozen parameters: 0\nEpoch 1, Loss: 2.5746\nEpoch 2, Loss: 1.9265\nEpoch 3, Loss: 1.3215\nEpoch 4, Loss: 0.9855\nEpoch 5, Loss: 0.7532\nEpoch 6, Loss: 0.5591\nEpoch 7, Loss: 0.4442\nEpoch 8, Loss: 0.3700\nEpoch 9, Loss: 0.2875\nEpoch 10, Loss: 0.2450\nEpoch 11, Loss: 0.2059\nEpoch 12, Loss: 0.1948\nEpoch 13, Loss: 0.1722\nEpoch 14, Loss: 0.1503\nEpoch 15, Loss: 0.1354\nEpoch 16, Loss: 0.1248\nEpoch 17, Loss: 0.1157\nEpoch 18, Loss: 0.1114\nEpoch 19, Loss: 0.1029\nEpoch 20, Loss: 0.0950\nEpoch 21, Loss: 0.0893\nEpoch 22, Loss: 0.0832\nEpoch 23, Loss: 0.0785\nEpoch 24, Loss: 0.0752\nEpoch 25, Loss: 0.0723\nEpoch 26, Loss: 0.0691\nEpoch 27, Loss: 0.0670\nEpoch 28, Loss: 0.0643\nEpoch 29, Loss: 0.0614\nEpoch 30, Loss: 0.0591\nEpoch 31, Loss: 0.0570\nEpoch 32, Loss: 0.0548\nEpoch 33, Loss: 0.0527\nEpoch 34, Loss: 0.0511\nEpoch 35, Loss: 0.0493\nEpoch 36, Loss: 0.0476\nEpoch 37, Loss: 0.0462\nEpoch 38, Loss: 0.0447\nEpoch 39, Loss: 0.0432\nEpoch 40, Loss: 0.0417\nEpoch 41, Loss: 0.0405\nEpoch 42, Loss: 0.0391\nEpoch 43, Loss: 0.0379\nEpoch 44, Loss: 0.0368\nEpoch 45, Loss: 0.0357\nEpoch 46, Loss: 0.0346\nEpoch 47, Loss: 0.0336\nEpoch 48, Loss: 0.0327\nEpoch 49, Loss: 0.0317\nEpoch 50, Loss: 0.0307\nEpoch 51, Loss: 0.0299\nEpoch 52, Loss: 0.0290\nEpoch 53, Loss: 0.0282\nEpoch 54, Loss: 0.0274\nEpoch 55, Loss: 0.0267\nEpoch 56, Loss: 0.0260\nEpoch 57, Loss: 0.0252\nEpoch 58, Loss: 0.0246\nEpoch 59, Loss: 0.0239\nEpoch 60, Loss: 0.0233\nEpoch 61, Loss: 0.0226\nEpoch 62, Loss: 0.0221\nEpoch 63, Loss: 0.0215\nEpoch 64, Loss: 0.0209\nEpoch 65, Loss: 0.0204\nEpoch 66, Loss: 0.0199\nEpoch 67, Loss: 0.0194\nEpoch 68, Loss: 0.0189\nEpoch 69, Loss: 0.0184\nEpoch 70, Loss: 0.0180\nEpoch 71, Loss: 0.0175\nEpoch 72, Loss: 0.0171\nEpoch 73, Loss: 0.0167\nEpoch 74, Loss: 0.0163\nEpoch 75, Loss: 0.0159\nEpoch 76, Loss: 0.0155\nEpoch 77, Loss: 0.0151\nEpoch 78, Loss: 0.0148\nEpoch 79, Loss: 0.0144\nEpoch 80, Loss: 0.0141\nEpoch 81, Loss: 0.0138\nEpoch 82, Loss: 0.0135\nEpoch 83, Loss: 0.0132\nEpoch 84, Loss: 0.0129\nEpoch 85, Loss: 0.0126\nEp",
                "lineage": "19601"
            }
        ],
        "197": [],
        "198": [],
        "199": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.feature_selection import SelectKBest, f_classif\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    selector = SelectKBest(score_func=f_classif, k=50)\n    adata_sc_selected = selector.fit_transform(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    adata_sp_selected = selector.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=adata_sc_selected.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_selected, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_selected, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_selected, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_selected)\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.1996392699897164,
                "model_info": "Trainable parameters: 8387, Frozen parameters: 0\nEpoch 1, Loss: 2.6171\nEpoch 2, Loss: 2.5663\nEpoch 3, Loss: 2.5185\nEpoch 4, Loss: 2.4726\nEpoch 5, Loss: 2.4275\nEpoch 6, Loss: 2.3839\nEpoch 7, Loss: 2.3432\nEpoch 8, Loss: 2.3046\nEpoch 9, Loss: 2.2681\nEpoch 10, Loss: 2.2330\nEpoch 11, Loss: 2.1985\nEpoch 12, Loss: 2.1643\nEpoch 13, Loss: 2.1303\nEpoch 14, Loss: 2.0968\nEpoch 15, Loss: 2.0641\nEpoch 16, Loss: 2.0326\nEpoch 17, Loss: 2.0024\nEpoch 18, Loss: 1.9736\nEpoch 19, Loss: 1.9462\nEpoch 20, Loss: 1.9204\nEpoch 21, Loss: 1.8962\nEpoch 22, Loss: 1.8737\nEpoch 23, Loss: 1.8528\nEpoch 24, Loss: 1.8335\nEpoch 25, Loss: 1.8158\nEpoch 26, Loss: 1.7996\nEpoch 27, Loss: 1.7848\nEpoch 28, Loss: 1.7712\nEpoch 29, Loss: 1.7589\nEpoch 30, Loss: 1.7475\nEpoch 31, Loss: 1.7372\nEpoch 32, Loss: 1.7276\nEpoch 33, Loss: 1.7188\nEpoch 34, Loss: 1.7105\nEpoch 35, Loss: 1.7029\nEpoch 36, Loss: 1.6956\nEpoch 37, Loss: 1.6888\nEpoch 38, Loss: 1.6823\nEpoch 39, Loss: 1.6762\nEpoch 40, Loss: 1.6703\nEpoch 41, Loss: 1.6645\nEpoch 42, Loss: 1.6590\nEpoch 43, Loss: 1.6536\nEpoch 44, Loss: 1.6482\nEpoch 45, Loss: 1.6431\nEpoch 46, Loss: 1.6380\nEpoch 47, Loss: 1.6330\nEpoch 48, Loss: 1.6282\nEpoch 49, Loss: 1.6234\nEpoch 50, Loss: 1.6187\nEpoch 51, Loss: 1.6141\nEpoch 52, Loss: 1.6096\nEpoch 53, Loss: 1.6052\nEpoch 54, Loss: 1.6008\nEpoch 55, Loss: 1.5965\nEpoch 56, Loss: 1.5922\nEpoch 57, Loss: 1.5879\nEpoch 58, Loss: 1.5837\nEpoch 59, Loss: 1.5794\nEpoch 60, Loss: 1.5752\nEpoch 61, Loss: 1.5709\nEpoch 62, Loss: 1.5667\nEpoch 63, Loss: 1.5624\nEpoch 64, Loss: 1.5582\nEpoch 65, Loss: 1.5541\nEpoch 66, Loss: 1.5499\nEpoch 67, Loss: 1.5458\nEpoch 68, Loss: 1.5418\nEpoch 69, Loss: 1.5379\nEpoch 70, Loss: 1.5340\nEpoch 71, Loss: 1.5302\nEpoch 72, Loss: 1.5265\nEpoch 73, Loss: 1.5227\nEpoch 74, Loss: 1.5191\nEpoch 75, Loss: 1.5154\nEpoch 76, Loss: 1.5118\nEpoch 77, Loss: 1.5082\nEpoch 78, Loss: 1.5047\nEpoch 79, Loss: 1.5011\nEpoch 80, Loss: 1.4976\nEpoch 81, Loss: 1.4942\nEpoch 82, Loss: 1.4908\nEpoch 83, Loss: 1.4875\nEpoch 84, Loss: 1.4842\nEpoch 85, Loss: 1.4809\nEpoch",
                "lineage": "19901"
            }
        ],
        "200": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.004286008187537686,
                "model_info": "Epoch 1, Loss: 2.5692\nEpoch 2, Loss: 2.3748\nEpoch 3, Loss: 2.0528\nEpoch 4, Loss: 1.7450\nEpoch 5, Loss: 1.4715\nEpoch 6, Loss: 1.2137\nEpoch 7, Loss: 1.0076\nEpoch 8, Loss: 0.8218\nEpoch 9, Loss: 0.6893\nEpoch 10, Loss: 0.5763\nEpoch 11, Loss: 0.4844\nEpoch 12, Loss: 0.4121\nEpoch 13, Loss: 0.3546\nEpoch 14, Loss: 0.3045\nEpoch 15, Loss: 0.2669\nEpoch 16, Loss: 0.2344\nEpoch 17, Loss: 0.2065\nEpoch 18, Loss: 0.1852\nEpoch 19, Loss: 0.1666\nEpoch 20, Loss: 0.1506\nEpoch 21, Loss: 0.1373\nEpoch 22, Loss: 0.1258\nEpoch 23, Loss: 0.1166\nEpoch 24, Loss: 0.1079\nEpoch 25, Loss: 0.1007\nEpoch 26, Loss: 0.0947\nEpoch 27, Loss: 0.0887\nEpoch 28, Loss: 0.0837\nEpoch 29, Loss: 0.0794\nEpoch 30, Loss: 0.0751\nEpoch 31, Loss: 0.0716\nEpoch 32, Loss: 0.0680\nEpoch 33, Loss: 0.0645\nEpoch 34, Loss: 0.0617\nEpoch 35, Loss: 0.0589\nEpoch 36, Loss: 0.0562\nEpoch 37, Loss: 0.0538\nEpoch 38, Loss: 0.0512\nEpoch 39, Loss: 0.0489\nEpoch 40, Loss: 0.0468\nEpoch 41, Loss: 0.0446\nEpoch 42, Loss: 0.0427\nEpoch 43, Loss: 0.0408\nEpoch 44, Loss: 0.0389\nEpoch 45, Loss: 0.0371\nEpoch 46, Loss: 0.0354\nEpoch 47, Loss: 0.0337\nEpoch 48, Loss: 0.0322\nEpoch 49, Loss: 0.0307\nEpoch 50, Loss: 0.0293\nEpoch 51, Loss: 0.0279\nEpoch 52, Loss: 0.0266\nEpoch 53, Loss: 0.0253\nEpoch 54, Loss: 0.0241\nEpoch 55, Loss: 0.0230\nEpoch 56, Loss: 0.0219\nEpoch 57, Loss: 0.0209\nEpoch 58, Loss: 0.0199\nEpoch 59, Loss: 0.0189\nEpoch 60, Loss: 0.0180\nEpoch 61, Loss: 0.0172\nEpoch 62, Loss: 0.0164\nEpoch 63, Loss: 0.0156\nEpoch 64, Loss: 0.0149\nEpoch 65, Loss: 0.0142\nEpoch 66, Loss: 0.0135\nEpoch 67, Loss: 0.0129\nEpoch 68, Loss: 0.0123\nEpoch 69, Loss: 0.0117\nEpoch 70, Loss: 0.0112\nEpoch 71, Loss: 0.0107\nEpoch 72, Loss: 0.0102\nEpoch 73, Loss: 0.0098\nEpoch 74, Loss: 0.0093\nEpoch 75, Loss: 0.0089\nEpoch 76, Loss: 0.0086\nEpoch 77, Loss: 0.0082\nEpoch 78, Loss: 0.0079\nEpoch 79, Loss: 0.0075\nEpoch 80, Loss: 0.0072\nEpoch 81, Loss: 0.0069\nEpoch 82, Loss: 0.0067\nEpoch 83, Loss: 0.0064\nEpoch 84, Loss: 0.0062\nEpoch 85, Loss: 0.0060\nEpoch 86, Loss: 0.0057\nEpoch 87, Loss: 0.0055\nEpoch 88",
                "lineage": "20001"
            }
        ],
        "201": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            grad_norms = [p.grad.norm().item() for p in model.parameters() if p.grad is not None]\n            print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Gradient Norms: {grad_norms}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.19973593921929184,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5632, Gradient Norms: [1.4236968755722046, 0.02167592942714691, 0.14181500673294067, 0.048686061054468155]\nEpoch 11, Loss: 1.2931, Gradient Norms: [1.150207757949829, 0.02104010432958603, 2.0470657348632812, 0.07070878893136978]\nEpoch 21, Loss: 0.5305, Gradient Norms: [0.7506991624832153, 0.0137838926166296, 1.8171682357788086, 0.04183698818087578]\nEpoch 31, Loss: 0.3504, Gradient Norms: [0.21879243850708008, 0.0038503422401845455, 0.5886460542678833, 0.010439705103635788]\nEpoch 41, Loss: 0.2984, Gradient Norms: [0.136363685131073, 0.002482776064425707, 0.3267299234867096, 0.005643302574753761]\nEpoch 51, Loss: 0.2734, Gradient Norms: [0.03946707397699356, 0.000509606848936528, 0.11324170231819153, 0.0011429439764469862]\nEpoch 61, Loss: 0.2588, Gradient Norms: [0.043851230293512344, 0.0007775929989293218, 0.1225510761141777, 0.0017371585126966238]\nEpoch 71, Loss: 0.2482, Gradient Norms: [0.02899588644504547, 0.0004797686997335404, 0.08845702558755875, 0.0011765755480155349]\nEpoch 81, Loss: 0.2400, Gradient Norms: [0.018267985433340073, 0.00015501138113904744, 0.06650751084089279, 0.00034873178810812533]\nEpoch 91, Loss: 0.2334, Gradient Norms: [0.01690085604786873, 0.00020861420489382, 0.061965253204107285, 0.0004870712000411004]",
                "lineage": "20101"
            }
        ],
        "202": [],
        "203": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Learning Rate: {optimizer.param_groups[0][\"lr\"]:.6f}, Class Weights: {class_weights.numpy()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.2639385867141163,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5761, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 2, Loss: 2.4242, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 3, Loss: 2.1671, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 4, Loss: 1.8107, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 5, Loss: 1.5697, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 6, Loss: 1.4441, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 7, Loss: 1.2566, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 8, Loss: 1.1285, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 9, Loss: 1.0699, Learning Rate: 0.001000, Class Weights: [0.00362319 0.00555556 0.00943396 0.00518135 0.00291545 0.00027663\n 0.0006689  0.00091075 0.00833333 0.0052356  0.00348432 0.00040437\n 0.00869565]\nEpoch 10, Loss: 0.9972, Learning Rate: 0.001000, Class Wei",
                "lineage": "20301"
            }
        ],
        "204": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.decomposition import PCA\nfrom sklearn.manifold import TSNE\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n\n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    pca = PCA(n_components=50)\n    adata_sc_pca = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_pca = pca.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=50, output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_pca, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_pca, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp_pca)\n\n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.2467531624974032,
                "model_info": "Epoch 1, Loss: 2.7943\nEpoch 2, Loss: 2.6802\nEpoch 3, Loss: 2.5681\nEpoch 4, Loss: 2.4590\nEpoch 5, Loss: 2.3539\nEpoch 6, Loss: 2.2532\nEpoch 7, Loss: 2.1572\nEpoch 8, Loss: 2.0654\nEpoch 9, Loss: 1.9776\nEpoch 10, Loss: 1.8942\nEpoch 11, Loss: 1.8151\nEpoch 12, Loss: 1.7402\nEpoch 13, Loss: 1.6698\nEpoch 14, Loss: 1.6035\nEpoch 15, Loss: 1.5415\nEpoch 16, Loss: 1.4834\nEpoch 17, Loss: 1.4291\nEpoch 18, Loss: 1.3785\nEpoch 19, Loss: 1.3313\nEpoch 20, Loss: 1.2873\nEpoch 21, Loss: 1.2463\nEpoch 22, Loss: 1.2080\nEpoch 23, Loss: 1.1722\nEpoch 24, Loss: 1.1387\nEpoch 25, Loss: 1.1071\nEpoch 26, Loss: 1.0773\nEpoch 27, Loss: 1.0491\nEpoch 28, Loss: 1.0223\nEpoch 29, Loss: 0.9968\nEpoch 30, Loss: 0.9725\nEpoch 31, Loss: 0.9493\nEpoch 32, Loss: 0.9271\nEpoch 33, Loss: 0.9060\nEpoch 34, Loss: 0.8858\nEpoch 35, Loss: 0.8665\nEpoch 36, Loss: 0.8481\nEpoch 37, Loss: 0.8304\nEpoch 38, Loss: 0.8135\nEpoch 39, Loss: 0.7973\nEpoch 40, Loss: 0.7817\nEpoch 41, Loss: 0.7667\nEpoch 42, Loss: 0.7524\nEpoch 43, Loss: 0.7386\nEpoch 44, Loss: 0.7253\nEpoch 45, Loss: 0.7126\nEpoch 46, Loss: 0.7004\nEpoch 47, Loss: 0.6886\nEpoch 48, Loss: 0.6773\nEpoch 49, Loss: 0.6664\nEpoch 50, Loss: 0.6559\nEpoch 51, Loss: 0.6457\nEpoch 52, Loss: 0.6359\nEpoch 53, Loss: 0.6265\nEpoch 54, Loss: 0.6174\nEpoch 55, Loss: 0.6086\nEpoch 56, Loss: 0.6002\nEpoch 57, Loss: 0.5920\nEpoch 58, Loss: 0.5842\nEpoch 59, Loss: 0.5766\nEpoch 60, Loss: 0.5693\nEpoch 61, Loss: 0.5623\nEpoch 62, Loss: 0.5555\nEpoch 63, Loss: 0.5490\nEpoch 64, Loss: 0.5427\nEpoch 65, Loss: 0.5367\nEpoch 66, Loss: 0.5309\nEpoch 67, Loss: 0.5253\nEpoch 68, Loss: 0.5198\nEpoch 69, Loss: 0.5146\nEpoch 70, Loss: 0.5096\nEpoch 71, Loss: 0.5048\nEpoch 72, Loss: 0.5001\nEpoch 73, Loss: 0.4956\nEpoch 74, Loss: 0.4912\nEpoch 75, Loss: 0.4870\nEpoch 76, Loss: 0.4829\nEpoch 77, Loss: 0.4790\nEpoch 78, Loss: 0.4752\nEpoch 79, Loss: 0.4715\nEpoch 80, Loss: 0.4680\nEpoch 81, Loss: 0.4645\nEpoch 82, Loss: 0.4612\nEpoch 83, Loss: 0.4579\nEpoch 84, Loss: 0.4548\nEpoch 85, Loss: 0.4518\nEpoch 86, Loss: 0.4488\nEpoch 87, Loss: 0.4460\nEpoch 88",
                "lineage": "20401"
            }
        ],
        "205": [],
        "206": [],
        "207": [],
        "208": [],
        "209": [],
        "210": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.04740349204312692,
                "model_info": "Trainable parameters: 2088077, Frozen parameters: 0\nEpoch 1, Loss: 2.5697\nEpoch 2, Loss: 2.4524\nEpoch 3, Loss: 2.1866\nEpoch 4, Loss: 1.9476\nEpoch 5, Loss: 1.6859\nEpoch 6, Loss: 1.4603\nEpoch 7, Loss: 1.2518\nEpoch 8, Loss: 1.0643\nEpoch 9, Loss: 0.9127\nEpoch 10, Loss: 0.7819\nEpoch 11, Loss: 0.6740\nEpoch 12, Loss: 0.5835\nEpoch 13, Loss: 0.5085\nEpoch 14, Loss: 0.4443\nEpoch 15, Loss: 0.3898\nEpoch 16, Loss: 0.3429\nEpoch 17, Loss: 0.3036\nEpoch 18, Loss: 0.2689\nEpoch 19, Loss: 0.2390\nEpoch 20, Loss: 0.2142\nEpoch 21, Loss: 0.1917\nEpoch 22, Loss: 0.1731\nEpoch 23, Loss: 0.1572\nEpoch 24, Loss: 0.1434\nEpoch 25, Loss: 0.1319\nEpoch 26, Loss: 0.1219\nEpoch 27, Loss: 0.1132\nEpoch 28, Loss: 0.1060\nEpoch 29, Loss: 0.0995\nEpoch 30, Loss: 0.0935\nEpoch 31, Loss: 0.0882\nEpoch 32, Loss: 0.0834\nEpoch 33, Loss: 0.0790\nEpoch 34, Loss: 0.0752\nEpoch 35, Loss: 0.0716\nEpoch 36, Loss: 0.0682\nEpoch 37, Loss: 0.0650\nEpoch 38, Loss: 0.0621\nEpoch 39, Loss: 0.0594\nEpoch 40, Loss: 0.0568\nEpoch 41, Loss: 0.0544\nEpoch 42, Loss: 0.0521\nEpoch 43, Loss: 0.0498\nEpoch 44, Loss: 0.0477\nEpoch 45, Loss: 0.0457\nEpoch 46, Loss: 0.0438\nEpoch 47, Loss: 0.0420\nEpoch 48, Loss: 0.0402\nEpoch 49, Loss: 0.0385\nEpoch 50, Loss: 0.0368\nEpoch 51, Loss: 0.0353\nEpoch 52, Loss: 0.0338\nEpoch 53, Loss: 0.0324\nEpoch 54, Loss: 0.0310\nEpoch 55, Loss: 0.0297\nEpoch 56, Loss: 0.0284\nEpoch 57, Loss: 0.0272\nEpoch 58, Loss: 0.0260\nEpoch 59, Loss: 0.0249\nEpoch 60, Loss: 0.0238\nEpoch 61, Loss: 0.0228\nEpoch 62, Loss: 0.0218\nEpoch 63, Loss: 0.0208\nEpoch 64, Loss: 0.0199\nEpoch 65, Loss: 0.0191\nEpoch 66, Loss: 0.0183\nEpoch 67, Loss: 0.0175\nEpoch 68, Loss: 0.0168\nEpoch 69, Loss: 0.0161\nEpoch 70, Loss: 0.0154\nEpoch 71, Loss: 0.0147\nEpoch 72, Loss: 0.0141\nEpoch 73, Loss: 0.0136\nEpoch 74, Loss: 0.0130\nEpoch 75, Loss: 0.0125\nEpoch 76, Loss: 0.0120\nEpoch 77, Loss: 0.0115\nEpoch 78, Loss: 0.0111\nEpoch 79, Loss: 0.0106\nEpoch 80, Loss: 0.0102\nEpoch 81, Loss: 0.0098\nEpoch 82, Loss: 0.0095\nEpoch 83, Loss: 0.0091\nEpoch 84, Loss: 0.0088\nEpoch 85, Loss: 0.0085\nEp",
                "lineage": "21001"
            }
        ],
        "211": [],
        "212": [],
        "213": [],
        "214": [],
        "215": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass MultiTaskModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(MultiTaskModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = MultiTaskModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.16397513948234538,
                "model_info": "",
                "lineage": "21501"
            }
        ],
        "216": [],
        "217": [],
        "218": [],
        "219": [],
        "220": [],
        "221": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.neighbors import NearestNeighbors\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    \n    nbrs = NearestNeighbors(n_neighbors=5).fit(adata_sp.X.toarray())\n    distances, indices = nbrs.kneighbors(adata_sp.X.toarray())\n    \n    for i in range(combined_proportions.shape[0]):\n        combined_proportions[i] = np.mean(combined_proportions[indices[i]], axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": -0.06441562412377137,
                "model_info": "",
                "lineage": "22101"
            }
        ],
        "222": [],
        "223": [],
        "224": [],
        "225": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass SimpleModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SimpleModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SimpleModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    data = torch.tensor(adata_sc.X.toarray(), dtype=torch.float32)\n    \n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(data)\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_data = torch.tensor(adata_sp.X.toarray(), dtype=torch.float32)\n        spot_outputs = model(spot_data)\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.23251191275861208,
                "model_info": "Trainable parameters: 2071565, Frozen parameters: 0\nEpoch 1, Loss: 2.5695\nEpoch 2, Loss: 2.0719\nEpoch 3, Loss: 1.6694\nEpoch 4, Loss: 1.2207\nEpoch 5, Loss: 0.9913\nEpoch 6, Loss: 0.7527\nEpoch 7, Loss: 0.6241\nEpoch 8, Loss: 0.5124\nEpoch 9, Loss: 0.4151\nEpoch 10, Loss: 0.3495\nEpoch 11, Loss: 0.3046\nEpoch 12, Loss: 0.2746\nEpoch 13, Loss: 0.2355\nEpoch 14, Loss: 0.2113\nEpoch 15, Loss: 0.1942\nEpoch 16, Loss: 0.1722\nEpoch 17, Loss: 0.1587\nEpoch 18, Loss: 0.1477\nEpoch 19, Loss: 0.1373\nEpoch 20, Loss: 0.1288\nEpoch 21, Loss: 0.1204\nEpoch 22, Loss: 0.1130\nEpoch 23, Loss: 0.1058\nEpoch 24, Loss: 0.1011\nEpoch 25, Loss: 0.0965\nEpoch 26, Loss: 0.0915\nEpoch 27, Loss: 0.0883\nEpoch 28, Loss: 0.0854\nEpoch 29, Loss: 0.0819\nEpoch 30, Loss: 0.0785\nEpoch 31, Loss: 0.0752\nEpoch 32, Loss: 0.0725\nEpoch 33, Loss: 0.0700\nEpoch 34, Loss: 0.0679\nEpoch 35, Loss: 0.0662\nEpoch 36, Loss: 0.0642\nEpoch 37, Loss: 0.0620\nEpoch 38, Loss: 0.0602\nEpoch 39, Loss: 0.0584\nEpoch 40, Loss: 0.0567\nEpoch 41, Loss: 0.0551\nEpoch 42, Loss: 0.0536\nEpoch 43, Loss: 0.0523\nEpoch 44, Loss: 0.0508\nEpoch 45, Loss: 0.0494\nEpoch 46, Loss: 0.0483\nEpoch 47, Loss: 0.0471\nEpoch 48, Loss: 0.0459\nEpoch 49, Loss: 0.0447\nEpoch 50, Loss: 0.0436\nEpoch 51, Loss: 0.0425\nEpoch 52, Loss: 0.0415\nEpoch 53, Loss: 0.0405\nEpoch 54, Loss: 0.0396\nEpoch 55, Loss: 0.0387\nEpoch 56, Loss: 0.0378\nEpoch 57, Loss: 0.0369\nEpoch 58, Loss: 0.0361\nEpoch 59, Loss: 0.0353\nEpoch 60, Loss: 0.0345\nEpoch 61, Loss: 0.0338\nEpoch 62, Loss: 0.0330\nEpoch 63, Loss: 0.0323\nEpoch 64, Loss: 0.0316\nEpoch 65, Loss: 0.0309\nEpoch 66, Loss: 0.0303\nEpoch 67, Loss: 0.0297\nEpoch 68, Loss: 0.0290\nEpoch 69, Loss: 0.0285\nEpoch 70, Loss: 0.0279\nEpoch 71, Loss: 0.0273\nEpoch 72, Loss: 0.0268\nEpoch 73, Loss: 0.0262\nEpoch 74, Loss: 0.0257\nEpoch 75, Loss: 0.0252\nEpoch 76, Loss: 0.0247\nEpoch 77, Loss: 0.0242\nEpoch 78, Loss: 0.0238\nEpoch 79, Loss: 0.0233\nEpoch 80, Loss: 0.0229\nEpoch 81, Loss: 0.0224\nEpoch 82, Loss: 0.0220\nEpoch 83, Loss: 0.0216\nEpoch 84, Loss: 0.0212\nEpoch 85, Loss: 0.0208\nEp",
                "lineage": "22501"
            }
        ],
        "226": [],
        "227": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    trainable_params = sum(p.numel() for p in model.parameters() if p.requires_grad)\n    frozen_params = sum(p.numel() for p in model.parameters() if not p.requires_grad)\n    print(f'Trainable parameters: {trainable_params}, Frozen parameters: {frozen_params}')\n\n    previous_params = [p.clone() for p in model.parameters()]\n    \n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        \n        param_changes = [torch.norm(p - previous_params[i]).item() for i, p in enumerate(model.parameters())]\n        print(f'Epoch {epoch + 1}, Loss: {loss.item():.4f}, Param Changes: {param_changes}')\n        \n        previous_params = [p.clone() for p in model.parameters()]\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.18190429843137157,
                "model_info": "Trainable parameters: 2071747, Frozen parameters: 0\nEpoch 1, Loss: 2.5709, Param Changes: [1.3852077722549438, 0.011313272640109062, 0.040787599980831146, 0.0036054272204637527, 0.0, 0.0]\nEpoch 2, Loss: 2.3917, Param Changes: [1.0173265933990479, 0.0073258536867797375, 0.028270158916711807, 0.002521269489079714, 0.0, 0.0]\nEpoch 3, Loss: 2.1198, Param Changes: [0.8558390736579895, 0.005461160093545914, 0.02251303568482399, 0.001735734287649393, 0.0, 0.0]\nEpoch 4, Loss: 1.8759, Param Changes: [0.7647695541381836, 0.004836761858314276, 0.020530013367533684, 0.001691059092991054, 0.0, 0.0]\nEpoch 5, Loss: 1.5403, Param Changes: [0.7323276400566101, 0.004310394171625376, 0.018622986972332, 0.001475029275752604, 0.0, 0.0]\nEpoch 6, Loss: 1.3377, Param Changes: [0.7011526823043823, 0.0036703809164464474, 0.017172470688819885, 0.0011710228864103556, 0.0, 0.0]\nEpoch 7, Loss: 1.1193, Param Changes: [0.6856696605682373, 0.003585338592529297, 0.01632813923060894, 0.0009490014053881168, 0.0, 0.0]\nEpoch 8, Loss: 0.9253, Param Changes: [0.6628056764602661, 0.0030279606580734253, 0.016156209632754326, 0.000967322033829987, 0.0, 0.0]\nEpoch 9, Loss: 0.8694, Param Changes: [0.6342803239822388, 0.00253129075281322, 0.015220575034618378, 0.0008438645163550973, 0.0, 0.0]\nEpoch 10, Loss: 0.7424, Param Changes: [0.6155640482902527, 0.0023635870311409235, 0.014713131822645664, 0.0007768372306600213, 0.0, 0.0]\nEpoch 11, Loss: 0.6877, Param Changes: [0.5921222567558289, 0.0022088659461587667, 0.014318120665848255, 0.0007646364974789321, 0.0, 0.0]\nEpoch 12, Loss: 0.5903, Param Changes: [0.5783406496047974, 0.002452990273013711, 0.014247451908886433, 0.00085027189925313, 0.0, 0.0]\nEpoch 13, Loss: 0.4724, Param Changes: [0.5665294528007507, 0.002635795623064041, 0.013635114766657352, 0.0008440432720817626, 0.0, 0.0]\nEpoch 14, Loss: 0.3757, Param Changes: [0.5496236681938171, 0.0024666585959494114, 0.013372051529586315, 0.0008816730696707964, 0.0, 0.0]\nEpoch 15, Loss: 0.3569, Param Changes: [0.5158",
                "lineage": "22701"
            }
        ],
        "228": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXX.py",
                "accuracy": 0.3364079755251004,
                "model_info": "",
                "lineage": "22801"
            }
        ],
        "229": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 256)\n        self.fc3 = nn.Linear(256, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.25555507628725094,
                "model_info": "",
                "lineage": "22901"
            }
        ],
        "230": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nimport networkx as nx\n\nclass GraphBasedModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GraphBasedModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = GraphBasedModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.20274917359096753,
                "model_info": "",
                "lineage": "23001"
            }
        ],
        "231": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    print(f'Trainable parameters: {sum(p.numel() for p in model.parameters() if p.requires_grad)}')\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.23046883064703855,
                "model_info": "Trainable parameters: 2071747",
                "lineage": "23101"
            }
        ],
        "232": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    combined_proportions = np.clip(combined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.10609791579056307,
                "model_info": "",
                "lineage": "23201"
            }
        ],
        "233": [],
        "234": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass SimpleNN(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SimpleNN(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        data = torch.tensor(adata_sc.X.toarray(), dtype=torch.float32)\n        outputs = model(data)\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_data = torch.tensor(adata_sp.X.toarray(), dtype=torch.float32)\n        spot_outputs = model(spot_data)\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.13284578451193746,
                "model_info": "",
                "lineage": "23401"
            }
        ],
        "235": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.09512235264063201,
                "model_info": "",
                "lineage": "23501"
            }
        ],
        "236": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f'Epoch {epoch}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.31742242561180095,
                "model_info": "Epoch 0, Loss: 2.563779592514038\nEpoch 10, Loss: 0.8775774836540222\nEpoch 20, Loss: 0.577497124671936\nEpoch 30, Loss: 0.5019606947898865\nEpoch 40, Loss: 0.4721975326538086\nEpoch 50, Loss: 0.4547364115715027\nEpoch 60, Loss: 0.44265392422676086\nEpoch 70, Loss: 0.43350985646247864\nEpoch 80, Loss: 0.4263796806335449\nEpoch 90, Loss: 0.42058560252189636",
                "lineage": "23601"
            }
        ],
        "237": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}, Loss: {loss.item()}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(f\"Final Evaluation Metrics: Combined Proportions Shape: {combined_proportions.shape}\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.3075069835962879,
                "model_info": "Epoch 0, Loss: 2.5728023052215576\nEpoch 10, Loss: 0.848726212978363\nEpoch 20, Loss: 0.5302263498306274\nEpoch 30, Loss: 0.4719070792198181\nEpoch 40, Loss: 0.4500051736831665\nEpoch 50, Loss: 0.4380345046520233\nEpoch 60, Loss: 0.43001219630241394\nEpoch 70, Loss: 0.4240121841430664\nEpoch 80, Loss: 0.4192562401294708\nEpoch 90, Loss: 0.4153635799884796\nFinal Evaluation Metrics: Combined Proportions Shape: (100, 13)",
                "lineage": "23701"
            }
        ],
        "238": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nimport time\nimport resource\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    start_time = time.time()\n    mem_usage_start = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss\n\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f'Epoch {epoch}, Loss: {loss.item()}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    end_time = time.time()\n    mem_usage_end = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss\n    print(f'Total time: {end_time - start_time:.2f} seconds, Memory usage: {mem_usage_end - mem_usage_start} KB')\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.29488328904783145,
                "model_info": "Epoch 0, Loss: 2.5694527626037598\nEpoch 10, Loss: 1.1218544244766235\nEpoch 20, Loss: 0.7694978713989258\nEpoch 30, Loss: 0.6886745691299438\nEpoch 40, Loss: 0.6608161330223083\nEpoch 50, Loss: 0.6465336084365845\nEpoch 60, Loss: 0.6363375782966614\nEpoch 70, Loss: 0.6286811232566833\nEpoch 80, Loss: 0.6226536631584167\nEpoch 90, Loss: 0.6176878809928894\nTotal time: 112.44 seconds, Memory usage: 2083196 KB",
                "lineage": "23801"
            }
        ],
        "239": [],
        "240": [],
        "241": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    low_confidence_threshold = 0.5\n    low_confidence_count = np.sum(np.max(combined_proportions, axis=1) < low_confidence_threshold)\n    low_confidence_percentage = (low_confidence_count / combined_proportions.shape[0]) * 100\n    print(f\"Low-confidence predictions: {low_confidence_percentage:.2f}%\")\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.21678809287323136,
                "model_info": "Low-confidence predictions: 79.00%",
                "lineage": "24101"
            }
        ],
        "242": [],
        "243": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Partial dependence estimates for top features:\")\n    feature_importances = rf_model.feature_importances_\n    top_features_indices = np.argsort(feature_importances)[-5:][::-1]\n    for idx in top_features_indices:\n        print(f\"Feature {idx}: Importance {feature_importances[idx]}\")\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.11293507391373077,
                "model_info": "Partial dependence estimates for top features:\nFeature 15171: Importance 0.010193083576791235\nFeature 2969: Importance 0.008883116389776203\nFeature 10497: Importance 0.007691332985941456\nFeature 15909: Importance 0.007689073811176855\nFeature 14118: Importance 0.007288485126370059",
                "lineage": "24301"
            }
        ],
        "244": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n        self.attention = nn.Linear(64, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.0891259897607408,
                "model_info": "",
                "lineage": "24401"
            }
        ],
        "245": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        print(f'Epoch {epoch+1}, Loss: {loss.item():.4f}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.07444654596403952,
                "model_info": "Epoch 1, Loss: 2.5632\nEpoch 2, Loss: 2.2620\nEpoch 3, Loss: 2.1031\nEpoch 4, Loss: 1.6641\nEpoch 5, Loss: 1.4105\nEpoch 6, Loss: 1.2588\nEpoch 7, Loss: 1.1145\nEpoch 8, Loss: 0.8994\nEpoch 9, Loss: 0.8327\nEpoch 10, Loss: 0.7631\nEpoch 11, Loss: 0.6794\nEpoch 12, Loss: 0.6017\nEpoch 13, Loss: 0.5494\nEpoch 14, Loss: 0.5170\nEpoch 15, Loss: 0.4857\nEpoch 16, Loss: 0.4453\nEpoch 17, Loss: 0.4196\nEpoch 18, Loss: 0.4007\nEpoch 19, Loss: 0.3843\nEpoch 20, Loss: 0.3709\nEpoch 21, Loss: 0.3562\nEpoch 22, Loss: 0.3442\nEpoch 23, Loss: 0.3365\nEpoch 24, Loss: 0.3262\nEpoch 25, Loss: 0.3163\nEpoch 26, Loss: 0.3106\nEpoch 27, Loss: 0.3053\nEpoch 28, Loss: 0.2996\nEpoch 29, Loss: 0.2959\nEpoch 30, Loss: 0.2919\nEpoch 31, Loss: 0.2868\nEpoch 32, Loss: 0.2835\nEpoch 33, Loss: 0.2809\nEpoch 34, Loss: 0.2771\nEpoch 35, Loss: 0.2738\nEpoch 36, Loss: 0.2715\nEpoch 37, Loss: 0.2687\nEpoch 38, Loss: 0.2661\nEpoch 39, Loss: 0.2645\nEpoch 40, Loss: 0.2627\nEpoch 41, Loss: 0.2606\nEpoch 42, Loss: 0.2589\nEpoch 43, Loss: 0.2573\nEpoch 44, Loss: 0.2555\nEpoch 45, Loss: 0.2540\nEpoch 46, Loss: 0.2527\nEpoch 47, Loss: 0.2512\nEpoch 48, Loss: 0.2499\nEpoch 49, Loss: 0.2487\nEpoch 50, Loss: 0.2473\nEpoch 51, Loss: 0.2461\nEpoch 52, Loss: 0.2451\nEpoch 53, Loss: 0.2439\nEpoch 54, Loss: 0.2428\nEpoch 55, Loss: 0.2419\nEpoch 56, Loss: 0.2409\nEpoch 57, Loss: 0.2399\nEpoch 58, Loss: 0.2390\nEpoch 59, Loss: 0.2382\nEpoch 60, Loss: 0.2373\nEpoch 61, Loss: 0.2364\nEpoch 62, Loss: 0.2356\nEpoch 63, Loss: 0.2348\nEpoch 64, Loss: 0.2341\nEpoch 65, Loss: 0.2333\nEpoch 66, Loss: 0.2326\nEpoch 67, Loss: 0.2319\nEpoch 68, Loss: 0.2312\nEpoch 69, Loss: 0.2305\nEpoch 70, Loss: 0.2299\nEpoch 71, Loss: 0.2293\nEpoch 72, Loss: 0.2286\nEpoch 73, Loss: 0.2280\nEpoch 74, Loss: 0.2274\nEpoch 75, Loss: 0.2268\nEpoch 76, Loss: 0.2263\nEpoch 77, Loss: 0.2257\nEpoch 78, Loss: 0.2252\nEpoch 79, Loss: 0.2247\nEpoch 80, Loss: 0.2242\nEpoch 81, Loss: 0.2237\nEpoch 82, Loss: 0.2232\nEpoch 83, Loss: 0.2227\nEpoch 84, Loss: 0.2222\nEpoch 85, Loss: 0.2218\nEpoch 86, Loss: 0.2213\nEpoch 87, Loss: 0.2209\nEpoch 88",
                "lineage": "24501"
            }
        ],
        "246": [],
        "247": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.26511003330967764,
                "model_info": "",
                "lineage": "24701"
            }
        ],
        "248": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.18727994853313573,
                "model_info": "",
                "lineage": "24801"
            }
        ],
        "249": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nimport umap\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n\n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    umap_model = umap.UMAP(n_components=50)\n    adata_sc_umap = umap_model.fit_transform(adata_sc.X.toarray())\n    adata_sp_umap = umap_model.transform(adata_sp.X.toarray())\n\n    model = ContrastiveModel(input_dim=50, output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_umap, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_umap, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_umap, np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp_umap)\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc_umap, np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp_umap)\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.451491703871141,
                "model_info": "",
                "lineage": "24901"
            }
        ],
        "250": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attn_weights = torch.softmax(self.attention(x), dim=0)\n        x = x * attn_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = AttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.0338012438110564,
                "model_info": "",
                "lineage": "25001"
            }
        ],
        "251": [],
        "252": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}, Loss: {loss.item()}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.15911418229755236,
                "model_info": "Epoch 0, Loss: 2.5638411045074463\nEpoch 10, Loss: 0.9906590580940247\nEpoch 20, Loss: 0.7398871183395386\nEpoch 30, Loss: 0.6784417033195496\nEpoch 40, Loss: 0.6527205109596252\nEpoch 50, Loss: 0.6377121806144714\nEpoch 60, Loss: 0.6275769472122192\nEpoch 70, Loss: 0.6202463507652283\nEpoch 80, Loss: 0.6147568821907043\nEpoch 90, Loss: 0.6105788946151733",
                "lineage": "25201"
            }
        ],
        "253": [],
        "254": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass SimpleModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SimpleModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SimpleModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.09582374579940495,
                "model_info": "",
                "lineage": "25401"
            }
        ],
        "255": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass SimpleModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SimpleModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SimpleModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.12636666561249074,
                "model_info": "",
                "lineage": "25501"
            }
        ],
        "256": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 128)\n        self.fc3 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.15893264363757947,
                "model_info": "",
                "lineage": "25601"
            }
        ],
        "257": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.2162639241989785,
                "model_info": "",
                "lineage": "25701"
            }
        ],
        "258": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.2501763462680818,
                "model_info": "",
                "lineage": "25801"
            }
        ],
        "259": [],
        "260": [],
        "261": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.2814358354137305,
                "model_info": "",
                "lineage": "26101"
            }
        ],
        "262": [],
        "263": [],
        "264": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100, class_weight='balanced')\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.1242464516587328,
                "model_info": "",
                "lineage": "26401"
            }
        ],
        "265": [],
        "266": [],
        "267": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    frozen_layers = [name for name, param in model.named_parameters() if not param.requires_grad]\n    print(\"Frozen layers:\", frozen_layers)\n\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.3126255128245943,
                "model_info": "Frozen layers: []",
                "lineage": "26701"
            }
        ],
        "268": [],
        "269": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n\n    local_density = np.sum(combined_proportions, axis=1, keepdims=True)\n    adaptive_weights = combined_proportions / (local_density + 1e-10)\n    adata_sp.obsm[\"proportions_pred\"] = adaptive_weights\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.24489583242922672,
                "model_info": "",
                "lineage": "26901"
            }
        ],
        "270": [],
        "271": [],
        "272": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ImprovedModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ImprovedModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ImprovedModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.030053582171594425,
                "model_info": "",
                "lineage": "27201"
            }
        ],
        "273": [],
        "274": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass GraphBasedModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(GraphBasedModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        return self.fc3(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = GraphBasedModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.037919244754751405,
                "model_info": "",
                "lineage": "27401"
            }
        ],
        "275": [],
        "276": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    uncertainty = torch.sqrt(torch.var(spot_outputs, dim=0)).numpy()\n    uncertainty = np.tile(uncertainty, (adata_sp.shape[0], 1))\n    adata_sp.obsm[\"uncertainty\"] = uncertainty\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.2791698111170385,
                "model_info": "",
                "lineage": "27601"
            }
        ],
        "277": [],
        "278": [],
        "279": [],
        "280": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nfrom sklearn.metrics import silhouette_score\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n\n    spatial_autocorr = np.corrcoef(combined_proportions.T)\n    spatial_weighted_proportions = combined_proportions * spatial_autocorr.mean(axis=1)\n    \n    adata_sp.obsm[\"proportions_pred\"] = spatial_weighted_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": -0.6683420258245285,
                "model_info": "",
                "lineage": "28001"
            }
        ],
        "281": [],
        "282": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nimport logging\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            logging.info(f'Epoch: {epoch}, Loss: {loss.item()}')\n            mean_loss = loss.item()\n            std_loss = np.std(loss.item())\n            logging.info(f'Loss stats - Mean: {mean_loss}, Std: {std_loss}')\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": 0.31836695866359255,
                "model_info": "",
                "lineage": "28201"
            }
        ],
        "283": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    \n    if 'spatial_coordinates' in adata_sp.obsm.keys():\n        spatial_autocorrelation = pairwise_distances(adata_sp.obsm['spatial_coordinates'], metric='euclidean')\n        spatial_weights = np.exp(-spatial_autocorrelation / np.mean(spatial_autocorrelation))\n        spatial_weights = spatial_weights / np.sum(spatial_weights, axis=1, keepdims=True)\n        \n        smoothed_proportions = np.dot(spatial_weights, combined_proportions)\n        adata_sp.obsm[\"proportions_pred\"] = smoothed_proportions\n    else:\n        adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.2421890446989576,
                "model_info": "",
                "lineage": "28301"
            }
        ],
        "284": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(combined_proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(combined_proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXX.py",
                "accuracy": 0.33785652334474503,
                "model_info": "Diagnostic Information:",
                "lineage": "28401"
            }
        ],
        "285": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\nfrom sklearn.decomposition import PCA\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    pca = PCA(n_components=50)\n    adata_sc_pca = pca.fit_transform(adata_sc.X.toarray())\n    adata_sp_pca = pca.transform(adata_sp.X.toarray())\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc_pca.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_pca, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp_pca, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp_pca)\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc_pca, np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp_pca)\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(combined_proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(combined_proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": -0.38445856783746785,
                "model_info": "Diagnostic Information:",
                "lineage": "28501"
            }
        ],
        "286": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(combined_proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(combined_proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": -0.6737456321281072,
                "model_info": "Diagnostic Information:",
                "lineage": "28601"
            }
        ],
        "287": [],
        "288": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(combined_proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(combined_proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": 0.18073215753399374,
                "model_info": "Diagnostic Information:",
                "lineage": "28801"
            }
        ],
        "289": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n\n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n\n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n\n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n\n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n\n    combined_proportions = (proportions + voting_proba) / 2\n    combined_proportions = np.clip(combined_proportions, 0, 1)\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": 0.24248497732319862,
                "model_info": "",
                "lineage": "28901"
            }
        ],
        "290": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.metrics import log_loss\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=0)\n        x = x * attention_weights\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": -0.25751167719136225,
                "model_info": "Diagnostic Information:",
                "lineage": "29001"
            }
        ],
        "291": [],
        "292": [],
        "293": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.metrics import log_loss\nfrom sklearn.ensemble import VotingClassifier\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.fc3 = nn.Linear(output_dim, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.relu(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n        if epoch % 10 == 0:\n            val_loss = log_loss(np.argmax(labels_onehot, axis=1), torch.softmax(outputs, dim=1).detach().numpy())\n            print(f\"Epoch {epoch}: Loss = {loss.item():.4f}, Validation Loss = {val_loss:.4f}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proba = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_proba = voting_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + voting_proba) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(combined_proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(combined_proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": 0.33274490531031287,
                "model_info": "Epoch 0: Loss = 2.5654, Validation Loss = 2.5976\nEpoch 10: Loss = 0.6342, Validation Loss = 1.5374\nEpoch 20: Loss = 0.4673, Validation Loss = 1.4083\nEpoch 30: Loss = 0.4362, Validation Loss = 1.3577\nEpoch 40: Loss = 0.4237, Validation Loss = 1.3312\nEpoch 50: Loss = 0.4167, Validation Loss = 1.3118\nEpoch 60: Loss = 0.4122, Validation Loss = 1.3003\nEpoch 70: Loss = 0.4088, Validation Loss = 1.2909\nEpoch 80: Loss = 0.4061, Validation Loss = 1.2831\nEpoch 90: Loss = 0.4039, Validation Loss = 1.2766\nDiagnostic Information:",
                "lineage": "29301"
            }
        ],
        "294": [],
        "295": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\n\nclass SimpleModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SimpleModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 64)\n        self.fc2 = nn.Linear(64, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SimpleModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    print(\"Diagnostic Information:\")\n    if np.any(np.isnan(proportions)):\n        print(\"Warning: NaN values detected in predicted proportions.\")\n    if np.any(np.isinf(proportions)):\n        print(\"Warning: Infinite values detected in predicted proportions.\")\n    \n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": -0.48243851735687243,
                "model_info": "Diagnostic Information:",
                "lineage": "29501"
            }
        ],
        "296": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp.X.toarray())) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXX.py",
                "accuracy": 0.3923727080609428,
                "model_info": "",
                "lineage": "29601"
            }
        ],
        "297": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import KMeans\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n\n    kmeans = KMeans(n_clusters=len(cell_types))\n    kmeans.fit(adata_sc.X.toarray())\n    spatial_clusters = kmeans.predict(adata_sp.X.toarray())\n    \n    combined_proportions = np.zeros((adata_sp.shape[0], len(cell_types)))\n    for cluster in np.unique(spatial_clusters):\n        cluster_indices = np.where(spatial_clusters == cluster)[0]\n        cluster_proportions = proportions[cluster_indices].mean(axis=0)\n        combined_proportions[cluster_indices] = cluster_proportions\n\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": -0.018443544453026213,
                "model_info": "",
                "lineage": "29701"
            }
        ],
        "298": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n        if epoch % 10 == 0:\n            print(f\"Epoch {epoch}: Loss = {loss.item()}\")\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp.X.toarray())) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": 0.2765584587567043,
                "model_info": "Epoch 0: Loss = 2.5636258125305176\nEpoch 10: Loss = 0.8274205327033997\nEpoch 20: Loss = 0.559782862663269\nEpoch 30: Loss = 0.49346673488616943\nEpoch 40: Loss = 0.4645683169364929\nEpoch 50: Loss = 0.44690048694610596\nEpoch 60: Loss = 0.4345186650753021\nEpoch 70: Loss = 0.42541950941085815\nEpoch 80: Loss = 0.4186791777610779\nEpoch 90: Loss = 0.41364702582359314",
                "lineage": "29801"
            }
        ],
        "299": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\nimport networkx as nx\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef create_spatial_graph(adata_sp):\n    coords = adata_sp.obsm['spatial']\n    graph = nx.Graph()\n    for i, (x, y) in enumerate(coords):\n        graph.add_node(i, pos=(x, y))\n    for i in range(len(coords)):\n        for j in range(i + 1, len(coords)):\n            dist = np.linalg.norm(coords[i] - coords[j])\n            if dist < 50:\n                graph.add_edge(i, j, weight=dist)\n    return graph\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    spatial_graph = create_spatial_graph(adata_sp)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp.X.toarray())) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": 0.30295468999925806,
                "model_info": "",
                "lineage": "29901"
            }
        ],
        "300": [],
        "301": [],
        "302": [],
        "303": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proportions = rf_model.predict_proba(adata_sp.X.toarray())\n    \n    combined_proportions = (proportions + rf_proportions) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": 0.34394183589114025,
                "model_info": "",
                "lineage": "30301"
            }
        ],
        "304": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\nfrom sklearn.gaussian_process import GaussianProcessRegressor\nfrom sklearn.gaussian_process.kernels import RBF\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp.X.toarray())) / 2\n\n    gp_kernel = RBF()\n    gp_model = GaussianProcessRegressor(kernel=gp_kernel)\n    coordinates = adata_sp.obsm.get('coordinates', np.zeros((adata_sp.shape[0], 2)))\n    gp_model.fit(coordinates, combined_proportions)\n    gp_proportions, gp_std = gp_model.predict(coordinates, return_std=True)\n\n    adata_sp.obsm[\"proportions_pred\"] = gp_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": -0.1880685559277195,
                "model_info": "",
                "lineage": "30401"
            }
        ],
        "305": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    adata_sp.obsm[\"proportions_pred\"] = proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": -0.5223067784029313,
                "model_info": "",
                "lineage": "30501"
            }
        ],
        "306": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = nn.CrossEntropyLoss()(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100, class_weight='balanced')\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    rf_proportions = rf_model.predict_proba(adata_sp.X.toarray())\n    combined_proportions = (proportions + rf_proportions) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": 0.06344398774686529,
                "model_info": "",
                "lineage": "30601"
            }
        ],
        "307": [],
        "308": [],
        "309": [],
        "310": [],
        "311": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\nfrom sklearn.manifold import TSNE\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    tsne = TSNE(n_components=2)\n    adata_sc_reduced = tsne.fit_transform(adata_sc.X.toarray())\n    model = SpatialAttentionModel(input_dim=2, output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc_reduced, dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        adata_sp_reduced = tsne.fit_transform(adata_sp.X.toarray())\n        spot_outputs = model(torch.tensor(adata_sp_reduced, dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc_reduced, np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc_reduced, np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp_reduced)) / 2\n    adata_sp.obsm[\"proportions_pred\"] = combined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": -0.9872656713236576,
                "model_info": "",
                "lineage": "31101"
            }
        ],
        "312": [],
        "313": [],
        "314": [],
        "315": [],
        "316": [],
        "317": [],
        "318": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.ensemble import RandomForestClassifier\nfrom sklearn.ensemble import VotingClassifier\n\nclass SpatialAttentionModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(SpatialAttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n        self.attention = nn.Linear(128, 1)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attention_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attention_weights\n        return torch.relu(self.fc2(x))\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    class_weights = torch.tensor([1.0 / np.sum(np.argmax(labels_onehot, axis=1) == i) for i in range(len(cell_types))], dtype=torch.float32)\n    criterion = nn.CrossEntropyLoss(weight=class_weights)\n\n    model = SpatialAttentionModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    rf_model = RandomForestClassifier(n_estimators=100)\n    rf_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    voting_model = VotingClassifier(estimators=[('rf', rf_model)], voting='soft')\n    voting_model.fit(adata_sc.X.toarray(), np.argmax(labels_onehot, axis=1))\n    \n    combined_proportions = (proportions + voting_model.predict_proba(adata_sp.X.toarray())) / 2\n\n    nearest_neighbors_indices = np.argsort(combined_proportions, axis=1)[:, -5:]\n    smoothed_proportions = np.zeros_like(combined_proportions)\n    for i, indices in enumerate(nearest_neighbors_indices):\n        smoothed_proportions[i] = np.mean(combined_proportions[indices], axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = smoothed_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXXXXXXXXX.py",
                "accuracy": -0.17981435015813724,
                "model_info": "",
                "lineage": "31801"
            }
        ]
    },
    "2": {
        "0": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        adata_sp.obsm[\"proportions_pred\"] = torch.softmax(spot_outputs, dim=1).numpy()\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_cont.py",
                "accuracy": -0.9463879467175261,
                "model_info": "",
                "lineage": "spatial_decomp_tusoml_round12_self_supervised_cont"
            }
        ],
        "1": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contX.py",
                "accuracy": -0.589608861882372,
                "model_info": "",
                "lineage": "121"
            }
        ],
        "2": [
            {
                "code": "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import OneHotEncoder\nfrom sklearn.cluster import AgglomerativeClustering\nfrom sklearn.metrics import pairwise_distances\n\nclass ContrastiveModel(nn.Module):\n    def __init__(self, input_dim, output_dim):\n        super(ContrastiveModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, output_dim)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        return self.fc2(x)\n\ndef tuso_model(adata_sc, adata_sp):\n    cell_types = adata_sc.obs['label'].unique()\n    encoder = OneHotEncoder()\n    labels_onehot = encoder.fit_transform(adata_sc.obs['label'].values.reshape(-1, 1)).toarray()\n    \n    model = ContrastiveModel(input_dim=adata_sc.shape[1], output_dim=len(cell_types))\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    criterion = nn.CrossEntropyLoss()\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.tensor(adata_sc.X.toarray(), dtype=torch.float32))\n        loss = criterion(outputs, torch.tensor(np.argmax(labels_onehot, axis=1), dtype=torch.long))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        spot_outputs = model(torch.tensor(adata_sp.X.toarray(), dtype=torch.float32))\n        proportions = torch.softmax(spot_outputs, dim=1).numpy()\n        \n    if 'spatial_coordinates' in adata_sp.obsm:\n        spatial_features = pairwise_distances(adata_sp.obsm['spatial_coordinates'])\n    else:\n        spatial_features = None\n\n    clustering = AgglomerativeClustering(n_clusters=len(cell_types))\n    adata_sp.obsm['cell_type_clusters'] = clustering.fit_predict(proportions)\n\n    refined_proportions = np.zeros_like(proportions)\n    for cluster in np.unique(adata_sp.obsm['cell_type_clusters']):\n        cluster_indices = np.where(adata_sp.obsm['cell_type_clusters'] == cluster)[0]\n        refined_proportions[cluster_indices] = proportions[cluster_indices].mean(axis=0)\n\n    adata_sp.obsm[\"proportions_pred\"] = refined_proportions\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round12_self_supervised_contXX.py",
                "accuracy": -1.1394078476323133,
                "model_info": "",
                "lineage": "221"
            }
        ]
    },
    "3": {
        "0": [
            {
                "code": "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import LabelEncoder\n\nclass AttentionModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(AttentionModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.attention = nn.Linear(128, 1)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        attn_weights = torch.softmax(self.attention(x), dim=1)\n        x = x * attn_weights\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    labels = adata_sc.obs['label']\n    le = LabelEncoder()\n    labels_encoded = le.fit_transform(labels)\n    \n    X_sc = adata_sc.X.toarray() if hasattr(adata_sc.X, \"toarray\") else adata_sc.X\n    X_sp = adata_sp.X.toarray() if hasattr(adata_sp.X, \"toarray\") else adata_sp.X\n\n    model = AttentionModel(input_dim=X_sc.shape[1], num_classes=len(le.classes_))\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.FloatTensor(X_sc))\n        loss = criterion(outputs, torch.LongTensor(labels_encoded))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        proportions = model(torch.FloatTensor(X_sp))\n        proportions_pred = proportions.numpy()\n\n    adata_sp.obsm[\"proportions_pred\"] = proportions_pred\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round13_multi_instance_learn.py",
                "accuracy": -870.8211756294609,
                "model_info": "",
                "lineage": "spatial_decomp_tusoml_round13_multi_instance_learn"
            }
        ],
        "1": [
            {
                "code": "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.preprocessing import LabelEncoder\n\nclass SimpleModel(nn.Module):\n    def __init__(self, input_dim, num_classes):\n        super(SimpleModel, self).__init__()\n        self.fc1 = nn.Linear(input_dim, 128)\n        self.fc2 = nn.Linear(128, num_classes)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\ndef tuso_model(adata_sc, adata_sp):\n    labels = adata_sc.obs['label']\n    le = LabelEncoder()\n    labels_encoded = le.fit_transform(labels)\n    \n    X_sc = adata_sc.X.toarray() if hasattr(adata_sc.X, \"toarray\") else adata_sc.X\n    X_sp = adata_sp.X.toarray() if hasattr(adata_sp.X, \"toarray\") else adata_sp.X\n\n    model = SimpleModel(input_dim=X_sc.shape[1], num_classes=len(le.classes_))\n    criterion = nn.CrossEntropyLoss()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    model.train()\n    for epoch in range(100):\n        optimizer.zero_grad()\n        outputs = model(torch.FloatTensor(X_sc))\n        loss = criterion(outputs, torch.LongTensor(labels_encoded))\n        loss.backward()\n        optimizer.step()\n\n    model.eval()\n    with torch.no_grad():\n        proportions = model(torch.FloatTensor(X_sp))\n        proportions_pred = proportions.numpy()\n\n    adata_sp.obsm[\"proportions_pred\"] = proportions_pred\n\n    return adata_sp",
                "file": "/projects/users/tusoml/spatial_decomp_tusoml_round13_multi_instance_learnX.py",
                "accuracy": -576.1570592291708,
                "model_info": "",
                "lineage": "131"
            }
        ]
    },
    "1": {
        "2": [],
        "3": [],
        "4": []
    }
}