framework-selection

Framework selection guide for LangChain, LangGraph, and Deep Agents layered architecture. Layered frameworks where LangChain provides foundation primitives, LangGraph adds orchestration and control flow, and Deep Agents adds planning, memory, file management, and skill delegation Decision table guides framework choice based on task complexity: LangChain for single-purpose agents, LangGraph for custom control flow and loops, Deep Agents for multi-step planning and persistent sessions Deep Agents includes six built-in middleware modules (todo lists, filesystem, subagents, skills, memory, human-in-the-loop) that can be configured or extended Frameworks can be mixed in the same project; LangGraph graphs can be registered as subagents within Deep Agents, and LangChain primitives work across all layers

INSTALLATION
npx skills add https://github.com/langchain-ai/langchain-skills --skill framework-selection
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

$2c

This skill should be loaded at the top of any project before selecting other skills or writing agent code. The framework you choose dictates which other skills to invoke next.

Decision Guide

Answer these questions in order:

Question

Yes →

No →

Does the task require breaking work into sub-tasks, managing files across a long session, persistent memory, or loading on-demand skills?

Deep Agents

Does the task require complex control flow — loops, dynamic branching, parallel workers, human-in-the-loop, or custom state?

LangGraph

Is this a single-purpose agent that takes input, runs tools, and returns a result?

LangChain (create_agent)

Is this a pure model call, chain, or retrieval pipeline with no agent loop?

LangChain (chain)

Framework Profiles

LangChain — Use when the task is focused and self-contained

Best for:

  • Single-purpose agents that use a fixed set of tools
  • RAG pipelines and document Q&A
  • Model calls, prompt templates, output parsing
  • Quick prototypes where agent logic is simple

Not ideal when:

  • The agent needs to plan across many steps
  • State needs to persist across multiple sessions
  • Control flow is conditional or iterative

Skills to invoke next: langchain-models, langchain-rag, langchain-middleware

LangGraph — Use when you need to own the control flow

Best for:

  • Agents with branching logic or loops (e.g. retry-until-correct, reflection)
  • Multi-step workflows where different paths depend on intermediate results
  • Human-in-the-loop approval at specific steps
  • Parallel fan-out / fan-in (map-reduce patterns)
  • Persistent state across invocations within a session

Not ideal when:

  • You want planning, file management, and subagent delegation handled for you (use Deep Agents instead)
  • The workflow is straightforward enough for a simple agent

Skills to invoke next: langgraph-fundamentals, langgraph-human-in-the-loop, langgraph-persistence

Deep Agents — Use when the task is open-ended and multi-dimensional

Best for:

  • Long-running tasks that require breaking work into a todo list
  • Agents that need to read, write, and manage files across a session
  • Delegating subtasks to specialized subagents
  • Loading domain-specific skills on demand
  • Persistent memory that survives across multiple sessions

Not ideal when:

  • The task is simple enough for a single-purpose agent
  • You need precise, hand-crafted control over every graph edge (use LangGraph directly)

Middleware — built-in and extensible:

Deep Agents ships with a built-in middleware layer out of the box — you configure it, you don't implement it. The following come pre-wired; you can also add your own on top:

Middleware

What it provides

Always on?

TodoListMiddleware

write_todos tool — agent plans and tracks multi-step tasks

FilesystemMiddleware

ls, read_file, write_file, edit_file, glob, grep tools

SubAgentMiddleware

task tool — delegate work to named subagents

SkillsMiddleware

Load SKILL.md files on demand from a skills directory

Opt-in

MemoryMiddleware

Long-term memory across sessions via a Store instance

Opt-in

HumanInTheLoopMiddleware

Interrupt and request human approval before sensitive tool calls

Opt-in

Skills to invoke next: deep-agents-core, deep-agents-memory, deep-agents-orchestration

Mixing Layers

When to mix

Scenario

Recommended pattern

Main agent needs planning + memory, but one subtask requires precise graph control

Deep Agents orchestrator → LangGraph subagent

Specialized pipeline (e.g. RAG, reflection loop) is called by a broader agent

LangGraph graph wrapped as a tool or subagent

High-level coordination but low-level graph for a specific domain

Deep Agents + LangGraph compiled graph as a subagent

How it works in practice

A LangGraph compiled graph can be registered as a subagent inside Deep Agents. This means you can build a tightly-controlled LangGraph workflow (e.g. a retrieval-and-verify loop) and hand it off to the Deep Agents task tool as a named subagent — the Deep Agents orchestrator delegates to it without caring about its internal graph structure.

LangChain tools, chains, and retrievers can be used freely inside both LangGraph nodes and Deep Agents tools — they are the shared building blocks at every level.

Quick Reference

LangChain

LangGraph

Deep Agents

Control flow

Fixed (tool loop)

Custom (graph)

Managed (middleware)

Middleware layer

Callbacks only

✗ None

✓ Explicit, configurable

Planning

Manual

✓ TodoListMiddleware

File management

Manual

✓ FilesystemMiddleware

Persistent memory

With checkpointer

✓ MemoryMiddleware

Subagent delegation

Manual

✓ SubAgentMiddleware

On-demand skills

✓ SkillsMiddleware

Human-in-the-loop

Manual interrupt

✓ HumanInTheLoopMiddleware

Custom graph edges

✓ Full control

Limited

Setup complexity

Low

Medium

Low

Flexibility

Medium

High

Medium

Middleware is a concept specific to LangChain (callbacks) and Deep Agents (explicit middleware layer). LangGraph has no middleware — you wire behavior directly into nodes and edges.

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card