{
  "experiment": "imli_banknote_p16_s1001_w",
  "start_time": "2025-12-12T20:50:20.798420",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:20.798777",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798788",
      "level": "INFO",
      "message": "  Dataset: banknote"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798795",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798802",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798807",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798821",
      "level": "INFO",
      "message": "  Seed: 1001"
    },
    {
      "timestamp": "2025-12-12T20:50:20.798830",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:20.798835",
      "level": "INFO",
      "message": "Loading banknote dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:22.707966",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:22.707993",
      "level": "INFO",
      "message": "  Train: 1097 samples, 4 features"
    },
    {
      "timestamp": "2025-12-12T20:50:22.708744",
      "level": "INFO",
      "message": "  Test: 275 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:22.708902",
      "level": "INFO",
      "message": "  Class distribution: [609 488]"
    },
    {
      "timestamp": "2025-12-12T20:50:22.708920",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:22.708934",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:22.710540",
      "level": "INFO",
      "message": "  Train subset: 877 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:22.710557",
      "level": "INFO",
      "message": "  Validation: 220 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:22.710571",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:22.710592",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=1001"
    },
    {
      "timestamp": "2025-12-12T20:50:22.843169",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8803"
    },
    {
      "timestamp": "2025-12-12T20:50:22.950627",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8803"
    },
    {
      "timestamp": "2025-12-12T20:50:23.060250",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8803"
    },
    {
      "timestamp": "2025-12-12T20:50:23.169788",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8860"
    },
    {
      "timestamp": "2025-12-12T20:50:23.279115",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8803"
    },
    {
      "timestamp": "2025-12-12T20:50:23.280464",
      "level": "INFO",
      "message": "Training complete in 0.6s, acc=0.8803"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284117",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284127",
      "level": "INFO",
      "message": "  Train acc: 0.8842"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284133",
      "level": "INFO",
      "message": "  Test acc: 0.8509"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284139",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284145",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284150",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.284550",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.287494",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287508",
      "level": "INFO",
      "message": "  Min utility: -0.1515, Max: 0.2525"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287553",
      "level": "INFO",
      "message": "  Mean cost: 3.48, Std: 2.11"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287566",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 27"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287573",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287580",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287585",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287627",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~68 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287642",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=3.48)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.287908",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 68)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.295142",
      "level": "INFO",
      "message": "  Constraints: 1,092, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.298781",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.298789",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [68, 136)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.305501",
      "level": "INFO",
      "message": "  Constraints: 1,035, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.307119",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.307127",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [136, 204)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.314023",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.315697",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.315703",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [204, 272)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.323920",
      "level": "INFO",
      "message": "  Constraints: 1,107, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.325741",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.325751",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [272, 340)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.333038",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.334737",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.334745",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [340, 408)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.341930",
      "level": "INFO",
      "message": "  Constraints: 1,075, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.343590",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.343597",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [408, 476)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.351134",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.353310",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.353317",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [476, 544)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.360910",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.362694",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.362701",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [544, 612)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.369230",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.370676",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.370683",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [612, 680)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.378058",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.379702",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.380056",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [680, 748)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.386590",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.388187",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.388221",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [748, 816)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.394784",
      "level": "INFO",
      "message": "  Constraints: 987, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.396441",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.396450",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [816, 884)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.403479",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.405394",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.405402",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [884, 952)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.412953",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.414614",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.414621",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [952, 1020)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.422195",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.423862",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.423869",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [1020, 1097)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.433138",
      "level": "INFO",
      "message": "  Constraints: 1,482, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.435216",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:23.435221",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:23.851968",
      "level": "INFO",
      "message": "Total pos/neg pairs: 296,296"
    },
    {
      "timestamp": "2025-12-12T20:50:23.852408",
      "level": "INFO",
      "message": "Separation violations: 0 (0.00%)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.852417",
      "level": "INFO",
      "message": "\u2713 Global separation PRESERVED (all pairs differ in \u22651 clause)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.852566",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:23.858117",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:23.858125",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858131",
      "level": "INFO",
      "message": "TM accuracy: train=0.8842, test=0.8509"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858136",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8842, test=0.8509"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858142",
      "level": "INFO",
      "message": "Fidelity: train=1.0000, test=1.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858147",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858154",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858551",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:23.858558",
      "level": "INFO",
      "message": "Train: 1097 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.858564",
      "level": "INFO",
      "message": "Test:  275 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859091",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859097",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859101",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859106",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859114",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 clauses (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859119",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859124",
      "level": "INFO",
      "message": "Train time: 0.6s"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859550",
      "level": "INFO",
      "message": "Test fidelity: 100.00%"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859556",
      "level": "INFO",
      "message": "Test acc delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859562",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859568",
      "level": "INFO",
      "message": "Test fallback rate: 0.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:23.859574",
      "level": "INFO",
      "message": "Global separation: \u2713 PRESERVED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 4,
      "compression_ratio": 0.98,
      "tm_train_acc": 0.8842297174111212,
      "tm_test_acc": 0.850909090909091,
      "compressed_train_acc": 0.8842297174111212,
      "compressed_test_acc": 0.850909090909091,
      "train_fidelity": 1.0,
      "test_fidelity": 1.0,
      "test_acc_delta": 0.0,
      "n_patterns": 5,
      "n_train": 1097,
      "n_test": 275,
      "train_fallback": {
        "n_exact_matches": 1097,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "test_fallback": {
        "n_exact_matches": 275,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "solve_time": 0.028900623321533203,
      "train_time": 0.5685141086578369,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 1001,
      "dataset": "banknote",
      "dataset_name": "Banknote Authentication",
      "weighted": true,
      "verification": {
        "total_pairs": 296296,
        "violations": 0,
        "violation_rate": 0.0,
        "global_separation_preserved": true
      }
    }
  ],
  "end_time": "2025-12-12T20:50:23.859576"
}