All loops
RAGMedium 9 min· claude-opus-4-1
Hybrid search
Combines BM25 + dense embeddings with reciprocal rank fusion.
NOT DEPLOYEDNOT DEPLOYED
0164ms
Trigger
cron(0 7 * * *) fired · every day · 07:00
021184ms
Agent
claude-opus-4-1 · in 1684 tok · out 728 tok
03174ms
Tools
postgres-mcp/lovable cloud:invoke → 200 OK · 64ms
0454ms
Verify
schema check · pydantic v2 passed
0584ms
Output
eval passed · faithfulness 0.94
0644ms
Notify
audit log written · runbook link attached
SUCCESS
0%
0 runs
P50
0ms
median
P95
0ms
tail
AVG COST
—
per run
LAST OK
never
—
LAST FAIL
never
none
Latency · last 30 runs0 samples
no runs yet
Latest output · what your users see
RAG index · docs-prod
chunks
32
faithfulness
0.92
recall
0.84
Q: How do I rotate a secret without restarting the loop? A: Call `locker rotate <name>` — running loops pick up the new value on their next tick via the signed refresh channel.
// press Test to run once · Watch live to keep streaming · Deploy to make it real
The problem
Naive RAG embarrasses you in front of users — irrelevant chunks, no citations, drift.
The outcome
A measurable, evaluable RAG pipeline with cited answers and a quality dashboard.
Ingredients & skills
Secrets
- ANTHROPIC_API_KEY
- DATABASE_URL
Providers
- Anthropic
- Lovable Cloud
MCP servers
- postgres-mcp
- fetch-mcp
#rag#embeddings#hybrid
How it works
Combines BM25 + dense embeddings with reciprocal rank fusion.
Step 1
1 — Index
Chunk → embed → upsert into pgvector with a metadata JSON column.
Step 2
2 — Retrieve
Top-k vector + filter on metadata. Optional rerank pass.
Step 3
3 — Answer
Claude answers using only retrieved chunks. Empty retrieval ⇒ 'I don't know'.
One-line deploy
The button above runs the same command with your saved config. This is the raw CLI form.
bash
npx claudeloops deploy hybrid-search