CryptoScholar
Live crypto technical analysis MCP server — EMA, RSI, MACD, ATR, Bollinger Bands, TSS scoring, and Claude AI bull/bear debate via CoinGecko free API
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 14 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 |
|---|---|
watchlist_add | Add symbols to a named list (creates the list if needed) |
watchlist_remove | Remove symbols; also clears their alerts |
watchlist_show | Show all symbols + configured alerts for a list |
watchlist_lists | List all named watchlists with symbol counts |
watchlist_scan | Run a full TSS analysis on every coin in the list — parallel digest view |
alert_set | Set a tss_above, tss_below, or regime_change alert on any symbol |
alert_check | 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.
No API key required for market data. Only ANTHROPIC_API_KEY is needed for the debate tool.
What's new in v0.6.0
- GaussianHMM regime classification — volatility regime is now classified by a 3-state Hidden Markov Model trained on three features: 20-day historical volatility (hv_20), normalised ATR-14, and Bollinger Band width. The model learns what low/mid/high volatility looks like in feature space rather than applying fixed percentile thresholds.
- Auto-retrains every 7 days — on the first
analyze_coinorrank_coinscall after the threshold, the model retrains on BTC price history without any manual intervention. - Rule-based fallback — if no model exists yet, or if the HMM prediction fails for any reason, the original ATR + BBW percentile classifier is used silently.
regime_sourcefield —analyze_coinnow returnsregime_source: "hmm"or"rule_based"so you can see which classifier was used.train_regime_modeltool — force a manual retrain at any time (e.g. after a major market structure shift). Useforce=Trueto bypass the 7-day cooldown.- Model persisted to disk — trained model stored at
~/.cryptoscholar/hmm_model.pkl; survives server restarts.
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)
cryptoscholar
Add 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
Ranking BTC, ETH, and XRP by Trend Strength Score — then drilling into the bear case for XRP
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.
Full technical analysis snapshot for SOL — indicators, scoring, and bear case in one response
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 |
|---|---|---|
ANTHROPIC_API_KEY | — | Required for the debate tool |
CRYPTOSCHOLAR_MODEL | claude-haiku-4-5-20251001 | Claude model used for debates (swap for Sonnet/Opus for deeper analysis) |
CRYPTOSCHOLAR_LOG_DIR | /tmp | Directory for rotating log files |
CRYPTOSCHOLAR_DATA_DIR | ~/.cryptoscholar | 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 unavailable - Fetch 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_chart - Fetch 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 scan
205 tests, 0 failures.
Roadmap
See ROADMAP.md for planned versions. Highlights:
- v0.7 —
generate_reporttool: cluster → write → assemble pipeline for formatted markdown reports - v0.8 —
research_cointool: web search + Jina reader for news and narrative context - v0.9 — Market structure classification (HH/HL/LH/LL) via swing point detection; new
market_structurefield inanalyze_coin - v1.0 — Support & resistance zones clustered from swing pivots;
support_zones+resistance_zonesinanalyze_coin - v1.1 — Setup confluence score (1–5) measuring signal alignment; surfaces in
analyze_coin,rank_coins,watchlist_scan - v1.2 — Trade plan block:
entry_zone,take_profit,stop_loss,risk_reward_ratiocomputed from S/R zones + ATR - v1.3 — Pi Cycle indicator in
market_context;brieftool: Claude Haiku one-paragraph setup summary - v1.4 — EV filter:
ev_score+ev_signalflags negative-EV setups before acting on a trade plan - v1.5 —
backtest_strategytool: walk-forward simulation, fee-adjusted R, win rate, max drawdown
License
MIT
Verwandte Server
OraClaw Decision Intelligence
12 MCP tools with 19 ML algorithms for AI agents — bandits, solvers, forecasters, risk models. All under 25ms, deterministic.
Medigami
Attested healthcare-finance MCP. Scan medical bills, estimate appeal probability, generate state-specific appeal letters, benchmark commercial rates, look up ICD-10/CPT/NPI/DEA. Every response Ed25519-signed so LLMs can cite + verify.
SwitchBot
Control SwitchBot smart home devices through its official API, enabling automation and integration with AI assistants.
xuanxue-bazi-matching
Deterministic Chinese divination APIs (BaZi/QiMen/ZiWei/MeiHua/LiuYao/LiuRen) for AI agents — pay-per-call via x402 on Base.
İzmir Ulaşım
Access real-time public transportation data for the city of İzmir, allowing AI assistants to query routes and schedules.
Pylon
20+ pay-per-request APIs for AI agents — screenshots, web scraping, PDF, OCR, search, QR codes, translation & more. No API keys needed. Pay with USDC via x402. npm: @pylonapi/mcp
Memesio MCP Server
Hosted MCP server for meme generation, template search, caption rendering, and AI meme creation.
Zo
Zo is your personal vibe server in the cloud with 50+ tools and integrations. Add texting, email, calendar, research and more to your harness easily.
PublicFinance MCP
SEC EDGAR filings, treasury rates, labor statistics, and economic indicators for financial research
NVD CVE MCP Server
The NVD CVE MCP Server is a powerful security research tool