在当今应用开发领域,类似OpenAI API等生成式AI技术的蓬勃发展正在彻底改变着应用开发的格局。Python和JavaScript等语言已经拥有丰富的资源来支持这些技术,其中LangChain就是一个显著的例子。然而,Go语言开发者面临的选择却相对有限。LangChainGo,作为LangChain的Go语言版本,一直在努力与Go的编程理念保持一致,而LangChain本身则常被认为过于复杂。
为了满足对一个既简单又强大的Go兼容工具的需求,我们推出了Agency。这个Go框架采用了一种精简的方法论,与Go固有的静态类型和性能效率的优势完美契合。它代表了我们对向Go编程社区引入用户友好且高效的AI功能的解决方案。
Agency的特性
- Go编程理念契合: 与LangChainGo不同,Agency注重与Go的编程理念的一致性,使得开发者更容易上手。
- 简洁而强大: 我们精心打磨了Agency的框架,确保其在保持简洁易用的同时,不失强大的功能。
- 静态类型与性能效率: 利用Go语言的静态类型和出色的性能优势,Agency在处理AI功能时更为高效。
Agency在实战中的应用
package main
import (
"bufio"
"context"
"fmt"
"os"
_ "github.com/joho/godotenv/autoload"
"github.com/neurocult/agency"
"github.com/neurocult/agency/providers/openai"
)
func main() {
// 初始化Assistant
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)
// 执行Assistant
answer, err := assistant.SetMessages(messages).Execute(ctx, input)
if err != nil {
panic(err)
}
// 打印Assistant回答
fmt.Println("Assistant: ", answer)
// 更新消息记录
messages = append(messages, input, answer)
}
}
以上是一个简单的Chat例子,展示了如何使用Agency框架与OpenAI的API实现基于Go的交互式聊天。这个例子体现了Agency的简单易用,以及如何与Go的语言特性无缝结合,为Go语言开发者提供了一种高效且友好的AI功能引入方式。
结语
在这个AI盛行的时代,我们深知Go语言开发者对于高效、简单而强大的AI工具的需求。Agency的诞生旨在填补Go语言领域的空白,为开发者提供一种更直观、更贴近Go编程理念的AI解决方案。