"""
Basic usage demo for the four regression-tree models in `clari_tree`.

Each model supports fast fitting via `.fit(X, y)` and prediction via `.predict(X)`.
Here we show both constant-leaf and linear-leaf variants.
"""

import numpy as np
import pandas as pd
from sklearn.metrics import r2_score
from clari_tree import (
    Greedy, CLARITree,
    GreedyConst,   CLARITreeConst, read_csv
)

# === Load a regression dataset (replace with your own CSV) ===
# read_csv returns (X, y) tuple where X already includes intercept column
X, y = read_csv("data/auction/auction_continuous.csv")

# === Example 1: CLARITreeConst (constant-leaf CLARITree) ===
model = CLARITreeConst(depth=4, lambda_=0.001, stride=1, verbose=False)
loss = model.fit(X, y)
print("CLARITreeConst training loss =", loss)
print("Training R² =", r2_score(y, model.predict(X)))
print("Number of leaves =", model.n_leaves())
print(model.print_tree())

# === Example 2: CLARITree (linear-leaf) ===
model = CLARITree(depth=4, kappa=0.001, lambda_=0.001, stride=1, verbose=False)
loss = model.fit(X, y)
print("CLARITree training loss =", loss)
print("Training R² =", r2_score(y, model.predict(X)))
print("Number of leaves =", model.n_leaves())
print(model.print_tree())

# === Optional: greedy baseline variants for comparison ===
# model = GreedyConst(depth=5, lambda_=0.1)
# model = Greedy(depth=5, lambda_=0.1, ridge_penalty=0.1)
# (same API)
