# CRAMER: Control via Request-Aware Masking for Editing Recommenders

This repo contains our implementation of CRAMER for request-aware sequential recommendation.

---

## 1) Overview & Directory Structure

```
cramer/
├── __init__.py                
├── cli.py                  
├── cul.py                    
├── train.py                
├── tools/
│   ├── apply.py            
│   ├── data_utils.py         
│   ├── gumbel.py            
│   ├── masked.py            
│   ├── spec.py           
│   └── tau.py             
└── backends/
    ├── __init__.py         
    ├── sasrec.py      
    └── bert4rec.py    
```

---

## 2) File-by-file (one-line purpose)

* `cramer/__init__.py` — Re-exports the main symbols for convenient import.
* `cramer/cli.py` — Command-line script to load a RecBole checkpoint and train CRAMER.
* `cramer/cul.py` — Request encoder + projection to logits.
* `cramer/train.py` — Full training loop.
* `cramer/tools/apply.py` — Turn 1D gates into row/col masks and attach them to wrappers.
* `cramer/tools/data_utils.py` — Decode `req_text` from Interaction.
* `cramer/tools/gumbel.py` — Gumbel noise + Top-k + STE composite.
* `cramer/tools/masked.py` — Lightweight wrappers.
* `cramer/tools/spec.py` — Definitions for row/col indexing over layers.
* `cramer/tools/tau.py` — Temperature scheduling utilities.
* `cramer/backends/__init__.py` — Backend hook protocol and `get_backend("sasrec"|"bert4rec")`.
* `cramer/backends/sasrec.py` — **RecBole-only** SASRec: find layers, build specs, patch FFN/W\_O.
* `cramer/backends/bert4rec.py` — **RecBole-only** BERT4Rec: find layers, build specs, patch FFN/W\_O.

---

## 3) Installation & Requirements

* Python ≥ 3.9
* PyTorch ≥ 1.13

```bash
pip install torch recbole transformers
```

---

## 4) Data & Checkpoints

* This code expects a **RecBole checkpoint** (`.pth`) produced by training **SASRec** or **BERT4Rec**.
* For request-aware training, your Interaction (`.inter` file) must include `req_text` (token\_seq or string) and optionally `sid`.
* The CLI rebuilds a RecBole dataset with:
  ```yaml
  load_col:
    inter: [user_id, item_id, timestamp, req_text, sid]
  ```
* If `req_text` is missing at batch time, a **sid→request** fallback is attempted via the dataset’s `.inter` file.

---


## [Disclaimer]

> **This implementation is provided only for the purpose of paper submission and peer review.**

