{
  "experiment": "imli_banknote_p16_s456_w",
  "start_time": "2025-12-12T20:50:18.314701",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:18.315117",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315125",
      "level": "INFO",
      "message": "  Dataset: banknote"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315131",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315136",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315141",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315146",
      "level": "INFO",
      "message": "  Seed: 456"
    },
    {
      "timestamp": "2025-12-12T20:50:18.315150",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:18.315155",
      "level": "INFO",
      "message": "Loading banknote dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.173836",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:20.173847",
      "level": "INFO",
      "message": "  Train: 1097 samples, 4 features"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174119",
      "level": "INFO",
      "message": "  Test: 275 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174189",
      "level": "INFO",
      "message": "  Class distribution: [609 488]"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174197",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174202",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174781",
      "level": "INFO",
      "message": "  Train subset: 877 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174787",
      "level": "INFO",
      "message": "  Validation: 220 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:20.174792",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.174798",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=456"
    },
    {
      "timestamp": "2025-12-12T20:50:20.283503",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.393346",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.503182",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.612172",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.720933",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.721926",
      "level": "INFO",
      "message": "Training complete in 0.5s, acc=0.8791"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725507",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725514",
      "level": "INFO",
      "message": "  Train acc: 0.8815"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725521",
      "level": "INFO",
      "message": "  Test acc: 0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725526",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725531",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725536",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.725885",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.728784",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728798",
      "level": "INFO",
      "message": "  Min utility: -0.1429, Max: 0.1675"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728841",
      "level": "INFO",
      "message": "  Mean cost: 3.62, Std: 2.75"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728854",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 28"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728861",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728874",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728880",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728923",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~68 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:20.728937",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=3.62)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.729167",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 68)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.736377",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.739528",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.739538",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [68, 136)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.747925",
      "level": "INFO",
      "message": "  Constraints: 1,155, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.750718",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.750725",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [136, 204)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.758614",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.761174",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.761181",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [204, 272)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.768132",
      "level": "INFO",
      "message": "  Constraints: 960, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.770177",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.770184",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [272, 340)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.777773",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.780002",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.780009",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [340, 408)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.788647",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.791585",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.791596",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [408, 476)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.799478",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.802284",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.802293",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [476, 544)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.810319",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.812735",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.812745",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [544, 612)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.820506",
      "level": "INFO",
      "message": "  Constraints: 1,156, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.822964",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.822972",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [612, 680)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.831145",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.833627",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.834049",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [680, 748)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.841847",
      "level": "INFO",
      "message": "  Constraints: 1,131, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.844120",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.844127",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [748, 816)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.851491",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.853928",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.853939",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [816, 884)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.860961",
      "level": "INFO",
      "message": "  Constraints: 1,107, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.863006",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.863016",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [884, 952)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.871139",
      "level": "INFO",
      "message": "  Constraints: 1,147, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.873298",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.873309",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [952, 1020)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.880533",
      "level": "INFO",
      "message": "  Constraints: 1,152, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.882785",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.882801",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [1020, 1097)"
    },
    {
      "timestamp": "2025-12-12T20:50:20.892412",
      "level": "INFO",
      "message": "  Constraints: 1,480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:20.895128",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 4 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:20.895136",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:21.315674",
      "level": "INFO",
      "message": "Total pos/neg pairs: 300,040"
    },
    {
      "timestamp": "2025-12-12T20:50:21.316298",
      "level": "INFO",
      "message": "Separation violations: 0 (0.00%)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.316306",
      "level": "INFO",
      "message": "\u2713 Global separation PRESERVED (all pairs differ in \u22651 clause)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.316476",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:21.322076",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:21.322085",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322092",
      "level": "INFO",
      "message": "TM accuracy: train=0.8815, test=0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322098",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8815, test=0.8800"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322103",
      "level": "INFO",
      "message": "Fidelity: train=1.0000, test=1.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322109",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322114",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322636",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:21.322643",
      "level": "INFO",
      "message": "Train: 1097 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.322648",
      "level": "INFO",
      "message": "Test:  275 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323183",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323189",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323193",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323199",
      "level": "INFO",
      "message": "Dataset: Banknote Authentication"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323207",
      "level": "INFO",
      "message": "Compression: 200 \u2192 4 clauses (98.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323213",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323219",
      "level": "INFO",
      "message": "Train time: 0.5s"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323647",
      "level": "INFO",
      "message": "Test fidelity: 100.00%"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323653",
      "level": "INFO",
      "message": "Test acc delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323659",
      "level": "INFO",
      "message": "Patterns: 5"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323667",
      "level": "INFO",
      "message": "Test fallback rate: 0.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:21.323673",
      "level": "INFO",
      "message": "Global separation: \u2713 PRESERVED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 4,
      "compression_ratio": 0.98,
      "tm_train_acc": 0.8814949863263446,
      "tm_test_acc": 0.88,
      "compressed_train_acc": 0.8814949863263446,
      "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.03897905349731445,
      "train_time": 0.5461268424987793,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 456,
      "dataset": "banknote",
      "dataset_name": "Banknote Authentication",
      "weighted": true,
      "verification": {
        "total_pairs": 300040,
        "violations": 0,
        "violation_rate": 0.0,
        "global_separation_preserved": true
      }
    }
  ],
  "end_time": "2025-12-12T20:50:21.323675"
}