# kernel-agent

An AscendC custom operator development intelligent agent framework based on "memory retrieval + value-driven selection (Q value) + multi-round generation/optimization + compilation/correctness/performance verification".

## Code Entry and Directory Structure

- `src/run.py`: Main entry (builds LLM/Embedder, MemorySystem, CodeAgent, Verifier, runs dataset tasks and writes to `outputs/`)
- `src/agents/`: Generation and memory strategies (`code_agent.py`, `retriever.py`, `memory_curator.py`)
- `src/memorykit/`: Memory objects and vector database encapsulation (Qdrant + RL metadata)
- `src/verification/`: Rule audit + LLM audit + compilation/runtime verification (including multi-process multi-NPU worker)
- `src/prompts/`: Generation/retrieval/summary/audit prompt templates
- `examples/`: KernelBench dataset and reference operator implementations (`examples/dataset.py` + category directories)
- `test/optimization_tree_visualization_3_20260115_123127.html`: "Optimization tree" visualization of one experiment (including node metrics and code snapshots)

## Paper Writing Materials (recommended to directly reference/rewrite)

- `pipeline.md`: End-to-end pipeline and module mapping (more of a "system manual")
- `docs/paper_materials.md`: Method/algorithm/implementation details/experiment setup points organized by paper structure

## Key Verification/Anti-cheating Logic (can write about "security constraints/architecture consistency" in paper)

- `src/verification/rules_checker.py`: Static rules
  - `CodeFilter.filter_code()`: Constrains `ModelNew` from using `torch/aten` to reproduce semantics, must call `custom_ops_lib`
  - `filter_pybind_src()` / `evaluate_pybind_src()`: Constrains `python_bind_src` to only "allocate output + EXEC_NPU_CMD scheduling + return output"
- `src/verification/checker.py` + `src/prompts/verifer_prompt.py`: LLM as "architecture auditor" model-checker

## Running Method (environment dependencies are strong)

- Local verification: Requires Ascend CANN/AscendC toolchain, `msopgen`, `torch_npu`, available NPU
- Launch: `bash scripts/run.sh` (equivalent to `python -m src.run`)
- Configuration: `src/configs/presets/*.yaml`

