{
  "experiment": "imli_spect-heart_p16_s456_w",
  "start_time": "2025-12-12T20:50:12.016925",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:12.017563",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017574",
      "level": "INFO",
      "message": "  Dataset: spect-heart"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017582",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017589",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017595",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017600",
      "level": "INFO",
      "message": "  Seed: 456"
    },
    {
      "timestamp": "2025-12-12T20:50:12.017605",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:12.017610",
      "level": "INFO",
      "message": "Loading spect-heart dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.033953",
      "level": "INFO",
      "message": "Dataset: SPECT Heart (22 binary features)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.033964",
      "level": "INFO",
      "message": "  Train: 213 samples, 22 features"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034306",
      "level": "INFO",
      "message": "  Test: 54 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034378",
      "level": "INFO",
      "message": "  Class distribution: [ 44 169]"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034386",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034391",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034816",
      "level": "INFO",
      "message": "  Train subset: 170 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034822",
      "level": "INFO",
      "message": "  Validation: 43 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:12.034827",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.034834",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=456"
    },
    {
      "timestamp": "2025-12-12T20:50:12.062135",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8412"
    },
    {
      "timestamp": "2025-12-12T20:50:12.088614",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8353"
    },
    {
      "timestamp": "2025-12-12T20:50:12.115708",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8412"
    },
    {
      "timestamp": "2025-12-12T20:50:12.142316",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8412"
    },
    {
      "timestamp": "2025-12-12T20:50:12.169243",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8412"
    },
    {
      "timestamp": "2025-12-12T20:50:12.169542",
      "level": "INFO",
      "message": "Training complete in 0.1s, acc=0.8412"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170562",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170569",
      "level": "INFO",
      "message": "  Train acc: 0.8310"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170574",
      "level": "INFO",
      "message": "  Test acc: 0.7963"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170580",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170585",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:12.170589",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.171661",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.173927",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:12.173940",
      "level": "INFO",
      "message": "  Min utility: -0.2059, Max: 0.1928"
    },
    {
      "timestamp": "2025-12-12T20:50:12.173982",
      "level": "INFO",
      "message": "  Mean cost: 5.05, Std: 1.36"
    },
    {
      "timestamp": "2025-12-12T20:50:12.173994",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 114"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174000",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174005",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174010",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174045",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~13 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174056",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=5.05)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174281",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 13)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.174485",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.175223",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 0 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.175230",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [13, 26)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.175505",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.176288",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.176295",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [26, 39)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.176589",
      "level": "INFO",
      "message": "  Constraints: 36, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.176972",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 8 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.176980",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [39, 52)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.177420",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.177637",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 8 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.177644",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [52, 65)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.177928",
      "level": "INFO",
      "message": "  Constraints: 30, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.178275",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 11 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.178281",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [65, 78)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.178580",
      "level": "INFO",
      "message": "  Constraints: 36, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.178925",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 12 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.178931",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [78, 91)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.179183",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.179920",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 12 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.179927",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [91, 104)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.180104",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.180301",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 12 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.180307",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [104, 117)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.180587",
      "level": "INFO",
      "message": "  Constraints: 30, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.180870",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 14 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.180876",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [117, 130)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.181097",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.181393",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 17 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.181711",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [130, 143)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.181961",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.182376",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 17 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.182382",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [143, 156)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.182699",
      "level": "INFO",
      "message": "  Constraints: 36, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.183029",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 19 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.183035",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [156, 169)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.183220",
      "level": "INFO",
      "message": "  Constraints: 0, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.183417",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 19 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.183423",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [169, 182)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.184145",
      "level": "INFO",
      "message": "  Constraints: 12, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.184461",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 20 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.184470",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [182, 195)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.184742",
      "level": "INFO",
      "message": "  Constraints: 22, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.184991",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 20 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.184997",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [195, 213)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.185303",
      "level": "INFO",
      "message": "  Constraints: 32, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.185528",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 20 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:12.185533",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:12.193002",
      "level": "INFO",
      "message": "Total pos/neg pairs: 5,180"
    },
    {
      "timestamp": "2025-12-12T20:50:12.193427",
      "level": "INFO",
      "message": "Separation violations: 56 (1.08%)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.193435",
      "level": "INFO",
      "message": "\u26a0 Global separation VIOLATED (56 pairs are identical)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.193462",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:12.195997",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:12.196005",
      "level": "INFO",
      "message": "Compression: 200 \u2192 20 (90.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196012",
      "level": "INFO",
      "message": "TM accuracy: train=0.8310, test=0.7963"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196018",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8357, test=0.8704"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196023",
      "level": "INFO",
      "message": "Fidelity: train=0.9671, test=0.9259"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196029",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0741"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196035",
      "level": "INFO",
      "message": "Patterns: 98"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196468",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:12.196476",
      "level": "INFO",
      "message": "Train: 213 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.196482",
      "level": "INFO",
      "message": "Test:  39 exact / 15 fallback (27.8%)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197030",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197038",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197044",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197049",
      "level": "INFO",
      "message": "Dataset: SPECT Heart (22 binary features)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197059",
      "level": "INFO",
      "message": "Compression: 200 \u2192 20 clauses (90.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197065",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197070",
      "level": "INFO",
      "message": "Train time: 0.1s"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197516",
      "level": "INFO",
      "message": "Test fidelity: 92.59%"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197523",
      "level": "INFO",
      "message": "Test acc delta: +0.0741"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197529",
      "level": "INFO",
      "message": "Patterns: 98"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197538",
      "level": "INFO",
      "message": "Test fallback rate: 27.8%"
    },
    {
      "timestamp": "2025-12-12T20:50:12.197545",
      "level": "INFO",
      "message": "Global separation: \u26a0 VIOLATED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 20,
      "compression_ratio": 0.9,
      "tm_train_acc": 0.8309859154929577,
      "tm_test_acc": 0.7962962962962963,
      "compressed_train_acc": 0.8356807511737089,
      "compressed_test_acc": 0.8703703703703703,
      "train_fidelity": 0.9671361502347418,
      "test_fidelity": 0.9259259259259259,
      "test_acc_delta": 0.07407407407407407,
      "n_patterns": 98,
      "n_train": 213,
      "n_test": 54,
      "train_fallback": {
        "n_exact_matches": 213,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "test_fallback": {
        "n_exact_matches": 39,
        "n_fallback": 15,
        "fallback_rate": 0.2777777777777778
      },
      "solve_time": 0.005307912826538086,
      "train_time": 0.13440585136413574,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 456,
      "dataset": "spect-heart",
      "dataset_name": "SPECT Heart (22 binary features)",
      "weighted": true,
      "verification": {
        "total_pairs": 5180,
        "violations": 56,
        "violation_rate": 0.010810810810810811,
        "global_separation_preserved": false
      }
    }
  ],
  "end_time": "2025-12-12T20:50:12.197547"
}