|
@@ -0,0 +1,62 @@
|
|
1
|
+package com.gct.aoid.service.impl;
|
|
2
|
+
|
|
3
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
4
|
+import com.gct.aoid.entity.AoidDailyYield;
|
|
5
|
+import com.gct.aoid.feignclient.WarningClint;
|
|
6
|
+import com.gct.aoid.mapper.AoidDailyYieldMapper;
|
|
7
|
+import com.gct.aoid.service.AoidWarningService;
|
|
8
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
9
|
+
|
|
10
|
+import java.math.BigDecimal;
|
|
11
|
+
|
|
12
|
+public class AoidWarningServiceImpl implements AoidWarningService {
|
|
13
|
+
|
|
14
|
+ @Autowired
|
|
15
|
+ AoidDailyYieldMapper aoidDailyYieldMapper;
|
|
16
|
+ @Autowired
|
|
17
|
+ WarningClint warningClint;
|
|
18
|
+ @Override
|
|
19
|
+ public String isWarning(String wellId,String date) {
|
|
20
|
+
|
|
21
|
+ //获取前一个月的平均产液量
|
|
22
|
+ String avgForA2LiqProdDaily = aoidDailyYieldMapper.getAVGForA2LiqProdDaily(wellId, date);
|
|
23
|
+ //获取当前的产液量
|
|
24
|
+ QueryWrapper<AoidDailyYield> wrapper = new QueryWrapper<>();
|
|
25
|
+ wrapper.eq("well_id",wellId).eq("prod_date",date);
|
|
26
|
+ AoidDailyYield aoidDailyYield = aoidDailyYieldMapper.selectOne(wrapper);
|
|
27
|
+ Double aDouble = Double.valueOf(avgForA2LiqProdDaily);
|
|
28
|
+ double liqProdDaily = aoidDailyYield.getLiqProdDaily();
|
|
29
|
+ double difference = aDouble-liqProdDaily;
|
|
30
|
+ String result = "";
|
|
31
|
+ int[] num = {15,10,5,1,0};
|
|
32
|
+ double[] coefficient = {0.1,0.15,0.2,0.25,0.5};
|
|
33
|
+ for (int i = 0 ;i< num.length; i++){
|
|
34
|
+ if (aDouble>=num[i]){
|
|
35
|
+ if (aDouble * (1-coefficient[i]) > liqProdDaily){
|
|
36
|
+ result = "液量异常";
|
|
37
|
+ break;
|
|
38
|
+ }else {
|
|
39
|
+ result = "液量正常";
|
|
40
|
+ break;
|
|
41
|
+ }
|
|
42
|
+ }
|
|
43
|
+ }
|
|
44
|
+ //液量异常井 提取工况诊断是否正常,不正常 进入油井工况诊断 得出结论并输出 yuancheng wn_gk_msg context
|
|
45
|
+ if (result.equals("液量异常")){
|
|
46
|
+ String extractWorkingConditionDiagnosis = warningClint.extractWorkingConditionDiagnosis(wellId,date);
|
|
47
|
+ if(extractWorkingConditionDiagnosis.equals("正常")){
|
|
48
|
+ //正常 提取该井压力库数据,判断是否在高压区 默认 低压区
|
|
49
|
+ //如处在低压区,查看 平均值与当日值的差是否大于0 ,大于0 分析为油井见效,输出结果;小于0 分析为能量不足,输出结果
|
|
50
|
+ //如在高压区,查看 平均值与当日值的差是否大于0 ,大于0 分析为油井见效,输出结果;小于0分析为地层堵塞,输出结果
|
|
51
|
+ if (difference > 0){
|
|
52
|
+ result = "油井见效";
|
|
53
|
+ }else {
|
|
54
|
+ result = "能量不足";
|
|
55
|
+ }
|
|
56
|
+ }else{
|
|
57
|
+ result = extractWorkingConditionDiagnosis;
|
|
58
|
+ }
|
|
59
|
+ }
|
|
60
|
+ return result;
|
|
61
|
+ }
|
|
62
|
+}
|