Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neurocult/agency
🕵️♂️ Library designed for developers eager to explore the potential of Large Language Models (LLMs) and other generative AI through a clean, effective, and Go-idiomatic approach.
https://github.com/neurocult/agency
agents ai artificial-general-intelligence artificial-intelligence artificial-neural-networks autonomous-agents chatgpt generative-ai go golang gpt language-models llm llmops machine-learning neural-network nlp openai rag vector-database
Last synced: 4 months ago
JSON representation
🕵️♂️ Library designed for developers eager to explore the potential of Large Language Models (LLMs) and other generative AI through a clean, effective, and Go-idiomatic approach.
- Host: GitHub
- URL: https://github.com/neurocult/agency
- Owner: neurocult
- License: mit
- Created: 2023-11-13T19:49:03.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-13T12:59:11.000Z (10 months ago)
- Last Synced: 2024-04-14T02:43:49.653Z (10 months ago)
- Topics: agents, ai, artificial-general-intelligence, artificial-intelligence, artificial-neural-networks, autonomous-agents, chatgpt, generative-ai, go, golang, gpt, language-models, llm, llmops, machine-learning, neural-network, nlp, openai, rag, vector-database
- Language: Go
- Homepage:
- Size: 894 KB
- Stars: 373
- Watchers: 5
- Forks: 19
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-agents - Agency - idiomatic approach data:image/s3,"s3://crabby-images/48bb3/48bb3e847554b5bd92744cb57d82d6b88efec481" alt="GitHub Repo stars" (Software Development)
- awesome-langchain-zh - Agency
- awesome-langchain - Agency - idiomatic approach data:image/s3,"s3://crabby-images/48bb3/48bb3e847554b5bd92744cb57d82d6b88efec481" alt="GitHub Repo stars" (Other LLM Frameworks / Videos Playlists)
- awesome-ChatGPT-repositories - agency - 🕵️♂️ Library designed for developers eager to explore the potential of Large Language Models (LLMs) and other generative AI through a clean, effective, and Go-idiomatic approach. (NLP)
- awesome-agents - agency - idiomatic approach. | coding | 459 | 28 | 2 | 4 | 19 days, 2 hrs, 29 mins | 5 | MIT License | (Table of Open-Source AI Agents Projects)
README
# Agency: The Go Way to AI
Library designed for developers eager to explore the potential of Large Language Models (LLMs) and other generative AI through a clean, effective, and Go-idiomatic approach.
**Welcome to the agency!** 🕵️♂️
data:image/s3,"s3://crabby-images/34366/3436654ed06b0410c7f07c9a1066fa0f55432515" alt="Dracula-agent, mascot of the "agency" library."
## 💻 Quick Start
Install package:
```bash
go get github.com/neurocult/agency
```Chat example:
```go
package mainimport (
"bufio"
"context"
"fmt"
"os"_ "github.com/joho/godotenv/autoload"
"github.com/neurocult/agency"
"github.com/neurocult/agency/providers/openai"
)func main() {
assistant := openai.
New(openai.Params{Key: os.Getenv("OPENAI_API_KEY")}).
TextToText(openai.TextToTextParams{Model: "gpt-3.5-turbo"}).
SetPrompt("You are helpful assistant.")messages := []agency.Message{}
reader := bufio.NewReader(os.Stdin)
ctx := context.Background()for {
fmt.Print("User: ")text, err := reader.ReadString('\n')
if err != nil {
panic(err)
}input := agency.UserMessage(text)
answer, err := assistant.SetMessages(messages).Execute(ctx, input)
if err != nil {
panic(err)
}fmt.Println("Assistant: ", answer)
messages = append(messages, input, answer)
}
}
```That's it!
See [examples](./examples/) to find out more complex usecases including RAGs and multimodal operations.
## 🚀 Features
✨ **Pure Go**: fast and lightweight, statically typed, no need to mess with Python or JavaScript
✨ Write **clean code** and follow **clean architecture** by separating business logic from concrete implementations
✨ Easily create **custom operations** by implementing simple interface
✨ **Compose operations** together into **processes** with the ability to observe each step via **interceptors**
✨ **OpenAI API bindings** (can be used for any openai-compatable API: text to text (completion), text to image, text to speech, speech to text
## 🤔 Why need Agency?
At the heart of Agency is the ambition to empower users to build autonomous agents. While **perfect for all range of generative AI applications**, from chat interfaces to complex data analysis, our library's ultimate goal is to simplify the creation of autonomous AI systems. Whether you're building individual assistant or coordinating agent swarms, Agency provides the tools and flexibility needed to bring these advanced concepts to life with ease and efficiency.
In the generative AI landscape, Go-based libraries are rare. The most notable is [LangChainGo](https://github.com/tmc/langchaingo), a Go port of the Python LangChain. However, translating Python to Go can be clunky and may not fit well with Go's idiomatic style. Plus, some question LangChain's design, even in Python. This situation reveals a clear need for an idiomatic Go alternative.
Our goal is to fill this gap with a Go-centric library that emphasizes clean, simple code and avoids unnecessary complexities. Agency is designed with a small, robust core, easy to extend and perfectly suited to Go's strengths in static typing and performance. It's our answer to the lack of Go-native solutions in generative AI.
## Tutorial
- [Part 1](https://dev.to/emil14/agency-the-go-way-to-ai-part-1-1lhe) ([Russian translation](https://habr.com/ru/sandbox/204508/))
## 🛣 Roadmap
In the next versions:
- [ ] Support for external function calls
- [ ] Metadata (tokens used, audio duration, etc)
- [ ] More provider-adapters, not only openai
- [ ] Image to text operations
- [ ] Powerful API for autonomous agents
- [ ] Tagging and JSON output parser