{
  "experiment": "imli_banknote_p16_s123_w",
  "start_time": "2025-12-12T20:50:17.888434",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:17.888809",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888817",
      "level": "INFO",
      "message": "  Dataset: banknote"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888823",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888828",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888833",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888838",
      "level": "INFO",
      "message": "  Seed: 123"
    },
    {
      "timestamp": "2025-12-12T20:50:17.888842",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:17.888847",
      "level": "INFO",
      "message": "Loading banknote dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.719457",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:19.719466",
      "level": "INFO",
      "message": "  Train: 1097 samples, 4 features"
    },
    {
      "timestamp": "2025-12-12T20:50:19.719755",
      "level": "INFO",
      "message": "  Test: 275 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:19.719815",
      "level": "INFO",
      "message": "  Class distribution: [609 488]"
    },
    {
      "timestamp": "2025-12-12T20:50:19.719822",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:19.719826",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:19.720380",
      "level": "INFO",
      "message": "  Train subset: 877 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:19.720386",
      "level": "INFO",
      "message": "  Validation: 220 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:19.720391",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:19.720398",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=123"
    },
    {
      "timestamp": "2025-12-12T20:50:19.825000",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:19.931367",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:20.037883",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:20.143421",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:20.251575",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:20.252599",
      "level": "INFO",
      "message": "Training complete in 0.5s, acc=0.8780"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256214",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256221",
      "level": "INFO",
      "message": "  Train acc: 0.8769"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256226",
      "level": "INFO",
      "message": "  Test acc: 0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256232",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256237",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256242",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.256557",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.259496",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259508",
      "level": "INFO",
      "message": "  Min utility: -0.1466, Max: 0.1912"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259550",
      "level": "INFO",
      "message": "  Mean cost: 4.75, Std: 3.28"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259561",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 79"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259568",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259573",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259578",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259637",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~68 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259649",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=4.75)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.259891",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 68)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.266585",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.270197",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.270211",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [68, 136)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.277638",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.279882",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.279890",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [136, 204)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.287603",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.289913",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.289921",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [204, 272)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.298059",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.300333",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.300340",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [272, 340)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.307660",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.309719",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.309726",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [340, 408)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.317524",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.319768",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.319775",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [408, 476)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.326929",
      "level": "INFO",
      "message": "  Constraints: 1,075, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.329399",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.329406",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [476, 544)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.337385",
      "level": "INFO",
      "message": "  Constraints: 1,107, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.339759",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.339766",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [544, 612)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.347623",
      "level": "INFO",
      "message": "  Constraints: 1,140, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.349862",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.349868",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [612, 680)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.356860",
      "level": "INFO",
      "message": "  Constraints: 1,140, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.358773",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.359208",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [680, 748)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.367726",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.370265",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.370271",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [748, 816)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.377369",
      "level": "INFO",
      "message": "  Constraints: 1,156, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.379346",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.379352",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [816, 884)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.385414",
      "level": "INFO",
      "message": "  Constraints: 987, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.387196",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.387203",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [884, 952)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.395661",
      "level": "INFO",
      "message": "  Constraints: 1,140, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.397951",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.397958",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [952, 1020)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.405501",
      "level": "INFO",
      "message": "  Constraints: 1,107, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.407733",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.407739",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [1020, 1097)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.417983",
      "level": "INFO",
      "message": "  Constraints: 1,480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.420969",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.420974",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:20.837202",
      "level": "INFO",
      "message": "Total pos/neg pairs: 296,022"
    },
    {
      "timestamp": "2025-12-12T20:50:20.837647",
      "level": "INFO",
      "message": "Separation violations: 0 (0.00%)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.837653",
      "level": "INFO",
      "message": "\u2713 Global separation PRESERVED (all pairs differ in \u22651 clause)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.837834",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.843357",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:20.843364",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843370",
      "level": "INFO",
      "message": "TM accuracy: train=0.8769, test=0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843376",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8769, test=0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843381",
      "level": "INFO",
      "message": "Fidelity: train=1.0000, test=1.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843387",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843392",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843823",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:20.843829",
      "level": "INFO",
      "message": "Train: 1097 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.843833",
      "level": "INFO",
      "message": "Test:  275 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844347",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844352",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844357",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844361",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844368",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 clauses (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844374",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844380",
      "level": "INFO",
      "message": "Train time: 0.5s"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844789",
      "level": "INFO",
      "message": "Test fidelity: 100.00%"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844819",
      "level": "INFO",
      "message": "Test acc delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844827",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844833",
      "level": "INFO",
      "message": "Test fallback rate: 0.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844839",
      "level": "INFO",
      "message": "Global separation: \u2713 PRESERVED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 4,
      "compression_ratio": 0.98,
      "tm_train_acc": 0.8769371011850501,
      "tm_test_acc": 0.88,
      "compressed_train_acc": 0.8769371011850501,
      "compressed_test_acc": 0.88,
      "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.036852121353149414,
      "train_time": 0.5311741828918457,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 123,
      "dataset": "banknote",
      "dataset_name": "Banknote Authentication",
      "weighted": true,
      "verification": {
        "total_pairs": 296022,
        "violations": 0,
        "violation_rate": 0.0,
        "global_separation_preserved": true
      }
    }
  ],
  "end_time": "2025-12-12T20:50:20.844841"
}