mirror of
https://gitcode.com/ageerle/ruoyi-ai.git
synced 2026-04-10 02:07:33 +00:00
向量模型通过模型管理获取配置
This commit is contained in:
@@ -11,6 +11,8 @@ import org.ruoyi.common.chat.entity.embeddings.EmbeddingResponse;
|
|||||||
import org.ruoyi.common.chat.openai.OpenAiStreamClient;
|
import org.ruoyi.common.chat.openai.OpenAiStreamClient;
|
||||||
import org.ruoyi.knowledge.domain.vo.KnowledgeInfoVo;
|
import org.ruoyi.knowledge.domain.vo.KnowledgeInfoVo;
|
||||||
import org.ruoyi.knowledge.service.IKnowledgeInfoService;
|
import org.ruoyi.knowledge.service.IKnowledgeInfoService;
|
||||||
|
import org.ruoyi.system.domain.SysModel;
|
||||||
|
import org.ruoyi.system.service.ISysModelService;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.context.annotation.Lazy;
|
import org.springframework.context.annotation.Lazy;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
@@ -31,6 +33,9 @@ public class OpenAiVectorization implements Vectorization {
|
|||||||
@Lazy
|
@Lazy
|
||||||
@Resource
|
@Resource
|
||||||
private LocalModelsVectorization localModelsVectorization;
|
private LocalModelsVectorization localModelsVectorization;
|
||||||
|
@Lazy
|
||||||
|
@Resource
|
||||||
|
private ISysModelService sysModelService;
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
private OpenAiStreamClient openAiStreamClient;
|
private OpenAiStreamClient openAiStreamClient;
|
||||||
@@ -40,9 +45,18 @@ public class OpenAiVectorization implements Vectorization {
|
|||||||
@Override
|
@Override
|
||||||
public List<List<Double>> batchVectorization(List<String> chunkList, String kid) {
|
public List<List<Double>> batchVectorization(List<String> chunkList, String kid) {
|
||||||
List<List<Double>> vectorList;
|
List<List<Double>> vectorList;
|
||||||
openAiStreamClient = chatConfig.getOpenAiStreamClient();
|
|
||||||
// 获取知识库信息
|
// 获取知识库信息
|
||||||
KnowledgeInfoVo knowledgeInfoVo = knowledgeInfoService.queryById(Long.valueOf(kid));
|
KnowledgeInfoVo knowledgeInfoVo = knowledgeInfoService.queryById(Long.valueOf(kid));
|
||||||
|
if(knowledgeInfoVo == null){
|
||||||
|
log.warn("知识库不存在:请查检ID {}",kid);
|
||||||
|
vectorList=new ArrayList<>();
|
||||||
|
vectorList.add(new ArrayList<>());
|
||||||
|
return vectorList;
|
||||||
|
}
|
||||||
|
SysModel sysModel = sysModelService.selectModelByName(knowledgeInfoVo.getVectorModel());
|
||||||
|
String apiHost= sysModel.getApiHost();
|
||||||
|
String apiKey= sysModel.getApiKey();
|
||||||
|
openAiStreamClient = chatConfig.createOpenAiStreamClient(apiHost,apiKey);
|
||||||
|
|
||||||
Embedding embedding = buildEmbedding(chunkList, knowledgeInfoVo);
|
Embedding embedding = buildEmbedding(chunkList, knowledgeInfoVo);
|
||||||
EmbeddingResponse embeddings = openAiStreamClient.embeddings(embedding);
|
EmbeddingResponse embeddings = openAiStreamClient.embeddings(embedding);
|
||||||
|
|||||||
@@ -63,6 +63,7 @@ public class SysModelServiceImpl implements ISysModelService {
|
|||||||
lqw.like(StringUtils.isNotBlank(bo.getModelShow()), SysModel::getModelShow, bo.getModelShow());
|
lqw.like(StringUtils.isNotBlank(bo.getModelShow()), SysModel::getModelShow, bo.getModelShow());
|
||||||
lqw.eq(StringUtils.isNotBlank(bo.getModelDescribe()), SysModel::getModelDescribe, bo.getModelDescribe());
|
lqw.eq(StringUtils.isNotBlank(bo.getModelDescribe()), SysModel::getModelDescribe, bo.getModelDescribe());
|
||||||
lqw.eq(StringUtils.isNotBlank(bo.getModelType()), SysModel::getModelType, bo.getModelType());
|
lqw.eq(StringUtils.isNotBlank(bo.getModelType()), SysModel::getModelType, bo.getModelType());
|
||||||
|
lqw.eq(StringUtils.isNotBlank(bo.getCategory()), SysModel::getCategory, bo.getCategory());
|
||||||
return lqw;
|
return lqw;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user