{
  "experiment": "imli_tictactoe_p16_s456_w",
  "start_time": "2025-12-12T20:50:13.359388",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:13.360111",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360121",
      "level": "INFO",
      "message": "  Dataset: tictactoe"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360129",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360135",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360141",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360147",
      "level": "INFO",
      "message": "  Seed: 456"
    },
    {
      "timestamp": "2025-12-12T20:50:13.360153",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:13.360158",
      "level": "INFO",
      "message": "Loading tictactoe dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.368019",
      "level": "INFO",
      "message": "Dataset: TicTacToe (27 one-hot features)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368028",
      "level": "INFO",
      "message": "  Train: 766 samples, 27 features"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368309",
      "level": "INFO",
      "message": "  Test: 192 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368370",
      "level": "INFO",
      "message": "  Class distribution: [265 501]"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368377",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368382",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368860",
      "level": "INFO",
      "message": "  Train subset: 612 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368865",
      "level": "INFO",
      "message": "  Validation: 154 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.368870",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.368877",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=456"
    },
    {
      "timestamp": "2025-12-12T20:50:13.466453",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8480"
    },
    {
      "timestamp": "2025-12-12T20:50:13.569433",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8497"
    },
    {
      "timestamp": "2025-12-12T20:50:13.670659",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8431"
    },
    {
      "timestamp": "2025-12-12T20:50:13.773111",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8497"
    },
    {
      "timestamp": "2025-12-12T20:50:13.873930",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.8513"
    },
    {
      "timestamp": "2025-12-12T20:50:13.875093",
      "level": "INFO",
      "message": "Training complete in 0.5s, acc=0.8513"
    },
    {
      "timestamp": "2025-12-12T20:50:13.878970",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.878978",
      "level": "INFO",
      "message": "  Train acc: 0.8394"
    },
    {
      "timestamp": "2025-12-12T20:50:13.878984",
      "level": "INFO",
      "message": "  Test acc: 0.7708"
    },
    {
      "timestamp": "2025-12-12T20:50:13.878990",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.878995",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:13.879000",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.879309",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.882242",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882256",
      "level": "INFO",
      "message": "  Min utility: -0.1245, Max: 0.2157"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882301",
      "level": "INFO",
      "message": "  Mean cost: 3.51, Std: 1.29"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882319",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 18"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882326",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882334",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882338",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882388",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~47 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882400",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=3.51)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.882668",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 47)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.884921",
      "level": "INFO",
      "message": "  Constraints: 462, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.887323",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 6 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.887333",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [47, 94)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.889513",
      "level": "INFO",
      "message": "  Constraints: 496, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.891014",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 16 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.891022",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [94, 141)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.892944",
      "level": "INFO",
      "message": "  Constraints: 420, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.893725",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 20 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.893733",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [141, 188)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.896049",
      "level": "INFO",
      "message": "  Constraints: 442, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.897016",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 24 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.897022",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [188, 235)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.899072",
      "level": "INFO",
      "message": "  Constraints: 442, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.899754",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 26 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.899761",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [235, 282)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.902072",
      "level": "INFO",
      "message": "  Constraints: 496, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.902794",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 27 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.902801",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [282, 329)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.904157",
      "level": "INFO",
      "message": "  Constraints: 280, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.905027",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 29 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.905034",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [329, 376)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.907025",
      "level": "INFO",
      "message": "  Constraints: 442, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.907765",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 32 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.907772",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [376, 423)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.909704",
      "level": "INFO",
      "message": "  Constraints: 462, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.910453",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 38 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.910460",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [423, 470)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.912626",
      "level": "INFO",
      "message": "  Constraints: 532, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.913283",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 39 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.913647",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [470, 517)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.915597",
      "level": "INFO",
      "message": "  Constraints: 462, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.916169",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 42 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.916176",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [517, 564)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.918192",
      "level": "INFO",
      "message": "  Constraints: 420, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.918824",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 43 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.918830",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [564, 611)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.921227",
      "level": "INFO",
      "message": "  Constraints: 480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.922040",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 44 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.922049",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [611, 658)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.924847",
      "level": "INFO",
      "message": "  Constraints: 496, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.925506",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 44 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.925515",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [658, 705)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.927673",
      "level": "INFO",
      "message": "  Constraints: 510, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.928387",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 45 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.928394",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [705, 766)"
    },
    {
      "timestamp": "2025-12-12T20:50:13.932414",
      "level": "INFO",
      "message": "  Constraints: 874, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:13.933450",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 47 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:13.933456",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:14.112895",
      "level": "INFO",
      "message": "Total pos/neg pairs: 124,488"
    },
    {
      "timestamp": "2025-12-12T20:50:14.113481",
      "level": "INFO",
      "message": "Separation violations: 278 (0.22%)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.113489",
      "level": "INFO",
      "message": "\u26a0 Global separation VIOLATED (278 pairs are identical)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.113609",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:14.129310",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:14.129323",
      "level": "INFO",
      "message": "Compression: 200 \u2192 47 (76.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129331",
      "level": "INFO",
      "message": "TM accuracy: train=0.8394, test=0.7708"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129337",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8446, test=0.7969"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129342",
      "level": "INFO",
      "message": "Fidelity: train=0.9634, test=0.8906"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129348",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0260"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129354",
      "level": "INFO",
      "message": "Patterns: 528"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129880",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:14.129888",
      "level": "INFO",
      "message": "Train: 766 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.129895",
      "level": "INFO",
      "message": "Test:  98 exact / 94 fallback (49.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130523",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130530",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130537",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130543",
      "level": "INFO",
      "message": "Dataset: TicTacToe (27 one-hot features)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130552",
      "level": "INFO",
      "message": "Compression: 200 \u2192 47 clauses (76.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130558",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130565",
      "level": "INFO",
      "message": "Train time: 0.5s"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130991",
      "level": "INFO",
      "message": "Test fidelity: 89.06%"
    },
    {
      "timestamp": "2025-12-12T20:50:14.130999",
      "level": "INFO",
      "message": "Test acc delta: +0.0260"
    },
    {
      "timestamp": "2025-12-12T20:50:14.131005",
      "level": "INFO",
      "message": "Patterns: 528"
    },
    {
      "timestamp": "2025-12-12T20:50:14.131012",
      "level": "INFO",
      "message": "Test fallback rate: 49.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:14.131018",
      "level": "INFO",
      "message": "Global separation: \u26a0 VIOLATED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 47,
      "compression_ratio": 0.765,
      "tm_train_acc": 0.839425587467363,
      "tm_test_acc": 0.7708333333333334,
      "compressed_train_acc": 0.8446475195822454,
      "compressed_test_acc": 0.796875,
      "train_fidelity": 0.9634464751958225,
      "test_fidelity": 0.890625,
      "test_acc_delta": 0.02604166666666663,
      "n_patterns": 528,
      "n_train": 766,
      "n_test": 192,
      "train_fallback": {
        "n_exact_matches": 766,
        "n_fallback": 0,
        "fallback_rate": 0.0
      },
      "test_fallback": {
        "n_exact_matches": 98,
        "n_fallback": 94,
        "fallback_rate": 0.4895833333333333
      },
      "solve_time": 0.013842105865478516,
      "train_time": 0.5050489902496338,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 456,
      "dataset": "tictactoe",
      "dataset_name": "TicTacToe (27 one-hot features)",
      "weighted": true,
      "verification": {
        "total_pairs": 124488,
        "violations": 278,
        "violation_rate": 0.0022331469699890753,
        "global_separation_preserved": false
      }
    }
  ],
  "end_time": "2025-12-12T20:50:14.131020"
}