It was only six months ago that we released the first version of LangChain, but it seems like several years. When we launched, generative AI was starting to go mainstream: stable diffusion had just been released and was captivating people’s imagination and fueling an explosion in developer activity, Jasper announced a funding round, and investors released the first Gen AI market maps.
Alongside this boon in content creation, people started to realize that the true power of this technology was not using a language model in isolation, but using the language model as part of a new, more intelligent system. Developers were discussing how to connect language models to their own proprietary documents, APIs, and structured data. Research papers like Self-Ask with Search and ReAct were published, demonstrating the power of these approaches.
Amongst these early tremors of a tectonic shift in computing, we released the first version of the LangChain Python package on October 24th, 2022. In the very first tweet thread, Harrison said:
- “a python package aimed at helping build LLM applications through composability”
- “The real power comes when you are able to combine [LLMs] with other things.”
- “LangChain aims to help with that by creating… a comprehensive collection of pieces you would ever want to combine… a flexible interface for combining pieces into a single comprehensive ‘chain’”
Why Raise Funding?
This all started as an open-source side project, without any intention of building a company. It began by noticing common patterns in how people were approaching problems, and attempting to create abstractions that made it easier. These first simple abstractions struck a chord and the project took off, thanks largely to your community support and contributions. LangChain now has over 20K stars on GitHub, 10K active Discord members, over 30K followers on Twitter, and - most importantly - over 350 contributors.
It became clear that the combination of LangChain + LLMs blows open the frontier of amazing products and applications to be built. And, it also is clear that far more work and tooling are needed to make these applications work well (particularly in production). You’re asking us every day for more (400+ GitHub issues, 100 open PRs) and we want to help!
With that in mind, we are excited to publicly announce that we have raised $10 million in seed funding. Benchmark led the round and we’re thrilled to have their counsel as they’ve been the first lead investors in some of the iconic open source software we all use including Docker, Confluent, Elastic, Clickhouse and more. With this capital we are going to invest aggressively to keep up with the ground breaking work the community is doing building intelligent apps. Our goal is simple: empower developers to build useful applications powered by language models.
So what can you expect from us?
LangChain Today
LangChain is a framework for developing applications powered by language models, offered as both a Python and a TypeScript package. We believe that the most powerful and differentiated language model applications will:
- Be data-aware: connect a language model to other sources of data
- Be agentic: allow a language model to interact with its environment
The LangChain framework is designed with the above objective principles in mind. We believe that the two main value props it provides are:
Components
LangChain offers a modular set of abstractions and components that provide everything developers need to build applications using language models. It also includes collections of implementations for these abstractions.
These components are largely community driven. There are over 300 contributors on the Python repo alone. Some highlights:
- Integrations with 20+ different model providers or hosting platforms
- Collection of 50+ Document Loaders to load data from different sources
- Collection of 10+ methods for splitting text data into chunks so that a Language Model can easily use it
- Integrations with 10+ different vector databases
- Collection of 15+ different tools to let Language Models use
Pre-built Chains and Agents
Chains allow developers to assemble components in a specific manner to accomplish a particular task, such as summarizing a large pdf document or querying a SQL database. Agents can be thought of as “dynamic chains” in which the sequence of steps taken are determined by a language model on the fly. In addition to providing a high-level interface that makes it easy for developers to create custom chains and agents, LangChain provides many pre-built ones that can be used out-of-the-box.
Again, these components are largely community driven. Some highlights:
- Implementations of ~20 different chains
- Implementations of 6 different generic agent types (chains specifically designed to use tools and interact with the outside world)
- Implementations of 7 different “Agent Toolkits” (agents equipped with a specific set of tools to accomplish a specific task)
Future Plans
As mentioned earlier, we believe that language models are unlocking new types of high-value applications, and it is still non-trivial to create and maintain these applications — particularly in production settings. Some of our more recent releases are focused on addressing these problems:
- Bringing the TypeScript package up to feature parity with Python to enable more full-stack and frontend developers to create LLM applications
- Implementing several types of OutputParsers, to allow for more safety and guidance on the text returned by a LLM
- Introducing a Retriever abstraction to enable more complicated and necessary types of document retrieval
- Building integrations with solutions like Weights & Biases, AIM, ClearML to enable more observability and experimentation with LLM applications
We will continue to add features to LangChain and provide other offerings that will:
- Make it easy to quickly prototype applications.
- Bridge the gap between prototyping and putting something into production.
We’re incredibly excited to see what will be built and to do more to support you. We are also especially grateful to the entire LangChain community. LangChain will continue to be open-source and focused on developers — our funding allows us to allocate more resources to take it to the next level. If this mission and journey sounds interesting to you, we are actively hiring founding engineers. If you have suggestions on new features or are interested in evaluating and running your LangChain applications in production, we’d especially love to hear from you at support@langchain.dev!
Thank you for everything so far, and let’s build some cool stuff 🙂