Name: CryptoScholar
Fetches 300 days of real-time OHLCV candle data to compute technical analysis indicators, including trend, momentum, and volatility metrics.
CryptoScholar
Crypto technical analysis, directly inside Claude. CryptoScholar is a Model Context Protocol (MCP) server that gives Claude real-time TA capabilities — no chart-switching, no copy-pasting data, no context loss.
Ask Claude "Is SOL set up for a swing trade?" and it fetches live data from Binance, runs a full indicator suite, scores it, and delivers a grounded bull/bear debate — all in one response.
What it does
CryptoScholar exposes 15 MCP tools that Claude can call natively:
analyze_coin
Full technical analysis snapshot for any coin. Fetches 300 days of real OHLCV candles from Binance (with CoinGecko fallback) and computes:
Indicator | Details |
Trend | EMA-20, EMA-50, EMA-200 alignment + weekly EMA slope |
Momentum | RSI-14, MACD (line / signal / histogram), ADX-14 |
Volatility | ATR-14, Bollinger Band width, Historical Volatility (20-day annualised) |
Relative Strength | Coin vs BTC (20-day ratio change) |
Multi-timeframe | 4H EMA alignment — ±3 TSS bonus/penalty based on 4H EMA-20 vs EMA-50 |
RSI Divergence | Bullish / bearish / none — price vs RSI extremes over last 30 bars |
OBV Trend | On-Balance Volume direction (rising / falling / flat) — ±2 TSS confirmation bonus |
Funding Rate | Current USDT-M perpetual funding rate — positive extremes = over-leveraged longs |
Regime | Low / mid / high volatility — classified by 3-state GaussianHMM (falls back to rule-based) |
TSS | Trend Strength Score — 0–100 composite (40% trend + 30% momentum + 30% RS ± MTF ± OBV) |
rank_coins
Pass a list of symbols and get them back ranked by TSS. Runs in parallel (up to 8 workers) for fast results on large lists. Each result includes TSS, regime, EMA alignment, 4H MTF alignment, RSI divergence, OBV trend, funding rate, RSI-14, ADX-14, and RS vs BTC.
top_coins
No symbol list needed. Fetches the top 50 coins by market cap from CoinGecko and returns them ranked by TSS. Smart filtering automatically removes:
Stablecoins (USDT, USDC, DAI, etc.)
Wrapped / synthetic tokens (WBTC, WETH, stETH, cbBTC, etc.)
Low-liquidity coins with < $10M daily volume
correlate_coins
Compute pairwise Pearson correlation of 30-day daily returns across 2–20 coins. Returns the full correlation matrix, high-correlation clusters (>0.85), and uncorrelated pairs (<0.30) — useful for portfolio diversification analysis.
market_context
Macro market signals to frame individual coin analysis. Uses CoinGecko global data, DefiLlama stablecoin supply, and Alternative.me Fear & Greed Index. Returns:
Signal | Description |
BTC dominance | Current % and 30-day change — falling = capital rotating to alts |
ETH/BTC ratio | 20-day trend — rising = broadening rally |
TOTAL3 | Altcoin market cap (ex-BTC, ex-ETH) 30-day change |
Stablecoin supply | Total stablecoin market cap and 30-day trend (rising = more buying power) |
Fear & Greed | Alternative.me index (0–100) — extreme fear/greed applies ±5 modifier to MRS |
ARS | Altcoin Rotation Score 0–100 — how favourable macro is for alts |
MRS | Market Readiness Score 0–100 — overall market readiness for upside moves |
debate
Claude reads the live TA data and generates a structured bull/bear debate grounded in actual indicator values — not hallucinated opinion. Returns:
Bull case — what the technicals say in favour
Bear case — what could go wrong
Bottom line — one-sentence synthesis
Watchlist tools
Persistent coin lists stored in SQLite (~/.cryptoscholar/watchlist.db).
Tool | What it does |
| Add symbols to a named list (creates the list if needed) |
| Remove symbols; also clears their alerts |
| Show all symbols + configured alerts for a list |
| List all named watchlists with symbol counts |
| Run a full TSS analysis on every coin in the list — parallel digest view |
| Set a |
| Fetch live TA for all alerted symbols, report which alerts fired, update baseline |
train_regime_model
Manually trigger a retrain of the HMM volatility regime model on fresh BTC price history. The model auto-retrains every 7 days automatically — use this after a major market structure shift to force an immediate update. Accepts an optional force=True flag to bypass the 7-day cooldown.
generate_report
Generate a structured analysis report for one or more coins. Uses a 3-stage pipeline:
Cluster — groups TA signals into thematic sections (trend, momentum, volume/on-chain, volatility, relative strength)
Write — Claude writes a narrative paragraph for each section based on the clustered signals
Assemble — combines sections into a formatted markdown report with a key statistics table at the top
Supports single-coin deep-dives and multi-coin comparison reports (e.g. ["BTC", "ETH", "SOL"]). Pass output_format="json" for structured output instead of markdown. Up to 10 symbols per call.
No API key required for market data. ANTHROPIC_API_KEY is needed for the debate and generate_report tools.
What's new in v0.7.0
generate_reporttool (tool #15) — 3-stage Cluster → Write → Assemble pipeline that produces a formatted markdown report for any coin or list of coins. Stage 1 groups TA signals into thematic clusters; Stage 2 uses Claude to write narrative sections; Stage 3 assembles a report with a key statistics table.Multi-coin comparison — pass up to 10 symbols and get a comparative report with per-coin summaries, a strongest/weakest setup call, and an overall comparative summary.
JSON output option — pass
output_format="json"to get the full structured report dict instead of markdown, useful for downstream processing.Parallel analysis — coin data for multi-symbol reports is fetched in parallel (up to 8 workers) before the Claude write stage.
Quick start
Requirements: Python 3.11+
git clone https://github.com/cryptographer11/cryptoscholar.git
cd cryptoscholar
make install
cp .env.example .env
# Add your ANTHROPIC_API_KEY to .env (only needed for debate tool)
cryptoscholarAdd to Claude Code
In ~/.claude/.mcp.json:
{
"mcpServers": {
"cryptoscholar": {
"command": "python",
"args": ["-m", "cryptoscholar"],
"env": {
"ANTHROPIC_API_KEY": "your_key_here"
}
}
}
}Restart Claude Code. You can now ask:
"Analyze BTC for me"
"Rank ETH, SOL, AVAX, and LINK by trend strength"
"Show me the top 50 coins ranked by trend strength"
"What does the macro market look like right now?"
"Give me the bull and bear case for DOGE based on current TA"
"How correlated are BTC, ETH, SOL, and AVAX over the last month?"
"Add BTC, ETH, and SOL to my main watchlist"
"Set an alert on BTC if TSS drops below 35"
"Check my alerts"
"Give me the digest for my main watchlist"
Screenshots
rank_coins scores each coin across trend, momentum, and relative strength vs BTC and returns them sorted by TSS. Here BTC leads at 63.7, ETH at 53.0, and XRP trails at 47.8 — all in low_vol regime. Asking for the XRP bear case immediately after surfaces the specific technical reasons: a steepest weekly EMA slope, faltering MACD, and ETH underperformance vs BTC flagged as early institutional exit pressure.
analyze_coin returns a structured breakdown covering EMA stack alignment, RSI, MACD, ADX, ATR, Bollinger Band width, OBV trend, funding rate, and relative strength vs BTC — all computed from 300 days of live Binance candles. Claude then reads the raw indicator values to generate a grounded bear case: EMA-200 resistance, weekly slope steepening, and MACD crossdown risk. No chart-switching, no copy-pasting — the full TA context is already in Claude's window.
Example output
market_context()
{
"btc_price_30d_change_pct": -8.4,
"btc_dominance_current": 54.2,
"btc_dominance_30d_change_pct": 2.1,
"eth_btc_20d_change_pct": -5.3,
"total3_30d_change_pct": -14.6,
"stablecoin_supply_usd": 196500000000,
"stablecoin_30d_change_pct": 2.8,
"fear_greed_value": 22,
"fear_greed_label": "Fear",
"btc_trend_score": 35.0,
"ars": 28.5,
"stablecoin_score": 60.0,
"fear_greed_modifier": 0.0,
"mrs": 42.3
}analyze_coin("SOL")
{
"symbol": "SOL",
"data_source": "binance",
"price": 142.30,
"tss": 79.2,
"regime": "mid_vol",
"regime_source": "hmm",
"vrs": 55,
"ema_alignment": "full_bull",
"mtf_alignment_4h": "bullish",
"rsi_divergence": "none",
"obv_trend": "rising",
"funding_rate": 0.00012,
"indicators": {
"rsi_14": 61.4,
"macd_hist": 0.42,
"adx_14": 28.1,
"atr_14": 6.82,
"hv_20": 68.4,
"rs_btc": 4.2,
"bb_width": 0.18,
"rsi_divergence": "none",
"obv_trend": "rising"
}
}correlate_coins(["BTC", "ETH", "SOL", "BNB"])
{
"symbols": ["BTC", "ETH", "SOL", "BNB"],
"lookback_days": 30,
"matrix": {
"BTC": {"BTC": 1.0, "ETH": 0.91, "SOL": 0.78, "BNB": 0.83},
"ETH": {"BTC": 0.91, "ETH": 1.0, "SOL": 0.82, "BNB": 0.79},
"SOL": {"BTC": 0.78, "ETH": 0.82, "SOL": 1.0, "BNB": 0.71},
"BNB": {"BTC": 0.83, "ETH": 0.79, "SOL": 0.71, "BNB": 1.0}
},
"high_correlation_pairs": [
{"symbol_a": "BTC", "symbol_b": "ETH", "correlation": 0.91}
],
"uncorrelated_pairs": []
}debate("SOL")
{
"bull_case": "SOL is in a full bullish EMA stack with RSI at 61 — healthy momentum without overbought conditions. ADX at 28 confirms trending structure, and relative strength vs BTC is positive at +4.2%, signalling capital rotation into SOL. Rising OBV confirms volume is flowing in on up-days.",
"bear_case": "Historical volatility at 68% is elevated, and Bollinger Band width is widening — conditions that often precede sharp reversals. A break below EMA-20 would invalidate the current trend structure. Funding rate at 0.012% hints at building long leverage.",
"bottom_line": "Technicals are constructive for continuation but volatility is high; position sizing should reflect the risk."
}Configuration
Variable | Default | Description |
| — | Required for the |
|
| Claude model used for debates (swap for Sonnet/Opus for deeper analysis) |
|
| Directory for rotating log files |
|
| Directory for watchlist SQLite DB |
Supported coins
CryptoScholar works with any coin listed on CoinGecko or Binance — just pass the ticker symbol. No configuration needed.
A built-in symbol map covers 65 major coins for instant resolution — the full top-50 market cap universe including BTC, ETH, SOL, BNB, XRP, ADA, AVAX, DOGE, LINK, DOT, SUI, TIA, WIF, BONK, and more. For anything outside that list, CryptoScholar automatically queries CoinGecko's search API to resolve the symbol and falls back to CoinGecko OHLCV if the coin isn't available on Binance.
In practice: if it trades somewhere and has a CoinGecko listing, it will work.
Architecture
Stateless by design — no database, no scheduler. Every tool call fetches fresh data.
Claude (MCP call)
└── server.py FastMCP entry point
├── tools/
│ ├── analyze.py Orchestrates fetch → indicators → regime → score
│ ├── rank.py Runs analyze_coin in parallel, sorts by TSS
│ ├── top_coins.py Fetches top N by market cap, delegates to rank_coins
│ ├── correlate.py Pairwise Pearson correlation of 30-day returns
│ ├── watchlist.py Watchlist + alert tools (7 tools)
│ ├── debate.py Builds prompt from TA data, calls Claude API
│ └── market_context.py ARS + MRS + macro signals
├── ta/
│ ├── indicators.py pandas-ta + custom HV / RS / OBV functions
│ ├── scoring.py TSS: trend + momentum + RS ± MTF ± OBV bonuses
│ ├── regime.py HMM-first regime classifier with rule-based fallback
│ └── hmm_regime.py GaussianHMM train / persist / classify / auto-retrain
├── market/
│ └── context.py BTC dominance, ETH/BTC, TOTAL3, F&G, ARS, MRS
└── data/
├── binance.py Binance klines + funding rate (1,200 req/min, no auth)
├── coingecko.py CoinGecko client, 5-min TTL cache, OHLCV builder
├── alternative_me.py Fear & Greed Index (Alternative.me, 1-hr cache)
├── defillama.py DefiLlama stablecoin supply history
└── watchlist_db.py SQLite watchlist + alert persistence (~/.cryptoscholar/)Data flow for analyze_coin("SOL"):
Map symbol → CoinGecko ID (
SOL→solana)Fetch 300-day daily OHLCV from Binance (
SOLUSDTklines); fall back to CoinGecko if unavailableFetch 200-bar 4H OHLCV from Binance for multi-timeframe analysis
Fetch USDT-M perpetual funding rate from Binance Futures (null if no perpetual)
Compute all daily indicators via pandas-ta (EMA, RSI, MACD, ADX, ATR, BB, HV, OBV, RS vs BTC)
Compute OBV trend (EMA-10 of OBV slope over last 5 bars)
Compute 4H indicators (EMA-20/50) and derive MTF alignment bonus (±3 TSS pts)
Detect RSI divergence over last 30 bars (bullish/bearish/none)
Classify regime via GaussianHMM (hv_20 + normalised ATR + BBW); falls back to rule-based if no model
Compute TSS (weighted composite of trend, momentum, RS vs BTC ± MTF bonus ± OBV bonus)
Fetch current market data (price, market cap, 24h change) from CoinGecko
Return structured dict to Claude
Data flow for market_context():
Fetch total market cap history (30d) from CoinGecko
/global/market_cap_chartFetch BTC and ETH market chart history (30d) from CoinGecko
Fetch stablecoin supply history from DefiLlama
Fetch Fear & Greed Index from Alternative.me (1-hr cache)
Compute BTC dominance trend, ETH/BTC ratio trend, TOTAL3 change
Score into ARS (altcoin rotation) and MRS (market readiness + F&G modifier)
Development
make test # run test suite
make test-parallel # run tests in parallel (pytest-xdist)
make coverage # coverage report
make lint-security # bandit security scan222 tests, 0 failures.
Roadmap
See ROADMAP.md for planned versions. Highlights:
v0.8 —
research_cointool: web search + Jina reader for news and narrative contextv0.9 — Market structure classification (HH/HL/LH/LL) via swing point detection; new
market_structurefield inanalyze_coinv1.0 — Support & resistance zones clustered from swing pivots;
support_zones+resistance_zonesinanalyze_coinv1.1 — Setup confluence score (1–5) measuring signal alignment; surfaces in
analyze_coin,rank_coins,watchlist_scanv1.2 — Trade plan block:
entry_zone,take_profit,stop_loss,risk_reward_ratiocomputed from S/R zones + ATRv1.3 — Pi Cycle indicator in
market_context;brieftool: Claude Haiku one-paragraph setup summaryv1.4 — EV filter:
ev_score+ev_signalflags negative-EV setups before acting on a trade planv1.5 —
backtest_strategytool: walk-forward simulation, fee-adjusted R, win rate, max drawdown
License
MIT
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/cryptographer11/cryptoscholar'
If you have feedback or need assistance with the MCP directory API, please join our Discord server