{
  "experiment": "imli_tictactoe_p16_s1001_w",
  "start_time": "2025-12-12T20:50:15.153880",
  "status": "completed",
  "completed_tasks": 1,
  "total_tasks": 0,
  "log_entries": [
    {
      "timestamp": "2025-12-12T20:50:15.154255",
      "level": "INFO",
      "message": "IMLI Compression Experiment"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154263",
      "level": "INFO",
      "message": "  Dataset: tictactoe"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154269",
      "level": "INFO",
      "message": "  Partitions: 16"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154274",
      "level": "INFO",
      "message": "  Clauses: 100 per class"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154279",
      "level": "INFO",
      "message": "  Epochs: 100"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154284",
      "level": "INFO",
      "message": "  Seed: 1001"
    },
    {
      "timestamp": "2025-12-12T20:50:15.154288",
      "level": "INFO",
      "message": ""
    },
    {
      "timestamp": "2025-12-12T20:50:15.154293",
      "level": "INFO",
      "message": "Loading tictactoe dataset..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.163233",
      "level": "INFO",
      "message": "Dataset: TicTacToe (27 one-hot features)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.163243",
      "level": "INFO",
      "message": "  Train: 766 samples, 27 features"
    },
    {
      "timestamp": "2025-12-12T20:50:15.163477",
      "level": "INFO",
      "message": "  Test: 192 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:15.163542",
      "level": "INFO",
      "message": "  Class distribution: [265 501]"
    },
    {
      "timestamp": "2025-12-12T20:50:15.163549",
      "level": "INFO",
      "message": "\n\u2699\ufe0f  Weighted compression mode enabled"
    },
    {
      "timestamp": "2025-12-12T20:50:15.163554",
      "level": "INFO",
      "message": "Splitting training set: 80% train, 20% validation"
    },
    {
      "timestamp": "2025-12-12T20:50:15.164071",
      "level": "INFO",
      "message": "  Train subset: 612 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:15.164077",
      "level": "INFO",
      "message": "  Validation: 154 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:15.164082",
      "level": "INFO",
      "message": "\nTraining Tsetlin Machine..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.164089",
      "level": "INFO",
      "message": "Training TM: 100 clauses, 100 epochs, seed=1001"
    },
    {
      "timestamp": "2025-12-12T20:50:15.262631",
      "level": "INFO",
      "message": "  Epoch 20/100: acc=0.8693"
    },
    {
      "timestamp": "2025-12-12T20:50:15.363975",
      "level": "INFO",
      "message": "  Epoch 40/100: acc=0.8954"
    },
    {
      "timestamp": "2025-12-12T20:50:15.466733",
      "level": "INFO",
      "message": "  Epoch 60/100: acc=0.8905"
    },
    {
      "timestamp": "2025-12-12T20:50:15.567634",
      "level": "INFO",
      "message": "  Epoch 80/100: acc=0.8971"
    },
    {
      "timestamp": "2025-12-12T20:50:15.669319",
      "level": "INFO",
      "message": "  Epoch 100/100: acc=0.9020"
    },
    {
      "timestamp": "2025-12-12T20:50:15.670515",
      "level": "INFO",
      "message": "Training complete in 0.5s, acc=0.9020"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674453",
      "level": "INFO",
      "message": "\nTM: 200 total clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674461",
      "level": "INFO",
      "message": "  Train acc: 0.8890"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674467",
      "level": "INFO",
      "message": "  Test acc: 0.8646"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674473",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674477",
      "level": "INFO",
      "message": "Computing Clause Importance Weights"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674482",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.674762",
      "level": "INFO",
      "message": "Computing clause utilities on validation set..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.677700",
      "level": "INFO",
      "message": "Clause utilities computed:"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677713",
      "level": "INFO",
      "message": "  Min utility: -0.0930, Max: 0.1625"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677754",
      "level": "INFO",
      "message": "  Mean cost: 3.62, Std: 1.66"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677766",
      "level": "INFO",
      "message": "  High-value clauses (cost>5): 39"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677773",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677779",
      "level": "INFO",
      "message": "Weighted IMLI Compression (p=16)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677786",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677831",
      "level": "INFO",
      "message": "IMLI p=16, partition size: ~47 samples"
    },
    {
      "timestamp": "2025-12-12T20:50:15.677845",
      "level": "INFO",
      "message": "Using clause importance weighting (mean=3.62)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.678082",
      "level": "INFO",
      "message": "\nPartition 1/16: samples [0, 47)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.679867",
      "level": "INFO",
      "message": "  Constraints: 420, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.681554",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 9 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.681562",
      "level": "INFO",
      "message": "\nPartition 2/16: samples [47, 94)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.683747",
      "level": "INFO",
      "message": "  Constraints: 462, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.685306",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 16 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.685313",
      "level": "INFO",
      "message": "\nPartition 3/16: samples [94, 141)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.687298",
      "level": "INFO",
      "message": "  Constraints: 442, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.688126",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 18 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.688133",
      "level": "INFO",
      "message": "\nPartition 4/16: samples [141, 188)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.690663",
      "level": "INFO",
      "message": "  Constraints: 480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.691844",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 23 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.691851",
      "level": "INFO",
      "message": "\nPartition 5/16: samples [188, 235)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.694328",
      "level": "INFO",
      "message": "  Constraints: 550, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.695121",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 25 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.695128",
      "level": "INFO",
      "message": "\nPartition 6/16: samples [235, 282)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.697455",
      "level": "INFO",
      "message": "  Constraints: 532, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.698367",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 28 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.698377",
      "level": "INFO",
      "message": "\nPartition 7/16: samples [282, 329)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.700521",
      "level": "INFO",
      "message": "  Constraints: 420, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.702150",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 32 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.702160",
      "level": "INFO",
      "message": "\nPartition 8/16: samples [329, 376)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.704360",
      "level": "INFO",
      "message": "  Constraints: 496, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.705216",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 35 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.705226",
      "level": "INFO",
      "message": "\nPartition 9/16: samples [376, 423)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.707585",
      "level": "INFO",
      "message": "  Constraints: 532, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.708431",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 36 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.708439",
      "level": "INFO",
      "message": "\nPartition 10/16: samples [423, 470)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.711539",
      "level": "INFO",
      "message": "  Constraints: 442, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.712279",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 38 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.712741",
      "level": "INFO",
      "message": "\nPartition 11/16: samples [470, 517)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.715220",
      "level": "INFO",
      "message": "  Constraints: 532, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.715980",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 38 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.715989",
      "level": "INFO",
      "message": "\nPartition 12/16: samples [517, 564)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.718226",
      "level": "INFO",
      "message": "  Constraints: 480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.718937",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 38 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.718944",
      "level": "INFO",
      "message": "\nPartition 13/16: samples [564, 611)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.720827",
      "level": "INFO",
      "message": "  Constraints: 462, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.721612",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 41 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.721622",
      "level": "INFO",
      "message": "\nPartition 14/16: samples [611, 658)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.723805",
      "level": "INFO",
      "message": "  Constraints: 396, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.724705",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 45 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.724715",
      "level": "INFO",
      "message": "\nPartition 15/16: samples [658, 705)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.726869",
      "level": "INFO",
      "message": "  Constraints: 480, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.727592",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 45 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.727603",
      "level": "INFO",
      "message": "\nPartition 16/16: samples [705, 766)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.730640",
      "level": "INFO",
      "message": "  Constraints: 624, solving..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.731560",
      "level": "INFO",
      "message": "  Solved in 0.0s, kept 45 clauses"
    },
    {
      "timestamp": "2025-12-12T20:50:15.731568",
      "level": "INFO",
      "message": "\n=== Verifying Global Separation Property ==="
    },
    {
      "timestamp": "2025-12-12T20:50:15.912844",
      "level": "INFO",
      "message": "Total pos/neg pairs: 126,808"
    },
    {
      "timestamp": "2025-12-12T20:50:15.913370",
      "level": "INFO",
      "message": "Separation violations: 276 (0.22%)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.913378",
      "level": "INFO",
      "message": "\u26a0 Global separation VIOLATED (276 pairs are identical)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.913461",
      "level": "INFO",
      "message": "\nEvaluating compressed model..."
    },
    {
      "timestamp": "2025-12-12T20:50:15.928373",
      "level": "INFO",
      "message": "\n=== Evaluation Results ==="
    },
    {
      "timestamp": "2025-12-12T20:50:15.928388",
      "level": "INFO",
      "message": "Compression: 200 \u2192 45 (77.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928396",
      "level": "INFO",
      "message": "TM accuracy: train=0.8890, test=0.8646"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928402",
      "level": "INFO",
      "message": "Compressed accuracy: train=0.8890, test=0.8646"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928408",
      "level": "INFO",
      "message": "Fidelity: train=0.9713, test=0.8750"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928415",
      "level": "INFO",
      "message": "Test accuracy delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928420",
      "level": "INFO",
      "message": "Patterns: 478"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928874",
      "level": "INFO",
      "message": "\n=== Prediction Statistics ==="
    },
    {
      "timestamp": "2025-12-12T20:50:15.928882",
      "level": "INFO",
      "message": "Train: 766 exact / 0 fallback (0.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.928889",
      "level": "INFO",
      "message": "Test:  98 exact / 94 fallback (49.0%)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929428",
      "level": "INFO",
      "message": "\n============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929435",
      "level": "INFO",
      "message": "\u2705 EXPERIMENT COMPLETE"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929441",
      "level": "INFO",
      "message": "============================================================"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929446",
      "level": "INFO",
      "message": "Dataset: TicTacToe (27 one-hot features)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929455",
      "level": "INFO",
      "message": "Compression: 200 \u2192 45 clauses (77.5%)"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929462",
      "level": "INFO",
      "message": "Solve time: 0.0s"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929469",
      "level": "INFO",
      "message": "Train time: 0.5s"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929900",
      "level": "INFO",
      "message": "Test fidelity: 87.50%"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929906",
      "level": "INFO",
      "message": "Test acc delta: +0.0000"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929913",
      "level": "INFO",
      "message": "Patterns: 478"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929919",
      "level": "INFO",
      "message": "Test fallback rate: 49.0%"
    },
    {
      "timestamp": "2025-12-12T20:50:15.929925",
      "level": "INFO",
      "message": "Global separation: \u26a0 VIOLATED"
    }
  ],
  "results": [
    {
      "original_clauses": 200,
      "compressed_clauses": 45,
      "compression_ratio": 0.775,
      "tm_train_acc": 0.8890339425587467,
      "tm_test_acc": 0.8645833333333334,
      "compressed_train_acc": 0.8890339425587467,
      "compressed_test_acc": 0.8645833333333334,
      "train_fidelity": 0.9712793733681462,
      "test_fidelity": 0.875,
      "test_acc_delta": 0.0,
      "n_patterns": 478,
      "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.014986038208007812,
      "train_time": 0.5052239894866943,
      "n_partitions": 16,
      "n_clauses": 100,
      "epochs": 100,
      "seed": 1001,
      "dataset": "tictactoe",
      "dataset_name": "TicTacToe (27 one-hot features)",
      "weighted": true,
      "verification": {
        "total_pairs": 126808,
        "violations": 276,
        "violation_rate": 0.002176518831619456,
        "global_separation_preserved": false
      }
    }
  ],
  "end_time": "2025-12-12T20:50:15.929927"
}