-
Notifications
You must be signed in to change notification settings - Fork 16.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
concepts docs: archictecture individual page (#27290)
Update architecture page
- Loading branch information
Showing
2 changed files
with
60 additions
and
53 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import ThemedImage from '@theme/ThemedImage'; | ||
import useBaseUrl from '@docusaurus/useBaseUrl'; | ||
|
||
In this section, you'll find explanations of the key concepts, providing a deeper understanding of core principles. | ||
|
||
The conceptual guide will not cover step-by-step instructions or specific implementation details — those are found in the [How-To Guides](/docs/how_to/) and [Tutorials](/docs/tutorials) sections. For detailed reference material, please visit the [API Reference](https://python.langchain.com/api_reference/). | ||
|
||
## Architecture | ||
|
||
LangChain as a framework consists of a number of packages. | ||
|
||
### `langchain-core` | ||
This package contains base abstractions of different components and ways to compose them together. | ||
The interfaces for core components like LLMs, vector stores, retrievers and more are defined here. | ||
No third party integrations are defined here. | ||
The dependencies are kept purposefully very lightweight. | ||
|
||
### `langchain` | ||
|
||
The main `langchain` package contains chains, agents, and retrieval strategies that make up an application's cognitive architecture. | ||
These are NOT third party integrations. | ||
All chains, agents, and retrieval strategies here are NOT specific to any one integration, but rather generic across all integrations. | ||
|
||
### `langchain-community` | ||
|
||
This package contains third party integrations that are maintained by the LangChain community. | ||
Key partner packages are separated out (see below). | ||
This contains all integrations for various components (LLMs, vector stores, retrievers). | ||
All dependencies in this package are optional to keep the package as lightweight as possible. | ||
|
||
### Partner packages | ||
|
||
While the long tail of integrations is in `langchain-community`, we split popular integrations into their own packages (e.g. `langchain-openai`, `langchain-anthropic`, etc). | ||
This was done in order to improve support for these important integrations. | ||
|
||
### [`langgraph`](https://langchain-ai.github.io/langgraph) | ||
|
||
`langgraph` is an extension of `langchain` aimed at | ||
building robust and stateful multi-actor applications with LLMs by modeling steps as edges and nodes in a graph. | ||
|
||
LangGraph exposes high level interfaces for creating common types of agents, as well as a low-level API for composing custom flows. | ||
|
||
### [`langserve`](/docs/langserve) | ||
|
||
A package to deploy LangChain chains as REST APIs. Makes it easy to get a production ready API up and running. | ||
|
||
### [LangSmith](https://docs.smith.langchain.com) | ||
|
||
A developer platform that lets you debug, test, evaluate, and monitor LLM applications. | ||
|
||
<ThemedImage | ||
alt="Diagram outlining the hierarchical organization of the LangChain framework, displaying the interconnected parts across multiple layers." | ||
sources={{ | ||
light: useBaseUrl('/svg/langchain_stack_062024.svg'), | ||
dark: useBaseUrl('/svg/langchain_stack_062024_dark.svg'), | ||
}} | ||
title="LangChain Framework Overview" | ||
style={{ width: "100%" }} | ||
/> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters