# quantifyme MCP server

Describe a trading strategy in plain English and deploy a live signal model in one call. No signup.

## Links
- Registry page: https://www.getdrio.com/mcp/ai-quantifyme-quantifyme
- Website: https://quantifyme.ai

## Install
- Endpoint: https://mcp.quantifyme.ai/mcp
- Auth: Not captured

## Setup notes
- Remote endpoint: https://mcp.quantifyme.ai/mcp

## Tools
- one_shot (Deploy Strategy (generate + backtest + go live)) - End-to-end deploy: generate strategy → train → deploy live.

    One of `prompt` (free-form NL), `preset` (curated winning strategy), or
    `community_id` (copy a published community strategy) is required. If more
    than one is passed, precedence is community_id > preset > prompt.

    Args:
      prompt: Natural-language strategy description (e.g. "Buy when RSI < 30, sell > 70").
      symbol: Currency pair to backtest on. One of: EURUSD, USDJPY, GBPUSD,
        USDCHF, USDCAD, AUDUSD, NZDUSD. Default EURUSD.
      timeframe: Candle granularity. One of: 1min, 5min, 15min, 1h. Default 15min.
      claude_model: Which Claude variant to use for code generation.
        "sonnet" (default — best quality, 1/day free) or "haiku" (faster, 3/day free).
        Ignored when `preset` is set (no generation needed).
      preset: Curated winning-strategy slug. Skips Claude generation entirely
        — deploys a pre-saved strategy known to backtest well on the chosen
        symbol. Available slugs: ema_cross_fast, momentum, scalper_stack,
        sma_only, trend_ema, volatility, bb_squeeze, all_mix, pivot_kid_ema.
        Not every slug exists for every symbol — call list_models afterwards
        to confirm what deployed.
      community_id: Copy-trade a published community strategy. Pass the `id`
        of an entry from `browse_community`. Loads that exact strategy code,
        skips Claude generation, then trains + deploys it. `symbol`/`timeframe`
        still apply to the backtest+deploy.
      webhook_url: Optional webhook to receive live signals.
      telegram_chat_id: Optional Telegram chat ID for signal delivery.

    Returns IMMEDIATELY (the deploy runs in the background so the live card can
    stream progress) with:
        - job_token (str): pass to get_deploy_result to fetch the final result.
        - poll_url (str): the card polls this for live progress; you can ignore it.
        - pending (bool): always true here — the deploy is still running.
        - symbol, timeframe (str).

    Call this EXACTLY ONCE per request. Pass the user's words as `prompt`; do not
    pre-pick presets/community strategies — the server routes (vague → a proven
    community strategy, specific rules → a fresh generation).

    NEXT STEP (always): call get_deploy_result(job_token) ONCE — it blocks until the
    deploy finishes and returns the out-of-sample stats + `stem` + `source`/`author`
    as TEXT so you can summarize. The live card already shows the chart, so you do
    NOT need get_model_chart. If source='community', tell the user it used a
    pre-existing strategy by @author and offer to generate a custom one.
     Endpoint: https://mcp.quantifyme.ai/mcp
- get_deploy_result (Get Deploy Result) - Wait for a `one_shot` deploy to finish and return its final result.

    `one_shot` returns a job_token immediately and the LIVE CARD already streams
    progress and renders the interactive backtest chart itself. Call this ONCE with
    the token to get the final numbers as TEXT so you can summarize them — it does
    NOT render another card (no need for get_model_chart). It BLOCKS until the deploy
    finishes (or ~2.5 min); on timeout it returns ok:false + pending:true — call it
    again with the same token.

    IMPORTANT: if `source == "community"`, the deploy used a PRE-EXISTING strategy by
    `@author` — tell the user that, share the `live_url` as the Live dashboard link,
    and ask whether they'd like to GENERATE A CUSTOM strategy instead. Use the
    `note` field as your guide.

    Args:
      job_token: the token returned by `one_shot`.

    Returns:
      dict with: ok, stem, model, live_url, symbol, timeframe, channels (list),
      stats:{ret, wr, pf, n, mdd} (out-of-sample test-split metrics — SHOW THESE),
      source ("community" | "generated"), author (community username if any),
      author_url + strategy_url (render @author and "pre-existing strategy" as those
      Markdown links), community_id, suggest_custom (bool), and note (a ready
      instruction — follow it). On failure: {ok:false, error} (or {pending:true}).
     Endpoint: https://mcp.quantifyme.ai/mcp
- list_models (List Trained Models) - List the user's trained models with pre-computed train/test stats. Endpoint: https://mcp.quantifyme.ai/mcp
- list_deployed (List Deployed Live Models) - List the user's currently deployed (live) models. Endpoint: https://mcp.quantifyme.ai/mcp
- generate_strategy (Generate Strategy Code (no training)) - Generate Python strategy code (no training/deploy). Use when the user wants raw code.

    Args:
      features: NL description of features (e.g. "RSI 14, Bollinger Bands").
      signals: NL description of signal logic (e.g. "Buy when RSI < 30").
      model: ML model name (default Random Forest).
      risk: NL risk rules (e.g. "0.5% stop loss").
      description: Optional one-line summary; treated as PRIMARY USER REQUEST.
      symbol: Currency pair the code should target. One of: EURUSD, USDJPY,
        GBPUSD, USDCHF, USDCAD, AUDUSD, NZDUSD. Default EURUSD.
      timeframe: Candle granularity. One of: 1min, 5min, 15min, 1h. Default 15min.
      claude_model: "sonnet" (default) or "haiku" (faster, higher daily cap).
     Endpoint: https://mcp.quantifyme.ai/mcp
- browse_community (Browse Community Strategies (leaderboard)) - Browse the public community leaderboard of published strategies, ranked
    by a composite performance score (best first). No signup or key needed.

    Copy-trade flow: call this to find a top strategy, then pass its `id` to
    `one_shot` as `community_id` to deploy a live signal model running that
    exact strategy in one call.

    Args:
      limit: How many top entries to return (default 20, max 200).

    Returns:
      dict with:
        - scripts (list[dict]): ranked entries, best first. Each has:
            id (int — pass to one_shot as community_id), username, title,
            description, created_at, score, and metrics {total_ret,
            sharpe_strat, win_rate, n_trades, mdd, profit_factor}. SHOW the
            top few with their win_rate / total_ret so the user can pick one.
        - count (int).
     Endpoint: https://mcp.quantifyme.ai/mcp
- find_strategy (Find a Matching Strategy) - Find an existing PROVEN strategy that matches a plain-English idea, so you
    can offer the user a choice — deploy the existing one, or generate a fresh
    custom one. Mirrors the quantifyme.ai landing experience: "Found <X> by
    @<author> (WR/PF) — Use it / Generate fresh".

    CALL THIS FIRST when a user describes a strategy idea. Then present the match
    (if any) and ASK which they want:
      • Use it          → one_shot(community_id=<match.community_id>) — deploys the
                          exact proven strategy (free, no generation).
      • Generate fresh  → one_shot(prompt="<their description>") — Claude writes a
                          brand-new custom strategy for them.
    If there's no match, just offer to generate fresh.

    Args:
      description: the user's strategy idea in plain English (e.g. "buy EURUSD
        15min when RSI < 30, sell when RSI > 70").
      symbol: optional pair to constrain the match (EURUSD, USDJPY, GBPUSD,
        USDCHF, USDCAD, AUDUSD, NZDUSD).
      timeframe: optional granularity to constrain the match (1min/5min/15min/1h).

    Returns:
      dict with:
        - match: the best existing strategy, or null. When present:
            {community_id, title, username, wr, pf, ret, n_trades, symbol,
             timeframe}. Pass community_id to one_shot to deploy it unchanged.
        - description: echoed back — pass as one_shot(prompt=...) to generate fresh.
        - suggestion: a ready-to-show sentence offering the user the choice.
     Endpoint: https://mcp.quantifyme.ai/mcp
- get_strategy_code (Get Community Strategy Code) - Get the actual Python code behind a community leaderboard strategy.

    Use after `browse_community`: pass an entry's `id` here to read its real
    `feature_engineering()` + `strategy_config()` source so the user can
    inspect or tweak it. To deploy it unchanged, pass the same id to
    `one_shot` as `community_id`. Read-only, no signup needed.

    Args:
      community_id: The `id` of a community entry (from `browse_community`).

    Returns:
      dict with: id, title, username, description, symbol, timeframe,
      metrics {total_ret, win_rate, profit_factor, n_trades, mdd, sharpe_strat},
      and `code` (the full Python source). SHOW the code to the user, and offer
      to deploy it via one_shot(community_id=...) or tweak it first.
     Endpoint: https://mcp.quantifyme.ai/mcp
- get_quote (Get Current Price (G7 FX quote)) - Get the latest price for a G7 FX pair — a quick "what's it at now" check.

    Useful for context before deploying a strategy. The price is the close of
    the most recent 1-minute bar from the platform's market feed (not a raw
    live tick); FX markets close on weekends, so the `stale` flag marks a bar
    that is more than 15 minutes old.

    Args:
      symbol: G7 pair — one of EURUSD, USDJPY, GBPUSD, USDCHF, USDCAD, AUDUSD,
        NZDUSD. Default EURUSD.

    Returns:
      dict with: symbol, price (latest close), time (bar timestamp, UTC),
      change + change_pct (vs the prior 1-min bar), stale (bool).
     Endpoint: https://mcp.quantifyme.ai/mcp
- get_model_chart (Show Backtest Chart (equity + trades)) - Visualize a trained model's backtest — a cumulative-return chart + trade log + stats.

    Use after `one_shot` / `list_models` with the model's `stem` to SHOW the user how it
    traded (the "is it actually any good" view). In ChatGPT this renders an interactive
    widget. In Claude, render an interactive **artifact** from this tool's structured
    output: a line chart of the cumulative return plus a table of the trades.

    Args:
      stem: The model stem (e.g. "14_EURUSD_15min_Model_24") from `list_models` / `one_shot`.

    Returns:
      dict with: ok, stem, symbol, timeframe, stats {ret, wr, pf, n, mdd, sharpe},
      and trades [{type, entry_time, exit_time, entry_price, exit_price, pnl,
      pnl_pct, exit_reason, period}] (most recent ~200). exit_reason is one of
      TP / SL / close_only / signal / end. ret/mdd/wr are fractions; pnl_pct is percent.
     Endpoint: https://mcp.quantifyme.ai/mcp
- stream_test (Live Streaming Diagnostic) - Diagnostic: test whether LIVE data streaming works in this client.

    Renders a widget with three panels — a JS timer (baseline), a WebSocket to
    the live price feed, and an HTTP poll of /quote — each showing a live value
    + status, so you can see exactly which streaming mechanisms the client's
    widget sandbox actually permits. Use when a live/ticking chart isn't moving.

    Args:
      symbol: G7 pair to stream (default EURUSD).
     Endpoint: https://mcp.quantifyme.ai/mcp

## Resources
- ui://widget/qm-oneshot-v14.html - QuantifyMe deployed model A live-deployed QuantifyMe model: live progress, then backtest chart (candles + buy/sell arrows + trades) + a one-click live link. MIME type: text/html;profile=mcp-app
- ui://widget/qm-community-v3.html - QuantifyMe community leaderboard Top community trading strategies, each with a one-click copy-and-deploy. MIME type: text/html;profile=mcp-app
- ui://widget/qm-deployed-v2.html - QuantifyMe live models The user's currently deployed live models and their delivery channels. MIME type: text/html;profile=mcp-app
- ui://widget/qm-chart-v20.html - QuantifyMe backtest chart A model's backtest: interactive price chart with buy/sell arrows + trade log + win-rate/profit-factor stats. MIME type: text/html;profile=mcp-app
- ui://widget/qm-livetest-v3.html - QuantifyMe streaming diagnostic Diagnostic panels that test live data streaming (timer / WebSocket / poll) inside this client. MIME type: text/html;profile=mcp-app

## Prompts
Not captured

## Metadata
- Owner: ai.quantifyme
- Version: 1.0.0
- Runtime: Streamable Http
- Transports: HTTP
- License: Not captured
- Language: Not captured
- Stars: Not captured
- Updated: May 20, 2026
- Source: https://registry.modelcontextprotocol.io
