Crawler Summary

stock-picker-agent answer-first brief

A multi-agent investment research assistant powered by CrewAI and LangGraph, this stock picker automates equity analysis using vector-based RAG pipelines, LLM summarization, and fundamental screening. Stock Picker Agent (CrewAI + LangGraph) A multi-agent investment research assistant that automates **equity research** and produces a **ranked list of stock ideas** using: - **CrewAI** for agent collaboration - **LangGraph** for deterministic, auditable workflows - **RAG** (vector search) for grounded analysis and citations - **LLM synthesis** for summaries, scoring, and investment-style screening **Audience (one sen Capability contract not published. No trust telemetry is available yet. Last updated 4/15/2026.

Freshness

Last checked 4/15/2026

Best For

stock-picker-agent is best for crewai, multi-agent workflows where OpenClaw compatibility matters.

Not Ideal For

Contract metadata is missing or unavailable for deterministic execution.

Evidence Sources Checked

editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack

Claim this agent
Agent DossierGitHubSafety: 66/100

stock-picker-agent

A multi-agent investment research assistant powered by CrewAI and LangGraph, this stock picker automates equity analysis using vector-based RAG pipelines, LLM summarization, and fundamental screening. Stock Picker Agent (CrewAI + LangGraph) A multi-agent investment research assistant that automates **equity research** and produces a **ranked list of stock ideas** using: - **CrewAI** for agent collaboration - **LangGraph** for deterministic, auditable workflows - **RAG** (vector search) for grounded analysis and citations - **LLM synthesis** for summaries, scoring, and investment-style screening **Audience (one sen

OpenClawself-declared

Public facts

4

Change events

1

Artifacts

0

Freshness

Apr 15, 2026

Verifiededitorial-contentNo verified compatibility signals

Capability contract not published. No trust telemetry is available yet. Last updated 4/15/2026.

Trust evidence available

Trust score

Unknown

Compatibility

OpenClaw

Freshness

Apr 15, 2026

Vendor

Crazy Horse

Artifacts

0

Benchmarks

0

Last release

Unpublished

Executive Summary

Key links, install path, and a quick operational read before the deeper crawl record.

Verifiededitorial-content

Summary

Capability contract not published. No trust telemetry is available yet. Last updated 4/15/2026.

Setup snapshot

git clone https://github.com/Crazy-Horse/stock-picker-agent.git
  1. 1

    Setup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.

  2. 2

    Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.

Evidence Ledger

Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.

Verifiededitorial-content
Vendor (1)

Vendor

Crazy Horse

profilemedium
Observed Apr 15, 2026Source linkProvenance
Compatibility (1)

Protocol compatibility

OpenClaw

contractmedium
Observed Apr 15, 2026Source linkProvenance
Security (1)

Handshake status

UNKNOWN

trustmedium
Observed unknownSource linkProvenance
Integration (1)

Crawlable docs

6 indexed pages on the official domain

search_documentmedium
Observed Apr 15, 2026Source linkProvenance

Release & Crawl Timeline

Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.

Self-declaredagent-index

Artifacts Archive

Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.

Self-declaredGITHUB OPENCLEW

Extracted files

0

Examples

6

Snippets

0

Languages

python

Executable Examples

text

stock-picker-agent/
├── src/
│   ├── ai_stock_picker_agent/
│   │   ├── config/
│   │   │   ├── agents.yaml
│   │   │   └── tasks.yaml
│   │   ├── models/                  # Pydantic schemas for state and outputs
│   │   ├── logic/                   # Core business logic and scoring math
│   │   ├── tools/                   # Serper, fundamentals, RAG tools
│   │   ├── crew.py                  # CrewAI agents + tasks wiring
│   │   ├── graph.py                 # LangGraph workflow nodes
│   │   └── main.py                  # Entrypoint
├── data/
│   └── raw/                         # Source documents for RAG
├── outputs/                         # Final decision.md
├── pyproject.toml
└── README.md

bash

git clone https://github.com/<YOUR_GITHUB_ORG>/stock-picker-agent.git
cd stock-picker-agent

bash

pip install uv

bash

uv sync

bash

# LLM provider (choose one)
OPENAI_API_KEY="..."
# or:
ANTHROPIC_API_KEY="..."
# or:
GEMINI_API_KEY="..."

# Optional: web search (Serper)
SERPER_API_KEY="..."

# Optional: Pinecone (RAG)
PINECONE_API_KEY="..."
PINECONE_INDEX="stock-picker"
PINECONE_ENVIRONMENT="..."  # if required by your Pinecone setup

# Optional: tracing/debugging
CREWAI_TRACING_ENABLED=false

bash

uv run python -m ai_stock_picker_agent.main

Docs & README

Full documentation captured from public sources, including the complete README when available.

Self-declaredGITHUB OPENCLEW

Docs source

GITHUB OPENCLEW

Editorial quality

ready

A multi-agent investment research assistant powered by CrewAI and LangGraph, this stock picker automates equity analysis using vector-based RAG pipelines, LLM summarization, and fundamental screening. Stock Picker Agent (CrewAI + LangGraph) A multi-agent investment research assistant that automates **equity research** and produces a **ranked list of stock ideas** using: - **CrewAI** for agent collaboration - **LangGraph** for deterministic, auditable workflows - **RAG** (vector search) for grounded analysis and citations - **LLM synthesis** for summaries, scoring, and investment-style screening **Audience (one sen

Full README

Stock Picker Agent (CrewAI + LangGraph)

A multi-agent investment research assistant that automates equity research and produces a ranked list of stock ideas using:

  • CrewAI for agent collaboration
  • LangGraph for deterministic, auditable workflows
  • RAG (vector search) for grounded analysis and citations
  • LLM synthesis for summaries, scoring, and investment-style screening

Audience (one sentence): Built for engineers, analysts, and builders who want a reproducible, modular “AI analyst team” that turns news + documents into ranked investment ideas.


Why this exists (business impact)

Investment research is time-consuming and inconsistent across sources (news, filings, transcripts, notes). This project provides a repeatable pipeline to:

  • reduce manual reading and summarization time
  • standardize screening criteria (value/growth/momentum/dividend)
  • keep outputs grounded in retrieved documents (RAG) with traceable sources
  • accelerate early-stage idea generation and triage (not execution)

⚠️ Not financial advice. This is a research automation demo for educational/engineering purposes.


What it does

End-to-end workflow

  1. Discover candidates (recent news/market activity)
  2. Retrieve evidence (RAG over your corpus: filings, transcripts, notes, articles)
  3. Summarize + extract signals (catalysts, risks, financial highlights)
  4. Score + rank ideas (style-aware rubric)
  5. Output a report (markdown + structured JSON) with citations and dates

Output artifacts

By default, the run generates:

  • outputs/decision.md — The final investment recommendation, including rationale, scores, and supporting evidence.

Architecture (high level)

CrewAI handles agent roles and tool usage, while LangGraph defines the workflow as a graph (stateful, inspectable, and easier to debug than pure prompting).

Typical agent responsibilities:

  • News Scout: finds candidate tickers and relevant items
  • Retriever: queries the vector store for grounding documents
  • Fundamentals Analyst: extracts metrics and constraints
  • Risk Analyst: flags red flags, uncertainty, missing data
  • Portfolio PM / Ranker: scores + ranks and produces final output

Tech stack

  • Python 3.12+ (recommended)
  • CrewAI (multi-agent orchestration)
  • LangGraph (workflow graph + state transitions)
  • LangChain (document loaders/splitters/retrieval helpers)
  • Chroma (vector database) (optional — can swap to FAISS/Pinecone)
  • LLM provider: OpenAI / Anthropic / Gemini
  • uv for dependency management

Project structure

stock-picker-agent/
├── src/
│   ├── ai_stock_picker_agent/
│   │   ├── config/
│   │   │   ├── agents.yaml
│   │   │   └── tasks.yaml
│   │   ├── models/                  # Pydantic schemas for state and outputs
│   │   ├── logic/                   # Core business logic and scoring math
│   │   ├── tools/                   # Serper, fundamentals, RAG tools
│   │   ├── crew.py                  # CrewAI agents + tasks wiring
│   │   ├── graph.py                 # LangGraph workflow nodes
│   │   └── main.py                  # Entrypoint
├── data/
│   └── raw/                         # Source documents for RAG
├── outputs/                         # Final decision.md
├── pyproject.toml
└── README.md

Quick Start (uv)

1) Clone

git clone https://github.com/<YOUR_GITHUB_ORG>/stock-picker-agent.git
cd stock-picker-agent

2) Install uv

pip install uv

3) Create environment + install dependencies

uv sync

4) Configure environment variables

Create a .env file in the repo root:

# LLM provider (choose one)
OPENAI_API_KEY="..."
# or:
ANTHROPIC_API_KEY="..."
# or:
GEMINI_API_KEY="..."

# Optional: web search (Serper)
SERPER_API_KEY="..."

# Optional: Pinecone (RAG)
PINECONE_API_KEY="..."
PINECONE_INDEX="stock-picker"
PINECONE_ENVIRONMENT="..."  # if required by your Pinecone setup

# Optional: tracing/debugging
CREWAI_TRACING_ENABLED=false

5) Run

Option A — run via module:

uv run python -m ai_stock_picker_agent.main

Option B — if you expose a CLI entrypoint:

uv run stock-picker

Usage

Common inputs

Most runs accept a small set of parameters (passed in main.py or CLI flags):

  • sector — e.g. "AI", "Healthcare", "Energy"
  • investment_style"value" | "growth" | "momentum" | "dividend"
  • max_candidates — e.g. 5
  • time_window_days — e.g. 7
  • universe — e.g. "US", "S&P 500", or a ticker list

Example:

uv run python -m ai_stock_picker_agent.main \
  --sector "AI" \
  --investment-style "growth" \
  --max-candidates 5 \
  --time-window-days 7

If you don’t have CLI flags yet, add them in src/ai_stock_picker_agent/main.py using argparse and pass the inputs into crew().kickoff(inputs=...).


RAG setup (Pinecone)

This project supports RAG so the model can cite your documents (transcripts, filings, notes).

1) Ingest documents (optional)

Put PDFs/text/markdown in data/raw/ and run:

uv run python -m ai_stock_picker_agent.tools.ingest_docs --input data/raw --out data/processed

2) Build embeddings + upsert to Pinecone

uv run python -m ai_stock_picker_agent.tools.build_index \
  --processed data/processed \
  --index "$PINECONE_INDEX"

3) Run research

Once indexed, the Retriever agent will pull top-k chunks per ticker and use them as grounded context.

Don’t want Pinecone? Swap the retriever to FAISS/Chroma and keep the same tool interface.


How CrewAI and LangGraph are used together

CrewAI (agents + tools)

  • Defines agent roles, goals, and tool access.
  • Great for “who does what” (analyst team simulation).

LangGraph (workflow)

  • Defines a graph like: discover -> retrieve -> analyze -> score -> rank -> write_outputs

  • Great for:

    • deterministic execution order
    • branching (e.g., skip fundamentals if missing)
    • retries and guardrails
    • auditing intermediate state

If you only need one: start with CrewAI. Add LangGraph when you need stricter control, branching, or debuggability.


Guardrails and limitations

  • Outputs depend on source coverage (news and your RAG corpus).
  • LLM scoring is approximate; treat scores as heuristic.
  • Avoid large time windows / huge candidate lists or you can hit token limits.
  • Consider rate limiting and caching for news + document retrieval.

Troubleshooting

KeyError: Template variable 'start_date' not found

Your task prompt references {start_date} / {end_date} but inputs don’t include them. Fix: add them to your inputs in main.py, or remove variables from task text.

RateLimitError: Request too large ... tokens per min

Reduce:

  • max_candidates
  • time_window_days
  • number of retrieved chunks (top_k) Also split your workflow: generate a short “research pack” first, then rank.

macOS ARM: onnxruntime-gpu cannot be installed

onnxruntime-gpu wheels are not available for macOS arm64. Use CPU (onnxruntime) or gate GPU deps by platform in pyproject.toml.


Roadmap

  • [ ] Add SEC/EDGAR ingestion (10-K, 10-Q)
  • [ ] Add earnings transcript loader + chunker
  • [ ] Add fundamentals provider integration (yfinance / FMP / Polygon)
  • [ ] Add evaluation harness (precision of picks vs benchmark, ablation)
  • [ ] Add portfolio constraints and risk budgeting

Related projects


License

MIT

Contract & API

Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.

MissingGITHUB OPENCLEW

Contract coverage

Status

missing

Auth

None

Streaming

No

Data region

Unspecified

Protocol support

OpenClaw: self-declared

Requires: none

Forbidden: none

Guardrails

Operational confidence: low

No positive guardrails captured.
Invocation examples
curl -s "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/snapshot"
curl -s "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/contract"
curl -s "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/trust"

Reliability & Benchmarks

Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.

Missingruntime-metrics

Trust signals

Handshake

UNKNOWN

Confidence

unknown

Attempts 30d

unknown

Fallback rate

unknown

Runtime metrics

Observed P50

unknown

Observed P95

unknown

Rate limit

unknown

Estimated cost

unknown

Do not use if

Contract metadata is missing or unavailable for deterministic execution.
No benchmark suites or observed failure patterns are available.

Media & Demo

Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.

Missingno-media
No screenshots, media assets, or demo links are available.

Related Agents

Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.

Self-declaredprotocol-neighbors
GITHUB_REPOSactivepieces

Rank

70

AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents

Traction

No public download signal

Freshness

Updated 2d ago

OPENCLAW
GITHUB_REPOScherry-studio

Rank

70

AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs

Traction

No public download signal

Freshness

Updated 5d ago

MCPOPENCLAW
GITHUB_REPOSAionUi

Rank

70

Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!

Traction

No public download signal

Freshness

Updated 6d ago

MCPOPENCLAW
GITHUB_REPOSCopilotKit

Rank

70

The Frontend for Agents & Generative UI. React + Angular

Traction

No public download signal

Freshness

Updated 23d ago

OPENCLAW
Machine Appendix

Contract JSON

{
  "contractStatus": "missing",
  "authModes": [],
  "requires": [],
  "forbidden": [],
  "supportsMcp": false,
  "supportsA2a": false,
  "supportsStreaming": false,
  "inputSchemaRef": null,
  "outputSchemaRef": null,
  "dataRegion": null,
  "contractUpdatedAt": null,
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Invocation Guide

{
  "preferredApi": {
    "snapshotUrl": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/snapshot",
    "contractUrl": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/contract",
    "trustUrl": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/trust"
  },
  "curlExamples": [
    "curl -s \"https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/snapshot\"",
    "curl -s \"https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/contract\"",
    "curl -s \"https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/trust\""
  ],
  "jsonRequestTemplate": {
    "query": "summarize this repo",
    "constraints": {
      "maxLatencyMs": 2000,
      "protocolPreference": [
        "OPENCLEW"
      ]
    }
  },
  "jsonResponseTemplate": {
    "ok": true,
    "result": {
      "summary": "...",
      "confidence": 0.9
    },
    "meta": {
      "source": "GITHUB_OPENCLEW",
      "generatedAt": "2026-04-17T00:05:09.083Z"
    }
  },
  "retryPolicy": {
    "maxAttempts": 3,
    "backoffMs": [
      500,
      1500,
      3500
    ],
    "retryableConditions": [
      "HTTP_429",
      "HTTP_503",
      "NETWORK_TIMEOUT"
    ]
  }
}

Trust JSON

{
  "status": "unavailable",
  "handshakeStatus": "UNKNOWN",
  "verificationFreshnessHours": null,
  "reputationScore": null,
  "p95LatencyMs": null,
  "successRate30d": null,
  "fallbackRate": null,
  "attempts30d": null,
  "trustUpdatedAt": null,
  "trustConfidence": "unknown",
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Capability Matrix

{
  "rows": [
    {
      "key": "OPENCLEW",
      "type": "protocol",
      "support": "unknown",
      "confidenceSource": "profile",
      "notes": "Listed on profile"
    },
    {
      "key": "crewai",
      "type": "capability",
      "support": "supported",
      "confidenceSource": "profile",
      "notes": "Declared in agent profile metadata"
    },
    {
      "key": "multi-agent",
      "type": "capability",
      "support": "supported",
      "confidenceSource": "profile",
      "notes": "Declared in agent profile metadata"
    }
  ],
  "flattenedTokens": "protocol:OPENCLEW|unknown|profile capability:crewai|supported|profile capability:multi-agent|supported|profile"
}

Facts JSON

[
  {
    "factKey": "vendor",
    "category": "vendor",
    "label": "Vendor",
    "value": "Crazy Horse",
    "href": "https://github.com/Crazy-Horse/stock-picker-agent",
    "sourceUrl": "https://github.com/Crazy-Horse/stock-picker-agent",
    "sourceType": "profile",
    "confidence": "medium",
    "observedAt": "2026-04-15T06:04:47.089Z",
    "isPublic": true
  },
  {
    "factKey": "protocols",
    "category": "compatibility",
    "label": "Protocol compatibility",
    "value": "OpenClaw",
    "href": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/contract",
    "sourceUrl": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/contract",
    "sourceType": "contract",
    "confidence": "medium",
    "observedAt": "2026-04-15T06:04:47.089Z",
    "isPublic": true
  },
  {
    "factKey": "docs_crawl",
    "category": "integration",
    "label": "Crawlable docs",
    "value": "6 indexed pages on the official domain",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  },
  {
    "factKey": "handshake_status",
    "category": "security",
    "label": "Handshake status",
    "value": "UNKNOWN",
    "href": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/trust",
    "sourceUrl": "https://xpersona.co/api/v1/agents/crewai-crazy-horse-stock-picker-agent/trust",
    "sourceType": "trust",
    "confidence": "medium",
    "observedAt": null,
    "isPublic": true
  }
]

Change Events JSON

[
  {
    "eventType": "docs_update",
    "title": "Docs refreshed: Sign in to GitHub · GitHub",
    "description": "Fresh crawlable documentation was indexed for the official domain.",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  }
]

Sponsored

Ads related to stock-picker-agent and adjacent AI workflows.