Skip to main content

A CLI tool to analyze academic papers and extract their core value

Project description

Paper Fluff Cutter

A CLI tool that cuts through academic paper fluff to extract what actually matters.

Most research has close to zero value. This tool uses multimodal LLMs to analyze papers and answer three questions:

  1. Why should I care? - What problem does this address and why does it matter?
  2. What's the actual innovation? - What's the core idea in plain terms?
  3. Is the evidence convincing? - Do the experiments actually support the claims?

Acknowledgement: the design of the fluff-cutter wiki is inspired by Andrej Karpathy's gist on LLM Wiki: https://gist.github.com/karpathy/442a6bf555914893e9891c11519de94f

Quick Start

pip install fluff-cutter
fluff-cutter init          # set up API keys and defaults
fluff-cutter analyze paper.pdf

Requires Python 3.10+.

Usage

# Local file
fluff-cutter analyze paper.pdf

# URL (arxiv /abs/ links are auto-converted to PDF)
fluff-cutter analyze https://arxiv.org/pdf/2411.19870

# Options
fluff-cutter analyze paper.pdf --output analysis.md   # custom output path
fluff-cutter analyze paper.pdf --print                 # stdout only, no file
fluff-cutter analyze paper.pdf --provider openai       # openai, anthropic, openrouter
fluff-cutter analyze paper.pdf --model gpt-5.2         # override default model
fluff-cutter analyze paper.pdf --max-pages 30          # limit pages for long papers

Wiki workflow

For persistent research tracking, you can keep a markdown wiki alongside the raw PDFs:

# Create a wiki project
fluff-cutter wiki init ./research-wiki

# `wiki init` saves this as your default wiki root, so later commands work
# from anywhere unless you explicitly override with --root
fluff-cutter wiki add https://arxiv.org/pdf/2411.19870

# Inspect the wiki
fluff-cutter wiki ls
fluff-cutter wiki show agents-for-useful-things
fluff-cutter wiki pdf agents-for-useful-things
fluff-cutter wiki query "agents planning"

# Maintenance
fluff-cutter wiki rebuild --root ./research-wiki
fluff-cutter wiki doctor --root ./research-wiki
fluff-cutter wiki remove paper-slug --root ./research-wiki --delete-pdf

The wiki layout looks like this:

research-wiki/
├── fluff-cutter.yaml
├── raw/
│   └── pdfs/
└── wiki/
    ├── papers/
    ├── index.md
    ├── overview.md
    └── log.md

By default, results are printed to the terminal and saved as a .md file next to the input PDF. Model output streams live during analysis (provider-side streaming), so you see tokens immediately instead of waiting for full completion.

Supported Providers

Provider Default Model Env Variable
OpenAI gpt-5.2 OPENAI_API_KEY
Anthropic claude-sonnet-4-5 ANTHROPIC_API_KEY
OpenRouter anthropic/claude-sonnet-4-5 OPENROUTER_API_KEY

All providers support native PDF input -- no external dependencies like poppler needed.

Configuration

Run fluff-cutter init for interactive setup, or set environment variables directly:

export OPENAI_API_KEY=sk-your-key-here
export FLUFF_CUTTER_PROVIDER=anthropic          # default provider
export FLUFF_CUTTER_ANTHROPIC_MODEL=claude-sonnet-4-5  # override model

Config is read in this order (highest priority first): CLI flags, env variables, ~/.fluff-cutter/config.yaml, provider defaults.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fluff_cutter-0.5.2.tar.gz (31.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fluff_cutter-0.5.2-py3-none-any.whl (24.1 kB view details)

Uploaded Python 3

File details

Details for the file fluff_cutter-0.5.2.tar.gz.

File metadata

  • Download URL: fluff_cutter-0.5.2.tar.gz
  • Upload date:
  • Size: 31.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fluff_cutter-0.5.2.tar.gz
Algorithm Hash digest
SHA256 90b8e8f91591127c75d5336ce6b1c31f046c6deb438ba42fe24effbb7e4ecbcc
MD5 bc75a0d570e8cef472cf895109cd9370
BLAKE2b-256 b613535286d5fa8ba87cc5e0818eea8d6f699a661dd49715ed9b32f393c6c5c6

See more details on using hashes here.

Provenance

The following attestation bundles were made for fluff_cutter-0.5.2.tar.gz:

Publisher: publish.yml on weijianzhg/paper-fluff-cutter

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fluff_cutter-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: fluff_cutter-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 24.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fluff_cutter-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 650ad447099994bed70e601e56b84731bb5120e08753be11337b335582b9c577
MD5 7988296ad476cd06417da99270b24a01
BLAKE2b-256 fd9c8bf5a475eedae7ad5f57269e84aaa2be1a518db165864e3a44f26091582a

See more details on using hashes here.

Provenance

The following attestation bundles were made for fluff_cutter-0.5.2-py3-none-any.whl:

Publisher: publish.yml on weijianzhg/paper-fluff-cutter

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page