EB-gMCR: Energy-Based Generative Modeling for Signal Unmixing

This bundle contains the EB-gMCR solver, scripts to reproduce the main results, and lightweight artifacts (summaries and figure data). Heavy raw artifacts (large checkpoints/weights) are not included to keep the package small, but can be regenerated with the provided scripts.

Contents
Data files:
  raw_results/ - the recorded result of our experiment (can be reproduced by following codebase).
  *.csv, *.xlsx - the summarized numerical result of all experiment in the paper.

Code files:
  ebgmcr/ - core solver source (synthesized data generator, training loop, EB-select, losses).
  real_dataset/ - scripts to construct real-data inputs (R code and helpers).

  Synthetic dataset experiments:
    batch_evaluate_ebgmcr.py - main repeated training program of EB-gMCR.
    run_component_number_evaluation.sh - script file of reproduce results in §5.1 Figs 2a-h (Table 2).
    evaluate_synthesized_benchmarks.py - script file of reproduce baseline methods resutls in §5.1 Figs 2e-h (Table 3).
    run_ablation_study.sh - script file of reproduce results of §5.3 (Table 1).

  Real dataset expeirments (Carbs, NIR):
    run_real_ebgmcr.py - run EB-gMCR on Carbs (max_epoch=0.5M) and NIR (max_epoch=3M).
    run_real_benchmarks.py - run baseline methods on Carbs and NIR dataset.
    evaluate_real_dataset.py - summarize result of EB-gMCR and baseline methods from their output files (Fig. 3, Table 4).
    
  Plotting proxy (use *.csv, *.xlsx to plot the figures used in paper):
    Notebook_EB-gMCR_main_results.ipynb - Fig. 2
    Notebook_EB-gMCR_real_dataset.ipynb - Fig. 3

Reproducing paper figures/tables (no heavy compute):
Use *.ipynb can reproduce all figure, and tables can be extracted from *.csv and *.xlsx files.

Full experiments (heavy, optional):
Use *.sh files and *.py for experiment proxy can reproduce similar results (put in raw_results/).
Weights of a checkpoint of 1024-component sovler NN might use more than 100MB, please notice the storage if really want to reproduce all results.

Determinism & environment:
Our env:
  python: 3.12.3
  torch: v2.7.0+cu126
  sklearn: 1.5.2
  
We use the Gumbel-softmax function in torch.nn.functional, so the code might runnable on Pytorch version upper than 1.2.0.
