name: sage-crossdomain-sf3d-100driver
id: sage-crossdomain-sf3d-100driver-220925_010101
version: 0.0.3
author: XYZ
maintainers:
  - XYZ
created_on: 220925_010101
description: Cross-domain behavioral divergence analysis using SAGE with saliency and embeddings
license: Apache-2.0
framework_type: pytorch
can_run_on_cpu: true
gpu_memory_in_gb: 1
half_precision: false
state: active
tags:
  - vDDD
  - saliency
  - crossdomain
  - divergence
models:
  efficientnet_b0_bboxseg_180925_111836:
    arch: efficientnet_b0
    dataset: sf3d-day-bydriver-bboxseg
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-180925_092013/efficientnet_b0-bs32-nc10-sf3d-day-bydriver-bboxseg-180925_111836/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_seg_180925_140950:
    arch: efficientnet_b0
    dataset: sf3d-day-bydriver-seg
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-180925_121026/efficientnet_b0-bs32-nc10-sf3d-day-bydriver-seg-180925_140950/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_bbox_180925_170211:
    arch: efficientnet_b0
    dataset: sf3d-day-bydriver-bbox
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-180925_150328/efficientnet_b0-bs32-nc10-sf3d-day-bydriver-bbox-180925_170211/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_seg_190925_021131:
    arch: efficientnet_b0
    dataset: 100-driver-day-cam2-sf3d-nc10-seg
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-180925_201947/efficientnet_b0-bs32-nc10-100-driver-day-cam2-sf3d-nc10-seg-190925_021131/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_bbox_190925_091010:
    arch: efficientnet_b0
    dataset: 100-driver-day-cam2-sf3d-nc10-bbox
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-190925_060101/efficientnet_b0-bs32-nc10-100-driver-day-cam2-sf3d-nc10-bbox-190925_091010/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_bboxseg_190925_175851:
    arch: efficientnet_b0
    dataset: 100-driver-day-cam2-sf3d-nc10-bboxseg
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-190925_145848/efficientnet_b0-bs32-nc10-100-driver-day-cam2-sf3d-nc10-bboxseg-190925_175851/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]

  efficientnet_b0_nc10_210925_230006:
    arch: efficientnet_b0
    dataset: 100-driver-day-cam2-sf3d-nc10
    variant: full
    weights_path: sage-experimental-logs/xai/train-CrossEntropyLoss_10-210925_161238/efficientnet_b0-bs32-nc10-100-driver-day-cam2-sf3d-nc10-210925_230006/efficientnet_b0-final.pth
    input_size: [224, 224]
    num_classes: 10
    target_layers: ["features.7"]
datasets:
  - id: sf3d
    variants: [fullbg, bbox, seg, bboxseg]
    label_map: data/label_map_100driver_sf3d.json
    split_files: data/splits/sf3d.yml
  - id: 100driver
    variants: [fullbg, bbox, seg, bboxseg]
    label_map: data/label_map_100driver_sf3d.json
    split_files: data/splits/100driver.yml
saliency_cfg:
  # methods: ["GradCAM","LayerCAM","EigenCAM"]
  methods: ["GradCAM"]
  target:
    selection: "auto"
    per_arch:
      resnet18: "auto"
      resnet50: "auto"
      efficientnet_b0: "auto"
      densenet121: "auto"
      squeezenet1_0: "auto"
  normalize: ["phi_relu"]
  masks:
    mode: "precomputed"
    save_runtime: true
  patchify:
    enabled: true
    save_patches: true
    grids: [[4,4],[8,8]]
    pad: "none"
  outputs:
    save_raw_maps: true
    save_overlays: true
    save_tokens: true
    format: "npy"
  batching:
    cam_batch_size: 16
    num_workers: 4
  fail_fast: false
run:
  inference: true
  cluster: false
  saliency: false
  embed: false
  divergence: false
  report: false
flowplan:
  - inference:
    # EfficientNet-B0 cross-domain runs
    - {fn: inference.load_split, params: {model: efficientnet_b0_bbox_180925_170211, train_dataset: sf3d-bbox, eval_dataset: 100driver-bbox, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}

    - {fn: inference.load_split, params: {model: efficientnet_b0_seg_180925_140950, train_dataset: sf3d-seg, eval_dataset: 100driver-seg, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}


    - {fn: inference.load_split, params: {model: efficientnet_b0_bboxseg_180925_111836, train_dataset: sf3d-bboxseg, eval_dataset: 100driver-bboxseg, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}


    - {fn: inference.load_split, params: {model: efficientnet_b0_bbox_190925_091010, train_dataset: 100driver-bbox, eval_dataset: sf3d-bbox, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}



    - {fn: inference.load_split, params: {model: efficientnet_b0_seg_190925_021131, train_dataset: 100driver-seg, eval_dataset: sf3d-seg, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}



    - {fn: inference.load_split, params: {model: efficientnet_b0_bboxseg_190925_175851, train_dataset: 100driver-bboxseg, eval_dataset: sf3d-bboxseg, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}



    - {fn: inference.load_split, params: {model: efficientnet_b0_nc10_210925_230006, train_dataset: 100driver-nc10, eval_dataset: sf3d-nc10, split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}


  - cluster:
    - {fn: load_predictions}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, cluster_params: {"n_clusters": 4}}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
  - saliency:
    - {fn: inference.load_split, params: {split: test}}
    - {fn: inference.predict}
    - {fn: inference.save_predictions}
    - {fn: inference.save_evaluations}
    - {fn: cluster.cluster_confidence, params: {method: KMeans, n_clusters: 4}}
    - {fn: cluster.save_clusters}
    - {fn: cluster.generate_dashboard}
    - {fn: saliency.generate_saliency, params: {use_clusters: true}}
    - {fn: saliency.save_saliency}
    - {fn: saliency_viz.run_viz_suite_from_context}


  - embed:
    - {fn: embed.load_saliency}
    - {fn: embed.embed_saliency, params: {encoders: [dinov2, clip-vit], tokenization: both, fg_bg: both}}
    - {fn: embed.save_embeddings}
  - divergence:
    - {fn: divergence.load_embeddings}
    - {fn: divergence.compute_divergence, params: {metrics: [cosine, jsd, wasserstein], aggregate: [per_class, per_cluster, fg_vs_bg], normalize: true}}
    - {fn: divergence.save_divergence}
  - report:
    - {fn: report.load_divergence}
    - {fn: report.generate_report, params: {formats: [json, csv, latex, plots], vllm_explain: true}}
    - {fn: report.save_report}
