# Block Test Validation Suite

This directory contains a suite of Python scripts designed to validate subgoals and plans generated by a PDDL planner. It provides tools to check for the satisfiability of subgoals in the initial state, validate plans using the VAL tool, and summarize the results.

## Key Scripts

### `initial_state_checker.py`

This script uses `pydatalog` to determine if a set of subgoals is satisfiable given an initial state. It reads a JSON file containing the initial state and a list of plans with their corresponding subgoals. For each plan, it asserts the initial state predicates as facts into a PyDatalog engine and then queries the engine to check if the subgoals hold true.

**Usage:**

```bash
python initial_state_checker.py --input <path_to_plan_output>.json --output <path_to_results>.json
```

This will produce a JSON file containing a detailed evaluation of each plan's subgoals against the initial state.

### `plan_to_subgoals.py`

This script processes the output from the `NLFOLRegressionPlanner` and converts it into a structured JSON format. It extracts the regressed subgoals and the corresponding action sequences for each potential plan. It can also convert the natural language-like representation of predicates and actions into standard PDDL format.

**Usage:**

```bash
python plan_to_subgoals.py \
  --domain <domain>.json \
  --problem <problem>.json \
  --max-depth 3 \
  --out <subgoals_output>.json
```

### `validate_with_val.py`

This script uses the external PDDL validator, **VAL**, to verify if a given plan is valid. It works by constructing a temporary PDDL problem file where the subgoals are set as the initial state (`:init`). It then invokes the VAL tool to check if the sequence of actions can successfully achieve the problem's original goal from this new initial state.

**Prerequisites:**

You must have the VAL tool compiled and available. The path to the `Validate` binary can be specified via the command line.

**Usage:**

```bash
python validate_with_val.py \
  --json <path_to_subgoals_output>.json \
  --domain <domain>.pddl \
  --problem <problem>.pddl \
  --val <path_to_val_binary> \
  --out <validation_summary>.json
```

### `summarize_out_pipeline.py`

After running the validation and satisfiability checks, this script aggregates the results from multiple `*_stats.json` files into a single summary. It provides statistics such as the average number of valid plans, the number of satisfiable subgoals, and more.

**Usage:**

```bash
python summarize_out_pipeline.py --dir <directory_with_stats_files>
```

