{
  "experiment": "imli_spect-heart_p16_s1001_w",
  "start_time": "2025-12-12T20:50:13.305033",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:13.305475",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305483",
      "level": "INFO",
      "message": "  Dataset: spect-heart"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305490",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305496",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305501",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305505",
      "level": "INFO",
      "message": "  Seed: 1001"
    },
    {
      "timestamp": "2025-12-12T20:50:13.305510",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:13.305515",
      "level": "INFO",
      "message": "Loading spect-heart dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.314074",
      "level": "INFO",
      "message": "Dataset: SPECT Heart (22 binary features)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314099",
      "level": "INFO",
      "message": "  Train: 213 samples, 22 features"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314370",
      "level": "INFO",
      "message": "  Test: 54 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314471",
      "level": "INFO",
      "message": "  Class distribution: [ 44 169]"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314481",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314486",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314895",
      "level": "INFO",
      "message": "  Train subset: 170 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314901",
      "level": "INFO",
      "message": "  Validation: 43 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.314906",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.314913",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=1001"
    },
    {
      "timestamp": "2025-12-12T20:50:13.342167",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8235"
    },
    {
      "timestamp": "2025-12-12T20:50:13.369778",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8529"
    },
    {
      "timestamp": "2025-12-12T20:50:13.396575",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8588"
    },
    {
      "timestamp": "2025-12-12T20:50:13.423273",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8588"
    },
    {
      "timestamp": "2025-12-12T20:50:13.449878",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8529"
    },
    {
      "timestamp": "2025-12-12T20:50:13.450176",
      "level": "INFO",
      "message": "Training complete in 0.1s, acc=0.8529"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451201",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451207",
      "level": "INFO",
      "message": "  Train acc: 0.8357"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451213",
      "level": "INFO",
      "message": "  Test acc: 0.8148"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451225",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451230",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451235",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.451543",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.453824",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453836",
      "level": "INFO",
      "message": "  Min utility: -0.2121, Max: 0.3182"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453875",
      "level": "INFO",
      "message": "  Mean cost: 4.47, Std: 1.53"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453887",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 30"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453894",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453899",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453904",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453926",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~13 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.453937",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=4.47)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.454151",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 13)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.454427",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.455379",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 1 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.455386",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [13, 26)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.455615",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.455868",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 1 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.455875",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [26, 39)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.456138",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.456378",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 1 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.456383",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [39, 52)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.456855",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.457083",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 1 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.457089",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [52, 65)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.457342",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.457660",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.457666",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [65, 78)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.457891",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.458104",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.458110",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [78, 91)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.458408",
      "level": "INFO",
      "message": "  Constraints: 30, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.458917",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.458923",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [91, 104)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.459220",
      "level": "INFO",
      "message": "  Constraints: 36, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.459436",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.459442",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [104, 117)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.459613",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.459802",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.459808",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [117, 130)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.460069",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.460275",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.460602",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [130, 143)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.460795",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.461183",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 2 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.461189",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [143, 156)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.461437",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.461969",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 7 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.461975",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [156, 169)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.462148",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.462349",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 7 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.462355",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [169, 182)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.462947",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.463158",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 7 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.463164",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [182, 195)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.463420",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.463807",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 10 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.463813",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [195, 213)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.464121",
      "level": "INFO",
      "message": "  Constraints: 32, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.464350",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 10 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.464355",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:13.471168",
      "level": "INFO",
      "message": "Total pos/neg pairs: 4,700"
    },
    {
      "timestamp": "2025-12-12T20:50:13.471642",
      "level": "INFO",
      "message": "Separation violations: 146 (3.11%)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.471651",
      "level": "INFO",
      "message": "\u26a0 Global separation VIOLATED (146 pairs are identical)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.471683",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.473481",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:13.473489",
      "level": "INFO",
      "message": "Compression: 200 \u2192 10 (95.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473495",
      "level": "INFO",
      "message": "TM accuracy: train=0.8357, test=0.8148"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473501",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8451, test=0.8704"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473505",
      "level": "INFO",
      "message": "Fidelity: train=0.9906, test=0.9444"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473510",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0556"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473515",
      "level": "INFO",
      "message": "Patterns: 33"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473913",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:13.473919",
      "level": "INFO",
      "message": "Train: 213 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.473925",
      "level": "INFO",
      "message": "Test:  54 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474489",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474495",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474501",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474506",
      "level": "INFO",
      "message": "Dataset: SPECT Heart (22 binary features)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474514",
      "level": "INFO",
      "message": "Compression: 200 \u2192 10 clauses (95.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474521",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474528",
      "level": "INFO",
      "message": "Train time: 0.1s"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474976",
      "level": "INFO",
      "message": "Test fidelity: 94.44%"
    },
    {
      "timestamp": "2025-12-12T20:50:13.474995",
      "level": "INFO",
      "message": "Test acc delta: +0.0556"
    },
    {
      "timestamp": "2025-12-12T20:50:13.475000",
      "level": "INFO",
      "message": "Patterns: 33"
    },
    {
      "timestamp": "2025-12-12T20:50:13.475013",
      "level": "INFO",
      "message": "Test fallback rate: 0.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:13.475020",
      "level": "INFO",
      "message": "Global separation: \u26a0 VIOLATED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 10,
      "compression_ratio": 0.95,
      "tm_train_acc": 0.8356807511737089,
      "tm_test_acc": 0.8148148148148148,
      "compressed_train_acc": 0.8450704225352113,
      "compressed_test_acc": 0.8703703703703703,
      "train_fidelity": 0.9906103286384976,
      "test_fidelity": 0.9444444444444444,
      "test_acc_delta": 0.05555555555555558,
      "n_patterns": 33,
      "n_train": 213,
      "n_test": 54,
      "train_fallback": {
        "n_exact_matches": 213,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "test_fallback": {
        "n_exact_matches": 54,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "solve_time": 0.00473475456237793,
      "train_time": 0.13496017456054688,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 1001,
      "dataset": "spect-heart",
      "dataset_name": "SPECT Heart (22 binary features)",
      "weighted": true,
      "verification": {
        "total_pairs": 4700,
        "violations": 146,
        "violation_rate": 0.031063829787234043,
        "global_separation_preserved": false
      }
    }
  ],
  "end_time": "2025-12-12T20:50:13.475022"
}