data_dir: !!python/object/apply:pathlib.PosixPath
- /
- projects
- 
- users
- 
- tusoml
- nasbench360
- aide_cosmic
desc_file: null
goal: "Build a method for predicting probabilistic maps to identify cosmic rays in\
  \ telescope images. Predict a binary label for each pixel of it is a cosmic ray\
  \ or not, ignoring masked pixels. Dataset overview\n\nArray shapes:\n  train_data:\
  \ np.ndarray of shape (N_train, 3, 256, 256)\n  val_data:   np.ndarray of shape\
  \ (N_val,   3, 256, 256)\n\nChannel semantics (axis=1):\n  [0] image          —\
  \ float/uint, shape (H=256, W=256). This is the ONLY model input.\n  [1] gt_mask\
  \        — {0,1},      shape (H, W). Ground-truth binary labels per pixel.\n  [2]\
  \ ignore_mask    — {0,1},      shape (H, W). 1 = ignore (exclude from loss/metrics).\n\
  \nImportant shape conventions:\n  • When batching for PyTorch, use tensors shaped\
  \ [B, C, H, W].\n  • Feed the model the image channel as a single-channel tensor\
  \ with shape [B, 1, 256, 256].\n    Example (from a batch `batch` of shape [B, 3,\
  \ 256, 256]):\n        x  = batch[:, 0:1, :, :].float()           # [B,1,H,W]\n\
  \        y  = batch[:, 1:2, :, :].float()           # [B,1,H,W] — target\n     \
  \   m  = batch[:, 2:2+1, :, :].float()         # [B,1,H,W] — ignore mask\n\nLoss/metrics\
  \ masking:\n  • Compute per-pixel loss (e.g., BCE with logits) and multiply by a\
  \ valid mask:\n        valid = (m == 0).float()                   # 1 where valid,\
  \ 0 where ignored\n        loss_per_pixel = bce_with_logits(pred, y)  # pred/logits\
  \ shape [B,1,H,W]\n        loss = (loss_per_pixel * valid).sum() / valid.sum().clamp_min(1.0)\n\
  \n  • For metrics (e.g., AUROC), evaluate ONLY on valid pixels (m == 0).\n\nModel\
  \ I/O:\n  • Model input:  x  -> [B,1,256,256]\n  • Model output: pred -> [B,1,256,256]\
  \ with per-pixel probabilities (use sigmoid on logits).\n"
eval: "Use this exact function for evaluation. Higher is better.\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"
log_dir: !!python/object/apply:pathlib.PosixPath
- /
- projects
- 
- users
- 
- tusoml
- logs
- 2-nippy-imported-ringtail
workspace_dir: !!python/object/apply:pathlib.PosixPath
- /
- projects
- 
- users
- 
- tusoml
- workspaces
- 2-nippy-imported-ringtail
preprocess_data: true
copy_data: true
exp_name: 2-nippy-imported-ringtail
exec:
  timeout: 3600
  agent_file_name: runfile.py
  format_tb_ipython: false
generate_report: true
report:
  model: gpt-4-turbo
  temp: 1.0
agent:
  steps: 20
  k_fold_validation: 5
  expose_prediction: false
  data_preview: true
  code:
    model: gpt-4o-mini
    temp: 0.5
  feedback:
    model: gpt-4-turbo
    temp: 0.5
  search:
    max_debug_depth: 3
    debug_prob: 0.5
    num_drafts: 5
