{
  "experiment": "imli_banknote_p16_s42_w",
  "start_time": "2025-12-12T20:50:16.993658",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:16.994022",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994033",
      "level": "INFO",
      "message": "  Dataset: banknote"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994041",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994049",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994054",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994061",
      "level": "INFO",
      "message": "  Seed: 42"
    },
    {
      "timestamp": "2025-12-12T20:50:16.994066",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:16.994071",
      "level": "INFO",
      "message": "Loading banknote dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:18.743759",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:18.743785",
      "level": "INFO",
      "message": "  Train: 1097 samples, 4 features"
    },
    {
      "timestamp": "2025-12-12T20:50:18.744433",
      "level": "INFO",
      "message": "  Test: 275 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:18.744594",
      "level": "INFO",
      "message": "  Class distribution: [609 488]"
    },
    {
      "timestamp": "2025-12-12T20:50:18.744612",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:18.744625",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:18.746187",
      "level": "INFO",
      "message": "  Train subset: 877 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:18.746203",
      "level": "INFO",
      "message": "  Validation: 220 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:18.746216",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:18.746236",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=42"
    },
    {
      "timestamp": "2025-12-12T20:50:18.878331",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8757"
    },
    {
      "timestamp": "2025-12-12T20:50:18.980334",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:19.083812",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:19.188613",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:19.290614",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:19.291608",
      "level": "INFO",
      "message": "Training complete in 0.5s, acc=0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:19.294998",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295005",
      "level": "INFO",
      "message": "  Train acc: 0.8733"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295010",
      "level": "INFO",
      "message": "  Test acc: 0.8945"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295015",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295020",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295024",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.295371",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.298088",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298100",
      "level": "INFO",
      "message": "  Min utility: -0.1958, Max: 0.1792"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298138",
      "level": "INFO",
      "message": "  Mean cost: 4.76, Std: 2.46"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298150",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 86"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298157",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298169",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298176",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298240",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~68 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298252",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=4.76)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.298484",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 68)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.305646",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.309212",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.309221",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [68, 136)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.315726",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.317744",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.317751",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [136, 204)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.324224",
      "level": "INFO",
      "message": "  Constraints: 1,140, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.326059",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.326067",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [204, 272)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.332755",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.334598",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.334605",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [272, 340)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.342012",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.344439",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.344446",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [340, 408)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.351355",
      "level": "INFO",
      "message": "  Constraints: 1,107, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.353406",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.353413",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [408, 476)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.360383",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.363020",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.363029",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [476, 544)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.369757",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.371661",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.371668",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [544, 612)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.378273",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.380205",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.380212",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [612, 680)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.387192",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.389336",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.389758",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [680, 748)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.396504",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.398566",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.398573",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [748, 816)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.405075",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.406859",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.406866",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [816, 884)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.413448",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.415700",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.415707",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [884, 952)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.423260",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.425454",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.425460",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [952, 1020)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.432060",
      "level": "INFO",
      "message": "  Constraints: 1,120, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.434071",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.434080",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [1020, 1097)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.442214",
      "level": "INFO",
      "message": "  Constraints: 1,482, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.444408",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 5 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:19.444415",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:19.834202",
      "level": "INFO",
      "message": "Total pos/neg pairs: 297,070"
    },
    {
      "timestamp": "2025-12-12T20:50:19.834726",
      "level": "INFO",
      "message": "Separation violations: 0 (0.00%)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.834734",
      "level": "INFO",
      "message": "\u2713 Global separation PRESERVED (all pairs differ in \u22651 clause)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.834871",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.840522",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:19.840530",
      "level": "INFO",
      "message": "Compression: 200 \u2192 5 (97.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.840536",
      "level": "INFO",
      "message": "TM accuracy: train=0.8733, test=0.8945"
    },
    {
      "timestamp": "2025-12-12T20:50:19.840541",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8733, test=0.8945"
    },
    {
      "timestamp": "2025-12-12T20:50:19.840546",
      "level": "INFO",
      "message": "Fidelity: train=1.0000, test=1.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:19.840552",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:19.840557",
      "level": "INFO",
      "message": "Patterns: 7"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841025",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:19.841031",
      "level": "INFO",
      "message": "Train: 1097 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841036",
      "level": "INFO",
      "message": "Test:  275 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841553",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841558",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841563",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841568",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841575",
      "level": "INFO",
      "message": "Compression: 200 \u2192 5 clauses (97.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841580",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:19.841586",
      "level": "INFO",
      "message": "Train time: 0.5s"
    },
    {
      "timestamp": "2025-12-12T20:50:19.842003",
      "level": "INFO",
      "message": "Test fidelity: 100.00%"
    },
    {
      "timestamp": "2025-12-12T20:50:19.842009",
      "level": "INFO",
      "message": "Test acc delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:19.842013",
      "level": "INFO",
      "message": "Patterns: 7"
    },
    {
      "timestamp": "2025-12-12T20:50:19.842018",
      "level": "INFO",
      "message": "Test fallback rate: 0.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:19.842023",
      "level": "INFO",
      "message": "Global separation: \u2713 PRESERVED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 5,
      "compression_ratio": 0.975,
      "tm_train_acc": 0.8732907930720146,
      "tm_test_acc": 0.8945454545454545,
      "compressed_train_acc": 0.8732907930720146,
      "compressed_test_acc": 0.8945454545454545,
      "train_fidelity": 1.0,
      "test_fidelity": 1.0,
      "test_acc_delta": 0.0,
      "n_patterns": 7,
      "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.03417682647705078,
      "train_time": 0.5443623065948486,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 42,
      "dataset": "banknote",
      "dataset_name": "Banknote Authentication",
      "weighted": true,
      "verification": {
        "total_pairs": 297070,
        "violations": 0,
        "violation_rate": 0.0,
        "global_separation_preserved": true
      }
    }
  ],
  "end_time": "2025-12-12T20:50:19.842025"
}