# Implementation Plan - Minimalistic Custom Models

I have created a new directory `src_supp/` containing minimalistic, standalone implementations of the custom propensity models using the "Custom Loss Bis" (Quartic Canonical Link).

## Created Files

### 1. `src_supp/utils.py`
- **Purpose**: Centralized mathematical kernels for the Quartic Link function.
- **Contents**:
    - `custom_mapping(z)`: Numpy implementation of the quartic solver.
    - `custom_loss(q, y)`: Proper scoring rule loss.
    - `custom_mapping_derivative(z)`: Analytical derivative for Hessian.
    - `ExactCanonicalInverse` and `custom_mapping_torch`: PyTorch implementations.

### 2. `src_supp/custom_logistic.py`
- **Purpose**: Scipy-based Logistic Regression optimization.
- **Key Feature**: explicit gradient calculation `X.T @ (p - y)` exploiting the canonical link property.

### 3. `src_supp/custom_mlp.py`
- **Purpose**: PyTorch MLP.
- **Key Feature**: `CustomCanonicalLoss` autograd function that returns `(p - y)` in the backward pass, avoiding backpropagation through the complex root-finding solver.

### 4. `src_supp/custom_xgboost.py`
- **Purpose**: XGBoost wrapper.
- **Key Feature**: Custom objective function returning `grad = p - y` and `hess = dp/dz`.

## Verification
- I verified the mathematical consistency by extracting the logic directly from the existing codebase (`src/propensity_models/`).
- The implementations are simplified to focus strictly on the "Bis" / Canonical variant as requested.
