Migrated repository
Go to file
2024-04-26 10:46:58 +08:00
agents-flex-bom chore: optimize pom.xml 2024-04-25 18:45:52 +08:00
agents-flex-core refactor: refactor chains 2024-04-26 10:46:58 +08:00
agents-flex-document-parser v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
agents-flex-llm refactor: rename chatAsync to chatStream 2024-04-25 18:44:38 +08:00
agents-flex-samples v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
agents-flex-spring-boot-starter v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
agents-flex-store refactor: refactor DocumentStore.java 2024-04-25 18:36:39 +08:00
agents-flex-test v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
docs v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
.editorconfig init 2024-01-12 16:24:14 +08:00
.gitignore feat: 添加 agents-flex-spring-boot-starter 模块。 2024-04-11 13:08:34 +08:00
changes.md init 2024-01-12 16:24:14 +08:00
LICENSE init 2024-01-12 16:24:14 +08:00
pom.xml v1.0.0-alpha.5 prepare 2024-04-25 17:31:00 +08:00
readme_zh.md refactor: rename chatAsync to chatStream 2024-04-25 18:44:38 +08:00
readme.md refactor: rename chatAsync to chatStream 2024-04-25 18:44:38 +08:00

English | 简体中文

Agents-Flex is a LLM Application Framework like LangChain base on Java.


Features

  • LLM Visit
  • Prompt、Prompt Template Loader
  • Function Calling Definer, Invoker、Running
  • Memory
  • Embedding
  • Vector Storage
  • Resource Loaders
  • Document
    • Splitter
    • Loader
    • Parser
      • PoiParser
      • PdfBoxParser
  • LLMs Chain
  • Agents Chain

Simple Chat

use OpenAi LLM:

 @Test
public void testChat() {
    OpenAiLlmConfig config = new OpenAiLlmConfig();
    config.setApiKey("sk-rts5NF6n*******");

    Llm llm = new OpenAiLlm(config);
    String response = llm.chat("what is your name?");

    System.out.println(response);
}

use Qwen LLM:

 @Test
public void testChat() {
    QwenLlmConfig config = new QwenLlmConfig();
    config.setApiKey("sk-28a6be3236****");
    config.setModel("qwen-turbo");

    Llm llm = new QwenLlm(config);
    String response = llm.chat("what is your name?");

    System.out.println(response);
}

use SparkAi LLM:

 @Test
public void testChat() {
    SparkLlmConfig config = new SparkLlmConfig();
    config.setAppId("****");
    config.setApiKey("****");
    config.setApiSecret("****");

    Llm llm = new SparkLlm(config);
    String response = llm.chat("what is your name?");

    System.out.println(response);
}

Chat With Histories

public static void main(String[] args) {
    SparkLlmConfig config = new SparkLlmConfig();
    config.setAppId("****");
    config.setApiKey("****");
    config.setApiSecret("****");

    Llm llm = new SparkLlm(config);

    HistoriesPrompt prompt = new HistoriesPrompt();

    System.out.println("ask for something...");
    Scanner scanner = new Scanner(System.in);
    String userInput = scanner.nextLine();

    while (userInput != null) {

        prompt.addMessage(new HumanMessage(userInput));

        llm.chatStream(prompt, (context, response) -> {
            System.out.println(">>>> " + response.getMessage().getContent());
        });

        userInput = scanner.nextLine();
    }
}

Function Calling

  • step 1: define the function native
public class WeatherUtil {

    @FunctionDef(name = "get_the_weather_info", description = "get the weather info")
    public static String getWeatherInfo(
        @FunctionParam(name = "city", description = "the city name") String name
    ) {
        //we should invoke the third part api for weather info here
        return "Today it will be dull and overcast in " + name;
    }
}

  • step 2: invoke the function from LLM
 public static void main(String[] args) {
    OpenAiLlmConfig config = new OpenAiLlmConfig();
    config.setApiKey("sk-rts5NF6n*******");

    OpenAiLlm llm = new OpenAiLlm(config);

    FunctionPrompt prompt = new FunctionPrompt("How is the weather in Beijing today?", WeatherUtil.class);
    FunctionResultResponse response = llm.chat(prompt);

    Object result = response.invoke();

    System.out.println(result);
    //Today it will be dull and overcast in Beijing
}

Communication

Modules