Browse Source

fix:【ai 大模型】科大讯飞星火 thinking 返回

YunaiV 10 months ago
parent
commit
d82c8e05d7

+ 1 - 2
yudao-module-ai/src/main/java/cn/iocoder/yudao/module/ai/framework/ai/core/model/xinghuo/XingHuoChatModel.java

@@ -6,7 +6,6 @@ import org.springframework.ai.chat.model.ChatModel;
 import org.springframework.ai.chat.model.ChatResponse;
 import org.springframework.ai.chat.prompt.ChatOptions;
 import org.springframework.ai.chat.prompt.Prompt;
-import org.springframework.ai.openai.OpenAiChatModel;
 import reactor.core.publisher.Flux;
 
 /**
@@ -31,7 +30,7 @@ public class XingHuoChatModel implements ChatModel {
     /**
      * v1 兼容 OpenAI 接口,进行复用
      */
-    private final OpenAiChatModel openAiChatModelV1;
+    private final ChatModel openAiChatModelV1;
 
     @Override
     public ChatResponse call(Prompt prompt) {

+ 2 - 2
yudao-module-ai/src/main/java/cn/iocoder/yudao/module/ai/util/AiUtils.java

@@ -51,7 +51,8 @@ public class AiUtils {
             case DEEP_SEEK:
             case DOU_BAO: // 复用 DeepSeek 客户端
             case HUN_YUAN: // 复用 DeepSeek 客户端
-            case SILICON_FLOW: // 复用 OpenAI 客户端
+            case SILICON_FLOW: // 复用 DeepSeek 客户端
+            case XING_HUO: // 复用 DeepSeek 客户端
                 return DeepSeekChatOptions.builder().model(model).temperature(temperature).maxTokens(maxTokens)
                         .toolNames(toolNames).toolContext(toolContext).build();
             case ZHI_PU:
@@ -65,7 +66,6 @@ public class AiUtils {
                         .toolNames(toolNames).toolContext(toolContext).build();
             case OPENAI:
             case GEMINI: // 复用 OpenAI 客户端
-            case XING_HUO: // 复用 OpenAI 客户端
             case BAI_CHUAN: // 复用 OpenAI 客户端
                 return OpenAiChatOptions.builder().model(model).temperature(temperature).maxTokens(maxTokens)
                         .toolNames(toolNames).toolContext(toolContext).build();

+ 19 - 0
yudao-module-ai/src/test/java/cn/iocoder/yudao/module/ai/framework/ai/core/model/chat/DouBaoChatModelTests.java

@@ -70,4 +70,23 @@ public class DouBaoChatModelTests {
         flux.doOnNext(System.out::println).then().block();
     }
 
+    @Test
+    @Disabled
+    public void testStream_thinking() {
+        // 准备参数
+        List<Message> messages = new ArrayList<>();
+        messages.add(new UserMessage("详细分析下,如何设计一个电商系统?"));
+        DeepSeekChatOptions options = DeepSeekChatOptions.builder()
+                .model("doubao-seed-1-6-thinking-250715")
+                .build();
+
+        // 调用
+        Flux<ChatResponse> flux = chatModel.stream(new Prompt(messages, options));
+        // 打印结果
+        flux.doOnNext(response -> {
+//            System.out.println(response);
+            System.out.println(response.getResult().getOutput());
+        }).then().block();
+    }
+
 }

+ 25 - 6
yudao-module-ai/src/test/java/cn/iocoder/yudao/module/ai/framework/ai/core/model/chat/XingHuoChatModelTests.java

@@ -8,9 +8,9 @@ import org.springframework.ai.chat.messages.SystemMessage;
 import org.springframework.ai.chat.messages.UserMessage;
 import org.springframework.ai.chat.model.ChatResponse;
 import org.springframework.ai.chat.prompt.Prompt;
-import org.springframework.ai.openai.OpenAiChatModel;
-import org.springframework.ai.openai.OpenAiChatOptions;
-import org.springframework.ai.openai.api.OpenAiApi;
+import org.springframework.ai.deepseek.DeepSeekChatModel;
+import org.springframework.ai.deepseek.DeepSeekChatOptions;
+import org.springframework.ai.deepseek.api.DeepSeekApi;
 import reactor.core.publisher.Flux;
 
 import java.util.ArrayList;
@@ -23,13 +23,13 @@ import java.util.List;
  */
 public class XingHuoChatModelTests {
 
-    private final OpenAiChatModel openAiChatModel = OpenAiChatModel.builder()
-        .openAiApi(OpenAiApi.builder()
+    private final DeepSeekChatModel openAiChatModel = DeepSeekChatModel.builder()
+        .deepSeekApi(DeepSeekApi.builder()
                 .baseUrl(XingHuoChatModel.BASE_URL_V2)
                 .completionsPath(XingHuoChatModel.BASE_COMPLETIONS_PATH_V2)
                 .apiKey("75b161ed2aef4719b275d6e7f2a4d4cd:YWYxYWI2MTA4ODI2NGZlYTQyNjAzZTcz") // appKey:secretKey
                 .build())
-        .defaultOptions(OpenAiChatOptions.builder()
+        .defaultOptions(DeepSeekChatOptions.builder()
 //                .model("generalv3.5") // 模型
                 .model("x1") // 模型
                 .temperature(0.7)
@@ -66,4 +66,23 @@ public class XingHuoChatModelTests {
         flux.doOnNext(System.out::println).then().block();
     }
 
+    @Test
+    @Disabled
+    public void testStream_thinking() {
+        // 准备参数
+        List<Message> messages = new ArrayList<>();
+        messages.add(new UserMessage("详细分析下,如何设计一个电商系统?"));
+        DeepSeekChatOptions options = DeepSeekChatOptions.builder()
+                .model("x1")
+                .build();
+
+        // 调用
+        Flux<ChatResponse> flux = chatModel.stream(new Prompt(messages, options));
+        // 打印结果
+        flux.doOnNext(response -> {
+//            System.out.println(response);
+            System.out.println(response.getResult().getOutput());
+        }).then().block();
+    }
+
 }

+ 1 - 1
yudao-server/src/main/resources/application.yaml

@@ -217,7 +217,7 @@ yudao:
       enable: true
       appKey: 75b161ed2aef4719b275d6e7f2a4d4cd
       secretKey: YWYxYWI2MTA4ODI2NGZlYTQyNjAzZTcz
-      model: generalv3.5
+      model: x1
     baichuan: # 百川智能
       enable: true
       api-key: sk-abc