# Local Covariate Selection (LCS)

This document describes the implementation details of the **Local Covariate Selection (LCS)** algorithm used in the experiments.

LCS is a local, rule-based causal inference method that identifies valid adjustment sets around a treatment variable and estimates causal effects from observational data.

# Function Interface

```python
alg_LCS(data, Tr_X, Out_Y, max_k=3, CI_type="Fisher_Z", alpha=0.01)
```

# Parameters

* **`data`** (`pd.DataFrame`)
  Observational data in **samples × variables** format.
  Each column corresponds to an observed variable.

* **`Tr_X`** (`str`)
  Name of the treatment variable.

* **`Out_Y`** (`str`)
  Name of the outcome variable.

* **`max_k`** (`int`, optional, default = `3`)
  Maximum size of conditioning sets considered in conditional independence tests
  during local structure learning.

* **`CI_type`** (`str`, optional, default = `"Fisher_Z"`)
  Conditional independence test used by LCS.
  In the experiments, Fisher’s Z test is used for continuous observational data.

* **`alpha`** (`float`, optional, default = `0.01`)
  Significance level for conditional independence tests.


# Output

The function returns a dictionary with the following fields:

* **`VASs`**
  Identified valid adjustment set(s):

  * a list of dictionaries of the form
    `{"VAS": [Z₁, Z₂, …]}`, or
  * `0`, indicating that LCS concludes **no causal effect** exists, or
  * `None`, indicating that LCS cannot draw a definitive conclusion.

* **`ATE`**
  Estimated average treatment effect.
  If one or more valid adjustment sets are identified, the reported ATE is the
  **average of the effect estimates across all identified adjustment sets**.

* **`CI_num`**
  Number of conditional independence tests performed by LCS.

# Example Usage

```python
import pandas as pd
import re

# Load data
data_V = pd.read_csv("Data/example_data_5000.csv")

# Remove latent variables (e.g., L1, L2, ...)
data_O = data_V[[c for c in data_V.columns if not re.match(r"^L\d+$", c)]]

# Specify treatment and outcome
Tr_X = "X"
Out_Y = "Y"

# Run LCS with default parameters
result = alg_LCS(data_O, Tr_X, Out_Y)

print(result)
```



