|
@@ -5,13 +5,12 @@ import cn.hutool.http.HttpRequest;
|
|
|
import com.alibaba.fastjson2.JSON;
|
|
|
import com.alibaba.fastjson2.JSONArray;
|
|
|
import com.alibaba.fastjson2.JSONObject;
|
|
|
+import com.alibaba.fastjson2.JSONWriter;
|
|
|
import com.google.protobuf.ByteString;
|
|
|
-import com.slibra.business.domain.TXinyiIndustry;
|
|
|
-import com.slibra.business.domain.TXinyiNormConfig;
|
|
|
-import com.slibra.business.domain.TXinyiRobot;
|
|
|
-import com.slibra.business.domain.TXinyiWarningRecord;
|
|
|
+import com.slibra.business.domain.*;
|
|
|
import com.slibra.business.mapper.*;
|
|
|
import com.slibra.business.req.ChatReq;
|
|
|
+import com.slibra.business.req.DecisionReq;
|
|
|
import com.slibra.common.constant.MyConstants;
|
|
|
import com.slibra.common.enums.BusinessEnum;
|
|
|
import com.slibra.common.enums.DataSourceType;
|
|
@@ -32,6 +31,7 @@ import org.springframework.util.CollectionUtils;
|
|
|
|
|
|
import java.io.IOException;
|
|
|
import java.math.BigDecimal;
|
|
|
+import java.math.RoundingMode;
|
|
|
import java.time.LocalDateTime;
|
|
|
import java.time.format.DateTimeFormatter;
|
|
|
import java.util.*;
|
|
@@ -79,6 +79,9 @@ public class RyTask
|
|
|
@Autowired
|
|
|
private TXinyiChatRecordMapper xinyiChatRecordMapper;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private TXinyiDailyMapper xinyiDailyMapper;
|
|
|
+
|
|
|
|
|
|
// public final static StopWatch watch = new StopWatch("task");
|
|
|
public static final String[] queryTags = {"信义污水厂JS_COD_Value","信义污水厂JS_PH_Value","信义污水厂JS_SS_Value","信义污水厂JS_ZL_Value","信义污水厂JS_ZA_Value","信义污水厂JS_AD_Value","信义污水厂JS_T_Value","信义污水厂进水泵房液位","信义污水厂出水瞬时流量","信义污水厂升级出水COD","信义污水厂升级出水PH","信义污水厂升级出水SS","信义污水厂升级出水TN","信义污水厂升级出水TP","信义污水厂升级出水氨氮","信义污水厂AIT202_Value","信义污水厂AIT203_Value","信义污水厂AIT207_Value","信义污水厂AIT206_Value","信义污水厂AIT209_Value","信义污水厂AIT210_Value","信义污水厂进水TDS","信义污水厂FT101_Value","信义污水厂SWCHHYHLB1_R_Value","信义污水厂SWCHHYHLB2_R_Value","信义污水厂SWCHHYHLB3_R_Value","信义污水厂SWCHHYHLB4_R_Value","信义污水厂SWCHHYHLB5_R_Value","信义污水厂SWCHHYHLB6_R_Value","信义污水厂SWCWNHLB1_R_Value","信义污水厂SWCWNHLB2_R_Value","信义污水厂SWCWNHLB3_R_Value","信义污水厂SWCWNHLB4_R_Value","信义污水厂SWCWNHLB5_R_Value","信义污水厂GFJ1_R_Value","信义污水厂GFJ2_R_Value","信义污水厂GFJ3_R_Value","信义污水厂GFJ4_R_Value","信义污水厂GFJ5_R_Value","信义污水厂GFJ6_R_Value","信义污水厂GFJ1_KQLL_Value","信义污水厂GFJ2_KQLL_Value","信义污水厂GFJ3_KQLL_Value","信义污水厂GFJ4_KQLL_Value","信义污水厂GFJ5_KQLL_Value","信义污水厂GFJ6_KQLL_Value","信义污水厂实际碳源加药量","信义污水厂除磷加药瞬时流量", "信义污水厂_除磷P04预测值_"};
|
|
@@ -426,13 +429,45 @@ public class RyTask
|
|
|
private void handleDecision(TXinyiWarningRecord tXinyiWarningRecord, TXinyiIndustry tXinyiIndustry, TXinyiNormConfig normConfig) {
|
|
|
log.info("进入了调⽤大模型决策接口");
|
|
|
ChatReq chatReq = new ChatReq();
|
|
|
- StringBuilder sb = new StringBuilder();
|
|
|
+// StringBuilder sb = new StringBuilder();
|
|
|
+ //大模型结果 放入一个结合中
|
|
|
+ List<String> resultData = new ArrayList<>();
|
|
|
//决策和问答不一样 没有历史的概念 所以sessionId都是新的 次数都是1
|
|
|
String sessionId = IdUtils.simpleUUID();
|
|
|
String feedback = chatReq.getFeedback();
|
|
|
//决策请求的业务参数
|
|
|
- List<HashMap<String, Object>> list = this.xinyiIndustryMapper.selectLast10RecordsForDecision();
|
|
|
- String rows = JSON.toJSONString(list);
|
|
|
+// List<HashMap<String, Object>> list = this.xinyiIndustryMapper.selectLast10RecordsForDecision();
|
|
|
+ //2024年5月21日15:23:07 这里不能用关联查询处理,日报要获取最新的一条而不是今日的数据。
|
|
|
+ List<DecisionReq> decisionReqs = this.xinyiIndustryMapper.selectLast10RecordsForDecisionOnlyIndustry();
|
|
|
+ if(!CollectionUtils.isEmpty(decisionReqs)){
|
|
|
+ for (DecisionReq decisionReq : decisionReqs) {
|
|
|
+ //处理日报数据
|
|
|
+ TXinyiDaily daily = this.xinyiDailyMapper.selectNewestData();
|
|
|
+ if(!Objects.isNull(daily)){
|
|
|
+ decisionReq.setT(daily.getJsSw());
|
|
|
+ decisionReq.setSVI(daily.getWntjzsAll());
|
|
|
+ decisionReq.setSV(daily.getWncjbAll());
|
|
|
+ decisionReq.setMLVSS(daily.getHfxwnndAll());
|
|
|
+ decisionReq.setDO_ana(daily.getYycRjyAll());
|
|
|
+ decisionReq.setDO_que(daily.getQycRjyAll());
|
|
|
+ BigDecimal jsBod5 = daily.getJsBod5();
|
|
|
+ decisionReq.setBOD_in(jsBod5);
|
|
|
+ BigDecimal tpIn = decisionReq.getTP_in();
|
|
|
+ BigDecimal tnIn = decisionReq.getTN_in();
|
|
|
+ if(!Objects.isNull(jsBod5)){
|
|
|
+ if(!Objects.isNull(tpIn) && tpIn.compareTo(new BigDecimal("0")) >0){
|
|
|
+ decisionReq.setC(jsBod5.divide(tpIn, 4, RoundingMode.HALF_UP));
|
|
|
+ }
|
|
|
+ if(!Objects.isNull(tnIn) && tnIn.compareTo(new BigDecimal("0")) >0){
|
|
|
+ decisionReq.setB(jsBod5.divide(tnIn, 4, RoundingMode.HALF_UP));
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ String rows = JSON.toJSONString(decisionReqs, JSONWriter.Feature.WriteNulls);
|
|
|
// 获取输出流
|
|
|
ManagedChannel channel = null;
|
|
|
String dataJson = "";
|
|
@@ -456,13 +491,16 @@ public class RyTask
|
|
|
if("complete".equals(responseStr)){
|
|
|
System.out.println("结尾语句并且是非JSON,无需处理");
|
|
|
}else{
|
|
|
- sb.append(responseStr);
|
|
|
+// sb.append(responseStr);
|
|
|
+ resultData.add(responseStr);
|
|
|
}
|
|
|
+ // todo 类型判断处理
|
|
|
}
|
|
|
} catch (Exception e) {
|
|
|
- throw new RuntimeException(e);
|
|
|
+// throw new RuntimeException(e);
|
|
|
+ log.error("处理大模型推理异常,异常信息为{}", JSON.toJSONString(e));
|
|
|
} finally {
|
|
|
- System.out.println(sb.toString());
|
|
|
+ System.out.println(JSON.toJSONString(resultData));
|
|
|
//保存聊天记录
|
|
|
//将问答更新到数据库中
|
|
|
chatReq.setSessionId(sessionId);
|
|
@@ -474,7 +512,7 @@ public class RyTask
|
|
|
String showVal = this.buildShowValue(tXinyiWarningRecord, tXinyiIndustry, normConfig);
|
|
|
chatReq.setShowVal(showVal);//前端展示的数据和提问的数据不一致
|
|
|
chatReq.setQuestion(dataJson);
|
|
|
- chatReq.setAnswer(sb.toString());
|
|
|
+ chatReq.setAnswer(JSON.toJSONString(resultData));
|
|
|
chatReq.setWarningId(String.valueOf(tXinyiWarningRecord.getId()));
|
|
|
chatReq.setCounts(1);//问答次数
|
|
|
|
|
@@ -821,6 +859,14 @@ public class RyTask
|
|
|
Date date = new Date();
|
|
|
System.out.println(DateUtils.differentHoursByMillisecond(date, date));
|
|
|
|
|
|
+ HashMap<Object, Object> map = new HashMap<>();
|
|
|
+ map.put("a", null);
|
|
|
+ map.put("b", "ab");
|
|
|
+ map.put("c", "");
|
|
|
+ map.put("d", '1');
|
|
|
+ System.out.println(JSON.toJSONString(map, JSONWriter.Feature.WriteNulls));
|
|
|
+ TXinyiIndustry tXinyiIndustry = new TXinyiIndustry();
|
|
|
+ System.out.println(JSON.toJSONString(tXinyiIndustry, JSONWriter.Feature.WriteNulls));
|
|
|
}
|
|
|
|
|
|
|