<!doctype html>
<html lang="en"> 
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script
      id="p5scripttag"
      src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.9.0/p5.min.js"
      integrity="sha512-uaz5GpnQoE6t5echKlX8P52czvsIGgLPcvlzfvRubLZ1Hp8JemUDnbUiAahbVtPb+jUVrNETuXvAhDDF/N3M4w=="
      crossorigin="anonymous"
      referrerpolicy="no-referrer"
    ></script>

    <link
      rel="stylesheet"
      href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css"
    />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/highlight.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/languages/python.min.js"></script>

    <script>
      const bgCol = "#F2F0E7";
const accentCol = "#fd4578";

hljs.initHighlightingOnLoad();

const updateTargetDims = () => {
  // width is max-width of `.contentContainer` - its padding
  // return [min(windowWidth, 900 - 80), 700]
  return [windowWidth * (1 / 2), windowHeight];
};

const setCodeAndPlan = (code, plan) => {
  const codeElm = document.getElementById("code");
  if (codeElm) {
    // codeElm.innerText = code;
    codeElm.innerHTML = hljs.highlight(code, { language: "python" }).value;
  }

  const planElm = document.getElementById("plan");
  if (planElm) {
    // planElm.innerText = plan.trim();
    planElm.innerHTML = hljs.highlight(plan, { language: "plaintext" }).value;
  }
};

windowResized = () => {
  resizeCanvas(...updateTargetDims());
  awaitingPostResizeOps = true;
};

const animEase = (t) => 1 - (1 - Math.min(t, 1.0)) ** 5;

// ---- global constants ----

const globalAnimSpeed = 1.1;
const scaleFactor = 0.57;

// ---- global vars ----

let globalTime = 0;
let manualSelection = false;

let currentElemInd = 0;

let treeStructData = {"edges": [[0, 8], [1, 5], [2, 10], [3, 11], [4, 6], [5, 7], [6, 48], [8, 53], [9, 14], [10, 27], [11, 13], [12, 66], [13, 39], [14, 21], [15, 23], [16, 25], [17, 30], [18, 31], [19, 64], [20, 22], [21, 33], [22, 65], [23, 44], [24, 41], [25, 40], [26, 38], [27, 36], [27, 28], [27, 32], [27, 37], [27, 35], [27, 34], [28, 29], [29, 52], [30, 51], [35, 60], [37, 50], [37, 42], [37, 58], [37, 45], [37, 55], [37, 59], [37, 63], [37, 67], [37, 54], [37, 47], [39, 61], [40, 56], [42, 43], [43, 46], [44, 62], [48, 49], [51, 57]], "layout": [[0.04333333333333329, 0.0], [0.0833333333333333, 0.0], [0.12333333333333331, 0.0], [0.56, 0.0], [0.6, 0.0], [0.0833333333333333, 0.16666666666666663], [0.6, 0.16666666666666663], [0.0833333333333333, 0.33333333333333337], [0.04333333333333329, 0.16666666666666663], [0.64, 0.0], [0.12333333333333331, 0.16666666666666663], [0.56, 0.16666666666666663], [0.68, 0.0], [0.56, 0.33333333333333337], [0.64, 0.16666666666666663], [0.72, 0.0], [0.76, 0.0], [0.7999999999999999, 0.0], [0.84, 0.0], [0.88, 0.0], [0.92, 0.0], [0.64, 0.33333333333333337], [0.92, 0.16666666666666663], [0.72, 0.16666666666666663], [0.96, 0.0], [0.76, 0.16666666666666663], [1.0, 0.0], [0.12333333333333331, 0.33333333333333337], [0.0, 0.5], [0.0, 0.6666666666666667], [0.7999999999999999, 0.16666666666666663], [0.84, 0.16666666666666663], [0.03999999999999993, 0.5], [0.64, 0.5], [0.07999999999999995, 0.5], [0.11999999999999994, 0.5], [0.15999999999999995, 0.5], [0.33999999999999997, 0.5], [1.0, 0.16666666666666663], [0.56, 0.5], [0.76, 0.33333333333333337], [0.96, 0.16666666666666663], [0.15999999999999995, 0.6666666666666667], [0.15999999999999995, 0.8333333333333334], [0.72, 0.33333333333333337], [0.19999999999999996, 0.6666666666666667], [0.15999999999999995, 1.0], [0.23999999999999996, 0.6666666666666667], [0.6, 0.33333333333333337], [0.6, 0.5], [0.27999999999999997, 0.6666666666666667], [0.7999999999999999, 0.33333333333333337], [0.0, 0.8333333333333334], [0.04333333333333329, 0.33333333333333337], [0.31999999999999995, 0.6666666666666667], [0.36, 0.6666666666666667], [0.76, 0.5], [0.7999999999999999, 0.5], [0.39999999999999997, 0.6666666666666667], [0.44, 0.6666666666666667], [0.11999999999999994, 0.6666666666666667], [0.56, 0.6666666666666667], [0.72, 0.5], [0.48, 0.6666666666666667], [0.88, 0.16666666666666663], [0.92, 0.33333333333333337], [0.68, 0.16666666666666663], [0.52, 0.6666666666666667]], "plan": ["To identify cosmic rays in telescope images, I will implement a simple\nconvolutional neural network (CNN) using PyTorch. The model will consist of\nseveral convolutional layers followed by activation functions and pooling layers\nto capture features in the images. The output will be a single-channel\nprobability map indicating the likelihood of each pixel being a cosmic ray. I\nwill use binary cross-entropy loss with logits and evaluate the model using the\nmasked area under the receiver operating characteristic curve (AUROC) metric.\nFinally, I will save the predictions on the validation set in a `submission.csv`\nfile.", "To tackle the problem of predicting cosmic rays in telescope images, I propose a\nsimple convolutional neural network (CNN) architecture. The model will consist\nof several convolutional layers followed by ReLU activations and pooling layers\nto extract features from the input images. The output layer will apply a sigmoid\nactivation function to produce per-pixel probabilities. We will use binary\ncross-entropy loss with masking to handle ignored pixels. The evaluation will be\nperformed using the masked AUROC metric on the validation set.", "To solve the task of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill take the single-channel image as input and output per-pixel probabilities\nfor cosmic rays. I will use binary cross-entropy loss with a mask to ignore the\ninvalid pixels during training. Finally, I will evaluate the model using the\nmasked Area Under the Receiver Operating Characteristic curve (AUROC) metric on\nthe validation set. Predictions will be saved to a `submission.csv` file.", "To solve the problem of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill take the single-channel image input and output per-pixel probabilities of\ncosmic rays. I will utilize binary cross-entropy loss with masking to handle\nignored pixels and evaluate the model using the masked area under the ROC curve\n(AUROC) metric. Finally, I will save the predictions for the validation set in a\n`submission.csv` file.", "To tackle the problem of predicting cosmic rays in telescope images, I propose\nusing a simple convolutional neural network (CNN) architecture. The model will\ntake the single-channel image input and output per-pixel probabilities of the\npresence of cosmic rays. We'll use binary cross-entropy loss with masking to\naccount for ignored pixels during training. The evaluation metric will be the\nmasked area under the receiver operating characteristic curve (AUROC), which\nwill be computed on the validation set. Finally, I'll save the predictions for\nthe test set in a `submission.csv` file.", "The issue in the previous implementation arises from the fact that the `F`\nmodule from `torch.nn.functional` was not imported, leading to a `NameError`\nwhen attempting to use `F.relu` in the model's forward method. To fix this, we\nneed to import `torch.nn.functional` as `F`. After making this change, the model\nshould work correctly, and we can proceed to compute the masked AUROC score as\nintended.", "The issue in the previous implementation is that the `F` module from PyTorch,\nwhich is required for applying activation functions like `relu`, was not\nimported. To fix this, I will import the `torch.nn.functional` module as `F`.\nAdditionally, I will ensure that the entire script is structured correctly to\nload the data, define the dataset and model, and perform training and\nvalidation, including the evaluation metric. Finally, I will save the\npredictions in the required submission format.", "The issue in the previous implementation arises from the way the model's output\nis reshaped. The model's output shape is not compatible with the intended output\nshape of `[B, 1, 256, 256]`, leading to a runtime error. To fix this, we need to\nensure that the output from the fully connected layer is reshaped correctly\nafter being processed by the convolutional layers. Specifically, we should use\nthe output size from the last pooling layer to determine the correct dimensions\nfor reshaping. The model should output a tensor of shape `[B, 1, 256, 256]`\nafter applying the sigmoid function.", "The issue in the previous implementation arises from a mismatch in the\ndimensions of the output from the model and the target labels during the loss\ncomputation. The model outputs a tensor of shape `[B, 1]`, while the target\ntensor for the loss function has the shape `[B, 1, 256, 256]`. To fix this, we\nneed to ensure that the target tensor is appropriately reshaped to match the\nmodel's output shape before computing the loss. Specifically, we should apply\nthe loss function on the pixel-wise predictions, which requires flattening the\ntensors to 2D shape `[B, H*W]` for both predictions and targets.", "To solve the problem of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill take the image channel as input and output per-pixel probabilities of\nwhether each pixel corresponds to a cosmic ray. I will use binary cross-entropy\nloss with logits while applying a mask to ignore certain pixels during training.\nThe evaluation metric will be the masked area under the receiver operating\ncharacteristic curve (AUROC), computed on the validation set. Finally,\npredictions will be saved in a `submission.csv` file.", "The issue in the previous implementation arises from a mismatch in the sizes of\nthe predicted output and the target labels during the loss calculation. The\nmodel outputs a tensor of shape [B, 1, 64, 64] due to the pooling layers, while\nthe target labels are of shape [B, 1, 256, 256]. To fix this, we should ensure\nthat the model's output maintains the original spatial dimensions of the input\nimage. We can do this by removing the pooling layers or adjusting the\narchitecture to maintain the output size. Additionally, we will ensure that the\nevaluation metric is computed correctly using the masked pixels.", "The issue in the previous implementation arises from a mismatch in the output\nsize of the model and the target size during the loss computation. The model\noutputs a tensor of shape [B, 1, 64, 64] after pooling operations, while the\ntarget tensor has the shape [B, 1, 256, 256]. To fix this, we need to ensure\nthat the model's output shape matches the target shape. This can be achieved by\nadjusting the model architecture to maintain the spatial dimensions throughout\nthe network, avoiding excessive pooling that reduces the size too much.", "To tackle the problem of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill consist of several convolutional layers followed by activation functions\nand pooling layers to extract features from the input images. The output will be\na single-channel probability map indicating the likelihood of each pixel being a\ncosmic ray. I will use binary cross-entropy loss with logits and evaluate the\nmodel's performance using the masked AUROC metric on the validation dataset.\nFinally, I will save the predictions for the test dataset in a `submission.csv`\nfile.", "The issue in the previous implementation arises from the mismatch in the output\nsize of the model and the target size during loss computation. The model's\noutput is downsampled due to the pooling layers, resulting in a shape of [B, 1,\n64, 64] instead of [B, 1, 256, 256]. To fix this, I will modify the architecture\nof the CNN to ensure that the output size matches the input size. This can be\nachieved by removing the pooling layers or adjusting the model to maintain the\nspatial dimensions. Additionally, I will ensure that the evaluation metric is\nprinted after the model has been trained.", "The issue in the previous implementation arises from the mismatch in the output\nsize of the model and the target size during the loss computation. The model\nproduces an output of shape `[B, 1, 64, 64]` due to the downsampling operations\nin the CNN, while the target has a shape of `[B, 1, 256, 256]`. To fix this, we\nshould modify the model architecture to ensure that the output size matches the\ninput size. Specifically, we can use an upsampling layer (like `nn.Upsample` or\na transposed convolution) to restore the original spatial dimensions of the\ninput image after processing through the CNN layers.   Here's the revised\nimplementation with the necessary changes:", "To tackle the problem of predicting cosmic rays in telescope images, I will\nbuild a simple convolutional neural network (CNN) using PyTorch. The model will\ntake single-channel images as input and output per-pixel probabilities of\nwhether each pixel represents a cosmic ray. I will implement a binary cross-\nentropy loss function, applying the ignore mask to ensure that only valid pixels\ncontribute to the loss calculation. Finally, I will evaluate the model's\nperformance using the masked AUROC metric on the validation set and save the\npredictions in a submission file.", "To tackle the problem of predicting cosmic rays in telescope images, I propose\nusing a simple convolutional neural network (CNN). The model will take the image\nchannel as input and output pixel-wise probabilities for the presence of cosmic\nrays. We will use binary cross-entropy loss with a masking mechanism to ignore\ninvalid pixels during training. The evaluation metric will be the masked AUROC\nscore, which assesses the model's performance on valid pixels only. Finally, we\nwill save the predictions for the test set in a `submission.csv` file.", "To tackle the problem of predicting cosmic rays in telescope images, I propose\nto use a simple convolutional neural network (CNN) architecture that processes\nthe input images and outputs pixel-wise probabilities. The model will consist of\nseveral convolutional layers followed by activation functions and pooling layers\nto capture the spatial features of the images. The loss function will be binary\ncross-entropy with logits, and we will apply a mask to ignore invalid pixels\nduring training. Finally, I will evaluate the model using the masked area under\nthe receiver operating characteristic curve (AUROC) metric to assess its\nperformance.", "To tackle the problem of identifying cosmic rays in telescope images, I propose\nusing a simple convolutional neural network (CNN) architecture. The model will\ntake the image channel as input and output a probability map indicating the\npresence of cosmic rays for each pixel. We will employ binary cross-entropy loss\nwith masking to handle ignored pixels during training, and the AUROC metric will\nbe used to evaluate the model's performance on valid pixels. Finally,\npredictions will be saved to a submission file.", "To tackle the problem of predicting cosmic rays in telescope images, I propose\nusing a simple convolutional neural network (CNN) architecture built with\nPyTorch. The model will take the image channel as input and output per-pixel\nprobabilities of cosmic rays. The loss function will be binary cross-entropy\nwith logits, which will be masked using the ignore mask provided in the dataset.\nFinally, we will evaluate the model using the masked AUROC metric to ensure that\nwe only consider valid pixels during evaluation. The predictions will be saved\nto a `submission.csv` file for grading.", "To solve the problem of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill consist of several convolutional layers followed by ReLU activations and\npooling layers to capture the spatial features of the images. The output layer\nwill use a sigmoid activation function to produce per-pixel probabilities. The\nmodel will be trained using binary cross-entropy loss, and I will evaluate the\nperformance using the masked AUROC metric. Finally, I will save the test\npredictions in a `submission.csv` file.", "The bug in the previous implementation arises from the way the `valid` boolean\nmask is applied to the `pred_probs` array. The `valid` mask is being created\nbased on the shape of the `val_data`, which is 2D (N, H, W), while `pred_probs`\nis a 4D array (N, 1, H, W). To fix this, we need to ensure that the `valid` mask\nis appropriately reshaped to match the dimensions of `pred_probs`. Specifically,\nwe should modify the mask to be compatible with the shape of `pred_probs` when\nindexing.", "To fix the bug in the previous implementation, we need to import the\n`torch.nn.functional` module as `F`, which is required for applying activation\nfunctions like `relu` in the model's forward method. Additionally, we will\nensure that the evaluation of the masked AUROC is printed correctly after the\nmodel evaluation. This will allow us to verify that the model is functioning as\nexpected without any errors.", "The issue in the previous implementation arises from the fact that the `F`\nmodule from `torch.nn.functional` was not imported, which leads to a `NameError`\nwhen trying to use `F.relu` in the forward method of the CNN. To fix this, we\nneed to import the `torch.nn.functional` module as `F` at the beginning of the\nscript. Additionally, I will ensure that the code is self-contained and includes\nthe necessary imports, training loop, evaluation, and saving of predictions as\nspecified.", "To tackle the problem of predicting cosmic rays in telescope images, I propose\nusing a simple convolutional neural network (CNN) architecture. The model will\ntake the single-channel image as input and output per-pixel probabilities\nindicating the presence of cosmic rays. We will utilize binary cross-entropy\nloss with logits while applying a mask to ignore certain pixels during training.\nFinally, we will evaluate the model's performance using the masked area under\nthe receiver operating characteristic curve (AUROC) metric.", "The issue in the previous implementation arises from the absence of the\n`torch.nn.functional` module, which is referenced as `F` in the model's forward\nmethod. To fix this, I will import the `torch.nn.functional` module at the\nbeginning of the script. This will allow the use of functions like `F.relu()`\nand ensure that the model can execute without errors. Additionally, I will\nmaintain the overall structure of the code to ensure it functions correctly.", "To tackle the problem of predicting cosmic rays in telescope images, I will\nimplement a simple convolutional neural network (CNN) using PyTorch. The model\nwill take the single-channel image as input and output per-pixel probabilities\nusing a sigmoid activation function. I will use binary cross-entropy loss with\nlogits, applying a mask to ignore certain pixels during training. For\nevaluation, I will compute the masked AUROC score on the validation set. The\npredictions will also be saved to a `submission.csv` file for grading.", "The issue in the previous implementation is that the\n`np.concatenate(pred_probs)` line is attempting to concatenate a list of arrays,\nbut if `pred_probs` is empty (which can happen if no predictions are made), it\nraises a ValueError. To fix this, we need to ensure that we are concatenating\nvalid arrays only. Additionally, we should also ensure that the predictions are\ncollected correctly as a list of arrays during evaluation. I'll implement these\nchanges by checking if `pred_probs` contains any elements before attempting to\nconcatenate and print the evaluation metric.", "To improve the previous solution, we can enhance the model's architecture by\nadding more convolutional layers and incorporating dropout layers to prevent\noverfitting. This should help the model learn more complex features from the\nimages and improve its performance on the validation set. Additionally, we will\nadjust the learning rate to ensure better convergence during training. By making\nthese changes, we aim to increase the model's ability to distinguish between\ncosmic rays and non-cosmic rays effectively.", "The previous implementation did not correctly handle the evaluation of the\nmodel's predictions against the validation set. Specifically, the evaluation\nmetric (AUROC) was calculated using the entire ground truth and predicted\nprobabilities, without properly applying the ignore mask which indicates which\npixels should be excluded from the evaluation. To fix this, the evaluation phase\nshould only consider valid pixels (where the ignore mask is 0) to compute the\nAUROC score. Additionally, I will ensure that the predictions are saved in the\nspecified submission format.", "The issue in the previous implementation arises from the shape mismatch between\nthe flattened output of the CNN and the input size of the first fully connected\nlayer. The input to `fc1` is incorrectly set to expect a flattened size of `64 *\n32 * 32`, but the actual output from the last convolutional layer is `64 * 64 *\n64` due to the pooling layers. To fix this, I will update the input size of the\nfirst fully connected layer to match the correct flattened size. Additionally, I\nwill ensure that the training and evaluation processes remain intact and save\nthe predictions for submission.", "The issue in the previous implementation arises from the mismatch in the output\nsize of the model and the target size during the loss computation. The model\noutputs predictions of shape [B, 1, 64, 64] due to the pooling layers, while the\ntarget has a shape of [B, 1, 256, 256]. To fix this, we need to ensure that the\nmodel's output retains the original spatial dimensions of the input image. This\ncan be achieved by modifying the model architecture to avoid downsampling\nthrough pooling layers or by using an upsampling layer to bring the output back\nto the original size. Additionally, I'll ensure that the predictions for the\nsubmission file are generated correctly.", "To improve the previous solution, we can implement model ensembling, which has\nbeen shown to enhance performance in many machine learning tasks. By training\nmultiple models and averaging their predictions, we can achieve better\ngeneralization and robustness. We can create a few instances of the `SimpleCNN`\nmodel with different initializations and combine their outputs during\nevaluation. This approach can help to reduce variance and improve the masked\nAUROC score.", "The issue in the previous implementation arises from the mismatch between the\ndimensions of the boolean mask and the ground truth labels when indexing. To\nresolve this, we need to ensure that the `valid` mask is correctly reshaped to\nmatch the dimensions of the ground truth labels. Specifically, we should reshape\n`valid` to match the shape of `y` after it has been flattened. Additionally, we\nshould ensure that the predictions are also flattened correctly to match the\nshape of `valid`. After these adjustments, the masked AUROC calculation should\nwork without raising an IndexError.", "To improve the previous solution, we can implement a more sophisticated model\narchitecture, such as a U-Net, which is well-suited for image segmentation tasks\nlike cosmic ray detection. U-Net's skip connections can help retain spatial\ninformation, which may enhance the model's ability to differentiate between\ncosmic rays and background noise. Additionally, we will still maintain the\nexisting data handling and evaluation procedures to ensure compatibility with\nthe current setup.", "To improve the previous solution, we can implement a more sophisticated model\narchitecture, such as a U-Net, which is well-suited for pixel-wise\nclassification tasks like this one. U-Net's architecture, with its encoder-\ndecoder structure and skip connections, can help capture both local and global\nfeatures more effectively than the simple CNN used previously. This should\nenhance the model's ability to distinguish cosmic rays from the background noise\nin the images. Additionally, we can implement early stopping during training to\nprevent overfitting and save the best model based on validation performance.", "To improve the previous solution, we can implement a more robust data\naugmentation strategy during training. Data augmentation can help the model\ngeneralize better by introducing variability in the training data, which can\nlead to improved performance on the validation set. We can apply random\ntransformations such as rotations, flips, and brightness adjustments to the\ninput images. This will enhance the model's ability to learn invariant features\nand potentially increase the masked AUROC score.", "To improve the previous solution, we can implement model ensembling by training\nmultiple instances of the `SimpleCNN` model with different initializations and\naveraging their predictions during evaluation. This approach is known to enhance\nmodel performance by reducing variance and improving generalization. We will\ncreate an ensemble of three models and combine their outputs to compute the\nfinal predictions, which should lead to a higher masked AUROC score.", "The issue in the previous implementation arises from the fact that the output of\nthe model has a smaller spatial dimension than the target labels due to the use\nof pooling layers. To fix this, we need to ensure that the model's output size\nmatches the target size. One way to achieve this is by modifying the model\narchitecture to avoid excessive downsampling or by using upsampling layers after\nthe convolutional operations. In this case, I will add an upsampling layer to\nrestore the output dimensions to match the input size.", "The issue in the previous implementation arises from the fact that the\n`masked_auroc` function is defined after it is called, leading to a `NameError`.\nTo fix this, I will move the definition of the `masked_auroc` function above its\nusage. Additionally, I will ensure that the evaluation metric is printed after\nthe model evaluation. The rest of the code will remain unchanged, as it\ncorrectly implements the model training and evaluation.", "The issue in the previous implementation arises from a mismatch between the\noutput dimensions of the model and the target dimensions used in the loss\nfunction. The model outputs a tensor of shape `[B, 1, 64, 64]` after the pooling\nlayers, while the target tensor has the shape `[B, 1, 256, 256]`. To fix this, I\nwill modify the model architecture to ensure that the output shape matches the\ninput shape of the images, specifically maintaining the spatial dimensions of\n`[256, 256]`. This can be achieved by removing pooling layers or using\ntransposed convolutions to upsample the output back to the desired shape.", "The issue in the previous implementation arises from the attempt to call the\n`.float()` method on a NumPy array, which is not valid since NumPy arrays do not\nhave a `.float()` method. To fix this, we need to convert the NumPy arrays to\nPyTorch tensors before applying the `.float()` method. I will update the\n`__getitem__` method in the `CosmicRayDataset` class to correctly convert the\nimages, ground truth, and masks to tensors. Additionally, I will ensure that the\nshapes are preserved during the conversion. Finally, I will include the\nevaluation metric calculation and save the predictions in the appropriate\nsubmission format.", "To further improve the previous solution, we can implement data augmentation\ntechniques during training. This will help the model generalize better by\nexposing it to a wider variety of training samples. We can apply random\ntransformations such as rotations, flips, and scaling to the input images. This\napproach may lead to improved performance and a higher masked AUROC score on the\nvalidation set.", "The issue in the previous implementation arises from the incorrect shape of the\ninput tensor fed into the model. The model expects a tensor with shape [B, 1,\n256, 256], but the input tensor is incorrectly shaped as [B, 256, 1, 256]. To\nfix this, I will ensure that the input tensor is correctly reshaped before being\npassed to the model. Additionally, I will modify the dataset class to convert\nthe data to PyTorch tensors using `.clone().detach()` to avoid warnings and\nensure proper gradient tracking. Finally, I will include the evaluation metric\ncalculation and save the predictions to a CSV file.", "The issue in the previous implementation arises from a mismatch between the\noutput size of the model and the target size during the loss computation. The\nmodel outputs a tensor of shape [B, 1, 64, 64] due to the pooling layers, while\nthe target tensor has a shape of [B, 1, 256, 256]. To fix this, I will modify\nthe model's architecture to ensure that the output size matches the input size.\nSpecifically, I will add an upsampling layer after the final convolution to\nrestore the output dimensions back to [B, 1, 256, 256].", "To further improve the previous solution, we can incorporate data augmentation\ntechniques during training. This will help the model generalize better by\nexposing it to a wider variety of input images. We can apply random\ntransformations such as rotation, flipping, and scaling to the input images in\nthe dataset. This should help in achieving a higher masked AUROC score by making\nthe model more robust to variations in the input data.", "The bug in the previous implementation arises from a type mismatch when\ntransforming the data in the `__getitem__` method of the `CosmicRayDataset`\nclass. Specifically, the issue occurs because the code attempts to convert an\nalready converted PyTorch tensor back into a tensor using `torch.from_numpy`,\nwhich is unnecessary and leads to a `TypeError`. To fix this, I will remove the\n`torch.from_numpy` calls and directly return the tensors after converting them\nto float. Additionally, I will ensure that the evaluation metric is printed\nafter the evaluation step.", "To further enhance the performance of the cosmic ray detection model, we can\nimplement data augmentation techniques during training. By applying random\ntransformations such as rotation, flipping, and scaling to the training images,\nwe can increase the diversity of the training dataset. This should help the\nmodel generalize better to unseen data, potentially improving the masked AUROC\nscore. Additionally, we will ensure that the transformations are applied\nconsistently to the ground truth and ignore masks.", "The issue in the previous implementation arises because the input data is in a\ndouble precision format, while the model expects float tensors. To resolve this,\nwe need to explicitly convert the input data to float32 when loading it into the\ndataset. Additionally, we should ensure that the model outputs are also in the\ncorrect format for evaluation. I will implement these changes in the dataset\nclass and during the evaluation process to ensure compatibility and avoid\nruntime errors.", "The issue in the previous implementation arises from a mismatch in the output\nsize of the model and the target size used in the loss calculation.\nSpecifically, the model's output is of shape [B, 1, 64, 64] after pooling\noperations, while the target shape is [B, 1, 256, 256]. To fix this, I will\nadjust the model architecture to ensure that the output size matches the target\nsize, which is [B, 1, 256, 256]. This can be achieved by modifying the pooling\nlayers or adding upsampling layers to maintain the spatial dimensions throughout\nthe model.", "To improve the previous solution, we can implement a more robust way of handling\nthe predictions during evaluation by ensuring that we collect predictions from\neach model and only concatenate them if they contain valid arrays. Additionally,\nwe will modify the evaluation function to handle cases where no predictions are\nmade gracefully. This will help avoid potential errors and ensure that our\nevaluation metric is calculated correctly.", "The issue in the previous implementation stems from the incorrect input size for\nthe fully connected layer `fc1`. The input size should match the flattened\noutput size after the convolutional and pooling layers. Since the input images\nare of size 256x256 and are downsampled twice by max pooling (each pooling\noperation reduces the dimensions by half), the final output from the last\nconvolutional layer will be of size 64x64. Therefore, the input to `fc1` should\nbe adjusted accordingly to 64 * 64 * 64, not 64 * 32 * 32. I will fix the input\nsize and ensure the model training and evaluation processes are intact.", "To address the timeout issue in the previous implementation, we can optimize the\nmodel architecture by reducing the number of layers and parameters, thereby\nspeeding up the training process. Instead of using a deep CNN with multiple\nlayers, we can implement a simpler architecture that maintains performance while\nallowing for faster computation. Additionally, we can reduce the batch size\nduring training to lessen memory consumption and processing time. Finally, we\nwill ensure that the evaluation metric is printed after the model completes its\npredictions.", "The issue in the previous implementation arises from a mismatch in the shapes of\nthe output from the model and the target labels during the loss computation. The\nmodel outputs a tensor of shape `[B, 1, 256, 256]`, while the target labels are\nreshaped to `[B, 1]`, causing a size mismatch. To fix this, we need to ensure\nthat the target labels are flattened correctly to match the model's output\nshape. Additionally, we should flatten the predictions as well before applying\nthe loss function. I will implement these changes in the training loop.", "To enhance the performance of the previous solution, we can implement data\naugmentation techniques during training. This will introduce variations in the\ntraining data and help the model generalize better. By applying random\ntransformations such as rotations, flips, and brightness adjustments to the\ninput images, we can create a more robust model that performs better on unseen\ndata. This should improve the masked AUROC score on the validation set.", "To further improve the previous solution, we can implement a more advanced model\narchitecture, such as a U-Net, which is known for its effectiveness in image\nsegmentation tasks. This architecture can capture spatial hierarchies and\ncontextual information better than a simple CNN, potentially leading to improved\nperformance in detecting cosmic rays. Additionally, we will maintain the model\nensembling strategy to combine predictions from multiple instances of the U-Net\nmodel, enhancing robustness and generalization.", "The issue in the previous implementation arises from the mismatch in the output\nsize of the model and the target size during the loss computation. The model's\noutput is incorrectly upsampled to a size of (16, 1, 512, 512) instead of the\nexpected (16, 1, 256, 256). To fix this, I will remove the upsampling layer in\nthe model architecture, ensuring that the output size matches the input size.\nThis will allow the binary cross-entropy loss to be computed correctly without\nany size mismatch errors.", "The issue in the previous implementation arises from a mismatch in the shapes of\nthe predicted outputs and the ground truth labels during the loss computation.\nThe predicted output `pred` has a shape of `[B, 1]`, but the target `y` has a\nshape of `[B, 1, 256, 256]`. To fix this, we need to ensure that the loss is\ncomputed correctly by flattening both the predictions and the targets to match\ntheir dimensions. Additionally, we should adjust the model's final linear layer\nto output the correct shape, which should be `[B, 1, 256, 256]` instead of `[B,\n1]`.   Here is the corrected implementation:", "To further improve the solution, we can implement data augmentation techniques\nduring the training phase. This will help the model generalize better by\nexposing it to a wider variety of training examples, which can enhance its\nrobustness against overfitting. We can apply random transformations such as\nrotations, flips, and scaling to the input images in the `CosmicRayDataset`\nclass. This should lead to improved performance on the validation set.", "To further improve the performance of the cosmic ray detection model, we can\nimplement a more advanced data augmentation strategy during training. This can\ninclude random rotations, flips, and brightness adjustments to enhance the\nmodel's robustness and generalization capabilities. By introducing variability\nin the training data, we can help the model learn more diverse features,\npotentially leading to better performance on the validation set.", "The issue in the previous implementation arises from the mismatch in tensor\nsizes during the skip connections in the UNet architecture. Specifically, the\nupsampled feature maps from the decoder need to match the spatial dimensions of\nthe corresponding encoder feature maps for concatenation. To fix this, I will\nmodify the `upconv_block` method to include an additional convolutional layer\nthat reduces the spatial dimensions of the feature maps after upsampling,\nensuring they match before concatenation. Additionally, I will ensure that the\nevaluation metric is printed at the end of the training loop.", "The issue in the previous implementation arises from the way the `pred_probs`\nare indexed using the boolean mask `valid`. The `valid` mask has a shape of `(N,\nH, W)`, while `pred_probs` has a shape of `(N, 1, H, W)`. To fix this, we need\nto adjust the indexing to ensure that we are correctly indexing the `pred_probs`\ntensor by removing the singleton dimension. This can be done by using\n`pred_probs.squeeze(1)` to change its shape to `(N, H, W)` before applying the\nboolean mask. Below is the revised implementation with the necessary changes.", "The issue in the previous implementation arises from the shape mismatch between\n`pred_probs` and the boolean mask `valid`. The `pred_probs` array has a shape of\n`(N, 1, H, W)` while `valid` has a shape of `(N, H, W)`, leading to an indexing\nerror. To fix this, we need to squeeze `pred_probs` to remove the singleton\ndimension before applying the boolean mask, ensuring that both arrays have\ncompatible shapes for indexing. Additionally, we need to ensure that the output\nprobabilities are flattened correctly for the AUROC calculation.", "To improve the previous solution, we can enhance the model's architecture by\nadding dropout layers to reduce overfitting and improve generalization. This\nwill help the model to perform better on unseen data by preventing it from\nrelying too heavily on any specific features. Additionally, we can adjust the\nlearning rate to optimize the training process further. Implementing these\nchanges should lead to an increase in the masked AUROC score.", "The issue in the previous implementation arises from the size mismatch between\nthe model's output and the target tensor during the loss computation. The model\nis downsampling the input images through pooling layers, resulting in the output\nshape being smaller than the target shape. To fix this, we need to ensure that\nthe model's output shape matches the target shape by either removing the pooling\nlayers or adjusting the architecture to maintain the input dimensions. Here, I\nwill adjust the model to use fewer pooling layers so that the output size\nremains consistent with the input size.", "The issue in the previous implementation arises from the incorrect reshaping of\nthe output tensor in the model's forward method. The output of the final fully\nconnected layer does not match the expected shape of `[B, 1, 256, 256]` because\nit only outputs a flattened tensor of size `B`. To fix this, I will change the\nmodel's forward method to ensure that the output shape is compatible with the\nexpected dimensions. Specifically, I will reshape the output after applying the\nsigmoid activation to have the correct dimensions for the pixel-wise\npredictions.", "The issue in the previous implementation arises from the fact that the\n`torch.nn.functional` module, which is typically imported as `F`, is not\nimported in the code. To fix this, we need to add the appropriate import\nstatement for `torch.nn.functional`. Additionally, we'll ensure that the model\noutputs probabilities using the sigmoid function before computing the AUROC\nmetric. The rest of the code structure will remain the same.", "To improve the previous solution, we can implement a more advanced model\narchitecture by adding dropout layers to the existing CNN. This will help reduce\noverfitting and improve generalization, potentially leading to better\nperformance on unseen data. Additionally, we can adjust the learning rate to\noptimize the training process further. These changes should help increase the\nmasked AUROC score, indicating improved model effectiveness in detecting cosmic\nrays in telescope images."], "code": ["import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Define dataset class\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1]),\n            torch.tensor(self.data[idx, 1:2]),\n            torch.tensor(self.data[idx, 2:3]),\n        )\n\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=32)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.fc1 = nn.Linear(64 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(nn.ReLU()(self.conv1(x)))\n        x = self.pool(nn.ReLU()(self.conv2(x)))\n        x = x.view(-1, 64 * 64 * 64)\n        x = nn.ReLU()(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = CosmicRayCNN()\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Train for 5 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images.float())\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets.float())\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        outputs = model(images.float())\n        pred_probs.append(torch.sigmoid(outputs).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Compute AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions to submission.csv\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3], dtype=torch.float32),\n        )\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc = nn.Linear(32 * 64 * 64, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = torch.sigmoid(self.fc(x))\n        return x.view(-1, 1, 256, 256)\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # 10 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nall_preds = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        outputs = model(images)\n        all_preds.append(outputs)\n\npred_probs = torch.cat(all_preds).cpu().numpy()\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(nn.ReLU()(self.conv1(x)))\n        x = self.pool(nn.ReLU()(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0).ravel()\ny_true = val_data[:, 1].ravel()\nm_mask = val_data[:, 2].ravel() == 0\nmasked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n# Save predictions\nsubmission = np.concatenate(pred_probs).astype(np.float32)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\nprint(f\"Masked AUROC: {masked_auroc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Custom dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground-truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16)\n\n\n# Simple CNN model\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return x\n\n\n# Training function\ndef train_model(model, criterion, optimizer, num_epochs=5):\n    model.train()\n    for epoch in range(num_epochs):\n        for images, targets, masks in train_loader:\n            optimizer.zero_grad()\n            outputs = model(images)\n            valid = (masks == 0).float()\n            loss_per_pixel = criterion(outputs, targets)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Evaluation function\ndef evaluate_model(model):\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n    return np.concatenate(all_preds)\n\n\n# Initialize model, criterion, optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\ntrain_model(model, criterion, optimizer, num_epochs=5)\n\n# Evaluate the model\npred_probs = evaluate_model(model)\nmasked_auc = masked_auroc(pred_probs, val_data)\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\n    \"./working/submission.csv\", submission, delimiter=\",\", header=\"\", comments=\"\"\n)\n\nprint(f\"Masked AUROC: {masked_auc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            self.data[idx, 0:1],\n            self.data[idx, 1:2],\n            self.data[idx, 2:3],\n        )  # image, gt_mask, ignore_mask\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\ndef masked_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Training\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):\n    model.train()\n    for images, targets, masks in tqdm(train_loader):\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_loss(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n# Validation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        outputs = model(images)\n        all_preds.append(outputs.cpu().numpy())\n        all_targets.append(targets.cpu().numpy())\n\nall_preds = np.concatenate(all_preds)\nall_targets = np.concatenate(all_targets)\n\n\n# Evaluation\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(all_preds, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = all_preds.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport torch.nn.functional as F\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3], dtype=torch.float32),\n        )\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc = nn.Linear(32 * 64 * 64, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = torch.sigmoid(self.fc(x))\n        return x.view(-1, 1, 256, 256)\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # 10 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nall_preds = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        outputs = model(images)\n        all_preds.append(outputs)\n\npred_probs = torch.cat(all_preds).cpu().numpy()\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport torch.nn.functional as F\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            self.data[idx, 0:1],\n            self.data[idx, 1:2],\n            self.data[idx, 2:3],\n        )  # image, gt_mask, ignore_mask\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\ndef masked_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Training\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):\n    model.train()\n    for images, targets, masks in tqdm(train_loader):\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_loss(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n# Validation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        outputs = model(images)\n        all_preds.append(outputs.cpu().numpy())\n        all_targets.append(targets.cpu().numpy())\n\nall_preds = np.concatenate(all_preds)\nall_targets = np.concatenate(all_targets)\n\n\n# Evaluation\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(all_preds, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = all_preds.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport torch.nn.functional as F\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3], dtype=torch.float32),\n        )\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc = nn.Linear(32 * 64 * 64, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = torch.sigmoid(self.fc(x))\n        return x.view(-1, 1, 1, 1)  # Fixing the output shape\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # 10 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nall_preds = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        outputs = model(images)\n        all_preds.append(outputs)\n\npred_probs = (\n    torch.cat(all_preds).cpu().numpy().reshape(-1, 256 * 256)\n)  # Reshape for submission\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Define dataset class\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3], dtype=torch.float32),\n        )\n\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=32)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.fc1 = nn.Linear(64 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(nn.ReLU()(self.conv1(x)))\n        x = self.pool(nn.ReLU()(self.conv2(x)))\n        x = x.view(-1, 64 * 64 * 64)\n        x = self.fc2(nn.ReLU()(self.fc1(x)))\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = CosmicRayCNN()\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Train for 5 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images.float())\n        valid = (masks == 0).float()\n        # Reshape targets to match outputs\n        targets_flat = targets.view(-1, 1)  # Shape: [B, 1]\n        loss_per_pixel = criterion(outputs, targets_flat)\n        loss = (loss_per_pixel * valid.view(-1)).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        outputs = model(images.float())\n        pred_probs.append(torch.sigmoid(outputs).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Compute AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions to submission.csv\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return x\n\n\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nmodel.train()\nfor epoch in range(5):  # Simple training loop\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        loss = masked_bce_loss(pred, y, m)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(torch.sigmoid(pred).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        # Removed pooling layers to maintain size\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Keep the output shape [B, 1, 256, 256]\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0).ravel()\ny_true = val_data[:, 1].ravel()\nm_mask = val_data[:, 2].ravel() == 0\nmasked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n# Save predictions\nsubmission = np.concatenate(pred_probs).astype(np.float32)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\nprint(f\"Masked AUROC: {masked_auroc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Custom dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground-truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16)\n\n\n# Adjusted CNN model to maintain dimensions\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.pool(x)\n        x = self.relu(self.conv2(x))\n        x = self.pool(x)\n        x = self.conv3(x)\n        return x\n\n\n# Training function\ndef train_model(model, criterion, optimizer, num_epochs=5):\n    model.train()\n    for epoch in range(num_epochs):\n        for images, targets, masks in train_loader:\n            optimizer.zero_grad()\n            outputs = model(images)\n            valid = (masks == 0).float()\n            loss_per_pixel = criterion(outputs, targets)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Evaluation function\ndef evaluate_model(model):\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n    return np.concatenate(all_preds)\n\n\n# Initialize model, criterion, optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\ntrain_model(model, criterion, optimizer, num_epochs=5)\n\n# Evaluate the model\npred_probs = evaluate_model(model)\nmasked_auc = masked_auroc(pred_probs, val_data)\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\n    \"./working/submission.csv\", submission, delimiter=\",\", header=\"\", comments=\"\"\n)\n\nprint(f\"Masked AUROC: {masked_auc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1, :, :], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2, :, :], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3, :, :], dtype=torch.float32),\n        )\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc1 = nn.Linear(32 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = F.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Small number of epochs for quick testing\n    model.train()\n    for images, labels, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, labels)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        outputs = model(images)\n        pred_probs.append(torch.sigmoid(outputs).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0).ravel()\nmasked_auroc = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {masked_auroc}\")\n\n# Save predictions to submission.csv\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Custom dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground-truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16)\n\n\n# Adjusted CNN model to maintain dimensions\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.relu(self.conv2(x))\n        x = self.conv3(x)\n        return x\n\n\n# Training function\ndef train_model(model, criterion, optimizer, num_epochs=5):\n    model.train()\n    for epoch in range(num_epochs):\n        for images, targets, masks in train_loader:\n            optimizer.zero_grad()\n            outputs = model(images)\n            valid = (masks == 0).float()\n            loss_per_pixel = criterion(outputs, targets)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Evaluation function\ndef evaluate_model(model):\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n    return np.concatenate(all_preds)\n\n\n# Initialize model, criterion, optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\ntrain_model(model, criterion, optimizer, num_epochs=5)\n\n# Evaluate the model\npred_probs = evaluate_model(model)\nmasked_auc = masked_auroc(pred_probs, val_data)\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\n    \"./working/submission.csv\", submission, delimiter=\",\", header=\"\", comments=\"\"\n)\n\nprint(f\"Masked AUROC: {masked_auc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return x\n\n\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nmodel.train()\nfor epoch in range(5):  # Simple training loop\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        loss = masked_bce_loss(pred, y, m)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(torch.sigmoid(pred).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Train for a few epochs\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        outputs = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(outputs, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        outputs = model(x)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Simple training for demonstration\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc1 = nn.Linear(64 * 32 * 32, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv3(x))\n        x = x.view(x.size(0), -1)  # Flatten\n        x = nn.functional.relu(self.fc1(x))\n        x = self.fc2(x)  # Logits\n        return x\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\ncriterion = nn.BCEWithLogitsLoss()\n\n# Training loop\nmodel.train()\nfor epoch in range(5):  # Number of epochs\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nval_dataset = CosmicRayDataset(val_data)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nall_preds = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred.sigmoid().cpu().numpy())\n\npred_probs = np.concatenate(all_preds)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Custom Dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Model Definition\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return x\n\n\n# Loss function with masking\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()  # 1 where valid, 0 where ignored\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Evaluation function\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\n# Training\ndef train_model(train_data, val_data, epochs=10, batch_size=32):\n    train_dataset = CosmicRayDataset(train_data)\n    val_dataset = CosmicRayDataset(val_data)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    val_loader = DataLoader(val_dataset, batch_size=batch_size, shuffle=False)\n\n    model = SimpleCNN().cuda()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(epochs):\n        model.train()\n        for x, y, m in train_loader:\n            x, y, m = x.cuda(), y.cuda(), m.cuda()\n            optimizer.zero_grad()\n            outputs = model(x)\n            loss = masked_bce_loss(outputs, y, m)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for x, _, m in val_loader:\n            x = x.cuda()\n            outputs = model(x)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n\n    pred_probs = np.concatenate(all_preds, axis=0)\n    return masked_auroc(pred_probs, val_data)\n\n\n# Run training and evaluation\nauroc_score = train_model(train_data, val_data)\nprint(f\"Masked AUROC Score: {auroc_score}\")\n\n# Save predictions for submission\nsubmission_preds = np.concatenate(\n    [\n        torch.sigmoid(\n            model(torch.tensor(val_data[:, 0:1, :, :].astype(np.float32)).cuda())\n        )\n        .cpu()\n        .numpy()\n        for _ in range(1)\n    ]\n).flatten()\nnp.savetxt(\"./working/submission.csv\", submission_preds, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return x\n\n\ndef masked_bce_with_logits(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\ndef train_model(model, train_loader, optimizer):\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_bce_with_logits(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n\ndef evaluate_model(model, val_loader):\n    model.eval()\n    all_preds = []\n    all_targets = []\n    all_masks = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            all_preds.append(torch.sigmoid(outputs).cpu().numpy())\n            all_targets.append(targets.cpu().numpy())\n            all_masks.append(masks.cpu().numpy())\n    return (\n        np.concatenate(all_preds),\n        np.concatenate(all_targets),\n        np.concatenate(all_masks),\n    )\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # Train for 10 epochs\n    train_model(model, train_loader, optimizer)\n\n# Evaluation\npred_probs, targets, masks = evaluate_model(model, val_loader)\nmasked_auroc = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {masked_auroc}\")\n\n# Save predictions to submission.csv\nsubmission = (pred_probs > 0.5).astype(int).reshape(-1)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Create datasets and data loaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc1 = nn.Linear(32 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = F.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.sigmoid(x).view(-1, 1, 256, 256)\n\n\n# Training the model\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = CosmicRayCNN().to(device)\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):  # Train for a few epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        images = images.to(device)\n        outputs = model(images)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return x\n\n\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nmodel.train()\nfor epoch in range(5):  # Simple training loop\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        loss = masked_bce_loss(pred, y, m)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(torch.sigmoid(pred).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = (m == 0).reshape(-1)  # Flatten the mask for compatibility\n    t = y[valid].ravel()\n    p = pred_probs[:, 0, :, :][valid].ravel()  # Use the first channel\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F  # Import F for activation functions\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Create datasets and data loaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc1 = nn.Linear(32 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = F.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.sigmoid(x).view(-1, 1, 256, 256)\n\n\n# Training the model\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = CosmicRayCNN().to(device)\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):  # Train for a few epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        images = images.to(device)\n        outputs = model(images)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F  # Importing F here to fix the NameError\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Using torch.sigmoid directly\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Train for a few epochs\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        outputs = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(outputs, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        outputs = model(x)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc = nn.Linear(64 * 32 * 32, 1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.pool(F.relu(self.conv3(x)))\n        x = x.view(-1, 64 * 32 * 32)\n        x = self.fc(x)\n        return self.sigmoid(x)\n\n\n# Custom Dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].float()  # Image\n        y = self.data[idx, 1:2, :, :].float()  # Ground truth\n        m = self.data[idx, 2:3, :, :].float()  # Ignore mask\n        return x, y, m\n\n\n# Load the data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n# Initialize model, loss function, and optimizer\nmodel = CosmicRayCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # Train for 10 epochs\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred)\n        all_targets.append(y)\n\npred_probs = torch.cat(all_preds).cpu().numpy()\ntargets = torch.cat(all_targets).cpu().numpy()\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F  # Importing functional module\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Simple training for demonstration\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\n# Define the model\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return x\n\n\n# Training settings\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Small number of epochs for demonstration\n    model.train()\n    for images, targets, masks in train_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        images = images.to(device)\n        outputs = model(images)\n        preds = torch.sigmoid(outputs).cpu().numpy()\n        pred_probs.append(preds)\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass ImprovedCNN(nn.Module):\n    def __init__(self):\n        super(ImprovedCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(64, 128, kernel_size=3, padding=1)\n        self.dropout = nn.Dropout(0.5)\n        self.conv4 = nn.Conv2d(128, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.dropout(x)\n        x = nn.ReLU()(self.conv3(x))\n        x = self.dropout(x)\n        x = self.conv4(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\nmodel = ImprovedCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.0005)  # Adjusted learning rate\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass ImprovedCNN(nn.Module):\n    def __init__(self):\n        super(ImprovedCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(64, 128, kernel_size=3, padding=1)\n        self.dropout = nn.Dropout(0.5)\n        self.conv4 = nn.Conv2d(128, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.dropout(x)\n        x = nn.ReLU()(self.conv3(x))\n        x = self.dropout(x)\n        x = self.conv4(x)\n        return torch.sigmoid(x)\n\n\nmodel = ImprovedCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc1 = nn.Linear(64 * 32 * 32, 256)  # Corrected input size\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv3(x))\n        x = x.view(x.size(0), -1)  # Flatten\n        x = nn.functional.relu(self.fc1(x))\n        x = self.fc2(x)  # Logits\n        return x\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\ncriterion = nn.BCEWithLogitsLoss()\n\n# Training loop\nmodel.train()\nfor epoch in range(5):  # Number of epochs\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nval_dataset = CosmicRayDataset(val_data)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nall_preds = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred.sigmoid().cpu().numpy())\n\npred_probs = np.concatenate(all_preds)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Custom Dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Model Definition\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.relu(self.conv2(x))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return x\n\n\n# Loss function with masking\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()  # 1 where valid, 0 where ignored\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Evaluation function\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\n# Training\ndef train_model(train_data, val_data, epochs=10, batch_size=32):\n    train_dataset = CosmicRayDataset(train_data)\n    val_dataset = CosmicRayDataset(val_data)\n    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n    val_loader = DataLoader(val_dataset, batch_size=batch_size, shuffle=False)\n\n    model = SimpleCNN().cuda()\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(epochs):\n        model.train()\n        for x, y, m in train_loader:\n            x, y, m = x.cuda(), y.cuda(), m.cuda()\n            optimizer.zero_grad()\n            outputs = model(x)\n            loss = masked_bce_loss(outputs, y, m)\n            loss.backward()\n            optimizer.step()\n\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for x, _, m in val_loader:\n            x = x.cuda()\n            outputs = model(x)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n\n    pred_probs = np.concatenate(all_preds, axis=0)\n    return masked_auroc(pred_probs, val_data)\n\n\n# Run training and evaluation\nauroc_score = train_model(train_data, val_data)\nprint(f\"Masked AUROC Score: {auroc_score}\")\n\n# Save predictions for submission\nsubmission_preds = np.concatenate(\n    [\n        torch.sigmoid(\n            model(torch.tensor(val_data[:, 0:1, :, :].astype(np.float32)).cuda())\n        )\n        .cpu()\n        .numpy()\n        for _ in range(1)\n    ]\n).flatten()\nnp.savetxt(\"./working/submission.csv\", submission_preds, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\ndef train_model(model, train_loader, criterion, optimizer):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n\n# Training multiple models for ensembling\nnum_models = 5\nmodels = []\nfor _ in range(num_models):\n    model = SimpleCNN()\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n    train_model(model, train_loader, criterion, optimizer)\n    models.append(model)\n\n# Evaluation with ensembling\nfor model in models:\n    model.eval()\n\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        preds = [model(x).cpu().numpy() for model in models]\n        avg_pred = np.mean(preds, axis=0)  # Average predictions from all models\n        pred_probs.append(avg_pred)\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return x\n\n\ndef masked_bce_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nmodel.train()\nfor epoch in range(5):  # Simple training loop\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        loss = masked_bce_loss(pred, y, m)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(torch.sigmoid(pred).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = (m == 0).reshape(-1)  # Flatten the mask for compatibility\n    t = y.flatten()[valid]  # Flatten y and apply valid mask\n    p = pred_probs[:, 0, :, :].flatten()[\n        valid\n    ]  # Flatten predictions and apply valid mask\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass UNet(nn.Module):\n    def __init__(self):\n        super(UNet, self).__init__()\n        self.encoder1 = self.conv_block(1, 16)\n        self.encoder2 = self.conv_block(16, 32)\n        self.encoder3 = self.conv_block(32, 64)\n        self.bottleneck = self.conv_block(64, 128)\n        self.decoder3 = self.upconv_block(128, 64)\n        self.decoder2 = self.upconv_block(64, 32)\n        self.decoder1 = self.upconv_block(32, 16)\n        self.final_conv = nn.Conv2d(16, 1, kernel_size=1)\n\n    def conv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.Conv2d(in_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n            nn.Conv2d(out_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n        )\n\n    def upconv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.ConvTranspose2d(in_channels, out_channels, kernel_size=2, stride=2),\n            nn.ReLU(inplace=True),\n        )\n\n    def forward(self, x):\n        enc1 = self.encoder1(x)\n        enc2 = self.encoder2(enc1)\n        enc3 = self.encoder3(enc2)\n        bottleneck = self.bottleneck(enc3)\n        dec3 = self.decoder3(bottleneck)\n        dec3 = torch.cat((dec3, enc3), dim=1)\n        dec2 = self.decoder2(dec3)\n        dec2 = torch.cat((dec2, enc2), dim=1)\n        dec1 = self.decoder1(dec2)\n        dec1 = torch.cat((dec1, enc1), dim=1)\n        return torch.sigmoid(self.final_conv(dec1))\n\n\nmodel = UNet()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\nclass UNet(nn.Module):\n    def __init__(self):\n        super(UNet, self).__init__()\n        self.encoder1 = self.conv_block(1, 16)\n        self.encoder2 = self.conv_block(16, 32)\n        self.encoder3 = self.conv_block(32, 64)\n        self.bottleneck = self.conv_block(64, 128)\n        self.decoder3 = self.upconv_block(128, 64)\n        self.decoder2 = self.upconv_block(64, 32)\n        self.decoder1 = self.upconv_block(32, 16)\n        self.final_conv = nn.Conv2d(16, 1, kernel_size=1)\n\n    def conv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.Conv2d(in_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n            nn.Conv2d(out_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n        )\n\n    def upconv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.ConvTranspose2d(in_channels, out_channels, kernel_size=2, stride=2),\n            nn.ReLU(inplace=True),\n        )\n\n    def forward(self, x):\n        enc1 = self.encoder1(x)\n        enc2 = self.encoder2(enc1)\n        enc3 = self.encoder3(enc2)\n        bottleneck = self.bottleneck(enc3)\n        dec3 = self.decoder3(bottleneck)\n        dec3 = torch.cat((dec3, enc3), dim=1)  # Skip connection\n        dec2 = self.decoder2(dec3)\n        dec2 = torch.cat((dec2, enc2), dim=1)  # Skip connection\n        dec1 = self.decoder1(dec2)\n        dec1 = torch.cat((dec1, enc1), dim=1)  # Skip connection\n        return torch.sigmoid(self.final_conv(dec1))\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nmodel = UNet()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training with early stopping\nbest_auroc = 0\npatience = 5\ntrigger_times = 0\n\nfor epoch in range(50):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n    # Evaluation\n    model.eval()\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            pred = model(x)\n            pred_probs.append(pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        if masked_auroc > best_auroc:\n            best_auroc = masked_auroc\n            trigger_times = 0\n        else:\n            trigger_times += 1\n\n        if trigger_times >= patience:\n            print(\"Early stopping\")\n            break\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\n\nprint(f\"Best Masked AUROC: {best_auroc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToPILImage(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomVerticalFlip(),\n        transforms.RandomRotation(10),\n        transforms.ColorJitter(brightness=0.1, contrast=0.1, saturation=0.1, hue=0.1),\n        transforms.ToTensor(),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training\nfor epoch in range(5):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\n# Define the model\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.relu = nn.ReLU()\n        self.upsample = nn.Upsample(scale_factor=2, mode=\"bilinear\", align_corners=True)\n\n    def forward(self, x):\n        x = self.pool(self.relu(self.conv1(x)))\n        x = self.pool(self.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to match input size\n        return x\n\n\n# Training settings\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Small number of epochs for demonstration\n    model.train()\n    for images, targets, masks in train_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        images = images.to(device)\n        outputs = model(images)\n        preds = torch.sigmoid(outputs).cpu().numpy()\n        pred_probs.append(preds)\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Evaluation function\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    # AUROC requires both classes present\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\n# Custom dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground-truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16)\n\n\n# Adjusted CNN model to maintain dimensions\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.relu(self.conv2(x))\n        x = self.conv3(x)\n        return x\n\n\n# Training function\ndef train_model(model, criterion, optimizer, num_epochs=5):\n    model.train()\n    for epoch in range(num_epochs):\n        for images, targets, masks in train_loader:\n            optimizer.zero_grad()\n            outputs = model(images)\n            valid = (masks == 0).float()\n            loss_per_pixel = criterion(outputs, targets)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Evaluation function\ndef evaluate_model(model):\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n    return np.concatenate(all_preds)\n\n\n# Initialize model, criterion, optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\ntrain_model(model, criterion, optimizer, num_epochs=5)\n\n# Evaluate the model\npred_probs = evaluate_model(model)\nmasked_auc = masked_auroc(pred_probs, val_data)\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\n    \"./working/submission.csv\", submission, delimiter=\",\", header=\"\", comments=\"\"\n)\n\nprint(f\"Masked AUROC: {masked_auc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.upsample = nn.ConvTranspose2d(\n            1, 1, kernel_size=2, stride=2\n        )  # Upsampling layer\n\n    def forward(self, x):\n        x = F.relu(self.conv1(x))\n        x = F.relu(self.conv2(x))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return torch.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc = nn.Linear(64 * 32 * 32, 1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.pool(F.relu(self.conv3(x)))\n        x = x.view(-1, 64 * 32 * 32)\n        x = self.fc(x)\n        return self.sigmoid(x)\n\n\n# Custom Dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = torch.tensor(self.data[idx, 0:1, :, :]).float()  # Image\n        y = torch.tensor(self.data[idx, 1:2, :, :]).float()  # Ground truth\n        m = torch.tensor(self.data[idx, 2:3, :, :]).float()  # Ignore mask\n        return x, y, m\n\n\n# Load the data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n# Initialize model, loss function, and optimizer\nmodel = CosmicRayCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # Train for 10 epochs\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred)\n        all_targets.append(y)\n\npred_probs = torch.cat(all_preds).cpu().numpy()\ntargets = torch.cat(all_targets).cpu().numpy()\n\n\n# Compute masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n            y = self.transform(y)\n            m = self.transform(m)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToTensor(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n            y = self.transform(y)\n            m = self.transform(m)\n\n        return (\n            torch.from_numpy(x).clone().detach(),\n            torch.from_numpy(y).clone().detach(),\n            torch.from_numpy(m).clone().detach(),\n        )\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToTensor(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return torch.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        outputs = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(outputs, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        outputs = model(x)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToTensor(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom torchvision import transforms\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n            y = self.transform(y)\n            m = self.transform(m)\n\n        return (\n            torch.tensor(x),  # Changed from torch.from_numpy to torch.tensor\n            torch.tensor(y),  # Changed from torch.from_numpy to torch.tensor\n            torch.tensor(m),  # Changed from torch.from_numpy to torch.tensor\n        )\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToTensor(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\nimport torchvision.transforms as transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n            y = self.transform(y)\n            m = self.transform(m)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToTensor(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomRotation(10),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport torch.nn.functional as F\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\").astype(np.float32)\nval_data = np.load(\"./input/cosmic_val.npy\").astype(np.float32)\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            self.data[idx, 0:1],\n            self.data[idx, 1:2],\n            self.data[idx, 2:3],\n        )  # image, gt_mask, ignore_mask\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        return self.sigmoid(x)\n\n\ndef masked_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Training\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):\n    model.train()\n    for images, targets, masks in tqdm(train_loader):\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_loss(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n# Validation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        outputs = model(images)\n        all_preds.append(outputs.cpu().numpy())\n        all_targets.append(targets.cpu().numpy())\n\nall_preds = np.concatenate(all_preds)\nall_targets = np.concatenate(all_targets)\n\n\n# Evaluation\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(all_preds, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = all_preds.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nimport torch.nn.functional as F\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\").astype(np.float32)\nval_data = np.load(\"./input/cosmic_val.npy\").astype(np.float32)\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            self.data[idx, 0:1],\n            self.data[idx, 1:2],\n            self.data[idx, 2:3],\n        )  # image, gt_mask, ignore_mask\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.upsample = nn.Upsample(scale_factor=2, mode=\"bilinear\", align_corners=True)\n        self.sigmoid = nn.Sigmoid()\n\n    def forward(self, x):\n        x = F.relu(self.conv1(x))\n        x = self.pool(x)\n        x = F.relu(self.conv2(x))\n        x = self.pool(x)\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to [B, 1, 256, 256]\n        return self.sigmoid(x)\n\n\ndef masked_loss(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\n# Training\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = SimpleCNN().to(device)\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):\n    model.train()\n    for images, targets, masks in tqdm(train_loader):\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_loss(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n# Validation\nmodel.eval()\nall_preds = []\nall_targets = []\nwith torch.no_grad():\n    for images, targets, masks in val_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        outputs = model(images)\n        all_preds.append(outputs.cpu().numpy())\n        all_targets.append(targets.cpu().numpy())\n\nall_preds = np.concatenate(all_preds)\nall_targets = np.concatenate(all_targets)\n\n\n# Evaluation\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(all_preds, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = all_preds.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc1 = nn.Linear(64 * 64 * 64, 256)  # Corrected input size\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv3(x))\n        x = x.view(x.size(0), -1)  # Flatten\n        x = nn.functional.relu(self.fc1(x))\n        x = self.fc2(x)  # Logits\n        return x\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\ncriterion = nn.BCEWithLogitsLoss()\n\n# Training loop\nmodel.train()\nfor epoch in range(5):  # Number of epochs\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nval_dataset = CosmicRayDataset(val_data)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nall_preds = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred.sigmoid().cpu().numpy())\n\npred_probs = np.concatenate(all_preds)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(\n    train_dataset, batch_size=8, shuffle=True\n)  # Reduced batch size\nval_loader = DataLoader(val_dataset, batch_size=8, shuffle=False)  # Reduced batch size\n\n\nclass ImprovedCNN(nn.Module):\n    def __init__(self):\n        super(ImprovedCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)  # Reduced channels\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)  # Reduced channels\n        self.dropout = nn.Dropout(0.3)  # Reduced dropout\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)  # Output layer\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.dropout(x)\n        x = self.conv3(x)\n        return torch.sigmoid(x)\n\n\nmodel = ImprovedCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.0005)\n\n# Training\nfor epoch in range(3):  # Reduced epochs\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\nif pred_probs:  # Check if there are any predictions collected\n    pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n    y_true = val_data[:, 1].ravel()\n    m_mask = val_data[:, 2].ravel() == 0\n    masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\nelse:\n    print(\"No predictions were collected.\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Define dataset class\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3], dtype=torch.float32),\n        )\n\n\n# Create datasets and dataloaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=32)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 32, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(kernel_size=2, stride=2)\n        self.fc1 = nn.Linear(64 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(nn.ReLU()(self.conv1(x)))\n        x = self.pool(nn.ReLU()(self.conv2(x)))\n        x = x.view(-1, 64 * 64 * 64)\n        x = self.fc2(nn.ReLU()(self.fc1(x)))\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = CosmicRayCNN()\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Train for 5 epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images.float())\n        valid = (masks == 0).float()\n        targets_flat = targets.view(-1)  # Shape: [B*H*W]\n        outputs_flat = outputs.view(-1)  # Shape: [B*H*W]\n        loss_per_pixel = criterion(outputs_flat, targets_flat)\n        loss = (loss_per_pixel * valid.view(-1)).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        outputs = model(images.float())\n        pred_probs.append(torch.sigmoid(outputs).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Compute AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions to submission.csv\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\nimport torchvision.transforms as transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)  # Apply transformations\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToPILImage(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomVerticalFlip(),\n        transforms.RandomRotation(10),\n        transforms.ColorJitter(brightness=0.1, contrast=0.1, saturation=0.1, hue=0.1),\n        transforms.ToTensor(),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass UNet(nn.Module):\n    def __init__(self):\n        super(UNet, self).__init__()\n        self.encoder1 = self.conv_block(1, 16)\n        self.encoder2 = self.conv_block(16, 32)\n        self.encoder3 = self.conv_block(32, 64)\n        self.bottleneck = self.conv_block(64, 128)\n        self.decoder3 = self.upconv_block(128, 64)\n        self.decoder2 = self.upconv_block(64, 32)\n        self.decoder1 = self.upconv_block(32, 16)\n        self.final_conv = nn.Conv2d(16, 1, kernel_size=1)\n\n    def conv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.Conv2d(in_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(),\n            nn.Conv2d(out_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(),\n        )\n\n    def upconv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.ConvTranspose2d(in_channels, out_channels, kernel_size=2, stride=2),\n            nn.ReLU(),\n        )\n\n    def forward(self, x):\n        enc1 = self.encoder1(x)\n        enc2 = self.encoder2(enc1)\n        enc3 = self.encoder3(enc2)\n        bottleneck = self.bottleneck(enc3)\n        dec3 = self.decoder3(bottleneck)\n        dec2 = self.decoder2(dec3 + enc3)  # Skip connection\n        dec1 = self.decoder1(dec2 + enc2)  # Skip connection\n        return torch.sigmoid(self.final_conv(dec1))  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [UNet() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)\n        y = self.data[idx, 1:2, :, :].astype(np.float32)\n        m = self.data[idx, 2:3, :, :].astype(np.float32)\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = F.relu(self.conv1(x))\n        x = F.relu(self.conv2(x))\n        x = self.conv3(x)  # No upsampling\n        return torch.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        pred = model(x)\n        pred_probs.append(pred.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nscore = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 64, kernel_size=3, padding=1)\n        self.fc1 = nn.Linear(64 * 32 * 32, 256)  # Corrected input size\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = nn.functional.relu(self.conv1(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv2(x))\n        x = nn.functional.max_pool2d(x, 2)\n        x = nn.functional.relu(self.conv3(x))\n        x = x.view(x.size(0), -1)  # Flatten\n        x = nn.functional.relu(self.fc1(x))\n        x = self.fc2(x)  # Logits\n        return x.view(-1, 1, 256, 256)  # Change output shape to [B, 1, H, W]\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\ncriterion = nn.BCEWithLogitsLoss()\n\n# Training loop\nmodel.train()\nfor epoch in range(5):  # Number of epochs\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\nval_dataset = CosmicRayDataset(val_data)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nall_preds = []\nwith torch.no_grad():\n    for x, y, m in val_loader:\n        pred = model(x)\n        all_preds.append(pred.sigmoid().cpu().numpy())\n\npred_probs = np.concatenate(all_preds)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\nimport torchvision.transforms as transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define data augmentation transformations\ndata_transforms = transforms.Compose(\n    [\n        transforms.ToPILImage(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomVerticalFlip(),\n        transforms.RandomRotation(10),\n        transforms.ToTensor(),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=data_transforms)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\nimport torchvision.transforms as transforms\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Data augmentation\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data, transform=None):\n        self.data = data\n        self.transform = transform\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n\n        if self.transform:\n            x = self.transform(x)\n            y = self.transform(y)\n            m = self.transform(m)\n\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Define transformations\ntransform = transforms.Compose(\n    [\n        transforms.ToPILImage(),\n        transforms.RandomHorizontalFlip(),\n        transforms.RandomVerticalFlip(),\n        transforms.RandomRotation(10),\n        transforms.ColorJitter(brightness=0.1),\n        transforms.ToTensor(),\n    ]\n)\n\ntrain_dataset = CosmicRayDataset(train_data, transform=transform)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = nn.ReLU()(self.conv2(x))\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.001)\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\nclass UNet(nn.Module):\n    def __init__(self):\n        super(UNet, self).__init__()\n        self.encoder1 = self.conv_block(1, 16)\n        self.encoder2 = self.conv_block(16, 32)\n        self.encoder3 = self.conv_block(32, 64)\n        self.bottleneck = self.conv_block(64, 128)\n        self.decoder3 = self.upconv_block(128, 64)\n        self.decoder2 = self.upconv_block(64, 32)\n        self.decoder1 = self.upconv_block(32, 16)\n        self.final_conv = nn.Conv2d(16, 1, kernel_size=1)\n\n    def conv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.Conv2d(in_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n            nn.Conv2d(out_channels, out_channels, kernel_size=3, padding=1),\n            nn.ReLU(inplace=True),\n        )\n\n    def upconv_block(self, in_channels, out_channels):\n        return nn.Sequential(\n            nn.ConvTranspose2d(in_channels, out_channels, kernel_size=2, stride=2),\n            nn.ReLU(inplace=True),\n            nn.Conv2d(\n                out_channels, out_channels, kernel_size=3, padding=1\n            ),  # Adjust spatial size\n            nn.ReLU(inplace=True),\n        )\n\n    def forward(self, x):\n        enc1 = self.encoder1(x)\n        enc2 = self.encoder2(enc1)\n        enc3 = self.encoder3(enc2)\n        bottleneck = self.bottleneck(enc3)\n        dec3 = self.decoder3(bottleneck)\n        dec3 = torch.cat((dec3, enc3), dim=1)  # Skip connection\n        dec2 = self.decoder2(dec3)\n        dec2 = torch.cat((dec2, enc2), dim=1)  # Skip connection\n        dec1 = self.decoder1(dec2)\n        dec1 = torch.cat((dec1, enc1), dim=1)  # Skip connection\n        return torch.sigmoid(self.final_conv(dec1))\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\nmodel = UNet()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training with early stopping\nbest_auroc = 0\npatience = 5\ntrigger_times = 0\n\nfor epoch in range(50):\n    model.train()\n    for x, y, m in tqdm(train_loader):\n        optimizer.zero_grad()\n        pred = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(pred, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n    # Evaluation\n    model.eval()\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            pred = model(x)\n            pred_probs.append(pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        if masked_auroc > best_auroc:\n            best_auroc = masked_auroc\n            trigger_times = 0\n        else:\n            trigger_times += 1\n\n        if trigger_times >= patience:\n            print(\"Early stopping\")\n            break\n\n    # Save predictions\n    submission = pred_probs.astype(np.float32)\n    np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n    print(f\"Masked AUROC: {masked_auroc}\")\n\nprint(f\"Best Masked AUROC: {best_auroc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\n# Evaluation function\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs.squeeze(1)[valid].ravel()  # Adjusted indexing\n    # AUROC requires both classes present\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\n# Custom dataset\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground-truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16)\n\n\n# Adjusted CNN model to maintain dimensions\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.relu(self.conv2(x))\n        x = self.conv3(x)\n        return x\n\n\n# Training function\ndef train_model(model, criterion, optimizer, num_epochs=5):\n    model.train()\n    for epoch in range(num_epochs):\n        for images, targets, masks in train_loader:\n            optimizer.zero_grad()\n            outputs = model(images)\n            valid = (masks == 0).float()\n            loss_per_pixel = criterion(outputs, targets)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Evaluation function\ndef evaluate_model(model):\n    model.eval()\n    all_preds = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            preds = torch.sigmoid(outputs).cpu().numpy()\n            all_preds.append(preds)\n    return np.concatenate(all_preds)\n\n\n# Initialize model, criterion, optimizer\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\ntrain_model(model, criterion, optimizer, num_epochs=5)\n\n# Evaluate the model\npred_probs = evaluate_model(model)\nmasked_auc = masked_auroc(pred_probs, val_data)\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\n    \"./working/submission.csv\", submission, delimiter=\",\", header=\"\", comments=\"\"\n)\n\nprint(f\"Masked AUROC: {masked_auc}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.upsample = nn.Upsample(\n            size=(256, 256), mode=\"bilinear\", align_corners=False\n        )\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = self.conv3(x)\n        x = self.upsample(x)  # Upsample to original size\n        return torch.sigmoid(x)\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):\n    model.train()\n    for x, y, m in train_loader:\n        optimizer.zero_grad()\n        outputs = model(x)\n        valid = (m == 0).float()\n        loss_per_pixel = criterion(outputs, y)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for x, _, m in val_loader:\n        outputs = model(x)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0).squeeze(1)  # Remove singleton dimension\n\n\n# Calculate AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.reshape(-1, 256 * 256), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.dropout = nn.Dropout(0.5)  # Adding dropout layer\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = self.dropout(x)  # Apply dropout after first conv layer\n        x = nn.ReLU()(self.conv2(x))\n        x = self.dropout(x)  # Apply dropout after second conv layer\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)  # Adjusted learning rate\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [SimpleCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.from_numpy(x), torch.from_numpy(y), torch.from_numpy(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.conv1(x))\n        x = self.relu(self.conv2(x))\n        x = self.conv3(x)  # No pooling to maintain size\n        return x\n\n\ndef masked_bce_with_logits(pred, target, mask):\n    valid = (mask == 0).float()\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n    loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n    return loss\n\n\ndef train_model(model, train_loader, optimizer):\n    model.train()\n    for images, targets, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        loss = masked_bce_with_logits(outputs, targets, masks)\n        loss.backward()\n        optimizer.step()\n\n\ndef evaluate_model(model, val_loader):\n    model.eval()\n    all_preds = []\n    all_targets = []\n    all_masks = []\n    with torch.no_grad():\n        for images, targets, masks in val_loader:\n            outputs = model(images)\n            all_preds.append(torch.sigmoid(outputs).cpu().numpy())\n            all_targets.append(targets.cpu().numpy())\n            all_masks.append(masks.cpu().numpy())\n    return (\n        np.concatenate(all_preds),\n        np.concatenate(all_targets),\n        np.concatenate(all_masks),\n    )\n\n\nmodel = SimpleCNN()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(10):  # Train for 10 epochs\n    train_model(model, train_loader, optimizer)\n\n# Evaluation\npred_probs, targets, masks = evaluate_model(model, val_loader)\nmasked_auroc = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {masked_auroc}\")\n\n# Save predictions to submission.csv\nsubmission = (pred_probs > 0.5).astype(int).reshape(-1)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth mask\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\n# Create datasets and data loaders\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\n# Define the CNN model\nclass CosmicRayCNN(nn.Module):\n    def __init__(self):\n        super(CosmicRayCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc1 = nn.Linear(32 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 256 * 256)  # Change output to match pixel count\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = F.relu(self.fc1(x))\n        x = self.fc2(x)\n        return torch.sigmoid(x).view(-1, 1, 256, 256)  # Reshape to [B, 1, 256, 256]\n\n\n# Training the model\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nmodel = CosmicRayCNN().to(device)\ncriterion = nn.BCELoss(reduction=\"none\")\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\nfor epoch in range(5):  # Train for a few epochs\n    model.train()\n    for images, targets, masks in train_loader:\n        images, targets, masks = images.to(device), targets.to(device), masks.to(device)\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, targets)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        images = images.to(device)\n        outputs = model(images)\n        pred_probs.append(outputs.cpu().numpy())\n\npred_probs = np.concatenate(pred_probs)\n\n\n# Calculate masked AUROC\ndef masked_auroc(pred_probs, val_data):\n    y = val_data[:, 1]  # (N,H,W)\n    m = val_data[:, 2]  # (N,H,W)\n    valid = m == 0\n    t = y[valid].ravel()\n    p = pred_probs[valid].ravel()\n    if np.unique(t).size < 2:\n        return np.nan\n    return roc_auc_score(t, p)\n\n\nauroc_score = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {auroc_score}\")\n\n# Save predictions for submission\nsubmission = pred_probs.reshape(-1, 256 * 256)\nnp.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, Dataset\nfrom sklearn.metrics import roc_auc_score\nimport torch.nn.functional as F  # Importing functional module\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        return (\n            torch.tensor(self.data[idx, 0:1, :, :], dtype=torch.float32),\n            torch.tensor(self.data[idx, 1:2, :, :], dtype=torch.float32),\n            torch.tensor(self.data[idx, 2:3, :, :], dtype=torch.float32),\n        )\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\n\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass SimpleCNN(nn.Module):\n    def __init__(self):\n        super(SimpleCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.pool = nn.MaxPool2d(2, 2)\n        self.fc1 = nn.Linear(32 * 64 * 64, 256)\n        self.fc2 = nn.Linear(256, 1)\n\n    def forward(self, x):\n        x = self.pool(F.relu(self.conv1(x)))\n        x = self.pool(F.relu(self.conv2(x)))\n        x = x.view(-1, 32 * 64 * 64)\n        x = F.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\n\nmodel = SimpleCNN()\ncriterion = nn.BCEWithLogitsLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nfor epoch in range(5):  # Small number of epochs for quick testing\n    model.train()\n    for images, labels, masks in train_loader:\n        optimizer.zero_grad()\n        outputs = model(images)\n        valid = (masks == 0).float()\n        loss_per_pixel = criterion(outputs, labels)\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n        loss.backward()\n        optimizer.step()\n\n# Evaluation\nmodel.eval()\npred_probs = []\nwith torch.no_grad():\n    for images, _, masks in val_loader:\n        outputs = model(images)\n        pred_probs.append(torch.sigmoid(outputs).cpu().numpy())\n\npred_probs = np.concatenate(pred_probs, axis=0).ravel()\nmasked_auroc = masked_auroc(pred_probs, val_data)\nprint(f\"Masked AUROC: {masked_auroc}\")\n\n# Save predictions to submission.csv\nsubmission = pred_probs.reshape(-1, 256, 256)\nnp.savetxt(\"./working/submission.csv\", submission.flatten(), delimiter=\",\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import roc_auc_score\nfrom torch.utils.data import DataLoader, Dataset\nfrom tqdm import tqdm\n\n# Load data\ntrain_data = np.load(\"./input/cosmic_train.npy\")\nval_data = np.load(\"./input/cosmic_val.npy\")\n\n\nclass CosmicRayDataset(Dataset):\n    def __init__(self, data):\n        self.data = data\n\n    def __len__(self):\n        return len(self.data)\n\n    def __getitem__(self, idx):\n        x = self.data[idx, 0:1, :, :].astype(np.float32)  # Image\n        y = self.data[idx, 1:2, :, :].astype(np.float32)  # Ground truth\n        m = self.data[idx, 2:3, :, :].astype(np.float32)  # Ignore mask\n        return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\n\ntrain_dataset = CosmicRayDataset(train_data)\nval_dataset = CosmicRayDataset(val_data)\ntrain_loader = DataLoader(train_dataset, batch_size=16, shuffle=True)\nval_loader = DataLoader(val_dataset, batch_size=16, shuffle=False)\n\n\nclass ImprovedCNN(nn.Module):\n    def __init__(self):\n        super(ImprovedCNN, self).__init__()\n        self.conv1 = nn.Conv2d(1, 16, kernel_size=3, padding=1)\n        self.dropout1 = nn.Dropout(p=0.3)\n        self.conv2 = nn.Conv2d(16, 32, kernel_size=3, padding=1)\n        self.dropout2 = nn.Dropout(p=0.3)\n        self.conv3 = nn.Conv2d(32, 1, kernel_size=3, padding=1)\n\n    def forward(self, x):\n        x = nn.ReLU()(self.conv1(x))\n        x = self.dropout1(x)\n        x = nn.ReLU()(self.conv2(x))\n        x = self.dropout2(x)\n        x = self.conv3(x)\n        return torch.sigmoid(x)  # Output shape [B, 1, 256, 256]\n\n\n# Function to train a model\ndef train_model(model):\n    criterion = nn.BCELoss(reduction=\"none\")\n    optimizer = optim.Adam(model.parameters(), lr=0.0005)  # Adjusted learning rate\n\n    for epoch in range(5):\n        model.train()\n        for x, y, m in tqdm(train_loader):\n            optimizer.zero_grad()\n            pred = model(x)\n            valid = (m == 0).float()\n            loss_per_pixel = criterion(pred, y)\n            loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n            loss.backward()\n            optimizer.step()\n\n\n# Train multiple models for ensembling\nnum_models = 3\nmodels = [ImprovedCNN() for _ in range(num_models)]\nfor model in models:\n    train_model(model)\n\n\n# Evaluation\ndef evaluate(models):\n    for model in models:\n        model.eval()\n\n    pred_probs = []\n    with torch.no_grad():\n        for x, y, m in val_loader:\n            preds = [model(x) for model in models]\n            avg_pred = torch.mean(torch.stack(preds), dim=0)\n            pred_probs.append(avg_pred.cpu().numpy())\n\n    if pred_probs:  # Check if there are any predictions collected\n        pred_probs = np.concatenate(pred_probs, axis=0).ravel()\n        y_true = val_data[:, 1].ravel()\n        m_mask = val_data[:, 2].ravel() == 0\n        masked_auroc = roc_auc_score(y_true[m_mask], pred_probs[m_mask])\n\n        # Save predictions\n        submission = pred_probs.astype(np.float32)\n        np.savetxt(\"./working/submission.csv\", submission, delimiter=\",\")\n\n        print(f\"Masked AUROC: {masked_auroc}\")\n    else:\n        print(\"No predictions were collected.\")\n\n\nevaluate(models)\n"], "term_out": ["Traceback (most recent call last):\n  File \"runfile.py\", line 67, in <module>\n    loss_per_pixel = criterion(outputs, targets.float())\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([32, 1, 256, 256])) must be the same as input size (torch.Size([32, 1]))\nExecution time: 4 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 61, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 44, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 61, in <module>\n    loss_per_pixel = criterion(pred, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 64, 64])) is deprecated. Please ensure they have the same size.\nExecution time: 32 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 84, in <module>\n    train_model(model, criterion, optimizer, num_epochs=5)\n  File \"runfile.py\", line 60, in train_model\n    loss_per_pixel = criterion(outputs, targets)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 64, 64]))\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 69, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 46, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 49, in forward\n    return x.view(-1, 1, 256, 256)\nRuntimeError: shape '[-1, 1, 256, 256]' is invalid for input of size 16\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 70, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 47, in forward\n    x = self.pool(F.relu(self.conv1(x)))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nRuntimeError: Input type (double) and bias type (float) should be the same\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 64, in <module>\n    loss_per_pixel = criterion(outputs, targets)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 1, 1])) is deprecated. Please ensure they have the same size.\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 68, in <module>\n    loss_per_pixel = criterion(outputs, targets_flat)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([2097152, 1])) must be the same as input size (torch.Size([32, 1]))\nExecution time: 4 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 66, in <module>\n    loss = masked_bce_loss(pred, y, m)\n  File \"runfile.py\", line 52, in masked_bce_loss\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 64, 64]))\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<02:45,  1.45it/s]\r  1%|          | 2/242 [00:01<02:37,  1.52it/s]\r  1%|1         | 3/242 [00:01<02:36,  1.53it/s]\r  2%|1         | 4/242 [00:02<02:23,  1.66it/s]\r  2%|2         | 5/242 [00:03<02:15,  1.74it/s]\r  2%|2         | 6/242 [00:03<02:11,  1.80it/s]\r  3%|2         | 7/242 [00:04<02:08,  1.83it/s]\r  3%|3         | 8/242 [00:04<02:06,  1.85it/s]\r  4%|3         | 9/242 [00:05<02:04,  1.87it/s]\r  4%|4         | 10/242 [00:05<02:04,  1.87it/s]\r  5%|4         | 11/242 [00:06<02:35,  1.49it/s]\r  5%|4         | 12/242 [00:07<02:24,  1.59it/s]\r  5%|5         | 13/242 [00:07<02:24,  1.58it/s]\r  6%|5         | 14/242 [00:08<02:16,  1.67it/s]\r  6%|6         | 15/242 [00:08<02:11,  1.73it/s]\r  7%|6         | 16/242 [00:09<02:19,  1.62it/s]\r  7%|7         | 17/242 [00:10<02:13,  1.69it/s]\r  7%|7         | 18/242 [00:10<02:08,  1.75it/s]\r  8%|7         | 19/242 [00:11<02:04,  1.79it/s]\r  8%|8         | 20/242 [00:11<02:02,  1.82it/s]\r  9%|8         | 21/242 [00:12<02:00,  1.84it/s]\r  9%|9         | 22/242 [00:12<01:58,  1.86it/s]\r 10%|9         | 23/242 [00:13<01:57,  1.87it/s]\r 10%|9         | 24/242 [00:13<01:56,  1.88it/s]\r 10%|#         | 25/242 [00:14<01:55,  1.89it/s]\r 11%|#         | 26/242 [00:14<01:54,  1.89it/s]\r 11%|#1        | 27/242 [00:15<01:53,  1.89it/s]\r 12%|#1        | 28/242 [00:15<01:53,  1.89it/s]\r 12%|#1        | 29/242 [00:16<01:52,  1.89it/s]\r 12%|#2        | 30/242 [00:16<01:51,  1.90it/s]\r 13%|#2        | 31/242 [00:17<01:51,  1.89it/s]\r 13%|#3        | 32/242 [00:18<01:50,  1.90it/s]\r 14%|#3        | 33/242 [00:18<01:49,  1.90it/s]\r 14%|#4        | 34/242 [00:19<01:49,  1.91it/s]\r 14%|#4        | 35/242 [00:19<01:48,  1.91it/s]\r 15%|#4        | 36/242 [00:20<01:47,  1.91it/s]\r 15%|#5        | 37/242 [00:20<01:47,  1.91it/s]\r 16%|#5        | 38/242 [00:21<01:46,  1.91it/s]\r 16%|#6        | 39/242 [00:21<01:46,  1.91it/s]\r 17%|#6        | 40/242 [00:22<01:45,  1.91it/s]\r 17%|#6        | 41/242 [00:22<01:45,  1.91it/s]\r 17%|#7        | 42/242 [00:23<01:44,  1.91it/s]\r 18%|#7        | 43/242 [00:23<01:44,  1.91it/s]\r 18%|#8        | 44/242 [00:24<01:43,  1.91it/s]\r 19%|#8        | 45/242 [00:24<01:42,  1.91it/s]\r 19%|#9        | 46/242 [00:25<01:42,  1.92it/s]\r 19%|#9        | 47/242 [00:25<01:41,  1.92it/s]\r 20%|#9        | 48/242 [00:26<01:40,  1.92it/s]\r 20%|##        | 49/242 [00:26<01:40,  1.92it/s]\r 21%|##        | 50/242 [00:27<01:39,  1.92it/s]\r 21%|##1       | 5\n ... [55673 characters truncated] ... \n#####2 | 199/242 [01:44<00:22,  1.92it/s]\r 83%|########2 | 200/242 [01:44<00:21,  1.92it/s]\r 83%|########3 | 201/242 [01:45<00:21,  1.92it/s]\r 83%|########3 | 202/242 [01:45<00:20,  1.92it/s]\r 84%|########3 | 203/242 [01:46<00:20,  1.92it/s]\r 84%|########4 | 204/242 [01:46<00:19,  1.93it/s]\r 85%|########4 | 205/242 [01:47<00:19,  1.92it/s]\r 85%|########5 | 206/242 [01:47<00:18,  1.92it/s]\r 86%|########5 | 207/242 [01:48<00:18,  1.92it/s]\r 86%|########5 | 208/242 [01:48<00:17,  1.92it/s]\r 86%|########6 | 209/242 [01:49<00:17,  1.92it/s]\r 87%|########6 | 210/242 [01:49<00:16,  1.91it/s]\r 87%|########7 | 211/242 [01:50<00:16,  1.91it/s]\r 88%|########7 | 212/242 [01:50<00:15,  1.91it/s]\r 88%|########8 | 213/242 [01:51<00:15,  1.91it/s]\r 88%|########8 | 214/242 [01:51<00:14,  1.91it/s]\r 89%|########8 | 215/242 [01:52<00:14,  1.91it/s]\r 89%|########9 | 216/242 [01:52<00:13,  1.92it/s]\r 90%|########9 | 217/242 [01:53<00:13,  1.92it/s]\r 90%|######### | 218/242 [01:53<00:12,  1.92it/s]\r 90%|######### | 219/242 [01:54<00:12,  1.91it/s]\r 91%|######### | 220/242 [01:55<00:11,  1.91it/s]\r 91%|#########1| 221/242 [01:55<00:10,  1.92it/s]\r 92%|#########1| 222/242 [01:56<00:10,  1.92it/s]\r 92%|#########2| 223/242 [01:56<00:09,  1.92it/s]\r 93%|#########2| 224/242 [01:57<00:09,  1.92it/s]\r 93%|#########2| 225/242 [01:57<00:08,  1.92it/s]\r 93%|#########3| 226/242 [01:58<00:08,  1.92it/s]\r 94%|#########3| 227/242 [01:58<00:07,  1.92it/s]\r 94%|#########4| 228/242 [01:59<00:07,  1.92it/s]\r 95%|#########4| 229/242 [01:59<00:06,  1.92it/s]\r 95%|#########5| 230/242 [02:00<00:06,  1.92it/s]\r 95%|#########5| 231/242 [02:00<00:05,  1.92it/s]\r 96%|#########5| 232/242 [02:01<00:05,  1.92it/s]\r 96%|#########6| 233/242 [02:01<00:04,  1.92it/s]\r 97%|#########6| 234/242 [02:02<00:04,  1.92it/s]\r 97%|#########7| 235/242 [02:02<00:03,  1.92it/s]\r 98%|#########7| 236/242 [02:03<00:03,  1.92it/s]\r 98%|#########7| 237/242 [02:03<00:02,  1.92it/s]\r 98%|#########8| 238/242 [02:04<00:02,  1.92it/s]\r 99%|#########8| 239/242 [02:04<00:01,  1.91it/s]\r 99%|#########9| 240/242 [02:05<00:01,  1.91it/s]\r100%|#########9| 241/242 [02:05<00:00,  1.91it/s]\r100%|##########| 242/242 [02:06<00:00,  2.24it/s]\r100%|##########| 242/242 [02:06<00:00,  1.92it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 79, in <module>\n    submission = np.concatenate(pred_probs).astype(np.float32)\nValueError: zero-dimensional arrays cannot be concatenated\nExecution time: 12 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 86, in <module>\n    train_model(model, criterion, optimizer, num_epochs=5)\n  File \"runfile.py\", line 62, in train_model\n    loss_per_pixel = criterion(outputs, targets)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 64, 64]))\nExecution time: 7 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 45, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 87, in <module>\n    masked_auc = masked_auroc(pred_probs, val_data)\nNameError: name 'masked_auroc' is not defined\nExecution time: 10 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 97, in <module>\n    auroc_score = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 91, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 4 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 59, in <module>\n    outputs = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 44, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 5 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 58, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 43, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 12 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 48, in forward\n    x = nn.functional.relu(self.fc1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/linear.py\", line 125, in forward\n    return F.linear(input, self.weight, self.bias)\nRuntimeError: mat1 and mat2 shapes cannot be multiplied (16x262144 and 65536x256)\nExecution time: 7 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 100, in <module>\n    auroc_score = train_model(train_data, val_data)\n  File \"runfile.py\", line 82, in train_model\n    loss = masked_bce_loss(outputs, y, m)\n  File \"runfile.py\", line 49, in masked_bce_loss\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([32, 1, 256, 256])) must be the same as input size (torch.Size([32, 1, 64, 64]))\nExecution time: 21 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 90, in <module>\n    train_model(model, train_loader, optimizer)\n  File \"runfile.py\", line 62, in train_model\n    loss = masked_bce_with_logits(outputs, targets, masks)\n  File \"runfile.py\", line 52, in masked_bce_with_logits\n    loss_per_pixel = nn.BCEWithLogitsLoss(reduction=\"none\")(pred, target)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 64, 64]))\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 64, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 45, in forward\n    x = self.pool(F.relu(self.conv1(x)))\nNameError: name 'F' is not defined\nExecution time: 10 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 97, in <module>\n    auroc_score = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 90, in masked_auroc\n    t = y[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 0; dimension is 966 but corresponding boolean dimension is 63307776\nExecution time: 4 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 65, in <module>\n    outputs = model(images)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 51, in forward\n    return torch.sigmoid(x).view(-1, 1, 256, 256)\nRuntimeError: shape '[-1, 1, 256, 256]' is invalid for input of size 16\nExecution time: 4 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 61, in <module>\n    loss_per_pixel = criterion(outputs, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 64, 64])) is deprecated. Please ensure they have the same size.\nExecution time: 5 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    for x, y, m in train_loader:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 38, in __getitem__\n    x = self.data[idx, 0:1, :, :].float()  # Image\nAttributeError: 'numpy.ndarray' object has no attribute 'float'. Did you mean: 'flat'?\nExecution time: 5 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 61, in <module>\n    loss_per_pixel = criterion(pred, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 64, 64])) is deprecated. Please ensure they have the same size.\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 65, in <module>\n    loss_per_pixel = criterion(outputs, targets)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 64, 64]))\nExecution time: 5 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<03:01,  1.33it/s]\r  1%|          | 2/242 [00:01<02:49,  1.42it/s]\r  1%|1         | 3/242 [00:02<02:51,  1.39it/s]\r  2%|1         | 4/242 [00:02<02:43,  1.46it/s]\r  2%|2         | 5/242 [00:03<02:37,  1.50it/s]\r  2%|2         | 6/242 [00:03<02:26,  1.61it/s]\r  3%|2         | 7/242 [00:04<02:19,  1.69it/s]\r  3%|3         | 8/242 [00:05<02:14,  1.74it/s]\r  4%|3         | 9/242 [00:05<02:10,  1.78it/s]\r  4%|4         | 10/242 [00:06<02:08,  1.80it/s]\r  5%|4         | 11/242 [00:07<02:38,  1.46it/s]\r  5%|4         | 12/242 [00:07<02:26,  1.57it/s]\r  5%|5         | 13/242 [00:08<02:26,  1.56it/s]\r  6%|5         | 14/242 [00:08<02:18,  1.65it/s]\r  6%|6         | 15/242 [00:09<02:13,  1.71it/s]\r  7%|6         | 16/242 [00:10<02:19,  1.62it/s]\r  7%|7         | 17/242 [00:10<02:12,  1.69it/s]\r  7%|7         | 18/242 [00:11<02:08,  1.75it/s]\r  8%|7         | 19/242 [00:11<02:04,  1.79it/s]\r  8%|8         | 20/242 [00:12<02:02,  1.82it/s]\r  9%|8         | 21/242 [00:12<02:00,  1.84it/s]\r  9%|9         | 22/242 [00:13<01:58,  1.86it/s]\r 10%|9         | 23/242 [00:13<01:56,  1.87it/s]\r 10%|9         | 24/242 [00:14<01:56,  1.88it/s]\r 10%|#         | 25/242 [00:14<01:54,  1.89it/s]\r 11%|#         | 26/242 [00:15<01:54,  1.89it/s]\r 11%|#1        | 27/242 [00:15<01:53,  1.89it/s]\r 12%|#1        | 28/242 [00:16<01:53,  1.89it/s]\r 12%|#1        | 29/242 [00:16<01:52,  1.89it/s]\r 12%|#2        | 30/242 [00:17<01:51,  1.90it/s]\r 13%|#2        | 31/242 [00:17<01:50,  1.90it/s]\r 13%|#3        | 32/242 [00:18<01:50,  1.90it/s]\r 14%|#3        | 33/242 [00:18<01:49,  1.90it/s]\r 14%|#4        | 34/242 [00:19<01:49,  1.91it/s]\r 14%|#4        | 35/242 [00:20<01:48,  1.90it/s]\r 15%|#4        | 36/242 [00:20<01:48,  1.90it/s]\r 15%|#5        | 37/242 [00:21<01:47,  1.90it/s]\r 16%|#5        | 38/242 [00:21<01:47,  1.90it/s]\r 16%|#6        | 39/242 [00:22<01:46,  1.90it/s]\r 17%|#6        | 40/242 [00:22<01:46,  1.90it/s]\r 17%|#6        | 41/242 [00:23<01:45,  1.90it/s]\r 17%|#7        | 42/242 [00:23<01:45,  1.90it/s]\r 18%|#7        | 43/242 [00:24<01:44,  1.90it/s]\r 18%|#8        | 44/242 [00:24<01:44,  1.90it/s]\r 19%|#8        | 45/242 [00:25<01:43,  1.91it/s]\r 19%|#9        | 46/242 [00:25<01:43,  1.90it/s]\r 19%|#9        | 47/242 [00:26<01:42,  1.91it/s]\r 20%|#9        | 48/242 [00:26<01:41,  1.91it/s]\r 20%|##        | 49/242 [00:27<01:41,  1.91it/s]\r 21%|##        | 50/242 [00:27<01:40,  1.91it/s]\r 21%|##1       | 5\n ... [55507 characters truncated] ... \n90it/s]\r 81%|########  | 196/242 [01:43<00:24,  1.90it/s]\r 81%|########1 | 197/242 [01:43<00:23,  1.90it/s]\r 82%|########1 | 198/242 [01:44<00:23,  1.90it/s]\r 82%|########2 | 199/242 [01:44<00:22,  1.90it/s]\r 83%|########2 | 200/242 [01:45<00:22,  1.90it/s]\r 83%|########3 | 201/242 [01:45<00:21,  1.90it/s]\r 83%|########3 | 202/242 [01:46<00:21,  1.90it/s]\r 84%|########3 | 203/242 [01:46<00:20,  1.90it/s]\r 84%|########4 | 204/242 [01:47<00:19,  1.91it/s]\r 85%|########4 | 205/242 [01:47<00:19,  1.91it/s]\r 85%|########5 | 206/242 [01:48<00:18,  1.91it/s]\r 86%|########5 | 207/242 [01:48<00:18,  1.91it/s]\r 86%|########5 | 208/242 [01:49<00:17,  1.91it/s]\r 86%|########6 | 209/242 [01:49<00:17,  1.91it/s]\r 87%|########6 | 210/242 [01:50<00:16,  1.91it/s]\r 87%|########7 | 211/242 [01:50<00:16,  1.91it/s]\r 88%|########7 | 212/242 [01:51<00:15,  1.91it/s]\r 88%|########8 | 213/242 [01:52<00:15,  1.91it/s]\r 88%|########8 | 214/242 [01:52<00:14,  1.91it/s]\r 89%|########8 | 215/242 [01:53<00:14,  1.91it/s]\r 89%|########9 | 216/242 [01:53<00:13,  1.91it/s]\r 90%|########9 | 217/242 [01:54<00:13,  1.91it/s]\r 90%|######### | 218/242 [01:54<00:12,  1.91it/s]\r 90%|######### | 219/242 [01:55<00:12,  1.91it/s]\r 91%|######### | 220/242 [01:55<00:11,  1.92it/s]\r 91%|#########1| 221/242 [01:56<00:10,  1.92it/s]\r 92%|#########1| 222/242 [01:56<00:10,  1.92it/s]\r 92%|#########2| 223/242 [01:57<00:09,  1.92it/s]\r 93%|#########2| 224/242 [01:57<00:09,  1.92it/s]\r 93%|#########2| 225/242 [01:58<00:08,  1.92it/s]\r 93%|#########3| 226/242 [01:58<00:08,  1.92it/s]\r 94%|#########3| 227/242 [01:59<00:07,  1.92it/s]\r 94%|#########4| 228/242 [01:59<00:07,  1.91it/s]\r 95%|#########4| 229/242 [02:00<00:06,  1.91it/s]\r 95%|#########5| 230/242 [02:00<00:06,  1.91it/s]\r 95%|#########5| 231/242 [02:01<00:05,  1.91it/s]\r 96%|#########5| 232/242 [02:01<00:05,  1.91it/s]\r 96%|#########6| 233/242 [02:02<00:04,  1.91it/s]\r 97%|#########6| 234/242 [02:03<00:04,  1.90it/s]\r 97%|#########7| 235/242 [02:03<00:03,  1.90it/s]\r 98%|#########7| 236/242 [02:04<00:03,  1.90it/s]\r 98%|#########7| 237/242 [02:04<00:02,  1.90it/s]\r 98%|#########8| 238/242 [02:05<00:02,  1.90it/s]\r 99%|#########8| 239/242 [02:05<00:01,  1.90it/s]\r 99%|#########9| 240/242 [02:06<00:01,  1.90it/s]\r100%|#########9| 241/242 [02:06<00:00,  1.90it/s]\r100%|##########| 242/242 [02:06<00:00,  2.22it/s]\r100%|##########| 242/242 [02:06<00:00,  1.91it/s]\nMasked AUROC: 0.9742498466583813\nExecution time: 13 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:04<18:06,  4.51s/it]\r  1%|          | 2/242 [00:08<16:48,  4.20s/it]\r  1%|1         | 3/242 [00:12<16:22,  4.11s/it]\r  2%|1         | 4/242 [00:16<16:10,  4.08s/it]\r  2%|2         | 5/242 [00:20<16:02,  4.06s/it]\r  2%|2         | 6/242 [00:24<15:57,  4.06s/it]\r  3%|2         | 7/242 [00:29<16:38,  4.25s/it]\r  3%|3         | 8/242 [00:36<19:41,  5.05s/it]\r  4%|3         | 9/242 [00:40<19:23,  4.99s/it]\r  4%|4         | 10/242 [00:47<21:35,  5.59s/it]\r  5%|4         | 11/242 [00:52<20:54,  5.43s/it]\r  5%|4         | 12/242 [00:58<21:37,  5.64s/it]\r  5%|5         | 13/242 [01:04<21:08,  5.54s/it]\r  6%|5         | 14/242 [01:11<22:27,  5.91s/it]\r  6%|6         | 15/242 [01:17<23:18,  6.16s/it]\r  7%|6         | 16/242 [01:24<24:14,  6.44s/it]\r  7%|7         | 17/242 [01:32<25:01,  6.67s/it]\r  7%|7         | 18/242 [01:41<27:37,  7.40s/it]\r  8%|7         | 19/242 [01:51<30:28,  8.20s/it]\r  8%|8         | 20/242 [02:02<33:38,  9.09s/it]\r  9%|8         | 21/242 [02:12<34:17,  9.31s/it]\r  9%|9         | 22/242 [02:18<31:04,  8.47s/it]\r 10%|9         | 23/242 [02:27<31:01,  8.50s/it]\r 10%|9         | 24/242 [02:35<30:49,  8.49s/it]\r 10%|#         | 25/242 [02:44<30:46,  8.51s/it]\r 11%|#         | 26/242 [02:51<29:23,  8.16s/it]\r 11%|#1        | 27/242 [02:59<28:20,  7.91s/it]\r 12%|#1        | 28/242 [03:06<28:00,  7.85s/it]\r 12%|#1        | 29/242 [03:17<30:49,  8.68s/it]\r 12%|#2        | 30/242 [03:25<29:40,  8.40s/it]\r 13%|#2        | 31/242 [03:34<30:27,  8.66s/it]\r 13%|#3        | 32/242 [03:43<30:24,  8.69s/it]\r 14%|#3        | 33/242 [03:51<30:22,  8.72s/it]\r 14%|#4        | 34/242 [04:01<31:33,  9.10s/it]\r 14%|#4        | 35/242 [04:11<32:02,  9.29s/it]\r 15%|#4        | 36/242 [04:19<30:30,  8.88s/it]\r 15%|#5        | 37/242 [04:29<31:50,  9.32s/it]\r 16%|#5        | 38/242 [04:41<34:11, 10.06s/it]\r 16%|#6        | 39/242 [04:52<34:23, 10.16s/it]\r 17%|#6        | 40/242 [05:02<34:16, 10.18s/it]\r 17%|#6        | 41/242 [05:13<35:08, 10.49s/it]\r 17%|#7        | 42/242 [05:22<33:48, 10.14s/it]\r 18%|#7        | 43/242 [05:31<31:59,  9.64s/it]\r 18%|#8        | 44/242 [05:43<34:01, 10.31s/it]\r 19%|#8        | 45/242 [05:50<31:10,  9.49s/it]\r 19%|#9        | 46/242 [05:59<30:40,  9.39s/it]\r 19%|#9        | 47/242 [06:11<32:56, 10.13s/it]\r 20%|#9        | 48/242 [06:22<33:25, 10.34s/it]\r 20%|##        | 49/242 [06:33<34:01, 10.58s/it]\r 21%|##        | 50/242 [06:44<33:57, 10.61s/it]\r 21%|##1       | 5\n ... [21460 characters truncated] ... \ns/it]\r 99%|#########9| 240/242 [21:21<00:08,  4.30s/it]\r100%|#########9| 241/242 [21:25<00:04,  4.27s/it]\r100%|##########| 242/242 [21:27<00:00,  3.61s/it]\r100%|##########| 242/242 [21:27<00:00,  5.32s/it]\n\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:04<17:05,  4.25s/it]\r  1%|          | 2/242 [00:08<17:58,  4.49s/it]\r  1%|1         | 3/242 [00:13<18:00,  4.52s/it]\r  2%|1         | 4/242 [00:17<17:27,  4.40s/it]\r  2%|2         | 5/242 [00:21<17:13,  4.36s/it]\r  2%|2         | 6/242 [00:26<16:49,  4.28s/it]\r  3%|2         | 7/242 [00:30<16:49,  4.29s/it]\r  3%|3         | 8/242 [00:34<16:38,  4.27s/it]\r  4%|3         | 9/242 [00:39<16:45,  4.31s/it]\r  4%|4         | 10/242 [00:43<16:36,  4.29s/it]\r  5%|4         | 11/242 [00:47<16:19,  4.24s/it]\r  5%|4         | 12/242 [00:51<16:14,  4.24s/it]\r  5%|5         | 13/242 [00:55<16:12,  4.25s/it]\r  6%|5         | 14/242 [01:00<16:01,  4.22s/it]\r  6%|6         | 15/242 [01:04<15:51,  4.19s/it]\r  7%|6         | 16/242 [01:08<16:16,  4.32s/it]\r  7%|7         | 17/242 [01:12<15:58,  4.26s/it]\r  7%|7         | 18/242 [01:17<16:11,  4.34s/it]\r  8%|7         | 19/242 [01:21<15:59,  4.30s/it]\r  8%|8         | 20/242 [01:25<15:43,  4.25s/it]\r  9%|8         | 21/242 [01:30<16:13,  4.40s/it]\r  9%|9         | 22/242 [01:34<15:59,  4.36s/it]\r 10%|9         | 23/242 [01:38<15:38,  4.29s/it]\r 10%|9         | 24/242 [01:43<15:23,  4.24s/it]\r 10%|#         | 25/242 [01:47<15:38,  4.33s/it]\r 11%|#         | 26/242 [01:51<15:26,  4.29s/it]\r 11%|#1        | 27/242 [01:55<15:12,  4.24s/it]\r 12%|#1        | 28/242 [02:00<14:59,  4.20s/it]\r 12%|#1        | 29/242 [02:04<15:13,  4.29s/it]\r 12%|#2        | 30/242 [02:09<15:38,  4.43s/it]\r 13%|#2        | 31/242 [02:14<16:10,  4.60s/it]\r 13%|#3        | 32/242 [02:18<16:04,  4.59s/it]\r 14%|#3        | 33/242 [02:23<16:03,  4.61s/it]\r 14%|#4        | 34/242 [02:27<15:27,  4.46s/it]\r 14%|#4        | 35/242 [02:32<15:18,  4.44s/it]\r 15%|#4        | 36/242 [02:36<14:53,  4.34s/it]\r 15%|#5        | 37/242 [02:40<14:42,  4.31s/it]\r 16%|#5        | 38/242 [02:44<14:29,  4.26s/it]\r 16%|#6        | 39/242 [02:48<14:17,  4.23s/it]\r 17%|#6        | 40/242 [02:53<15:05,  4.48s/it]\r 17%|#6        | 41/242 [02:58<15:17,  4.56s/it]\r 17%|#7        | 42/242 [03:02<14:44,  4.42s/it]\r 18%|#7        | 43/242 [03:06<14:20,  4.33s/it]\r 18%|#8        | 44/242 [03:11<14:49,  4.49s/it]\r 18%|#8        | 44/242 [03:16<14:43,  4.46s/it]TimeoutError: Execution exceeded the time limit of an hour", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:04<17:49,  4.44s/it]\r  1%|          | 2/242 [00:08<17:00,  4.25s/it]\r  1%|1         | 3/242 [00:12<16:44,  4.20s/it]\r  2%|1         | 4/242 [00:16<16:37,  4.19s/it]\r  2%|2         | 5/242 [00:21<16:32,  4.19s/it]\r  2%|2         | 6/242 [00:25<16:28,  4.19s/it]\r  3%|2         | 7/242 [00:30<17:24,  4.44s/it]\r  3%|3         | 8/242 [00:37<20:22,  5.22s/it]\r  4%|3         | 9/242 [00:42<20:02,  5.16s/it]\r  4%|4         | 10/242 [00:49<22:12,  5.74s/it]\r  5%|4         | 11/242 [00:54<21:25,  5.57s/it]\r  5%|4         | 12/242 [01:00<21:58,  5.73s/it]\r  5%|5         | 13/242 [01:05<21:24,  5.61s/it]\r  6%|5         | 14/242 [01:12<22:29,  5.92s/it]\r  6%|6         | 15/242 [01:19<23:15,  6.15s/it]\r  7%|6         | 16/242 [01:26<24:12,  6.43s/it]\r  7%|7         | 17/242 [01:33<25:07,  6.70s/it]\r  7%|7         | 18/242 [01:42<27:41,  7.42s/it]\r  8%|7         | 19/242 [01:52<30:38,  8.24s/it]\r  8%|8         | 20/242 [02:03<33:24,  9.03s/it]\r  9%|8         | 21/242 [02:13<34:13,  9.29s/it]\r  9%|9         | 22/242 [02:20<31:01,  8.46s/it]\r 10%|9         | 23/242 [02:28<30:52,  8.46s/it]\r 10%|9         | 24/242 [02:36<30:35,  8.42s/it]\r 10%|#         | 25/242 [02:45<30:19,  8.39s/it]\r 11%|#         | 26/242 [02:52<29:13,  8.12s/it]\r 11%|#1        | 27/242 [02:59<28:13,  7.88s/it]\r 12%|#1        | 28/242 [03:07<27:54,  7.83s/it]\r 12%|#1        | 29/242 [03:18<30:45,  8.67s/it]\r 12%|#2        | 30/242 [03:26<29:38,  8.39s/it]\r 13%|#2        | 31/242 [03:35<30:25,  8.65s/it]\r 13%|#3        | 32/242 [03:44<30:22,  8.68s/it]\r 14%|#3        | 33/242 [03:52<30:20,  8.71s/it]\r 14%|#4        | 34/242 [04:02<31:31,  9.09s/it]\r 14%|#4        | 35/242 [04:12<32:02,  9.29s/it]\r 15%|#4        | 36/242 [04:20<30:30,  8.89s/it]\r 15%|#5        | 37/242 [04:30<31:53,  9.33s/it]\r 16%|#5        | 38/242 [04:42<34:13, 10.07s/it]\r 16%|#6        | 39/242 [04:53<34:43, 10.26s/it]\r 17%|#6        | 40/242 [05:03<34:36, 10.28s/it]\r 17%|#6        | 41/242 [05:14<35:01, 10.46s/it]\r 17%|#7        | 42/242 [05:24<33:54, 10.17s/it]\r 18%|#7        | 43/242 [05:32<31:56,  9.63s/it]\r 18%|#8        | 44/242 [05:44<34:23, 10.42s/it]\r 19%|#8        | 45/242 [05:52<31:10,  9.50s/it]\r 19%|#9        | 46/242 [06:01<30:47,  9.43s/it]\r 19%|#9        | 47/242 [06:13<32:58, 10.15s/it]\r 20%|#9        | 48/242 [06:23<33:16, 10.29s/it]\r 20%|##        | 49/242 [06:34<33:48, 10.51s/it]\r 21%|##        | 50/242 [06:46<34:20, 10.73s/it]\r 21%|##1       | 5\n ... [22565 characters truncated] ... \n30,  4.15s/it]\r  8%|7         | 19/242 [01:18<15:23,  4.14s/it]\r  8%|8         | 20/242 [01:22<15:19,  4.14s/it]\r  9%|8         | 21/242 [01:27<15:59,  4.34s/it]\r  9%|9         | 22/242 [01:31<15:51,  4.32s/it]\r 10%|9         | 23/242 [01:35<15:33,  4.26s/it]\r 10%|9         | 24/242 [01:40<15:20,  4.22s/it]\r 10%|#         | 25/242 [01:44<15:37,  4.32s/it]\r 11%|#         | 26/242 [01:48<15:26,  4.29s/it]\r 11%|#1        | 27/242 [01:53<15:14,  4.25s/it]\r 12%|#1        | 28/242 [01:57<15:03,  4.22s/it]\r 12%|#1        | 29/242 [02:01<15:18,  4.31s/it]\r 12%|#2        | 30/242 [02:06<15:43,  4.45s/it]\r 13%|#2        | 31/242 [02:11<16:16,  4.63s/it]\r 13%|#3        | 32/242 [02:16<16:10,  4.62s/it]\r 14%|#3        | 33/242 [02:20<16:00,  4.60s/it]\r 14%|#4        | 34/242 [02:24<15:27,  4.46s/it]\r 14%|#4        | 35/242 [02:29<15:19,  4.44s/it]\r 15%|#4        | 36/242 [02:33<14:56,  4.35s/it]\r 15%|#5        | 37/242 [02:37<14:48,  4.33s/it]\r 16%|#5        | 38/242 [02:41<14:35,  4.29s/it]\r 16%|#6        | 39/242 [02:45<14:23,  4.25s/it]\r 17%|#6        | 40/242 [02:51<15:13,  4.52s/it]\r 17%|#6        | 41/242 [02:56<15:31,  4.63s/it]\r 17%|#7        | 42/242 [03:00<14:53,  4.47s/it]\r 17%|#7        | 42/242 [03:01<14:24,  4.32s/it]\nTraceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 49, in forward\n    x = self.conv4(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nKeyboardInterrupt\nTimeoutError: Execution exceeded the time limit of an hour", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 48, in forward\n    x = nn.functional.relu(self.fc1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/linear.py\", line 125, in forward\n    return F.linear(input, self.weight, self.bias)\nRuntimeError: mat1 and mat2 shapes cannot be multiplied (16x262144 and 65536x256)\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 103, in <module>\n    auroc_score = train_model(train_data, val_data)\n  File \"runfile.py\", line 99, in train_model\n    return masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 63, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 38 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<02:41,  1.50it/s]\r  1%|          | 2/242 [00:01<02:35,  1.54it/s]\r  1%|1         | 3/242 [00:02<02:51,  1.39it/s]\r  2%|1         | 4/242 [00:02<02:41,  1.48it/s]\r  2%|2         | 5/242 [00:03<02:27,  1.60it/s]\r  2%|2         | 6/242 [00:03<02:18,  1.70it/s]\r  3%|2         | 7/242 [00:04<02:12,  1.77it/s]\r  3%|3         | 8/242 [00:04<02:09,  1.80it/s]\r  4%|3         | 9/242 [00:05<02:06,  1.84it/s]\r  4%|4         | 10/242 [00:05<02:05,  1.85it/s]\r  5%|4         | 11/242 [00:06<02:35,  1.48it/s]\r  5%|4         | 12/242 [00:07<02:24,  1.59it/s]\r  5%|5         | 13/242 [00:07<02:23,  1.59it/s]\r  6%|5         | 14/242 [00:08<02:15,  1.68it/s]\r  6%|6         | 15/242 [00:09<02:10,  1.74it/s]\r  7%|6         | 16/242 [00:09<02:19,  1.63it/s]\r  7%|7         | 17/242 [00:10<02:12,  1.70it/s]\r  7%|7         | 18/242 [00:10<02:06,  1.77it/s]\r  8%|7         | 19/242 [00:11<02:03,  1.81it/s]\r  8%|8         | 20/242 [00:11<02:00,  1.84it/s]\r  9%|8         | 21/242 [00:12<01:58,  1.87it/s]\r  9%|9         | 22/242 [00:12<01:56,  1.89it/s]\r 10%|9         | 23/242 [00:13<01:55,  1.90it/s]\r 10%|9         | 24/242 [00:13<01:54,  1.90it/s]\r 10%|#         | 25/242 [00:14<01:53,  1.91it/s]\r 11%|#         | 26/242 [00:14<01:53,  1.91it/s]\r 11%|#1        | 27/242 [00:15<01:52,  1.91it/s]\r 12%|#1        | 28/242 [00:15<01:51,  1.91it/s]\r 12%|#1        | 29/242 [00:16<01:50,  1.92it/s]\r 12%|#2        | 30/242 [00:17<01:50,  1.92it/s]\r 13%|#2        | 31/242 [00:17<01:49,  1.93it/s]\r 13%|#3        | 32/242 [00:18<01:48,  1.93it/s]\r 14%|#3        | 33/242 [00:18<01:48,  1.93it/s]\r 14%|#4        | 34/242 [00:19<01:47,  1.93it/s]\r 14%|#4        | 35/242 [00:19<01:47,  1.93it/s]\r 15%|#4        | 36/242 [00:20<01:46,  1.93it/s]\r 15%|#5        | 37/242 [00:20<01:46,  1.93it/s]\r 16%|#5        | 38/242 [00:21<01:45,  1.93it/s]\r 16%|#6        | 39/242 [00:21<01:45,  1.93it/s]\r 17%|#6        | 40/242 [00:22<01:44,  1.93it/s]\r 17%|#6        | 41/242 [00:22<01:44,  1.93it/s]\r 17%|#7        | 42/242 [00:23<01:43,  1.93it/s]\r 18%|#7        | 43/242 [00:23<01:43,  1.93it/s]\r 18%|#8        | 44/242 [00:24<01:42,  1.93it/s]\r 19%|#8        | 45/242 [00:24<01:41,  1.93it/s]\r 19%|#9        | 46/242 [00:25<01:41,  1.94it/s]\r 19%|#9        | 47/242 [00:25<01:40,  1.94it/s]\r 20%|#9        | 48/242 [00:26<01:40,  1.94it/s]\r 20%|##        | 49/242 [00:26<01:39,  1.93it/s]\r 21%|##        | 50/242 [00:27<01:39,  1.93it/s]\r 21%|##1       | 5\n ... [55507 characters truncated] ... \n36it/s]\r 81%|########  | 196/242 [03:14<00:36,  1.25it/s]\r 81%|########1 | 197/242 [03:15<00:41,  1.10it/s]\r 82%|########1 | 198/242 [03:17<00:42,  1.04it/s]\r 82%|########2 | 199/242 [03:18<00:50,  1.17s/it]\r 83%|########2 | 200/242 [03:20<00:56,  1.34s/it]\r 83%|########3 | 201/242 [03:21<00:49,  1.21s/it]\r 83%|########3 | 202/242 [03:21<00:41,  1.03s/it]\r 84%|########3 | 203/242 [03:22<00:35,  1.11it/s]\r 84%|########4 | 204/242 [03:23<00:31,  1.22it/s]\r 85%|########4 | 205/242 [03:23<00:27,  1.33it/s]\r 85%|########5 | 206/242 [03:24<00:32,  1.11it/s]\r 86%|########5 | 207/242 [03:25<00:27,  1.25it/s]\r 86%|########5 | 208/242 [03:26<00:26,  1.27it/s]\r 86%|########6 | 209/242 [03:27<00:26,  1.24it/s]\r 87%|########6 | 210/242 [03:27<00:23,  1.36it/s]\r 87%|########7 | 211/242 [03:28<00:27,  1.13it/s]\r 88%|########7 | 212/242 [03:30<00:33,  1.12s/it]\r 88%|########8 | 213/242 [03:31<00:28,  1.00it/s]\r 88%|########8 | 214/242 [03:32<00:33,  1.20s/it]\r 89%|########8 | 215/242 [03:34<00:33,  1.23s/it]\r 89%|########9 | 216/242 [03:35<00:33,  1.30s/it]\r 90%|########9 | 217/242 [03:36<00:27,  1.09s/it]\r 90%|######### | 218/242 [03:37<00:23,  1.03it/s]\r 90%|######### | 219/242 [03:38<00:23,  1.04s/it]\r 91%|######### | 220/242 [03:38<00:20,  1.09it/s]\r 91%|#########1| 221/242 [03:39<00:17,  1.23it/s]\r 92%|#########1| 222/242 [03:40<00:15,  1.32it/s]\r 92%|#########2| 223/242 [03:40<00:13,  1.40it/s]\r 93%|#########2| 224/242 [03:42<00:16,  1.09it/s]\r 93%|#########2| 225/242 [03:43<00:15,  1.08it/s]\r 93%|#########3| 226/242 [03:44<00:17,  1.12s/it]\r 94%|#########3| 227/242 [03:45<00:14,  1.02it/s]\r 94%|#########4| 228/242 [03:46<00:13,  1.04it/s]\r 95%|#########4| 229/242 [03:47<00:12,  1.01it/s]\r 95%|#########5| 230/242 [03:47<00:10,  1.15it/s]\r 95%|#########5| 231/242 [03:48<00:10,  1.10it/s]\r 96%|#########5| 232/242 [03:49<00:09,  1.03it/s]\r 96%|#########6| 233/242 [03:51<00:09,  1.01s/it]\r 97%|#########6| 234/242 [03:51<00:07,  1.12it/s]\r 97%|#########7| 235/242 [03:52<00:05,  1.26it/s]\r 98%|#########7| 236/242 [03:53<00:05,  1.12it/s]\r 98%|#########7| 237/242 [03:54<00:04,  1.21it/s]\r 98%|#########8| 238/242 [03:54<00:03,  1.19it/s]\r 99%|#########8| 239/242 [03:56<00:02,  1.04it/s]\r 99%|#########9| 240/242 [03:56<00:01,  1.19it/s]\r100%|#########9| 241/242 [03:57<00:00,  1.16it/s]\r100%|##########| 242/242 [03:57<00:00,  1.45it/s]\r100%|##########| 242/242 [03:57<00:00,  1.02it/s]\nMasked AUROC: 0.9287991791057564\nExecution time: 15 minutes seconds (time limit is an hour).", "Masked AUROC: 0.8904836923811648\nExecution time: 5 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:04<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 83, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 66, in forward\n    dec3 = torch.cat((dec3, enc3), dim=1)\nRuntimeError: Sizes of tensors must match except in dimension 1. Expected size 512 but got size 256 for tensor number 1 in the list.\nExecution time: 8 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:04<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 86, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 60, in forward\n    dec3 = torch.cat((dec3, enc3), dim=1)  # Skip connection\nRuntimeError: Sizes of tensors must match except in dimension 1. Expected size 512 but got size 256 for tensor number 1 in the list.\nExecution time: 7 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 73, in <module>\n    for x, y, m in tqdm(train_loader):\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/tqdm/std.py\", line 1181, in __iter__\n    for obj in iterable:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 29, in __getitem__\n    x = self.transform(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 95, in __call__\n    img = t(img)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 234, in __call__\n    return F.to_pil_image(pic, self.mode)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/functional.py\", line 277, in to_pil_image\n    raise ValueError(f\"pic should not have > 4 channels. Got {pic.shape[-1]} channels.\")\nValueError: pic should not have > 4 channels. Got 256 channels.\nExecution time: 4 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<03:01,  1.33it/s]\r  1%|          | 2/242 [00:01<02:50,  1.41it/s]\r  1%|1         | 3/242 [00:02<02:42,  1.48it/s]\r  2%|1         | 4/242 [00:02<02:41,  1.47it/s]\r  2%|2         | 5/242 [00:03<02:35,  1.53it/s]\r  2%|2         | 6/242 [00:03<02:24,  1.64it/s]\r  3%|2         | 7/242 [00:04<02:16,  1.72it/s]\r  3%|3         | 8/242 [00:04<02:14,  1.74it/s]\r  4%|3         | 9/242 [00:05<02:10,  1.79it/s]\r  4%|4         | 10/242 [00:06<02:06,  1.83it/s]\r  5%|4         | 11/242 [00:06<02:17,  1.67it/s]\r  5%|4         | 12/242 [00:07<02:12,  1.74it/s]\r  5%|5         | 13/242 [00:07<02:09,  1.77it/s]\r  6%|5         | 14/242 [00:08<02:06,  1.81it/s]\r  6%|6         | 15/242 [00:08<02:04,  1.82it/s]\r  7%|6         | 16/242 [00:09<02:03,  1.84it/s]\r  7%|7         | 17/242 [00:09<02:00,  1.86it/s]\r  7%|7         | 18/242 [00:10<01:59,  1.87it/s]\r  8%|7         | 19/242 [00:10<01:58,  1.88it/s]\r  8%|8         | 20/242 [00:11<01:57,  1.89it/s]\r  9%|8         | 21/242 [00:12<01:56,  1.90it/s]\r  9%|9         | 22/242 [00:12<01:56,  1.89it/s]\r 10%|9         | 23/242 [00:13<01:55,  1.89it/s]\r 10%|9         | 24/242 [00:13<01:54,  1.90it/s]\r 10%|#         | 25/242 [00:14<01:54,  1.90it/s]\r 11%|#         | 26/242 [00:14<01:53,  1.90it/s]\r 11%|#1        | 27/242 [00:15<01:53,  1.90it/s]\r 12%|#1        | 28/242 [00:15<01:52,  1.91it/s]\r 12%|#1        | 29/242 [00:16<01:51,  1.91it/s]\r 12%|#2        | 30/242 [00:16<01:51,  1.91it/s]\r 13%|#2        | 31/242 [00:17<01:50,  1.91it/s]\r 13%|#3        | 32/242 [00:17<01:49,  1.91it/s]\r 14%|#3        | 33/242 [00:18<01:49,  1.91it/s]\r 14%|#4        | 34/242 [00:18<01:48,  1.91it/s]\r 14%|#4        | 35/242 [00:19<01:47,  1.92it/s]\r 15%|#4        | 36/242 [00:19<01:47,  1.92it/s]\r 15%|#5        | 37/242 [00:20<01:46,  1.92it/s]\r 16%|#5        | 38/242 [00:20<01:46,  1.92it/s]\r 16%|#6        | 39/242 [00:21<01:45,  1.92it/s]\r 17%|#6        | 40/242 [00:21<01:45,  1.92it/s]\r 17%|#6        | 41/242 [00:22<01:44,  1.92it/s]\r 17%|#7        | 42/242 [00:23<01:44,  1.92it/s]\r 18%|#7        | 43/242 [00:23<01:43,  1.92it/s]\r 18%|#8        | 44/242 [00:24<01:43,  1.92it/s]\r 19%|#8        | 45/242 [00:24<01:42,  1.92it/s]\r 19%|#9        | 46/242 [00:25<01:42,  1.92it/s]\r 19%|#9        | 47/242 [00:25<01:41,  1.92it/s]\r 20%|#9        | 48/242 [00:26<01:41,  1.91it/s]\r 20%|##        | 49/242 [00:26<01:41,  1.90it/s]\r 21%|##        | 50/242 [00:27<01:40,  1.91it/s]\r 21%|##1       | 5\n ... [176337 characters truncated] ... \n90it/s]\r 81%|########  | 196/242 [01:45<00:24,  1.90it/s]\r 81%|########1 | 197/242 [01:45<00:23,  1.90it/s]\r 82%|########1 | 198/242 [01:46<00:23,  1.90it/s]\r 82%|########2 | 199/242 [01:46<00:22,  1.90it/s]\r 83%|########2 | 200/242 [01:47<00:22,  1.90it/s]\r 83%|########3 | 201/242 [01:47<00:21,  1.91it/s]\r 83%|########3 | 202/242 [01:48<00:20,  1.91it/s]\r 84%|########3 | 203/242 [01:48<00:20,  1.90it/s]\r 84%|########4 | 204/242 [01:49<00:19,  1.90it/s]\r 85%|########4 | 205/242 [01:50<00:19,  1.90it/s]\r 85%|########5 | 206/242 [01:50<00:18,  1.90it/s]\r 86%|########5 | 207/242 [01:51<00:18,  1.89it/s]\r 86%|########5 | 208/242 [01:51<00:17,  1.90it/s]\r 86%|########6 | 209/242 [01:52<00:17,  1.90it/s]\r 87%|########6 | 210/242 [01:52<00:16,  1.90it/s]\r 87%|########7 | 211/242 [01:53<00:16,  1.90it/s]\r 88%|########7 | 212/242 [01:53<00:15,  1.90it/s]\r 88%|########8 | 213/242 [01:54<00:15,  1.90it/s]\r 88%|########8 | 214/242 [01:54<00:14,  1.90it/s]\r 89%|########8 | 215/242 [01:55<00:14,  1.90it/s]\r 89%|########9 | 216/242 [01:55<00:13,  1.91it/s]\r 90%|########9 | 217/242 [01:56<00:13,  1.90it/s]\r 90%|######### | 218/242 [01:56<00:12,  1.89it/s]\r 90%|######### | 219/242 [01:57<00:12,  1.89it/s]\r 91%|######### | 220/242 [01:57<00:11,  1.89it/s]\r 91%|#########1| 221/242 [01:58<00:11,  1.90it/s]\r 92%|#########1| 222/242 [01:58<00:10,  1.90it/s]\r 92%|#########2| 223/242 [01:59<00:09,  1.90it/s]\r 93%|#########2| 224/242 [02:00<00:09,  1.91it/s]\r 93%|#########2| 225/242 [02:00<00:08,  1.91it/s]\r 93%|#########3| 226/242 [02:01<00:08,  1.90it/s]\r 94%|#########3| 227/242 [02:01<00:07,  1.90it/s]\r 94%|#########4| 228/242 [02:02<00:07,  1.90it/s]\r 95%|#########4| 229/242 [02:02<00:06,  1.90it/s]\r 95%|#########5| 230/242 [02:03<00:06,  1.90it/s]\r 95%|#########5| 231/242 [02:03<00:05,  1.84it/s]\r 96%|#########5| 232/242 [02:04<00:05,  1.86it/s]\r 96%|#########6| 233/242 [02:04<00:04,  1.87it/s]\r 97%|#########6| 234/242 [02:05<00:04,  1.88it/s]\r 97%|#########7| 235/242 [02:05<00:03,  1.88it/s]\r 98%|#########7| 236/242 [02:06<00:03,  1.89it/s]\r 98%|#########7| 237/242 [02:06<00:02,  1.89it/s]\r 98%|#########8| 238/242 [02:07<00:02,  1.90it/s]\r 99%|#########8| 239/242 [02:07<00:01,  1.89it/s]\r 99%|#########9| 240/242 [02:08<00:01,  1.90it/s]\r100%|#########9| 241/242 [02:09<00:00,  1.90it/s]\r100%|##########| 242/242 [02:09<00:00,  2.21it/s]\r100%|##########| 242/242 [02:09<00:00,  1.87it/s]\nMasked AUROC: 0.9872082052989325\nExecution time: 35 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 67, in <module>\n    loss_per_pixel = criterion(outputs, targets)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1, 128, 128]))\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 100, in <module>\n    masked_auc = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 19, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 10 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 63, in <module>\n    loss_per_pixel = criterion(pred, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 512, 512])) is deprecated. Please ensure they have the same size.\nExecution time: 3 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 67, in <module>\n    loss_per_pixel = criterion(pred, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1]))\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]runfile.py:33: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 86, in <module>\n    train_model(model)\n  File \"runfile.py\", line 74, in train_model\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 59, in forward\n    x = nn.ReLU()(self.conv1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nRuntimeError: Given groups=1, weight of size [16, 1, 3, 3], expected input[16, 256, 1, 256] to have 1 channels, but got 256 channels instead\nExecution time: 5 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 90, in <module>\n    train_model(model)\n  File \"runfile.py\", line 76, in train_model\n    for x, y, m in tqdm(train_loader):\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/tqdm/std.py\", line 1181, in __iter__\n    for obj in iterable:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 34, in __getitem__\n    torch.from_numpy(x).clone().detach(),\nTypeError: expected np.ndarray (got Tensor)\nExecution time: 5 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 93, in <module>\n    auroc_score = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 87, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 7 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]runfile.py:31: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 84, in <module>\n    train_model(model)\n  File \"runfile.py\", line 72, in train_model\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 57, in forward\n    x = nn.ReLU()(self.conv1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nRuntimeError: Given groups=1, weight of size [16, 1, 3, 3], expected input[16, 256, 1, 256] to have 1 channels, but got 256 channels instead\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]runfile.py:34: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  torch.tensor(x),  # Changed from torch.from_numpy to torch.tensor\nrunfile.py:35: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  torch.tensor(y),  # Changed from torch.from_numpy to torch.tensor\nrunfile.py:36: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  torch.tensor(m),  # Changed from torch.from_numpy to torch.tensor\n\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 90, in <module>\n    train_model(model)\n  File \"runfile.py\", line 78, in train_model\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 63, in forward\n    x = nn.ReLU()(self.conv1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nRuntimeError: Given groups=1, weight of size [16, 1, 3, 3], expected input[16, 256, 1, 256] to have 1 channels, but got 256 channels instead\nExecution time: 4 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]runfile.py:33: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  return torch.tensor(x), torch.tensor(y), torch.tensor(m)\n\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 86, in <module>\n    train_model(model)\n  File \"runfile.py\", line 74, in train_model\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 59, in forward\n    x = nn.ReLU()(self.conv1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 554, in forward\n    return self._conv_forward(input, self.weight, self.bias)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/conv.py\", line 549, in _conv_forward\n    return F.conv2d(\nRuntimeError: Given groups=1, weight of size [16, 1, 3, 3], expected input[16, 256, 1, 256] to have 1 channels, but got 256 channels instead\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 71, in <module>\n    loss = masked_loss(outputs, targets, masks)\n  File \"runfile.py\", line 55, in masked_loss\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 64, 64])) is deprecated. Please ensure they have the same size.\nExecution time: 5 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 75, in <module>\n    loss = masked_loss(outputs, targets, masks)\n  File \"runfile.py\", line 59, in masked_loss\n    loss_per_pixel = nn.BCELoss(reduction=\"none\")(pred, target)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 699, in forward\n    return F.binary_cross_entropy(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3560, in binary_cross_entropy\n    raise ValueError(\nValueError: Using a target size (torch.Size([16, 1, 256, 256])) that is different to the input size (torch.Size([16, 1, 128, 128])) is deprecated. Please ensure they have the same size.\nExecution time: 5 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<02:44,  1.47it/s]\r  1%|          | 2/242 [00:01<02:42,  1.47it/s]\r  1%|1         | 3/242 [00:01<02:37,  1.52it/s]\r  2%|1         | 4/242 [00:02<02:33,  1.55it/s]\r  2%|2         | 5/242 [00:03<02:25,  1.63it/s]\r  2%|2         | 6/242 [00:03<02:17,  1.72it/s]\r  3%|2         | 7/242 [00:04<02:11,  1.78it/s]\r  3%|3         | 8/242 [00:04<02:10,  1.79it/s]\r  4%|3         | 9/242 [00:05<02:07,  1.83it/s]\r  4%|4         | 10/242 [00:05<02:05,  1.85it/s]\r  5%|4         | 11/242 [00:06<02:16,  1.69it/s]\r  5%|4         | 12/242 [00:07<02:11,  1.75it/s]\r  5%|5         | 13/242 [00:07<02:09,  1.77it/s]\r  6%|5         | 14/242 [00:08<02:05,  1.81it/s]\r  6%|6         | 15/242 [00:08<02:04,  1.83it/s]\r  7%|6         | 16/242 [00:09<02:02,  1.85it/s]\r  7%|7         | 17/242 [00:09<02:00,  1.87it/s]\r  7%|7         | 18/242 [00:10<01:58,  1.89it/s]\r  8%|7         | 19/242 [00:10<01:57,  1.89it/s]\r  8%|8         | 20/242 [00:11<01:56,  1.91it/s]\r  9%|8         | 21/242 [00:11<01:55,  1.91it/s]\r  9%|9         | 22/242 [00:12<01:56,  1.89it/s]\r 10%|9         | 23/242 [00:12<01:54,  1.91it/s]\r 10%|9         | 24/242 [00:13<01:53,  1.92it/s]\r 10%|#         | 25/242 [00:13<01:53,  1.92it/s]\r 11%|#         | 26/242 [00:14<01:52,  1.91it/s]\r 11%|#1        | 27/242 [00:14<01:52,  1.92it/s]\r 12%|#1        | 28/242 [00:15<01:51,  1.92it/s]\r 12%|#1        | 29/242 [00:15<01:50,  1.92it/s]\r 12%|#2        | 30/242 [00:16<01:50,  1.92it/s]\r 13%|#2        | 31/242 [00:16<01:49,  1.93it/s]\r 13%|#3        | 32/242 [00:17<01:49,  1.93it/s]\r 14%|#3        | 33/242 [00:18<01:48,  1.93it/s]\r 14%|#4        | 34/242 [00:18<01:47,  1.93it/s]\r 14%|#4        | 35/242 [00:19<01:47,  1.93it/s]\r 15%|#4        | 36/242 [00:19<01:46,  1.93it/s]\r 15%|#5        | 37/242 [00:20<01:46,  1.93it/s]\r 16%|#5        | 38/242 [00:20<01:45,  1.93it/s]\r 16%|#6        | 39/242 [00:21<01:45,  1.92it/s]\r 17%|#6        | 40/242 [00:21<01:45,  1.92it/s]\r 17%|#6        | 41/242 [00:22<01:44,  1.92it/s]\r 17%|#7        | 42/242 [00:22<01:43,  1.92it/s]\r 18%|#7        | 43/242 [00:23<01:43,  1.92it/s]\r 18%|#8        | 44/242 [00:23<01:42,  1.92it/s]\r 19%|#8        | 45/242 [00:24<01:42,  1.93it/s]\r 19%|#9        | 46/242 [00:24<01:41,  1.92it/s]\r 19%|#9        | 47/242 [00:25<01:41,  1.92it/s]\r 20%|#9        | 48/242 [00:25<01:41,  1.92it/s]\r 20%|##        | 49/242 [00:26<01:40,  1.92it/s]\r 21%|##        | 50/242 [00:26<01:39,  1.93it/s]\r 21%|##1       | 5\n ... [176337 characters truncated] ... \n82it/s]\r 81%|########  | 196/242 [01:44<00:25,  1.82it/s]\r 81%|########1 | 197/242 [01:44<00:24,  1.85it/s]\r 82%|########1 | 198/242 [01:45<00:23,  1.88it/s]\r 82%|########2 | 199/242 [01:45<00:22,  1.90it/s]\r 83%|########2 | 200/242 [01:46<00:22,  1.90it/s]\r 83%|########3 | 201/242 [01:46<00:21,  1.92it/s]\r 83%|########3 | 202/242 [01:47<00:20,  1.92it/s]\r 84%|########3 | 203/242 [01:48<00:20,  1.88it/s]\r 84%|########4 | 204/242 [01:48<00:20,  1.88it/s]\r 85%|########4 | 205/242 [01:49<00:19,  1.91it/s]\r 85%|########5 | 206/242 [01:49<00:18,  1.92it/s]\r 86%|########5 | 207/242 [01:50<00:18,  1.93it/s]\r 86%|########5 | 208/242 [01:50<00:17,  1.95it/s]\r 86%|########6 | 209/242 [01:51<00:17,  1.91it/s]\r 87%|########6 | 210/242 [01:51<00:16,  1.92it/s]\r 87%|########7 | 211/242 [01:52<00:16,  1.92it/s]\r 88%|########7 | 212/242 [01:52<00:15,  1.92it/s]\r 88%|########8 | 213/242 [01:53<00:15,  1.92it/s]\r 88%|########8 | 214/242 [01:53<00:14,  1.92it/s]\r 89%|########8 | 215/242 [01:54<00:14,  1.92it/s]\r 89%|########9 | 216/242 [01:54<00:13,  1.92it/s]\r 90%|########9 | 217/242 [01:55<00:12,  1.92it/s]\r 90%|######### | 218/242 [01:55<00:12,  1.92it/s]\r 90%|######### | 219/242 [01:56<00:11,  1.92it/s]\r 91%|######### | 220/242 [01:56<00:11,  1.93it/s]\r 91%|#########1| 221/242 [01:57<00:10,  1.93it/s]\r 92%|#########1| 222/242 [01:57<00:10,  1.93it/s]\r 92%|#########2| 223/242 [01:58<00:09,  1.93it/s]\r 93%|#########2| 224/242 [01:58<00:09,  1.92it/s]\r 93%|#########2| 225/242 [01:59<00:08,  1.92it/s]\r 93%|#########3| 226/242 [01:59<00:08,  1.92it/s]\r 94%|#########3| 227/242 [02:00<00:07,  1.92it/s]\r 94%|#########4| 228/242 [02:01<00:07,  1.92it/s]\r 95%|#########4| 229/242 [02:01<00:06,  1.92it/s]\r 95%|#########5| 230/242 [02:02<00:06,  1.92it/s]\r 95%|#########5| 231/242 [02:02<00:05,  1.86it/s]\r 96%|#########5| 232/242 [02:03<00:05,  1.88it/s]\r 96%|#########6| 233/242 [02:03<00:04,  1.89it/s]\r 97%|#########6| 234/242 [02:04<00:04,  1.89it/s]\r 97%|#########7| 235/242 [02:04<00:03,  1.90it/s]\r 98%|#########7| 236/242 [02:05<00:03,  1.91it/s]\r 98%|#########7| 237/242 [02:05<00:02,  1.91it/s]\r 98%|#########8| 238/242 [02:06<00:02,  1.92it/s]\r 99%|#########8| 239/242 [02:06<00:01,  1.91it/s]\r 99%|#########9| 240/242 [02:07<00:01,  1.92it/s]\r100%|#########9| 241/242 [02:07<00:00,  1.92it/s]\r100%|##########| 242/242 [02:08<00:00,  2.24it/s]\r100%|##########| 242/242 [02:08<00:00,  1.89it/s]\nMasked AUROC: 0.9872082052989325\nExecution time: 34 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 64, in <module>\n    loss_per_pixel = criterion(pred, y)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1]))\nExecution time: 5 seconds seconds (time limit is an hour).", "\r  0%|          | 0/483 [00:00<?, ?it/s]\r  0%|          | 1/483 [00:00<03:13,  2.50it/s]\r  0%|          | 2/483 [00:00<03:02,  2.63it/s]\r  1%|          | 3/483 [00:01<02:58,  2.69it/s]\r  1%|          | 4/483 [00:01<03:04,  2.60it/s]\r  1%|1         | 5/483 [00:02<03:18,  2.41it/s]\r  1%|1         | 6/483 [00:02<03:01,  2.62it/s]\r  1%|1         | 7/483 [00:02<02:50,  2.79it/s]\r  2%|1         | 8/483 [00:02<02:48,  2.82it/s]\r  2%|1         | 9/483 [00:03<02:41,  2.94it/s]\r  2%|2         | 10/483 [00:03<02:37,  3.01it/s]\r  2%|2         | 11/483 [00:03<02:34,  3.06it/s]\r  2%|2         | 12/483 [00:04<02:32,  3.10it/s]\r  3%|2         | 13/483 [00:04<02:59,  2.61it/s]\r  3%|2         | 14/483 [00:05<02:49,  2.77it/s]\r  3%|3         | 15/483 [00:05<02:42,  2.88it/s]\r  3%|3         | 16/483 [00:05<03:19,  2.35it/s]\r  4%|3         | 17/483 [00:06<03:02,  2.55it/s]\r  4%|3         | 18/483 [00:06<02:58,  2.60it/s]\r  4%|3         | 19/483 [00:06<02:48,  2.75it/s]\r  4%|4         | 20/483 [00:07<02:45,  2.80it/s]\r  4%|4         | 21/483 [00:07<03:24,  2.26it/s]\r  5%|4         | 22/483 [00:08<03:06,  2.47it/s]\r  5%|4         | 23/483 [00:08<02:54,  2.64it/s]\r  5%|4         | 24/483 [00:08<02:44,  2.78it/s]\r  5%|5         | 25/483 [00:09<02:59,  2.55it/s]\r  5%|5         | 26/483 [00:09<03:15,  2.33it/s]\r  6%|5         | 27/483 [00:10<02:59,  2.54it/s]\r  6%|5         | 28/483 [00:10<03:19,  2.28it/s]\r  6%|6         | 29/483 [00:11<03:31,  2.15it/s]\r  6%|6         | 30/483 [00:11<03:10,  2.38it/s]\r  6%|6         | 31/483 [00:12<03:14,  2.33it/s]\r  7%|6         | 32/483 [00:12<03:23,  2.22it/s]\r  7%|6         | 33/483 [00:12<03:18,  2.27it/s]\r  7%|7         | 34/483 [00:13<03:00,  2.49it/s]\r  7%|7         | 35/483 [00:13<02:49,  2.65it/s]\r  7%|7         | 36/483 [00:13<02:41,  2.76it/s]\r  8%|7         | 37/483 [00:14<03:00,  2.47it/s]\r  8%|7         | 38/483 [00:14<02:55,  2.54it/s]\r  8%|8         | 39/483 [00:15<02:43,  2.72it/s]\r  8%|8         | 40/483 [00:15<02:54,  2.54it/s]\r  8%|8         | 41/483 [00:15<02:42,  2.72it/s]\r  9%|8         | 42/483 [00:16<02:40,  2.75it/s]\r  9%|8         | 43/483 [00:16<02:32,  2.88it/s]\r  9%|9         | 44/483 [00:16<02:27,  2.98it/s]\r  9%|9         | 45/483 [00:17<02:34,  2.84it/s]\r 10%|9         | 46/483 [00:17<02:29,  2.92it/s]\r 10%|9         | 47/483 [00:17<02:40,  2.72it/s]\r 10%|9         | 48/483 [00:18<02:32,  2.86it/s]\r 10%|#         | 49/483 [00:18<02:26,  2.96it/s]\r 10%|#         | 50/483 [00:18<02:22,  3.04it/s]\r 11%|#         | 5\n ... [67491 characters truncated] ... \n28it/s]\r 90%|######### | 437/483 [02:17<00:14,  3.27it/s]\r 91%|######### | 438/483 [02:18<00:13,  3.28it/s]\r 91%|######### | 439/483 [02:18<00:13,  3.29it/s]\r 91%|#########1| 440/483 [02:18<00:13,  3.17it/s]\r 91%|#########1| 441/483 [02:19<00:13,  3.20it/s]\r 92%|#########1| 442/483 [02:19<00:13,  3.12it/s]\r 92%|#########1| 443/483 [02:19<00:12,  3.16it/s]\r 92%|#########1| 444/483 [02:20<00:12,  3.21it/s]\r 92%|#########2| 445/483 [02:20<00:11,  3.23it/s]\r 92%|#########2| 446/483 [02:20<00:11,  3.25it/s]\r 93%|#########2| 447/483 [02:20<00:11,  3.27it/s]\r 93%|#########2| 448/483 [02:21<00:10,  3.28it/s]\r 93%|#########2| 449/483 [02:21<00:11,  3.03it/s]\r 93%|#########3| 450/483 [02:21<00:10,  3.11it/s]\r 93%|#########3| 451/483 [02:22<00:10,  3.16it/s]\r 94%|#########3| 452/483 [02:22<00:09,  3.20it/s]\r 94%|#########3| 453/483 [02:22<00:09,  3.24it/s]\r 94%|#########3| 454/483 [02:23<00:08,  3.26it/s]\r 94%|#########4| 455/483 [02:23<00:08,  3.27it/s]\r 94%|#########4| 456/483 [02:23<00:08,  3.28it/s]\r 95%|#########4| 457/483 [02:24<00:07,  3.28it/s]\r 95%|#########4| 458/483 [02:24<00:07,  3.28it/s]\r 95%|#########5| 459/483 [02:24<00:07,  3.29it/s]\r 95%|#########5| 460/483 [02:24<00:07,  3.15it/s]\r 95%|#########5| 461/483 [02:25<00:06,  3.20it/s]\r 96%|#########5| 462/483 [02:25<00:07,  3.00it/s]\r 96%|#########5| 463/483 [02:25<00:06,  3.08it/s]\r 96%|#########6| 464/483 [02:26<00:06,  3.11it/s]\r 96%|#########6| 465/483 [02:26<00:05,  3.17it/s]\r 96%|#########6| 466/483 [02:26<00:05,  3.21it/s]\r 97%|#########6| 467/483 [02:27<00:04,  3.24it/s]\r 97%|#########6| 468/483 [02:27<00:04,  3.25it/s]\r 97%|#########7| 469/483 [02:27<00:04,  3.27it/s]\r 97%|#########7| 470/483 [02:28<00:03,  3.28it/s]\r 98%|#########7| 471/483 [02:28<00:03,  3.28it/s]\r 98%|#########7| 472/483 [02:28<00:03,  3.29it/s]\r 98%|#########7| 473/483 [02:29<00:03,  3.29it/s]\r 98%|#########8| 474/483 [02:29<00:02,  3.29it/s]\r 98%|#########8| 475/483 [02:29<00:02,  3.27it/s]\r 99%|#########8| 476/483 [02:29<00:02,  3.28it/s]\r 99%|#########8| 477/483 [02:30<00:02,  2.98it/s]\r 99%|#########8| 478/483 [02:30<00:01,  3.07it/s]\r 99%|#########9| 479/483 [02:31<00:01,  2.69it/s]\r 99%|#########9| 480/483 [02:31<00:01,  2.83it/s]\r100%|#########9| 481/483 [02:31<00:00,  2.95it/s]\r100%|#########9| 482/483 [02:32<00:00,  3.05it/s]\r100%|##########| 483/483 [02:32<00:00,  3.12it/s]\r100%|##########| 483/483 [02:32<00:00,  3.17it/s]\nMasked AUROC: 0.9733522811708079\nExecution time: 10 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 68, in <module>\n    loss_per_pixel = criterion(outputs_flat, targets_flat)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([2097152])) must be the same as input size (torch.Size([32]))\nExecution time: 6 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 87, in <module>\n    train_model(model)\n  File \"runfile.py\", line 73, in train_model\n    for x, y, m in tqdm(train_loader):\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/tqdm/std.py\", line 1181, in __iter__\n    for obj in iterable:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 29, in __getitem__\n    x = self.transform(x)  # Apply transformations\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 95, in __call__\n    img = t(img)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 234, in __call__\n    return F.to_pil_image(pic, self.mode)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/functional.py\", line 277, in to_pil_image\n    raise ValueError(f\"pic should not have > 4 channels. Got {pic.shape[-1]} channels.\")\nValueError: pic should not have > 4 channels. Got 256 channels.\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:04<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 92, in <module>\n    train_model(model)\n  File \"runfile.py\", line 80, in train_model\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 66, in forward\n    dec2 = self.decoder2(dec3 + enc3)  # Skip connection\nRuntimeError: The size of tensor a (512) must match the size of tensor b (256) at non-singleton dimension 3\nExecution time: 7 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 87, in <module>\n    score = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 81, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 10 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 62, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 48, in forward\n    x = nn.functional.relu(self.fc1(x))\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/linear.py\", line 125, in forward\n    return F.linear(input, self.weight, self.bias)\nRuntimeError: mat1 and mat2 shapes cannot be multiplied (16x262144 and 65536x256)\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 86, in <module>\n    train_model(model)\n  File \"runfile.py\", line 72, in train_model\n    for x, y, m in tqdm(train_loader):\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/tqdm/std.py\", line 1181, in __iter__\n    for obj in iterable:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 29, in __getitem__\n    x = self.transform(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 95, in __call__\n    img = t(img)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 234, in __call__\n    return F.to_pil_image(pic, self.mode)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/functional.py\", line 277, in to_pil_image\n    raise ValueError(f\"pic should not have > 4 channels. Got {pic.shape[-1]} channels.\")\nValueError: pic should not have > 4 channels. Got 256 channels.\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:00<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 90, in <module>\n    train_model(model)\n  File \"runfile.py\", line 76, in train_model\n    for x, y, m in tqdm(train_loader):\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/tqdm/std.py\", line 1181, in __iter__\n    for obj in iterable:\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 708, in __next__\n    data = self._next_data()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/dataloader.py\", line 764, in _next_data\n    data = self._dataset_fetcher.fetch(index)  # may raise StopIteration\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in fetch\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/utils/data/_utils/fetch.py\", line 52, in <listcomp>\n    data = [self.dataset[idx] for idx in possibly_batched_index]\n  File \"runfile.py\", line 30, in __getitem__\n    x = self.transform(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 95, in __call__\n    img = t(img)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/transforms.py\", line 234, in __call__\n    return F.to_pil_image(pic, self.mode)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torchvision/transforms/functional.py\", line 277, in to_pil_image\n    raise ValueError(f\"pic should not have > 4 channels. Got {pic.shape[-1]} channels.\")\nValueError: pic should not have > 4 channels. Got 256 channels.\nExecution time: 4 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 0/242 [00:05<?, ?it/s]\nTraceback (most recent call last):\n  File \"runfile.py\", line 90, in <module>\n    pred = model(x)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"runfile.py\", line 64, in forward\n    dec3 = torch.cat((dec3, enc3), dim=1)  # Skip connection\nRuntimeError: Sizes of tensors must match except in dimension 1. Expected size 512 but got size 256 for tensor number 1 in the list.\nExecution time: 12 seconds seconds (time limit is an hour).", "Masked AUROC: 0.9704710430238492\nExecution time: 11 minutes seconds (time limit is an hour).", "Masked AUROC: 0.858137452891327\nExecution time: 8 minutes seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<03:33,  1.13it/s]\r  1%|          | 2/242 [00:01<03:19,  1.20it/s]\r  1%|1         | 3/242 [00:02<03:03,  1.30it/s]\r  2%|1         | 4/242 [00:03<02:54,  1.36it/s]\r  2%|2         | 5/242 [00:03<02:49,  1.40it/s]\r  2%|2         | 6/242 [00:04<02:44,  1.43it/s]\r  3%|2         | 7/242 [00:05<02:41,  1.45it/s]\r  3%|3         | 8/242 [00:05<02:46,  1.41it/s]\r  4%|3         | 9/242 [00:06<02:45,  1.41it/s]\r  4%|4         | 10/242 [00:07<02:47,  1.39it/s]\r  5%|4         | 11/242 [00:08<02:50,  1.35it/s]\r  5%|4         | 12/242 [00:08<02:51,  1.34it/s]\r  5%|5         | 13/242 [00:09<02:53,  1.32it/s]\r  6%|5         | 14/242 [00:10<02:52,  1.32it/s]\r  6%|6         | 15/242 [00:11<02:56,  1.28it/s]\r  7%|6         | 16/242 [00:12<03:08,  1.20it/s]\r  7%|7         | 17/242 [00:13<03:09,  1.19it/s]\r  7%|7         | 18/242 [00:13<03:08,  1.19it/s]\r  8%|7         | 19/242 [00:14<03:09,  1.18it/s]\r  8%|8         | 20/242 [00:15<03:14,  1.14it/s]\r  9%|8         | 21/242 [00:16<03:22,  1.09it/s]\r  9%|9         | 22/242 [00:17<03:29,  1.05it/s]\r 10%|9         | 23/242 [00:18<03:25,  1.07it/s]\r 10%|9         | 24/242 [00:19<03:23,  1.07it/s]\r 10%|#         | 25/242 [00:20<03:30,  1.03it/s]\r 11%|#         | 26/242 [00:21<03:38,  1.01s/it]\r 11%|#1        | 27/242 [00:22<03:31,  1.01it/s]\r 12%|#1        | 28/242 [00:23<03:29,  1.02it/s]\r 12%|#1        | 29/242 [00:24<03:30,  1.01it/s]\r 12%|#2        | 30/242 [00:25<03:31,  1.00it/s]\r 13%|#2        | 31/242 [00:26<03:26,  1.02it/s]\r 13%|#3        | 32/242 [00:27<03:31,  1.01s/it]\r 14%|#3        | 33/242 [00:28<03:35,  1.03s/it]\r 14%|#4        | 34/242 [00:29<03:34,  1.03s/it]\r 14%|#4        | 35/242 [00:30<03:32,  1.02s/it]\r 15%|#4        | 36/242 [00:31<03:30,  1.02s/it]\r 15%|#5        | 37/242 [00:32<03:29,  1.02s/it]\r 16%|#5        | 38/242 [00:33<03:33,  1.05s/it]\r 16%|#6        | 39/242 [00:34<03:32,  1.05s/it]\r 17%|#6        | 40/242 [00:35<03:30,  1.04s/it]\r 17%|#6        | 41/242 [00:37<03:30,  1.05s/it]\r 17%|#7        | 42/242 [00:38<03:28,  1.04s/it]\r 18%|#7        | 43/242 [00:39<03:31,  1.06s/it]\r 18%|#8        | 44/242 [00:40<03:28,  1.05s/it]\r 19%|#8        | 45/242 [00:41<03:25,  1.04s/it]\r 19%|#9        | 46/242 [00:42<03:26,  1.05s/it]\r 19%|#9        | 47/242 [00:43<03:30,  1.08s/it]\r 20%|#9        | 48/242 [00:44<03:30,  1.09s/it]\r 20%|##        | 49/242 [00:45<03:24,  1.06s/it]\r 21%|##        | 50/242 [00:46<03:28,  1.09s/it]\r 21%|##1       | 5\n ... [176337 characters truncated] ... \n52it/s]\r 81%|########  | 196/242 [02:07<00:30,  1.53it/s]\r 81%|########1 | 197/242 [02:08<00:29,  1.54it/s]\r 82%|########1 | 198/242 [02:09<00:29,  1.49it/s]\r 82%|########2 | 199/242 [02:09<00:28,  1.51it/s]\r 83%|########2 | 200/242 [02:10<00:27,  1.51it/s]\r 83%|########3 | 201/242 [02:11<00:27,  1.47it/s]\r 83%|########3 | 202/242 [02:11<00:26,  1.49it/s]\r 84%|########3 | 203/242 [02:12<00:25,  1.52it/s]\r 84%|########4 | 204/242 [02:13<00:25,  1.47it/s]\r 85%|########4 | 205/242 [02:13<00:24,  1.49it/s]\r 85%|########5 | 206/242 [02:14<00:23,  1.51it/s]\r 86%|########5 | 207/242 [02:15<00:22,  1.52it/s]\r 86%|########5 | 208/242 [02:15<00:22,  1.50it/s]\r 86%|########6 | 209/242 [02:16<00:21,  1.52it/s]\r 87%|########6 | 210/242 [02:17<00:21,  1.48it/s]\r 87%|########7 | 211/242 [02:17<00:21,  1.47it/s]\r 88%|########7 | 212/242 [02:18<00:20,  1.48it/s]\r 88%|########8 | 213/242 [02:19<00:19,  1.49it/s]\r 88%|########8 | 214/242 [02:19<00:18,  1.51it/s]\r 89%|########8 | 215/242 [02:20<00:17,  1.53it/s]\r 89%|########9 | 216/242 [02:21<00:16,  1.54it/s]\r 90%|########9 | 217/242 [02:21<00:16,  1.52it/s]\r 90%|######### | 218/242 [02:22<00:15,  1.51it/s]\r 90%|######### | 219/242 [02:23<00:15,  1.49it/s]\r 91%|######### | 220/242 [02:23<00:14,  1.50it/s]\r 91%|#########1| 221/242 [02:24<00:13,  1.52it/s]\r 92%|#########1| 222/242 [02:25<00:13,  1.45it/s]\r 92%|#########2| 223/242 [02:25<00:13,  1.44it/s]\r 93%|#########2| 224/242 [02:26<00:12,  1.47it/s]\r 93%|#########2| 225/242 [02:27<00:11,  1.44it/s]\r 93%|#########3| 226/242 [02:27<00:10,  1.48it/s]\r 94%|#########3| 227/242 [02:28<00:10,  1.48it/s]\r 94%|#########4| 228/242 [02:29<00:09,  1.49it/s]\r 95%|#########4| 229/242 [02:29<00:08,  1.51it/s]\r 95%|#########5| 230/242 [02:30<00:07,  1.52it/s]\r 95%|#########5| 231/242 [02:31<00:07,  1.49it/s]\r 96%|#########5| 232/242 [02:31<00:06,  1.51it/s]\r 96%|#########6| 233/242 [02:32<00:06,  1.48it/s]\r 97%|#########6| 234/242 [02:33<00:05,  1.50it/s]\r 97%|#########7| 235/242 [02:33<00:04,  1.48it/s]\r 98%|#########7| 236/242 [02:34<00:03,  1.51it/s]\r 98%|#########7| 237/242 [02:35<00:03,  1.53it/s]\r 98%|#########8| 238/242 [02:35<00:02,  1.52it/s]\r 99%|#########8| 239/242 [02:36<00:01,  1.53it/s]\r 99%|#########9| 240/242 [02:37<00:01,  1.49it/s]\r100%|#########9| 241/242 [02:37<00:00,  1.51it/s]\r100%|##########| 242/242 [02:38<00:00,  1.76it/s]\r100%|##########| 242/242 [02:38<00:00,  1.53it/s]\nMasked AUROC: 0.9718573446614275\nExecution time: 55 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 93, in <module>\n    masked_auroc = masked_auroc(pred_probs, val_data)\nNameError: name 'masked_auroc' is not defined\nExecution time: 20 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 96, in <module>\n    auroc_score = masked_auroc(pred_probs, val_data)\n  File \"runfile.py\", line 90, in masked_auroc\n    p = pred_probs[valid].ravel()\nIndexError: boolean index did not match indexed array along dimension 1; dimension is 1 but corresponding boolean dimension is 256\nExecution time: 24 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 65, in <module>\n    loss_per_pixel = criterion(outputs, labels)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1739, in _wrapped_call_impl\n    return self._call_impl(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/module.py\", line 1750, in _call_impl\n    return forward_call(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/modules/loss.py\", line 821, in forward\n    return F.binary_cross_entropy_with_logits(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/nn/functional.py\", line 3639, in binary_cross_entropy_with_logits\n    raise ValueError(\nValueError: Target size (torch.Size([16, 1, 256, 256])) must be the same as input size (torch.Size([16, 1]))\nExecution time: 3 seconds seconds (time limit is an hour).", "\r  0%|          | 0/242 [00:00<?, ?it/s]\r  0%|          | 1/242 [00:00<03:15,  1.24it/s]\r  1%|          | 2/242 [00:01<03:04,  1.30it/s]\r  1%|1         | 3/242 [00:02<02:50,  1.40it/s]\r  2%|1         | 4/242 [00:02<02:49,  1.41it/s]\r  2%|2         | 5/242 [00:03<02:45,  1.43it/s]\r  2%|2         | 6/242 [00:04<02:40,  1.47it/s]\r  3%|2         | 7/242 [00:04<02:37,  1.49it/s]\r  3%|3         | 8/242 [00:05<02:50,  1.37it/s]\r  4%|3         | 9/242 [00:06<02:47,  1.39it/s]\r  4%|4         | 10/242 [00:07<02:47,  1.39it/s]\r  5%|4         | 11/242 [00:07<02:47,  1.38it/s]\r  5%|4         | 12/242 [00:08<02:43,  1.40it/s]\r  5%|5         | 13/242 [00:09<02:48,  1.36it/s]\r  6%|5         | 14/242 [00:10<02:45,  1.38it/s]\r  6%|6         | 15/242 [00:10<02:53,  1.31it/s]\r  7%|6         | 16/242 [00:11<03:13,  1.17it/s]\r  7%|7         | 17/242 [00:12<03:16,  1.15it/s]\r  7%|7         | 18/242 [00:13<03:12,  1.16it/s]\r  8%|7         | 19/242 [00:14<03:11,  1.16it/s]\r  8%|8         | 20/242 [00:15<03:14,  1.14it/s]\r  9%|8         | 21/242 [00:16<03:32,  1.04it/s]\r  9%|9         | 22/242 [00:17<03:47,  1.03s/it]\r 10%|9         | 23/242 [00:18<03:31,  1.04it/s]\r 10%|9         | 24/242 [00:19<03:22,  1.08it/s]\r 10%|#         | 25/242 [00:20<03:35,  1.01it/s]\r 11%|#         | 26/242 [00:21<03:51,  1.07s/it]\r 11%|#1        | 27/242 [00:22<03:41,  1.03s/it]\r 12%|#1        | 28/242 [00:23<03:39,  1.03s/it]\r 12%|#1        | 29/242 [00:24<03:31,  1.01it/s]\r 12%|#2        | 30/242 [00:25<03:26,  1.03it/s]\r 13%|#2        | 31/242 [00:26<03:21,  1.05it/s]\r 13%|#3        | 32/242 [00:27<03:23,  1.03it/s]\r 14%|#3        | 33/242 [00:28<03:22,  1.03it/s]\r 14%|#4        | 34/242 [00:29<03:29,  1.01s/it]\r 14%|#4        | 35/242 [00:30<03:20,  1.03it/s]\r 15%|#4        | 36/242 [00:31<03:20,  1.03it/s]\r 15%|#5        | 37/242 [00:32<03:31,  1.03s/it]\r 16%|#5        | 38/242 [00:33<03:26,  1.01s/it]\r 16%|#6        | 39/242 [00:34<03:30,  1.04s/it]\r 17%|#6        | 40/242 [00:35<03:18,  1.02it/s]\r 17%|#6        | 41/242 [00:36<03:15,  1.03it/s]\r 17%|#7        | 42/242 [00:37<03:24,  1.02s/it]\r 18%|#7        | 43/242 [00:38<03:21,  1.01s/it]\r 18%|#8        | 44/242 [00:39<03:24,  1.03s/it]\r 19%|#8        | 45/242 [00:40<03:26,  1.05s/it]\r 19%|#9        | 46/242 [00:42<03:30,  1.07s/it]\r 19%|#9        | 47/242 [00:43<03:34,  1.10s/it]\r 20%|#9        | 48/242 [00:44<03:29,  1.08s/it]\r 20%|##        | 49/242 [00:45<03:27,  1.08s/it]\r 21%|##        | 50/242 [00:46<03:20,  1.04s/it]\r 21%|##1       | 5\n ... [176337 characters truncated] ... \n46it/s]\r 81%|########  | 196/242 [02:20<00:30,  1.49it/s]\r 81%|########1 | 197/242 [02:21<00:29,  1.51it/s]\r 82%|########1 | 198/242 [02:22<00:31,  1.40it/s]\r 82%|########2 | 199/242 [02:22<00:29,  1.44it/s]\r 83%|########2 | 200/242 [02:23<00:28,  1.46it/s]\r 83%|########3 | 201/242 [02:24<00:29,  1.38it/s]\r 83%|########3 | 202/242 [02:24<00:28,  1.43it/s]\r 84%|########3 | 203/242 [02:25<00:26,  1.46it/s]\r 84%|########4 | 204/242 [02:26<00:27,  1.37it/s]\r 85%|########4 | 205/242 [02:26<00:26,  1.42it/s]\r 85%|########5 | 206/242 [02:27<00:24,  1.45it/s]\r 86%|########5 | 207/242 [02:28<00:23,  1.48it/s]\r 86%|########5 | 208/242 [02:29<00:23,  1.42it/s]\r 86%|########6 | 209/242 [02:29<00:22,  1.46it/s]\r 87%|########6 | 210/242 [02:30<00:23,  1.38it/s]\r 87%|########7 | 211/242 [02:31<00:22,  1.36it/s]\r 88%|########7 | 212/242 [02:31<00:21,  1.39it/s]\r 88%|########8 | 213/242 [02:32<00:20,  1.41it/s]\r 88%|########8 | 214/242 [02:33<00:19,  1.45it/s]\r 89%|########8 | 215/242 [02:33<00:18,  1.47it/s]\r 89%|########9 | 216/242 [02:34<00:17,  1.49it/s]\r 90%|########9 | 217/242 [02:35<00:16,  1.47it/s]\r 90%|######### | 218/242 [02:36<00:16,  1.42it/s]\r 90%|######### | 219/242 [02:36<00:16,  1.36it/s]\r 91%|######### | 220/242 [02:37<00:16,  1.37it/s]\r 91%|#########1| 221/242 [02:38<00:14,  1.42it/s]\r 92%|#########1| 222/242 [02:39<00:15,  1.30it/s]\r 92%|#########2| 223/242 [02:39<00:14,  1.31it/s]\r 93%|#########2| 224/242 [02:40<00:13,  1.37it/s]\r 93%|#########2| 225/242 [02:41<00:12,  1.32it/s]\r 93%|#########3| 226/242 [02:41<00:11,  1.38it/s]\r 94%|#########3| 227/242 [02:42<00:10,  1.41it/s]\r 94%|#########4| 228/242 [02:43<00:09,  1.42it/s]\r 95%|#########4| 229/242 [02:43<00:08,  1.46it/s]\r 95%|#########5| 230/242 [02:44<00:08,  1.49it/s]\r 95%|#########5| 231/242 [02:45<00:07,  1.40it/s]\r 96%|#########5| 232/242 [02:46<00:06,  1.44it/s]\r 96%|#########6| 233/242 [02:46<00:06,  1.39it/s]\r 97%|#########6| 234/242 [02:47<00:05,  1.44it/s]\r 97%|#########7| 235/242 [02:48<00:05,  1.39it/s]\r 98%|#########7| 236/242 [02:48<00:04,  1.44it/s]\r 98%|#########7| 237/242 [02:49<00:03,  1.47it/s]\r 98%|#########8| 238/242 [02:50<00:02,  1.47it/s]\r 99%|#########8| 239/242 [02:50<00:02,  1.49it/s]\r 99%|#########9| 240/242 [02:51<00:01,  1.39it/s]\r100%|#########9| 241/242 [02:52<00:00,  1.44it/s]\r100%|##########| 242/242 [02:52<00:00,  1.68it/s]\r100%|##########| 242/242 [02:52<00:00,  1.40it/s]\nMasked AUROC: 0.9748024092560525\nExecution time: 44 minutes seconds (time limit is an hour)."], "analysis": ["The execution failed due to a mismatch in the dimensions of the model's output and the expected target dimensions in the loss function. The model output is of shape [32, 1] while the target is [32, 1, 256, 256]. To fix this, the final layer of the model should be adjusted to output a tensor of shape [B, 1, 256, 256] instead of [B, 1]. This can be achieved by replacing the fully connected layers with convolutional layers that preserve spatial dimensions or by reshaping the output appropriately.", "The script failed due to a NameError. The function 'F.relu' is called in the forward method of the SimpleCNN class, but 'F' is not defined. To fix this, you need to import the functional module from torch.nn as 'F' at the beginning of the script. Adding the line 'import torch.nn.functional as F' should resolve the issue.", "The error occurred due to a mismatch between the target size and the input size in the loss computation. The model's output size is [16, 1, 64, 64], which does not match the expected target size of [16, 1, 256, 256]. To fix this, remove the pooling layers or adjust the architecture to ensure the output dimensions match the target dimensions.", "The model training failed due to a mismatch in the target and input sizes of the loss function. The model reduces the spatial dimensions of the input from 256x256 to 64x64 due to pooling layers, but the target size remains at 256x256. To fix this, either remove the pooling layers or use upsampling layers in the model to match the output size with the target size.", "The code failed to run due to a missing import for the `F` module used in the `forward` method of the `SimpleCNN` class. To fix this issue, add `import torch.nn.functional as F` at the beginning of the script. This will allow the model to properly use the functional API from PyTorch, which is necessary for operations like ReLU in the model's forward pass.", "The error is due to an incorrect reshaping operation in the forward method of the SimpleCNN model. The output of the fully connected layer is being reshaped to [B, 1, 256, 256], which does not match the expected total number of elements. A correct implementation would involve using appropriate convolutional or upsampling layers to ensure the output matches the expected dimensions without losing the spatial structure necessary for pixel-wise classification.", "The execution failed due to a type mismatch between the input tensor and the bias of the convolutional layers in the model. The input tensor is of type double, whereas the bias expects a float. To fix this issue, ensure that the input tensor is converted to float type before being passed to the model. This can be done by modifying the data loading or the forward pass in the model to include a type conversion (e.g., `.float()`).", "The error arises due to a mismatch in the target and output tensor sizes in the loss calculation. The model's final output is of shape [B, 1, 1, 1], whereas the target tensor shape is [B, 1, 256, 256]. To fix this, the model's architecture should be adjusted to produce an output of the same spatial dimensions as the input (256x256). This can be achieved by using a series of convolutional and upsampling layers to maintain the spatial dimensions throughout the network.", "The script encountered a size mismatch error between the target and input tensors in the loss calculation. This is due to incorrect reshaping of the output tensor before calculating the loss. The output tensor should be reshaped to match the flattened target tensor's shape, ensuring they align for the loss computation.", "The execution failed due to a mismatch between the target and input sizes in the loss function. The model output shape is (16, 1, 64, 64), while the target shape is (16, 1, 256, 256). To fix this, the model architecture should be adjusted to ensure that the output shape matches the target shape. This can be done by removing the pooling layers or adding upsampling layers to compensate for the reduction in spatial dimensions.", "The execution failed due to a ValueError when trying to concatenate zero-dimensional arrays. This error occurs because `pred_probs` is expected to be a list of arrays but seems to be incorrectly formatted or empty. To fix this, ensure that `pred_probs` is correctly populated with arrays from the model output in the evaluation loop. Additionally, check the dimensions and content of `pred_probs` before attempting to concatenate.", "The training script failed due to a mismatch in tensor sizes between the model output and the target. The model's output tensor shape is [16, 1, 64, 64] while the target tensor shape is [16, 1, 256, 256]. This discrepancy arises because the model architecture includes pooling layers that reduce the spatial dimensions of the output. To fix this, either remove the pooling layers or replace them with layers that maintain the original dimensions (e.g., using padding or dilation).", "The code failed due to a missing import of the `torch.nn.functional` module, which is aliased as `F` in the code. Specifically, the error `NameError: name 'F' is not defined` was triggered when trying to use `F.relu` in the `SimpleCNN` model's forward method. To fix this, add `import torch.nn.functional as F` at the beginning of the script.", "The code execution failed due to a NameError: the function 'masked_auroc' is not defined within the script. To resolve this, ensure that the definition of 'masked_auroc' is included in the script or imported properly if it's defined externally.", "The script contains a bug in the `masked_auroc` function where the boolean indexing does not match the dimensions of the `pred_probs` array. The `pred_probs` array is shaped as [N, 1, H, W], but the boolean mask is shaped as [N, H, W]. To fix this, ensure that the `pred_probs` is reshaped or sliced to match the dimensions of the `valid` mask before indexing.", "The code execution failed due to a NameError: 'F' is not defined in the forward method of the SimpleCNN class. This error occurs because the torch.nn.functional module, typically imported as 'F', is not imported but is referenced in the forward method. To fix this, add 'import torch.nn.functional as F' at the beginning of the script.", "The script failed due to a NameError because the module 'F' was not defined in the forward method of the SimpleCNN model. To fix this, you need to import the functional module from torch.nn as 'F' by adding 'import torch.nn.functional as F' at the beginning of the script.", "The script encountered a runtime error due to a mismatch in matrix shapes during a linear layer operation. The error occurred because the dimensions of the input tensor to the first fully connected layer (fc1) did not match the expected dimensions. The model's architecture may need adjustment, specifically in the flattening and input size of the fc1 layer, to ensure the dimensions align correctly.", "The output log indicates a bug due to a mismatch in the target and input sizes in the loss function. The model output is of shape [32, 1, 64, 64] while the target size is [32, 1, 256, 256]. To fix this, the model architecture should be adjusted to ensure the output size matches the target size. This can be achieved by removing the pooling layers or adding additional upsampling layers to compensate for the reduction in spatial dimensions.", "The error occurred because the output tensor dimensions from the model do not match the expected target dimensions. The model outputs a tensor of shape [16, 1, 64, 64], while the target tensor is of shape [16, 1, 256, 256]. To fix this issue, the model architecture should be adjusted to ensure the output tensor matches the target tensor dimensions, either by removing pooling layers or by adding upsampling layers to regain the original dimensions.", "The execution failed due to a NameError: 'F' is not defined in the model's forward method. This error occurs because the torch.nn.functional module, commonly abbreviated as 'F', was not imported but is used in the forward method of the model. To fix this, add 'import torch.nn.functional as F' at the beginning of the script.", "The script encountered an IndexError in the masked_auroc function, specifically when attempting to index with a boolean array that does not match the dimensions of the data array. To fix this issue, ensure that the boolean mask used for indexing is reshaped or adjusted to correctly match the dimensions of the array it is intended to index.", "The code fails due to an invalid shape error during the forward pass of the model. The model's output layer attempts to reshape the tensor to a size [-1, 1, 256, 256], which doesn't match the computed output size of 16. This issue arises because the model's architecture and output layer are not correctly designed to handle the expected output dimensions for a per-pixel classification task.", "The error arises due to a mismatch in the dimensions of the output from the model and the target labels. The model's output dimension is (16, 1, 64, 64) while the target label dimension is (16, 1, 256, 256). To fix this, ensure the output of the model matches the target dimensions by removing pooling layers or adjusting the architecture to maintain the original image dimensions.", "The error occurred due to the incorrect use of the 'float' method on a numpy array within the '__getitem__' method of the 'CosmicRayDataset' class. To fix this, the numpy array should be converted to a PyTorch tensor before applying the 'float' method.", "The error arises due to a mismatch in the dimensions of the model's output and the target labels. The model's output is (16, 1, 64, 64) while the target labels are (16, 1, 256, 256). This discrepancy causes the `binary_cross_entropy` function to fail. To fix this, the model architecture should be adjusted to ensure the output size matches the target size, potentially by removing the pooling layers or adjusting the stride and padding settings in the convolutional layers.", "The script encountered a size mismatch error between the target and input tensors in the loss calculation. The model's output tensor has a shape of (16, 1, 64, 64) due to pooling operations, but the target tensor maintains its original shape of (16, 1, 256, 256). To fix this, either adjust the model architecture to maintain the input size or modify the target tensor to match the output size by appropriate resizing or pooling.", "The training script executed successfully and achieved a Masked AUROC of 0.9742 on the validation set. This high AUROC value indicates that the model has performed very well in distinguishing between cosmic rays and non-cosmic rays in the telescope images. The training and evaluation process was executed without any errors, and the model converged effectively over the epochs.", "The execution output indicates a TimeoutError, suggesting that the training process exceeded the time limit of one hour. This indicates inefficiencies in the training loop or possibly too large a batch size or network complexity. To address this, consider reducing the model complexity, optimizing the training loop, or using a smaller batch size to ensure the training completes within the acceptable time frame.", "The script encountered a runtime error due to a `KeyboardInterrupt` caused by a long execution time. The model training process was not completed, and no predictions were collected for evaluation. This indicates inefficiencies or potential infinite loops within the training loop or model architecture.", "The code execution failed due to a shape mismatch error in the matrix multiplication during the forward pass of the neural network. Specifically, the error occurs because the input size to the fully connected layer `fc1` does not match the expected size. The model architecture or data preprocessing needs adjustment to ensure the correct tensor dimensions are used.", "The script encountered an IndexError during the evaluation of the model's predictions. This error occurred because the boolean indexing did not match the dimensions of the `pred_probs` array. A potential fix would be to ensure that the `valid` mask and `pred_probs` are properly aligned in terms of dimensions before indexing.", "The training script successfully trained multiple CNN models on the cosmic ray detection task using a dataset of telescope images, and achieved an AUROC of approximately 0.929. This suggests that the ensemble of models is fairly effective at distinguishing between cosmic rays and other phenomena in the images.", "The training and evaluation script for predicting cosmic rays in telescope images achieved a Masked AUROC of 0.8905. The model was trained for 5 epochs and evaluated using a custom AUROC function that only considers valid (unmasked) pixels. This score indicates a good predictive performance of the model on the validation set.", "The code execution failed due to a tensor size mismatch error during the concatenation operation in the UNet model's forward method. The error arises because the spatial dimensions of the tensors 'dec3' and 'enc3' do not match when attempting to concatenate them along dimension 1. A potential fix would be to ensure that the spatial dimensions of all tensors match before concatenation, possibly by adding appropriate padding or adjusting the convolutional or transpose convolutional layers to preserve spatial dimensions.", "The code execution failed due to a size mismatch error during the concatenation operation in the UNet model's forward method. Specifically, the error occurred when attempting to concatenate `dec3` and `enc3` tensors, which do not have matching dimensions. To fix the issue, ensure that the output dimensions of the upconvolution layers match the corresponding skip connection layers from the encoder part of the network.", "There is a bug in the data transformation process for the training data. The error arises from passing a numpy array directly to torchvision transforms, which expects a PIL image or a tensor. The error message indicates that the transformation process is trying to convert an array with 256 channels to a PIL image, which is not valid as images should have at most 4 channels (RGB or RGBA).", "The training and evaluation of the model were successful. The script trained multiple CNN models and evaluated them using a masked AUROC metric, achieving a high score of 0.987, indicating excellent model performance in detecting cosmic rays in telescope images.", "The error encountered during execution is due to a mismatch in tensor dimensions between the model output and the target labels. The model outputs predictions of shape [16, 1, 128, 128], while the expected target shape is [16, 1, 256, 256]. To fix this, ensure that the model's output matches the target size by adjusting the architecture or the upscaling method.", "The script encountered an IndexError during the evaluation phase while trying to index `pred_probs` with a boolean mask that does not match its dimensions. To fix this, reshape `pred_probs` to match the dimensions of `valid` before applying the mask. Ensure that `pred_probs` is reshaped to (N, H, W) format after concatenation, matching the dimensions of the validation data masks.", "The script encountered a bug due to a mismatch in the dimensions of the input and target tensors in the loss calculation. The model's output tensor has a shape of [16, 1, 512, 512] after upsampling, which does not match the target tensor shape of [16, 1, 256, 256]. To fix this, the upsampling layer in the model should be adjusted or removed to ensure that the output tensor matches the target tensor's dimensions.", "The code execution failed due to a mismatch in the sizes of the input tensor and the target tensor in the loss calculation. The model outputs a tensor of shape [16, 1], but the target tensor is of shape [16, 1, 256, 256]. To fix this, the model's final layer should be adjusted to output a tensor that matches the spatial dimensions of the input images, i.e., [B, 1, H, W].", "The script encountered a RuntimeError due to incorrect input dimensions to the convolutional layers. The input tensor to the model was expected to have 1 channel, but it was provided with 256 channels instead. This issue can be fixed by ensuring that the input tensor is correctly reshaped or transposed to match the expected dimensions ([B, 1, H, W]).", "The code contains a bug in the data transformation pipeline. The error `TypeError: expected np.ndarray (got Tensor)` occurs because the transforms.ToTensor() is applied inappropriately in the __getitem__ method of the CosmicRayDataset class, resulting in attempts to convert an already tensor object back to tensor. To fix this, remove the transforms.ToTensor() from the data_transforms or adjust the __getitem__ method to handle the data correctly without redundant transformations.", "The script failed due to an IndexError in the `masked_auroc` function. The error occurred because the boolean indexing did not match the indexed array dimensions. To fix this, ensure that the `pred_probs` array dimensions match those of the `y` and `m` arrays in the `val_data` before applying the boolean mask.", "The code has a bug related to incorrect input dimensions being fed to the convolutional layers. The model expects a single-channel input, but it receives a tensor with incorrect dimensions. This is likely due to improper handling of tensor dimensions or transformations in the data loading process. To fix this, ensure that the tensor dimensions are correctly set when feeding into the model, specifically ensuring that the channel dimension is correctly positioned and matches the model's expected input.", "The code execution failed due to a shape mismatch error in the convolutional layer. The model expects input with shape [B, 1, H, W] but received input with shape [B, H, 1, W]. To fix this issue, ensure that the input tensor is correctly reshaped or transposed to match the expected input dimensions before passing it to the model.", "The script encountered a runtime error related to tensor dimension mismatch during the forward pass of the convolutional layer. Specifically, the error message indicates that the input tensor to the convolutional layer has a mismatch in the number of channels expected. To fix this issue, ensure that the input tensor dimensions are correctly set when loading and transforming the data, particularly ensuring that the channel dimension is correctly handled.", "The output log indicates a bug due to a mismatch in tensor sizes between the model's output and the target labels during the loss calculation. The model output is (16, 1, 64, 64) while the target size is (16, 1, 256, 256). This discrepancy arises because the model architecture includes pooling layers that reduce the spatial dimensions of the output. To fix this, either adjust the model to maintain the original input dimensions or interpolate the output back to the original dimensions before calculating the loss.", "The error occurs due to a mismatch in tensor sizes between the output of the model and the target labels during the loss calculation. The model's output is [16, 1, 128, 128], while the target label size is [16, 1, 256, 256]. To fix this, the upsampling in the model should be adjusted to ensure the output size matches the target size of [256, 256]. Specifically, the upsampling factor or method needs to be corrected to achieve the correct output dimensions.", "The training and evaluation script successfully trained multiple CNN models to predict cosmic rays in telescope images, achieving a high Masked AUROC of approximately 0.987. This indicates excellent model performance in distinguishing between cosmic ray affected pixels and normal pixels, especially considering the complex nature of the task.", "The script encountered a ValueError due to a mismatch in the size of the input and target tensors in the BCEWithLogitsLoss calculation. The model's output tensor shape does not match the expected shape of the target tensor. To fix this, ensure the final output of the model is reshaped to match the target tensor shape (16, 1, 256, 256). Adjusting the model's architecture or the output layer to output the correct shape would resolve this issue.", "The training and evaluation script for the cosmic ray detection model successfully completed without any bugs. The model achieved a high AUROC score of approximately 0.973, indicating excellent performance in distinguishing between cosmic rays and background noise in the telescope images.", "The code execution failed due to a mismatch in the target and input sizes in the loss function. The model's output size did not match the expected size of the target labels. To fix this, ensure that the final output of the model has the same dimensions as the input image, particularly after reshaping operations in the model's forward pass.", "The code failed due to a ValueError during the data transformation step, where the input to the PIL image conversion expects a 2D or 3D tensor but received a tensor with incorrect dimensions (256 channels instead of 1-4). To fix this, ensure that the tensor passed to the transformation has the correct shape by checking the dimensions before applying transformations. It could be beneficial to reshape or select the correct channel dimensions if necessary.", "The code has a bug related to incorrect tensor sizes during the skip connection operations in the UNet model. Specifically, the size mismatch error occurs when adding tensors `dec3` and `enc3` due to their different spatial dimensions. To fix this issue, ensure that the spatial dimensions of `dec3` and `enc3` match before performing the addition. This may require adjusting the convolutional or transpose convolutional layers to maintain the same spatial dimensions throughout the network.", "There is a bug in the code related to indexing with a boolean mask in the masked_auroc function. The error occurs because the pred_probs array and the valid mask do not have matching dimensions. To fix this, ensure that both arrays have the same shape before applying the boolean mask.", "The error occurred due to a mismatch in the matrix multiplication shapes in the forward pass of the SimpleCNN model. Specifically, the input size to the fully connected layer (fc1) was incorrect, causing a shape mismatch error during matrix multiplication. To fix this, the input size to the fc1 layer should be correctly computed based on the output dimensions from the preceding convolutional and pooling layers.", "The error occurs due to the incorrect handling of image channels with the torchvision transformations. The provided image data has shape (1, 256, 256), but the ToPILImage transform expects the channel dimension to be at the last position. To fix this, the image tensor should be permuted to move the channel dimension to the last position before applying the transformations.", "The code encountered a bug during the data transformation step in the training loop. The error arises because the transform function expects a PIL image but receives a tensor with incorrect dimensions. The transformation attempts to convert a tensor with shape [1, 256, 256] into a PIL image, incorrectly interpreting the last dimension as channels. To fix this, ensure that the input to the transformation is correctly formatted as a single-channel image or modify the transformation to handle the tensor shape appropriately.", "The script encountered a runtime error due to a size mismatch during tensor concatenation in the forward method of the UNet model. Specifically, the sizes of tensors to be concatenated must match except in dimension 1. The error arose because the spatial dimensions of the 'dec3' and 'enc3' tensors do not align. A potential fix would involve ensuring that the spatial dimensions of the decoder outputs match those of the corresponding encoder outputs before concatenation.", "The model achieved a high Masked AUROC of 0.9705, indicating excellent performance in predicting cosmic rays in telescope images. This metric suggests that the model is effectively differentiating between cosmic ray affected pixels and normal pixels, while correctly ignoring the masked pixels as per the evaluation protocol.", "The model successfully completed training and evaluation, achieving a Masked AUROC score of 0.858. This result indicates a relatively high performance in distinguishing between cosmic rays and other elements in telescope images, considering the complexity of the task.", "The training script successfully executed, training multiple models and evaluating them using an ensemble approach. The evaluation metric used was AUROC, which is appropriate for binary classification tasks like this one. The final reported AUROC was approximately 0.9719, indicating a high model performance in distinguishing cosmic rays in telescope images.", "The script failed due to a NameError because the function 'masked_auroc' was called but was not defined within the script. To fix this, the function 'masked_auroc' should be explicitly defined before its usage in the script, following the provided task evaluation details.", "The script encountered an IndexError due to a mismatch in dimensions when trying to index `pred_probs` with the boolean mask `valid`. To fix this, ensure that both `pred_probs` and `valid` have compatible dimensions before indexing. Specifically, reshape `pred_probs` to match the dimensions of `valid` before applying the mask.", "The error occurred because the output size of the model does not match the expected target size. The model's final layer outputs a tensor of shape [16, 1], but the expected shape is [16, 1, 256, 256]. To fix this, the model architecture needs to be adjusted to output a tensor that matches the spatial dimensions of the input images.", "The training and evaluation process completed successfully with an impressive AUROC of 0.9748. This indicates that the model ensemble is highly effective at distinguishing cosmic rays in telescope images, based on the provided data and model architecture. The training utilized multiple models and averaged their predictions, which likely contributed to the robust performance."], "exp_name": "2-nippy-imported-ringtail", "metrics": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]}

let lastClick = 0;
let firstFrameTime = undefined;

let nodes = [];
let edges = [];

let lastScrollPos = 0;

setup = () => {
  canvas = createCanvas(...updateTargetDims());
};

class Node {
  x;
  y;
  size;
  xT;
  yT;
  xB;
  yB;
  treeInd;
  color;
  relSize;
  animationStart = Number.MAX_VALUE;
  animationProgress = 0;
  isStatic = false;
  hasChildren = false;
  isRootNode = true;
  isStarred = false;
  selected = false;
  renderSize = 10;
  edges = [];
  bgCol;

  constructor(x, y, relSize, treeInd) {
    const minSize = 35;
    const maxSize = 60;

    const maxColor = 10;
    const minColor = 125;

    this.relSize = relSize;
    this.treeInd = treeInd;
    this.size = minSize + (maxSize - minSize) * relSize;
    this.color = minColor + (maxColor - minColor) * relSize;
    this.bgCol = Math.round(Math.max(this.color / 2, 0));

    this.x = x;
    this.y = y;
    this.xT = x;
    this.yT = y - this.size / 2;
    this.xB = x;
    this.yB = y + this.size / 2;

    nodes.push(this);
  }

  startAnimation = (offset = 0) => {
    if (this.animationStart == Number.MAX_VALUE)
      this.animationStart = globalTime + offset;
  };

  child = (node) => {
    let edge = new Edge(this, node);
    this.edges.push(edge);
    edges.push(edge);
    this.hasChildren = true;
    node.isRootNode = false;
    return node;
  };

  render = () => {
    if (globalTime - this.animationStart < 0) return;

    const mouseXlocalCoords = (mouseX - width / 2) / scaleFactor;
    const mouseYlocalCoords = (mouseY - height / 2) / scaleFactor;
    const isMouseOver =
      dist(mouseXlocalCoords, mouseYlocalCoords, this.x, this.y) <
      this.renderSize / 1.5;
    if (isMouseOver) cursor(HAND);
    if (isMouseOver && mouseIsPressed) {
      nodes.forEach((n) => (n.selected = false));
      this.selected = true;
      setCodeAndPlan(
        treeStructData.code[this.treeInd],
        treeStructData.plan[this.treeInd],
      );
      manualSelection = true;
    }

    this.renderSize = this.size;
    if (!this.isStatic) {
      this.animationProgress = animEase(
        (globalTime - this.animationStart) / 1000,
      );
      if (this.animationProgress >= 1) {
        this.isStatic = true;
      } else {
        this.renderSize =
          this.size *
          (0.8 +
            0.2 *
              (-3.33 * this.animationProgress ** 2 +
                4.33 * this.animationProgress));
      }
    }

    fill(this.color);
    if (this.selected) {
      fill(accentCol);
    }

    noStroke();
    square(
      this.x - this.renderSize / 2,
      this.y - this.renderSize / 2,
      this.renderSize,
      10,
    );

    noStroke();
    textAlign(CENTER, CENTER);
    textSize(this.renderSize / 2);
    fill(255);
    // fill(lerpColor(color(accentCol), color(255), this.animationProgress))
    text("{ }", this.x, this.y - 1);
    // DEBUG PRINT:
    // text(round(this.relSize, 2), this.x, this.y - 1)
    // text(this.treeInd, this.x, this.y + 15)

    const dotAnimThreshold = 0.85;
    if (this.isStarred && this.animationProgress >= dotAnimThreshold) {
      let dotAnimProgress =
        (this.animationProgress - dotAnimThreshold) / (1 - dotAnimThreshold);
      textSize(
        ((-3.33 * dotAnimProgress ** 2 + 4.33 * dotAnimProgress) *
          this.renderSize) /
          2,
      );
      if (this.selected) {
        fill(0);
        stroke(0);
      } else {
        fill(accentCol);
        stroke(accentCol);
      }
      strokeWeight((-(dotAnimProgress ** 2) + dotAnimProgress) * 2);
      text("*", this.x + 20, this.y - 11);
      noStroke();
    }

    if (!this.isStatic) {
      fill(bgCol);
      const progressAnimBaseSize = this.renderSize + 5;
      rect(
        this.x - progressAnimBaseSize / 2,
        this.y -
          progressAnimBaseSize / 2 +
          progressAnimBaseSize * this.animationProgress,
        progressAnimBaseSize,
        progressAnimBaseSize * (1 - this.animationProgress),
      );
    }
    if (this.animationProgress >= 0.9) {
      this.edges
        .sort((a, b) => a.color() - b.color())
        .forEach((e, i) => {
          e.startAnimation((i / this.edges.length) ** 2 * 1000);
        });
    }
  };
}

class Edge {
  nodeT;
  nodeB;
  animX = 0;
  animY = 0;
  animationStart = Number.MAX_VALUE;
  animationProgress = 0;
  isStatic = false;
  weight = 0;

  constructor(nodeT, nodeB) {
    this.nodeT = nodeT;
    this.nodeB = nodeB;
    this.weight = 2 + nodeB.relSize * 1;
  }

  color = () => this.nodeB.color;

  startAnimation = (offset = 0) => {
    if (this.animationStart == Number.MAX_VALUE)
      this.animationStart = globalTime + offset;
  };

  render = () => {
    if (globalTime - this.animationStart < 0) return;

    if (!this.isStatic) {
      this.animationProgress = animEase(
        (globalTime - this.animationStart) / 1000,
      );
      if (this.animationProgress >= 1) {
        this.isStatic = true;
        this.animX = this.nodeB.xT;
        this.animY = this.nodeB.yT;
      } else {
        this.animX = bezierPoint(
          this.nodeT.xB,
          this.nodeT.xB,
          this.nodeB.xT,
          this.nodeB.xT,
          this.animationProgress,
        );

        this.animY = bezierPoint(
          this.nodeT.yB,
          (this.nodeT.yB + this.nodeB.yT) / 2,
          (this.nodeT.yB + this.nodeB.yT) / 2,
          this.nodeB.yT,
          this.animationProgress,
        );
      }
    }
    if (this.animationProgress >= 0.97) {
      this.nodeB.startAnimation();
    }

    strokeWeight(this.weight);
    noFill();
    stroke(
      lerpColor(color(bgCol), color(accentCol), this.nodeB.relSize * 1 + 0.7),
    );
    bezier(
      this.nodeT.xB,
      this.nodeT.yB,
      this.nodeT.xB,
      (this.nodeT.yB + this.nodeB.yT) / 2,
      this.animX,
      (this.nodeT.yB + this.nodeB.yT) / 2,
      this.animX,
      this.animY,
    );
  };
}

draw = () => {
  cursor(ARROW);
  frameRate(120);
  if (!firstFrameTime && frameCount <= 1) {
    firstFrameTime = millis();
  }
  // ---- update global animation state ----
  const initialSpeedScalingEaseIO =
    (cos(min((millis() - firstFrameTime) / 8000, 1.0) * PI) + 1) / 2;
  const initialSpeedScalingEase =
    (cos(min((millis() - firstFrameTime) / 8000, 1.0) ** (1 / 2) * PI) + 1) / 2;
  const initAnimationSpeedFactor = 1.0 - 0.4 * initialSpeedScalingEaseIO;
  // update global scaling-aware clock
  globalTime += globalAnimSpeed * initAnimationSpeedFactor * deltaTime;

  if (nodes.length == 0) {
    const spacingHeight = height * 1.3;
    const spacingWidth = width * 1.3;
    treeStructData.layout.forEach((lay, index) => {
      new Node(
        spacingWidth * lay[0] - spacingWidth / 2,
        20 + spacingHeight * lay[1] - spacingHeight / 2,
        1 - treeStructData.metrics[index],
        index,
      );
    });
    treeStructData.edges.forEach((ind) => {
      nodes[ind[0]].child(nodes[ind[1]]);
    });
    nodes.forEach((n) => {
      if (n.isRootNode) n.startAnimation();
    });
    nodes[0].selected = true;
    setCodeAndPlan(
      treeStructData.code[0],
      treeStructData.plan[0],
    )
  }

  const staticNodes = nodes.filter(
    (n) => n.isStatic || n.animationProgress >= 0.7,
  );
  if (staticNodes.length > 0) {
    const largestNode = staticNodes.reduce((prev, current) =>
      prev.relSize > current.relSize ? prev : current,
    );
    if (!manualSelection) {
      if (!largestNode.selected) {
        setCodeAndPlan(
          treeStructData.code[largestNode.treeInd],
          treeStructData.plan[largestNode.treeInd],
        );
      }
      staticNodes.forEach((node) => {
        node.selected = node === largestNode;
      });
    }
  }
  background(bgCol);
  // global animation transforms
  translate(width / 2, height / 2);
  scale(scaleFactor);

  
  // ---- fg render ----
  edges.forEach((e) => e.render());
  nodes.forEach((n) => n.render());
  
};

    </script>
    <title>AIDE Run Visualization</title>
    <style>
      body,
      * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        overflow: scroll;
      }
      body {
        background-color: #f2f0e7;
      }
      canvas {
        float: left;
        height: 100vh;
        width: 40vw;
      }
      #text-container {
        float: right;
        height: 100vh;
        width: 50vw;
        background-color: #282c34;
      }
      #plan {
        /* border-left: 2px solid #282c34; */
        background-color: #282c34;
        color: #f2f0e7;
        min-height: 5rem;
        padding: 1em 0 1em 1em;
      }
    </style>
  </head>
  <body>
    <pre
      id="text-container"
    ><div id="plan"></div><hr><code id="code" class="language-python"></code></pre>
  </body>
</html>
