Explorar o código

状态判定修改

shilin hai 1 ano
pai
achega
810ff424c0

+ 2 - 218
realtime/generationXK-service/src/main/java/com/gyee/generation/GenerationMain.java

@@ -16,227 +16,11 @@ public class GenerationMain {
     public static void main(String[] args) throws Exception {
         SpringApplication.run(GenerationMain.class, args);
 
-//        InputOrOutPutService inputOrOutPutService= SpringUtils.getBean("inputOrOutPutService");
+//        StatusService statusService= SpringUtils.getBean("statusService");
 //
-//        inputOrOutPutService.initialInputOrOutputSpeed();
-//
-//
-//        CacheService cacheService= SpringUtils.getBean("cacheService");
-//        cacheService.initRedisCache();
-//
-//
-//        Calendar c=Calendar.getInstance();
-//        //故障转换率记录调度程序执行开始!
-//        TimelinessRateService timelinessRateService= SpringUtils.getBean("timelinessRateService");
-//        timelinessRateService.failRate(c.getTime());
-
-//        ProEconEqOriginalService proEconEqOriginalService= SpringUtils.getBean("proEconEqOriginalService");
-//        System.out.println("开始生成风机报表指标统计。。。。。。");
-//        proEconEqOriginalService.calEquipmentInfoDay(new Date());
-//        System.out.println("结束生成风机报表指标统计。。。。。。");
-//
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,1);
-//        c.set(Calendar.DAY_OF_MONTH,24);
-//        c.set(Calendar.HOUR_OF_DAY, 0);
-//        c.set(Calendar.MINUTE, 0);
-//        c.set(Calendar.SECOND, 0);
-//        c.set(Calendar.MILLISECOND, 0);
-//        Date date = c.getTime();
-//        ProEconStaOriginalService proEconStaOriginalService= SpringUtils.getBean("proEconStaOriginalService");
-//         System.out.println("开始生成场站报表指标统计。。。。。。");
-//         proEconStaOriginalService.calEquipmentInfoDay(date);
-//         System.out.println("结束生成场站报表指标统计。。。。。。");
-//        InitialPointGoldenXkByEqEdosService initialPointGoldenXkByEqEdosService= SpringUtils.getBean("initialPointGoldenXkByEqEdosService");
+//       statusService.startStatusReal();
 
-//
-//
-//
-//        System.out.println("开始导出主变测点。。。。。。");
-//        initialPointGoldenXkByEqEdosService.initalZb();
-//        System.out.println("结束导出主变测点。。。。。。");
-//
-//        System.out.println("开始导出风机测点。。。。。。");
-//        initialPointGoldenXkByEqEdosService.initalFj();
-//        System.out.println("结束导出风机测点。。。。。。");
-//
-//        System.out.println("开始导出风场测点。。。。。。");
-//        initialPointGoldenXkByEqEdosService.initalFc();
-//        System.out.println("结束导出风场测点。。。。。。");
-//
-//
-//        System.out.println("开始导出测风塔风功率AGC测点表。。。。。。");
-//        initialPointGoldenXkByEqEdosService.initalFgl();
-//        System.out.println("结束导出测风塔风功率AGC测点表。。。。。。");
-//
-//        System.out.println("开始导出气象测点表。。。。。。");
-//        initialPointGoldenXkByEqEdosService.initalQx();
-//        System.out.println("结束导出气象测点表。。。。。。");
-//
-//        PowerCurveFittingByTimeService powerCurveFittingByTimeService= SpringUtils.getBean("powerCurveFittingByTimeService");
-//        Calendar c=Calendar.getInstance();
-////        c.set(Calendar.MONTH,7);
-////        c.set(Calendar.DAY_OF_MONTH,2);
-//        Date date =c.getTime();
-//
-//        powerCurveFittingByTimeService.cureFittingMonth(date,"1");
-//        powerCurveFittingByTimeService.cureFittingYear(date);
-//        CacheService cacheService= SpringUtils.getBean("cacheService");
-//        cacheService.initRedisCache();
-//        InputOrOutPutService inputOrOutPutService= SpringUtils.getBean("inputOrOutPutService");
-//       inputOrOutPutService.inputOrOutput(new Date());
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,7);
-//        c.set(Calendar.DAY_OF_MONTH,2);
-//        c.set(Calendar.HOUR_OF_DAY, 0);
-//        c.set(Calendar.MINUTE, 0);
-//        c.set(Calendar.SECOND, 0);
-//        c.set(Calendar.MILLISECOND, 0);
-//        Date date = c.getTime();
-//
-//       for(int i=0;i<288*10;i++)
-//       {
-//           inputOrOutPutService.inputOrOutputSpeed(date);
-//           c.add(Calendar.MINUTE, 6);
-//           date = c.getTime();
-//           System.out.println("date"+DateUtils.toDate1(date));
-//       }
-//        while (true)
-//        {
-//            inputOrOutPutService.inputOrOutputSpeed(new Date());
-//        }
-//
-//        Date date =new Date();
-//
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,1);
-//        c.set(Calendar.DAY_OF_MONTH,10);
-//        Date date = DateUtils.truncate(c.getTime());
-//
-//        for (int i = 0; i < 6; i++) {
-//
-//            WindPowerInfo1Service windPowerInfo1Service = SpringUtils.getBean("windPowerInfo1Service");
-//
-//            windPowerInfo1Service.calLineInfoDay(date);
-//            windPowerInfo1Service.calProjectInfoDay(date);
-//            windPowerInfo1Service.calWindpowerInfoDay(date);
-//            windPowerInfo1Service.calCompanyInfoDay(date);
-//            windPowerInfo1Service.calRegionInfoDay(date);
-//
-//            WindPowerInfo2Service windPowerInfo2Service = SpringUtils.getBean("windPowerInfo2Service");
-//            windPowerInfo2Service.calLineInfoDay(date);
-//            windPowerInfo2Service.calProjectInfoDay(date);
-//            windPowerInfo2Service.calWindpowerInfoDay(date);
-//            windPowerInfo2Service.calCompanyInfoDay(date);
-//            windPowerInfo2Service.calRegionInfoDay(date);
-//
-//            WindPowerInfo3Service windPowerInfo3Service = SpringUtils.getBean("windPowerInfo3Service");
-//            windPowerInfo3Service.calLineInfoDay(date);
-//            windPowerInfo3Service.calProjectInfoDay(date);
-//            windPowerInfo3Service.calWindpowerInfoDay(date);
-//            windPowerInfo3Service.calCompanyInfoDay(date);
-//            windPowerInfo3Service.calRegionInfoDay(date);
-//
-//            WindPowerInfo4Service windPowerInfo4Service = SpringUtils.getBean("windPowerInfo4Service");
-//            windPowerInfo4Service.calLineInfoDay(date);
-//            windPowerInfo4Service.calProjectInfoDay(date);
-//            windPowerInfo4Service.calWindpowerInfoDay(date);
-//            windPowerInfo4Service.calCompanyInfoDay(date);
-//            windPowerInfo4Service.calRegionInfoDay(date);
-//
-//            WindPowerInfo5Service windPowerInfo5Service = SpringUtils.getBean("windPowerInfo5Service");
-//            windPowerInfo5Service.calLineInfoDay(date);
-//            windPowerInfo5Service.calProjectInfoDay(date);
-//            windPowerInfo5Service.calWindpowerInfoDay(date);
-//            windPowerInfo5Service.calCompanyInfoDay(date);
-//            windPowerInfo5Service.calRegionInfoDay(date);
-//
-//            WindPowerInfo6Service windPowerInfo6Service = SpringUtils.getBean("windPowerInfo6Service");
-//            windPowerInfo6Service.calLineInfoDay(date);
-//            windPowerInfo6Service.calProjectInfoDay(date);
-//            windPowerInfo6Service.calWindpowerInfoDay(date);
-//            windPowerInfo6Service.calCompanyInfoDay(date);
-//            windPowerInfo6Service.calRegionInfoDay(date);
-//
-//
-//            EquipmentInfo1Service equipmentInfo1Service = SpringUtils.getBean("equipmentInfo1Service");
-//            equipmentInfo1Service.calEquipmentInfoDay(date);
-//            EquipmentInfo2Service equipmentInfo2Service = SpringUtils.getBean("equipmentInfo2Service");
-//            equipmentInfo2Service.calEquipmentInfoDay(date);
-//            EquipmentInfo3Service equipmentInfo3Service = SpringUtils.getBean("equipmentInfo3Service");
-//            equipmentInfo3Service.calEquipmentInfoDay(date);
-//            EquipmentInfo4Service equipmentInfo4Service = SpringUtils.getBean("equipmentInfo4Service");
-//            equipmentInfo4Service.calEquipmentInfoDay(date);
-//            EquipmentInfo5Service equipmentInfo5Service = SpringUtils.getBean("equipmentInfo5Service");
-//            equipmentInfo5Service.calEquipmentInfoDay(date);
-//
-//
-//            WtAlysisDayService wtAlysisDayService = SpringUtils.getBean("wtAlysisDayService");
-//            wtAlysisDayService.calEquipmentInfoDay(date);
-//
-//            EquipmentInfoDayTopService equipmentInfoDayTopService = SpringUtils.getBean("equipmentInfoDayTopService");
-//            equipmentInfoDayTopService.calEquipmentInfoDayTop(date);
-//            equipmentInfoDayTopService.calEquipmentInfoMonthTop(date);
-//            equipmentInfoDayTopService.calEquipmentInfoYearTop(date);
-//            c.add(Calendar.DAY_OF_MONTH, 1);
-//            date = c.getTime();
-//            System.out.println(DateUtils.toDate1(date)+"完成");
-//
-//        }
-//
-//
-//
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,1);
-//        c.set(Calendar.DAY_OF_MONTH,10);
-//        Date date = DateUtils.truncate(c.getTime());
-//
-//        for (int i = 0; i < 2; i++) {
-//
-//       WindturbineGoodnessService windturbineGoodnessService= SpringUtils.getBean("windturbineGoodnessService");
-//        windturbineGoodnessService.calWindturbineGoodness(c.getTime());
-//            c.add(Calendar.DAY_OF_MONTH, 1);
-//            date = c.getTime();
-//            System.out.println(DateUtils.toDate1(date)+"完成");
-//
-//        }
-//
-//
 
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,7);
-//        c.set(Calendar.DAY_OF_MONTH,31);
-//        PowerCurveFittingByTimeService powerCurveFittingByTimeService= SpringUtils.getBean("powerCurveFittingByTimeService");
-////        powerCurveFittingByTimeService.cureFittingDay(c.getTime());
-//        powerCurveFittingByTimeService.cureFittingMonth(c.getTime(),"0");
-////        powerCurveFittingByTimeService.cureFittingYear(c.getTime());
-//        Date end=new Date();
-//        System.out.println("执行用时"+ DateUtils.secondsDiff(date,end) +"秒");
-//        System.out.println("计算完成");
-//
-//        CacheService cacheService= SpringUtils.getBean("cacheService");
-//        cacheService.initRedisCache();
-//
-//        PowerCurveFittingModelService powerCurveFittingModelService= SpringUtils.getBean("powerCurveFittingModelService");
-//        powerCurveFittingModelService.cureFittingModel();
-////
-//        Calendar c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,7);
-//        c.set(Calendar.DAY_OF_MONTH,2);
-//        WindturbineGoodnessService windturbineGoodnessService= SpringUtils.getBean("windturbineGoodnessService");
-//        windturbineGoodnessService.calWindturbineGoodness(c.getTime());
-//
-//        WtwindDayInfoService wtwindDayInfoService= SpringUtils.getBean("wtwindDayInfoService");
-//        Date date =c.getTime();
-//        wtwindDayInfoService.calWpwindDayInfo(c.getTime());
-//
-//        WpwindDayInfoService wpwindDayInfoService= SpringUtils.getBean("wpwindDayInfoService");
-//        c=Calendar.getInstance();
-//        c.set(Calendar.MONTH,7);
-//        c.set(Calendar.DAY_OF_MONTH,2);
-//        date =c.getTime();
-//
-//        wpwindDayInfoService.calWpwindDayInfo(c.getTime());
         System.out.println("完成");
     }
 }

+ 83 - 83
realtime/generationXK-service/src/main/java/com/gyee/generation/config/XxlJobConfig.java

@@ -1,84 +1,84 @@
-package com.gyee.generation.config;
-
-
-import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.springframework.context.EnvironmentAware;
-import org.springframework.context.annotation.Bean;
-import org.springframework.context.annotation.Configuration;
-import org.springframework.context.annotation.PropertySource;
-import org.springframework.core.env.Environment;
-
-/**
- * xxl-job config
- *
- * @author xuxueli 2017-04-28
- */
-
-
-@Configuration
-//@PropertySource("classpath:xxl-job-executor.properties")
-//@PropertySource("classpath:xxl-job-executor2.properties")
-//@PropertySource("classpath:xxl-job-executor3.properties")
-//@PropertySource("classpath:xxl-job-executor4.properties")
-//@PropertySource("classpath:xxl-job-executorWPLY.properties")
-//@PropertySource("classpath:xxl-job-executorRG.properties")
-//@PropertySource("classpath:xxl-job-executorJN.properties")
-
-//@PropertySource("classpath:xxl-job-7001.properties")
-//@PropertySource("classpath:xxl-job-7002.properties")
-//@PropertySource("classpath:xxl-job-7003.properties")
-//@PropertySource("classpath:xxl-job-executorGF001.properties")
-//@PropertySource("classpath:xxl-job-executorGF002.properties")
-//@PropertySource("classpath:xxl-job-executorGF003.properties")
-//@PropertySource("classpath:xxl-job-executorGF004.properties")
-@PropertySource("classpath:xxl-job-executorGF005.properties")
+//package com.gyee.generation.config;
+//
+//
+//import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
+//import org.slf4j.Logger;
+//import org.slf4j.LoggerFactory;
+//import org.springframework.context.EnvironmentAware;
+//import org.springframework.context.annotation.Bean;
+//import org.springframework.context.annotation.Configuration;
+//import org.springframework.context.annotation.PropertySource;
+//import org.springframework.core.env.Environment;
+//
+///**
+// * xxl-job config
+// *
+// * @author xuxueli 2017-04-28
+// */
+//
+//
+//@Configuration
+////@PropertySource("classpath:xxl-job-executor.properties")
+////@PropertySource("classpath:xxl-job-executor2.properties")
+////@PropertySource("classpath:xxl-job-executor3.properties")
+////@PropertySource("classpath:xxl-job-executor4.properties")
+////@PropertySource("classpath:xxl-job-executorWPLY.properties")
+////@PropertySource("classpath:xxl-job-executorRG.properties")
+////@PropertySource("classpath:xxl-job-executorJN.properties")
+//
+////@PropertySource("classpath:xxl-job-7001.properties")
+////@PropertySource("classpath:xxl-job-7002.properties")
+////@PropertySource("classpath:xxl-job-7003.properties")
+////@PropertySource("classpath:xxl-job-executorGF001.properties")
+////@PropertySource("classpath:xxl-job-executorGF002.properties")
+////@PropertySource("classpath:xxl-job-executorGF003.properties")
+////@PropertySource("classpath:xxl-job-executorGF004.properties")
+////@PropertySource("classpath:xxl-job-executorGF005.properties")
 //@PropertySource("classpath:xxl-job-executorGF006.properties")
-public class XxlJobConfig implements EnvironmentAware {
-    private Environment env;
-
-
-    @Override
-    public void setEnvironment(Environment environment) {
-        this.env=environment;
-    }
-
-    private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);
-
-
-
-    @Bean
-    public XxlJobSpringExecutor xxlJobExecutor() {
-        logger.info(">>>>>>>>>>> xxl-job config init.");
-        XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
-        xxlJobSpringExecutor.setAdminAddresses(env.getProperty("xxl.job.admin.addresses"));
-        xxlJobSpringExecutor.setAppname(env.getProperty("xxl.job.executor.appname"));
-        xxlJobSpringExecutor.setAddress(env.getProperty("xxl.job.executor.address"));
-        xxlJobSpringExecutor.setIp(env.getProperty("xxl.job.executor.ip"));
-        xxlJobSpringExecutor.setPort(Integer.parseInt(env.getProperty("xxl.job.executor.port")));
-        xxlJobSpringExecutor.setAccessToken(env.getProperty("xxl.job.accessToken"));
-        xxlJobSpringExecutor.setLogPath(env.getProperty("xxl.job.executor.logpath"));
-        xxlJobSpringExecutor.setLogRetentionDays(Integer.parseInt(env.getProperty("xxl.job.executor.logretentiondays")));
-        return xxlJobSpringExecutor;
-    }
-
-    /**
-     * 针对多网卡、容器内部署等情况,可借助 "spring-cloud-commons" 提供的 "InetUtils" 组件灵活定制注册IP;
-     *
-     *      1、引入依赖:
-     *          <dependency>
-     *             <groupId>org.springframework.cloud</groupId>
-     *             <artifactId>spring-cloud-commons</artifactId>
-     *             <version>${version}</version>
-     *         </dependency>
-     *
-     *      2、配置文件,或者容器启动变量
-     *          spring.cloud.inetutils.preferred-networks: 'xxx.xxx.xxx.'
-     *
-     *      3、获取IP
-     *          String ip_ = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress();
-     */
-
-
-}
+//public class XxlJobConfig implements EnvironmentAware {
+//    private Environment env;
+//
+//
+//    @Override
+//    public void setEnvironment(Environment environment) {
+//        this.env=environment;
+//    }
+//
+//    private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);
+//
+//
+//
+//    @Bean
+//    public XxlJobSpringExecutor xxlJobExecutor() {
+//        logger.info(">>>>>>>>>>> xxl-job config init.");
+//        XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
+//        xxlJobSpringExecutor.setAdminAddresses(env.getProperty("xxl.job.admin.addresses"));
+//        xxlJobSpringExecutor.setAppname(env.getProperty("xxl.job.executor.appname"));
+//        xxlJobSpringExecutor.setAddress(env.getProperty("xxl.job.executor.address"));
+//        xxlJobSpringExecutor.setIp(env.getProperty("xxl.job.executor.ip"));
+//        xxlJobSpringExecutor.setPort(Integer.parseInt(env.getProperty("xxl.job.executor.port")));
+//        xxlJobSpringExecutor.setAccessToken(env.getProperty("xxl.job.accessToken"));
+//        xxlJobSpringExecutor.setLogPath(env.getProperty("xxl.job.executor.logpath"));
+//        xxlJobSpringExecutor.setLogRetentionDays(Integer.parseInt(env.getProperty("xxl.job.executor.logretentiondays")));
+//        return xxlJobSpringExecutor;
+//    }
+//
+//    /**
+//     * 针对多网卡、容器内部署等情况,可借助 "spring-cloud-commons" 提供的 "InetUtils" 组件灵活定制注册IP;
+//     *
+//     *      1、引入依赖:
+//     *          <dependency>
+//     *             <groupId>org.springframework.cloud</groupId>
+//     *             <artifactId>spring-cloud-commons</artifactId>
+//     *             <version>${version}</version>
+//     *         </dependency>
+//     *
+//     *      2、配置文件,或者容器启动变量
+//     *          spring.cloud.inetutils.preferred-networks: 'xxx.xxx.xxx.'
+//     *
+//     *      3、获取IP
+//     *          String ip_ = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress();
+//     */
+//
+//
+//}

+ 8 - 6
realtime/generationXK-service/src/main/java/com/gyee/generation/service/realtimelibrary/CycleCalculationService.java

@@ -68,7 +68,7 @@ public class CycleCalculationService {
                 ProBasicEquipmentPoint ssglPoint = equipmentPointMap.get(ContantXk.CJ_SSGL);
                 ProBasicEquipmentPoint rssfdlPoint = equipmentPointMap.get(ContantXk.CJ_FDL);
                 ProBasicEquipmentPoint dwglPoint = equipmentPointMap.get(ContantXk.CJ_DWGL);
-                ProBasicEquipmentPoint kyglPoint = equipmentPointMap.get(ContantXk.KYGL);
+//                ProBasicEquipmentPoint kyglPoint = equipmentPointMap.get(ContantXk.KYGL);
                 ProBasicEquipmentPoint zsglPoint = equipmentPointMap.get(ContantXk.ZSGL);
                 ProBasicEquipmentPoint mxztPoint = equipmentPointMap.get(ContantXk.MXZT);
 
@@ -251,11 +251,13 @@ public class CycleCalculationService {
                     if (ssglFirst.isPresent()) {
                         dataMap.put("pjgl", ssglFirst.get().getPointValueInDouble());
                     }
-                    List<PointData> kyglList = edosUtil.getHistStat(kyglPoint, date15age.getTime() / 1000, currentDate.getTime() / 1000, 1l, 900l, 2);
-                    Optional<PointData> kyglFirst = kyglList.stream().findFirst();
-                    if (kyglFirst.isPresent()) {
-                        dataMap.put("kydl", kyglFirst.get().getPointValueInDouble());
-                    }
+//                    List<PointData> kyglList = edosUtil.getHistStat(kyglPoint, date15age.getTime() / 1000, currentDate.getTime() / 1000, 1l, 900l, 2);
+//                    Optional<PointData> kyglFirst = kyglList.stream().findFirst();
+//                    if (kyglFirst.isPresent()) {
+//                        dataMap.put("kydl", kyglFirst.get().getPointValueInDouble());
+//                    }
+
+                    dataMap.put("kydl", 0.0);
                     List<PointData> zsglList = edosUtil.getHistStat(zsglPoint, date15age.getTime() / 1000, currentDate.getTime() / 1000, 1l, 900l, 2);
                     Optional<PointData> zsglFirst = zsglList.stream().findFirst();
                     if (zsglFirst.isPresent()) {

+ 43 - 43
realtime/generationXK-service/src/main/java/com/gyee/generation/service/realtimelibrary/RealtimeService.java

@@ -149,18 +149,18 @@ public class RealtimeService {
 
                     wtResultList.add(PointUtil.createPointData(currentDate, wtPowerCurveFitting.getActualPower(), zsglPoint.getNemCode(), zsglPoint.getName()));
                     wtResultList.add(PointUtil.createPointData(currentDate, wtPowerCurveFitting.getOptimalPower(), zyglPoint.getNemCode(), zyglPoint.getName()));
-                    if (mxzt == 4 || mxzt == 5 || mxzt == 6 || mxzt == 7) {
-                        wtResultList.add(PointUtil.createPointData(currentDate, 0, kyglPoint.getNemCode(), kyglPoint.getName()));
-                    } else {
-                        wtResultList.add(PointUtil.createPointData(currentDate, wtPowerCurveFitting.getActualPower(), kyglPoint.getNemCode(), kyglPoint.getName()));
-                    }
+//                    if (mxzt == 4 || mxzt == 5 || mxzt == 6 || mxzt == 7) {
+//                        wtResultList.add(PointUtil.createPointData(currentDate, 0, kyglPoint.getNemCode(), kyglPoint.getName()));
+//                    } else {
+//                        wtResultList.add(PointUtil.createPointData(currentDate, wtPowerCurveFitting.getActualPower(), kyglPoint.getNemCode(), kyglPoint.getName()));
+//                    }
                 } else {
                     wtResultList.add(PointUtil.createPointData(currentDate, 0, ssqfztPoint.getNemCode(), ssqfztPoint.getName()));
                     wtResultList.add(PointUtil.createPointData(currentDate, 0, lsqfztPoint.getNemCode(), lsqfztPoint.getName()));
 
                     wtResultList.add(PointUtil.createPointData(currentDate, 0, zsglPoint.getNemCode(), zsglPoint.getName()));
                     wtResultList.add(PointUtil.createPointData(currentDate, 0, zyglPoint.getNemCode(), zyglPoint.getName()));
-                    wtResultList.add(PointUtil.createPointData(currentDate, 0, kyglPoint.getNemCode(), kyglPoint.getName()));
+//                    wtResultList.add(PointUtil.createPointData(currentDate, 0, kyglPoint.getNemCode(), kyglPoint.getName()));
                 }
             }
 
@@ -190,7 +190,7 @@ public class RealtimeService {
             ProBasicPowerstationPoint bzglWpPoint = proBasicWppointMap.get(ContantXk.SSZBZGL);
             ProBasicPowerstationPoint zsglWpPoint = proBasicWppointMap.get(ContantXk.SSZNHGLZS);
             ProBasicPowerstationPoint zyglWpPoint = proBasicWppointMap.get(ContantXk.SSZZYGL);
-            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
+//            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
 
             double ssglsyz = 0;
             if (proBasicWppointMap.containsKey(ContantXk.SSGLSYZ)){
@@ -239,8 +239,8 @@ public class RealtimeService {
                 ProBasicEquipmentPoint zsglPoint = equipmentPointMap.get(ContantXk.ZSGL);
                 //最优功率测点
                 ProBasicEquipmentPoint zyglPoint = equipmentPointMap.get(ContantXk.ZYGL);
-                //可用功率测点
-                ProBasicEquipmentPoint kyglPoint = equipmentPointMap.get(ContantXk.KYGL);
+//                //可用功率测点
+//                ProBasicEquipmentPoint kyglPoint = equipmentPointMap.get(ContantXk.KYGL);
 
                 ProBasicEquipmentPoint finalSsbfPoint = ssbfPoint;
                 zssbf.updateAndGet(v -> {
@@ -291,14 +291,14 @@ public class RealtimeService {
                     }
                     return v;
                 });
-                zkygl.updateAndGet(v -> {
-                    try {
-                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
-                    } catch (Exception e) {
-                        e.printStackTrace();
-                    }
-                    return v;
-                });
+//                zkygl.updateAndGet(v -> {
+//                    try {
+//                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
+//                    } catch (Exception e) {
+//                        e.printStackTrace();
+//                    }
+//                    return v;
+//                });
 //            });
             }
             lineResultList.add(PointUtil.createPointData(currentDate, zssbf.get() / proBasicWindturbines.size(), ssfsWpPoint.getNemCode(), ssfsWpPoint.getName()));
@@ -307,7 +307,7 @@ public class RealtimeService {
             lineResultList.add(PointUtil.createPointData(currentDate, zbzgl.get(), bzglWpPoint.getNemCode(), bzglWpPoint.getName()));
             lineResultList.add(PointUtil.createPointData(currentDate, zzsgl.get(), zsglWpPoint.getNemCode(), zsglWpPoint.getName()));
             lineResultList.add(PointUtil.createPointData(currentDate, zzygl.get(), zyglWpPoint.getNemCode(), zyglWpPoint.getName()));
-            lineResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
+//            lineResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
         });
         edosUtil.sendMultiPoint(lineResultList);
         //保存期次点
@@ -335,7 +335,7 @@ public class RealtimeService {
             ProBasicPowerstationPoint bzglWpPoint = proBasicWppointMap.get(ContantXk.SSZBZGL);
             ProBasicPowerstationPoint zsglWpPoint = proBasicWppointMap.get(ContantXk.SSZNHGLZS);
             ProBasicPowerstationPoint zyglWpPoint = proBasicWppointMap.get(ContantXk.SSZZYGL);
-            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
+//            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
             ProBasicPowerstationPoint ssglsyzWpPoint = proBasicWppointMap.get(ContantXk.SSZGLSYZ);
 
             proBasicLines.stream().forEach(wp -> {
@@ -357,8 +357,8 @@ public class RealtimeService {
                 ProBasicPowerstationPoint zsglPoint = basicWppointMap.get(ContantXk.SSZNHGLZS);
                 //最优功率测点
                 ProBasicPowerstationPoint zyglPoint = basicWppointMap.get(ContantXk.SSZZYGL);
-                //可用功率测点
-                ProBasicPowerstationPoint kyglPoint = basicWppointMap.get(ContantXk.SSZKYGL);
+//                //可用功率测点
+//                ProBasicPowerstationPoint kyglPoint = basicWppointMap.get(ContantXk.SSZKYGL);
 
                 ProBasicPowerstationPoint finalSsbfPoint = ssbfPoint;
                 zssbf.updateAndGet(v -> {
@@ -417,14 +417,14 @@ public class RealtimeService {
                     }
                     return v;
                 });
-                zkygl.updateAndGet(v -> {
-                    try {
-                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
-                    } catch (Exception e) {
-                        e.printStackTrace();
-                    }
-                    return v;
-                });
+//                zkygl.updateAndGet(v -> {
+//                    try {
+//                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
+//                    } catch (Exception e) {
+//                        e.printStackTrace();
+//                    }
+//                    return v;
+//                });
             });
             projectResultList.add(PointUtil.createPointData(currentDate, zssbf.get() / proBasicLines.size(), ssfsWpPoint.getNemCode(), ssfsWpPoint.getName()));
             projectResultList.add(PointUtil.createPointData(currentDate, zssgl.get(), ssglWpPoint.getNemCode(), ssglWpPoint.getName()));
@@ -433,7 +433,7 @@ public class RealtimeService {
             projectResultList.add(PointUtil.createPointData(currentDate, zbzgl.get(), bzglWpPoint.getNemCode(), bzglWpPoint.getName()));
             projectResultList.add(PointUtil.createPointData(currentDate, zzsgl.get(), zsglWpPoint.getNemCode(), zsglWpPoint.getName()));
             projectResultList.add(PointUtil.createPointData(currentDate, zzygl.get(), zyglWpPoint.getNemCode(), zyglWpPoint.getName()));
-            projectResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
+//            projectResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
         });
         edosUtil.sendMultiPoint(projectResultList);
         //保存场站点
@@ -448,7 +448,7 @@ public class RealtimeService {
             AtomicReference<Double> zbzgl = new AtomicReference<>((double) 0);
             AtomicReference<Double> zzsgl = new AtomicReference<>((double) 0);
             AtomicReference<Double> zzygl = new AtomicReference<>((double) 0);
-            AtomicReference<Double> zkygl = new AtomicReference<>((double) 0);
+//            AtomicReference<Double> zkygl = new AtomicReference<>((double) 0);
 
             ProBasicPowerstationPoint ssfsWpPoint = null;
             if (wps.getSpare4().equals("1")){
@@ -463,7 +463,7 @@ public class RealtimeService {
             ProBasicPowerstationPoint bzglWpPoint = proBasicWppointMap.get(ContantXk.SSZBZGL);
             ProBasicPowerstationPoint zsglWpPoint = proBasicWppointMap.get(ContantXk.SSZNHGLZS);
             ProBasicPowerstationPoint zyglWpPoint = proBasicWppointMap.get(ContantXk.SSZZYGL);
-            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
+//            ProBasicPowerstationPoint kyglWpPoint = proBasicWppointMap.get(ContantXk.SSZKYGL);
 
             proBasicProjects.stream().forEach(wp -> {
                 Map<String, ProBasicPowerstationPoint> basicWppointMap = propointmap.get(wp.getId());
@@ -484,8 +484,8 @@ public class RealtimeService {
                 ProBasicPowerstationPoint zsglPoint = basicWppointMap.get(ContantXk.SSZNHGLZS);
                 //最优功率测点
                 ProBasicPowerstationPoint zyglPoint = basicWppointMap.get(ContantXk.SSZZYGL);
-                //可用功率测点
-                ProBasicPowerstationPoint kyglPoint = basicWppointMap.get(ContantXk.SSZKYGL);
+//                //可用功率测点
+//                ProBasicPowerstationPoint kyglPoint = basicWppointMap.get(ContantXk.SSZKYGL);
 
                 ProBasicPowerstationPoint finalSsbfPoint = ssbfPoint;
                 zssbf.updateAndGet(v -> {
@@ -544,14 +544,14 @@ public class RealtimeService {
                     }
                     return v;
                 });
-                zkygl.updateAndGet(v -> {
-                    try {
-                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
-                    } catch (Exception e) {
-                        e.printStackTrace();
-                    }
-                    return v;
-                });
+//                zkygl.updateAndGet(v -> {
+//                    try {
+//                        return new Double((double) (v + edosUtil.getRealData(kyglPoint).getPointValueInDouble()));
+//                    } catch (Exception e) {
+//                        e.printStackTrace();
+//                    }
+//                    return v;
+//                });
             });
             wpResultList.add(PointUtil.createPointData(currentDate, zssbf.get() / proBasicProjects.size(), ssfsWpPoint.getNemCode(), ssfsWpPoint.getName()));
             wpResultList.add(PointUtil.createPointData(currentDate, zssgl.get(), ssglWpPoint.getNemCode(), ssglWpPoint.getName()));
@@ -560,7 +560,7 @@ public class RealtimeService {
             wpResultList.add(PointUtil.createPointData(currentDate, zbzgl.get(), bzglWpPoint.getNemCode(), bzglWpPoint.getName()));
             wpResultList.add(PointUtil.createPointData(currentDate, zzsgl.get(), zsglWpPoint.getNemCode(), zsglWpPoint.getName()));
             wpResultList.add(PointUtil.createPointData(currentDate, zzygl.get(), zyglWpPoint.getNemCode(), zyglWpPoint.getName()));
-            wpResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
+//            wpResultList.add(PointUtil.createPointData(currentDate, zkygl.get(), kyglWpPoint.getNemCode(), kyglWpPoint.getName()));
         });
         edosUtil.sendMultiPoint(wpResultList);
 

+ 378 - 110
realtime/generationXK-service/src/main/java/com/gyee/generation/service/realtimelibrary/StatusService.java

@@ -238,19 +238,197 @@ public class StatusService {
      */
     private boolean isJcl(Date currentDate, Map<String, ProBasicEquipmentPoint> stringWindturbinetestingpointnewMap) throws Exception {
         boolean isJcl = false;
-        ProBasicEquipmentPoint zsgdPoint = stringWindturbinetestingpointnewMap.get(ContantXk.CJ_YLZSGD);
-        if (zsgdPoint != null){
-            if (!zsgdPoint.getNemCode().equals("INITIAL")){
-                Double realData = edosUtil.getSectionData(zsgdPoint,currentDate.getTime()).getPointValueInDouble();
-                if (realData<Double.parseDouble(AI110)){
-                    isJcl = true;
+
+        if(stringWindturbinetestingpointnewMap.containsKey(ContantXk.CJ_YLZSGD))
+        {
+            ProBasicEquipmentPoint zsgdPoint = stringWindturbinetestingpointnewMap.get(ContantXk.CJ_YLZSGD);
+            if (zsgdPoint != null){
+                if (!zsgdPoint.getNemCode().equals("INITIAL")){
+                    Double realData = edosUtil.getSectionData(zsgdPoint,currentDate.getTime()).getPointValueInDouble();
+                    if (realData<Double.parseDouble(AI110)){
+                        isJcl = true;
+                    }
                 }
             }
         }
 
+
         return isJcl;
     }
 
+
+    /**
+     * 计算风机中间状态(0 正常,1离线,2降出力,3限电)
+     */
+    public void middleStatusReal() throws Exception {
+
+        Map<String, Map<String, ProBasicEquipmentPoint>> wtpAimap = CacheContext.wtpAimap;
+        List<ProBasicEquipment> wtls = CacheContext.wtls;
+        Map<String, List<ProBasicStatusPoint>> statusMap = CacheContext.statusMap;
+        Map<String, ProEconEquipmentmodel> modelMap = CacheContext.modelMap;
+        Map<String, Map<Integer, Integer>> aistateMap = CacheContext.aistateMap;
+        Date currentDate = DateUtils.getCurrentDate();
+
+        List<PointData> resultList = new ArrayList<>();
+
+
+        for(ProBasicEquipment wt:wtls) {
+
+            //获得设备测点
+            Map<String, ProBasicEquipmentPoint> equipmentPointMap = wtpAimap.get(wt.getId());
+
+            //中间状态点
+            ProBasicEquipmentPoint zjztPoint = equipmentPointMap.get(ContantXk.ZJZT);
+            //遍历中断判定点
+            String[] interruption = null;
+            if (wt.getEquipmentCategory() == -1) {
+                interruption = ContantXk.INTERRUPTION.split(",");
+            } else if (wt.getEquipmentCategory() == -2) {
+
+                interruption = ContantXk.INTERRUPTIONGF.split(",");
+            }
+
+            List<String> interruptionList = new ArrayList<>();
+            Arrays.stream(interruption).forEach(i -> {
+                ProBasicEquipmentPoint equipmentPoint = equipmentPointMap.get(i);
+                if (!equipmentPoint.getNemCode().equals("INITIAL")) {
+                    interruptionList.add(equipmentPoint.getNemCode());
+                }
+            });
+
+            //初始化状态
+            Double status = 0.0;
+
+            try {
+                //如果没有配置中断诊断点,判定为中断状态
+                if (StringUtils.isEmpty(interruptionList)) {
+                    status = 1.0;
+                } else {
+                    //读取中断测点数据
+                    List<PointData> interruptionRealData = edosUtil.getRealData(interruptionList);
+                    Calendar c = Calendar.getInstance();
+                    c.setTime(currentDate);
+
+                    int state = 0;
+                    for (int i = 0; i < interruptionList.size(); i++) {
+                        String str = interruptionList.get(i);
+                        c.add(Calendar.MINUTE, -10);
+                        long oldtime = c.getTime().getTime() / 1000;
+
+//                        List<PointData> ls= edosUtil.getHistoryDatasSnap(str,c.getTime().getTime()/1000,currentDate.getTime()/1000,null,60l);
+//
+//                        for(PointData po:ls)
+//                        {
+//                            if (po.getPointValueInDouble() != interruptionRealData.get(i).getPointValueInDouble()) {
+//                                state++;
+//                            }
+//                        }
+                        //读取三分钟前的切面值进行对比,如果数据一致判定通信中断
+                        PointData oldValue = edosUtil.getHistMatrix(str, oldtime);
+                        if (oldValue.getPointValueInDouble() == interruptionRealData.get(i).getPointValueInDouble()) {
+                            state++;
+                        }
+                    }
+                    //判定是否所有中断盘点点的取值时间,距离当前时间相差大于指定值,就统计到新的集合里,如果结果集数量等于中断点数量,说明设备通信中断
+                    List<PointData> collect = interruptionRealData.stream().filter(i -> (currentDate.getTime() - i.getPointTime()) / 1000 > Integer.parseInt(second)).collect(Collectors.toList());
+
+                    if (state == 3 || collect.size() == interruptionRealData.size()) {
+                        //离线
+                        status = 1.0;
+                    }else
+                    {
+                        //进行其它状态判断
+                        status = getStatus(modelMap, aistateMap, statusMap, wt);
+                    }
+
+                }
+                //统计所有记录,准备同时批量写入数据
+                resultList.add(PointUtil.createPointData(currentDate, status, zjztPoint.getNemCode(), zjztPoint.getName()));
+            } catch (Exception e) {
+                e.printStackTrace();
+            }
+
+
+//        });
+        }
+        edosUtil.sendMultiPoint(resultList);
+    }
+
+    /**
+     * 判断中间状态
+     * @param modelMap 型号集合
+     * @param aistateMap ai测点集合
+     * @param statusMap di测点集合
+     * @param wt 设备对象
+     * @return
+     * @throws Exception
+     */
+    private double getStatus(Map<String, ProEconEquipmentmodel> modelMap,Map<String, Map<Integer, Integer>> aistateMap,Map<String, List<ProBasicStatusPoint>> statusMap,ProBasicEquipment wt) throws Exception {
+
+        double status = 0;
+
+        String aiordi = modelMap.get(wt.getModelId()).getDescription();
+        if (aiordi.equals("AI")) {
+            Map<Integer, Integer> stateMap = aistateMap.get(wt.getModelId());
+            Optional<ProBasicStatusPoint> first = statusMap.get(wt.getId()).stream().filter(w -> w.getUniformCode().equals(Contant.AI422)).findFirst();
+            if (first.isPresent()) {
+                ProBasicStatusPoint windturbinestatusdi = first.get();
+                int pointValueInDouble = (int) edosUtil.getRealData(windturbinestatusdi.getNemCode()).getPointValueInDouble();
+
+                if (stateMap.containsKey(pointValueInDouble)) {
+                    status = (double) stateMap.get(pointValueInDouble);
+
+                    if(status==3)
+                    {
+                        status=2;
+                    }else  if(status==8 || status==9)
+                    {
+                        status=3;
+                    }
+                }
+
+            }
+        } else {
+            //每个状态一个状态点
+            Map<String, String> stateMap = new HashMap<>();
+            List<ProBasicStatusPoint> windturbinestatusdis = statusMap.get(wt.getId()).stream().filter(w -> w.getUniformCode().equals(Contant.MX000) || w.getUniformCode().equals(Contant.MX002) || w.getUniformCode().equals(Contant.MX003) || w.getUniformCode().equals(Contant.MX006) || w.getUniformCode().equals(Contant.MX008)).collect(Collectors.toList());
+
+            List<String> pointls=new ArrayList<>();
+            for (ProBasicStatusPoint w : windturbinestatusdis) {
+                pointls.add(w.getNemCode());
+            }
+            List<PointData> values= edosUtil.getRealData(pointls);
+
+            if(values.size()==windturbinestatusdis.size())
+            {
+                for (int i=0;i< windturbinestatusdis.size();i++) {
+                    ProBasicStatusPoint w=windturbinestatusdis.get(i);
+                    if (values.get(i).getPointValueInDouble() == 1) {
+                        stateMap.put(w.getUniformCode(), w.getTypeId());
+
+                    }
+                }
+            }else
+            {
+                for (ProBasicStatusPoint w : windturbinestatusdis) {
+                    PointData realData = edosUtil.getRealData(w.getNemCode());
+                    if (realData.getPointValueInDouble() == 1) {
+                        stateMap.put(w.getUniformCode(), w.getTypeId());
+                    }
+                }
+            }
+
+            if (stateMap.containsKey("MX002") && stateMap.containsKey("MX003")) {
+                status = 2;
+            }
+
+            if (stateMap.containsKey("MX005")) {
+                status = 3;
+            }
+        }
+
+        return status;
+    }
     /**
      * 计算风机状态
      */
@@ -264,14 +442,17 @@ public class StatusService {
 
         List<PointData> resultList = new ArrayList<>();
 
-        wtls.stream().forEach(wt->{
+        int times=0;
+
+        List<String> pointls=new ArrayList<>();
+
+        List<PointData> pointDatals = new ArrayList<>();
+        for(ProBasicEquipment wt:wtls) {
             Map<String, ProBasicEquipmentPoint> equipmentPointMap = wtpAimap.get(wt.getId());
-            //限电状态点
-            ProBasicEquipmentPoint xdztPoint = equipmentPointMap.get(ContantXk.XDZT);
+            //中间状态点
+            ProBasicEquipmentPoint zjztPoint = equipmentPointMap.get(ContantXk.ZJZT);
             //挂牌状态点
             ProBasicEquipmentPoint gpztPoint = equipmentPointMap.get(ContantXk.GPZT);
-            //设备状态点
-            ProBasicEquipmentPoint sbztPoint = equipmentPointMap.get(ContantXk.SBZT);
             //明细状态点
             ProBasicEquipmentPoint mxztPoint = equipmentPointMap.get(ContantXk.MXZT);
             //实时功率点
@@ -279,26 +460,63 @@ public class StatusService {
             //状态持续时间,以秒计算
             ProBasicEquipmentPoint ztcxsjPoint = equipmentPointMap.get(ContantXk.ZTCXSJ);
 
+            pointls.add(zjztPoint.getNemCode());
+            pointls.add(gpztPoint.getNemCode());
+
+            pointls.add(mxztPoint.getNemCode());
+            pointls.add(ssglPoint.getNemCode());
+            pointls.add(ztcxsjPoint.getNemCode());
+
+            times++;
+            if(times==1000)
+            {
+                List<PointData> templs=edosUtil.getRealData(pointls);
+                pointDatals.addAll(templs);
+                pointls=new ArrayList<>();
+                times=0;
+            }
+        }
+        if(!pointls.isEmpty())
+        {
+            List<PointData> templs=edosUtil.getRealData(pointls);
+            pointDatals.addAll(templs);
+        }
+
+
+        for(int x=0;x<wtls.size();x++) {
+            ProBasicEquipment wt=wtls.get(x);
+            Map<String, ProBasicEquipmentPoint> equipmentPointMap = wtpAimap.get(wt.getId());
+
+            //设备状态点
+            ProBasicEquipmentPoint sbztPoint = equipmentPointMap.get(ContantXk.SBZT);
+            //明细状态点
+            ProBasicEquipmentPoint mxztPoint = equipmentPointMap.get(ContantXk.MXZT);
+            //状态持续时间,以秒计算
+            ProBasicEquipmentPoint ztcxsjPoint = equipmentPointMap.get(ContantXk.ZTCXSJ);
+
             String[] interruption = null;
-            if (wt.getEquipmentCategory()==-1){
+            if (wt.getEquipmentCategory() == -1) {
                 interruption = ContantXk.INTERRUPTION.split(",");
-            }else if (wt.getEquipmentCategory()==-2){
+            } else if (wt.getEquipmentCategory() == -2) {
 
                 interruption = ContantXk.INTERRUPTIONGF.split(",");
             }
 
             List<String> interruptionList = new ArrayList<>();
-            Arrays.stream(interruption).forEach(i->{
+            Arrays.stream(interruption).forEach(i -> {
                 ProBasicEquipmentPoint equipmentPoint = equipmentPointMap.get(i);
-                if (!equipmentPoint.getNemCode().equals("INITIAL")){
+                if (!equipmentPoint.getNemCode().equals("INITIAL")) {
                     interruptionList.add(equipmentPoint.getNemCode());
                 }
             });
             double mxzt = 0;
             double ztcxsj = 0;
             try {
-                mxzt = edosUtil.getSectionData(mxztPoint,currentDate.getTime()).getPointValueInDouble();
-                ztcxsj = edosUtil.getSectionData(ztcxsjPoint,currentDate.getTime()).getPointValueInDouble();
+                mxzt = pointDatals.get(x*5+2).getPointValueInDouble();
+                ztcxsj =pointDatals.get(x*5+4).getPointValueInDouble();
+
+//                mxzt = edosUtil.getSectionData(mxztPoint, currentDate.getTime()).getPointValueInDouble();
+//                ztcxsj = edosUtil.getSectionData(ztcxsjPoint, currentDate.getTime()).getPointValueInDouble();
             } catch (Exception e) {
                 e.printStackTrace();
             }
@@ -306,120 +524,66 @@ public class StatusService {
             Double status = 0.0;
             Double mxstatus = 2.0;
             try {
-                if (StringUtils.isEmpty(interruptionList)){
+                if (StringUtils.isEmpty(interruptionList)) {
                     mxstatus = 12.0;
                     status = 6.0;
-                }
-                else {
+                } else {
 
 
-                    List<PointData> interruptionRealData = edosUtil.getRealData(interruptionList);
-                    Calendar c=Calendar.getInstance();
+                    Calendar c = Calendar.getInstance();
                     c.setTime(currentDate);
-                    c.add(Calendar.MINUTE,-3);
-                    long oldtime =c.getTime().getTime()/1000 ;
-                    if(wt.getId().equals("SXJ_KGDL_HSM_F_WT_0047_EQ"))
-                    {
-                        System.out.println("");
-                    }
-                    int state=0;
-                    for(int i=0;i<interruptionList.size();i++)
-                    {
-                        String str=interruptionList.get(i);
-                        List<PointData> oldValueLs = edosUtil.getHistoryDatasSnap(str,c.getTime().getTime()/1000,currentDate.getTime()/1000,null,30l);
-                        if(!oldValueLs.isEmpty())
-                        {
-                            for(PointData oldValue:oldValueLs)
-                            {
-                                if(oldValue.getPointValueInDouble()!=interruptionRealData.get(i).getPointValueInDouble())
-                                {
-                                    state++;
-                                }
-                            }
-                        }
-                    }
 
-                    List<PointData> collect = interruptionRealData.stream().filter(i -> (currentDate.getTime() - i.getPointTime()) / 1000 > Integer.parseInt(second)).collect(Collectors.toList());
+//
+//                    if (wt.getId().equals("SXJ_KGDL_BHB_F_WT_0032_EQ")) {
+//                        System.out.println("");
+//                    }
 
 
-                    double ssgl = edosUtil.getSectionData(ssglPoint,currentDate.getTime()).getPointValueInDouble();
-                    double gpzt = edosUtil.getSectionData(gpztPoint,currentDate.getTime()).getPointValueInDouble();
-                    double xdzt = edosUtil.getSectionData(xdztPoint,currentDate.getTime()).getPointValueInDouble();
+                    double ssgl = pointDatals.get(x*5+3).getPointValueInDouble();
+                    double gpzt = pointDatals.get(x*5+1).getPointValueInDouble();
+                    double zjzt = pointDatals.get(x*5).getPointValueInDouble();
+//                    double ssgl = edosUtil.getSectionData(ssglPoint, currentDate.getTime()).getPointValueInDouble();
+//                    double gpzt = edosUtil.getSectionData(gpztPoint, currentDate.getTime()).getPointValueInDouble();
+//                    double xdzt = edosUtil.getSectionData(xdztPoint, currentDate.getTime()).getPointValueInDouble();
 
-                    if(state==0 || collect.size()==interruptionRealData.size())
-                    {
-                        //离线
+                    if (zjzt == 1) {
                         mxstatus = 12.0;
-                    }else {
-                        if (xdzt == 1){
-                            mxstatus = getGpzt(1,ssgl);
-                        }else {
-                            mxstatus = getMxzt(modelMap,aistateMap,statusMap,wt);
-                        }
-                        if (mxstatus == 2){
-                            boolean isJcl = isJcl(currentDate, equipmentPointMap);
-                            if (ssgl<=0){
-                                mxstatus=0.0;
-                            }else if (isJcl){
-                                mxstatus = 3.0;
-                            }
-                        }
+                    }else  if (zjzt == 3) {
+                        mxstatus = getGpzt(gpzt, ssgl);
+                    } else {
+                        mxstatus = getMxzt(zjzt,modelMap, aistateMap, statusMap, wt);
                     }
 
-
-
-                    if (collect.size()==interruptionRealData.size()){
-
-                        //  0, "正常状态";1, "限电";2, "场内受累检修";3, "场内受累故障";4, "场外受累电网";5, "场外受累天气";6, "发电限负荷";
-                        if(gpzt != 0){
-                            //获取挂牌状态给明细状态赋值
-                            mxstatus = getGpzt(gpzt,ssgl);
-                        }
-//                        else if (xdzt == 1){
-//                            mxstatus = getGpzt(1,ssgl);
-//                        }else {
-//                            mxstatus = getMxzt(modelMap,aistateMap,statusMap,wt);
-//                        }
-//                        if (mxstatus == 2){
-//                            boolean isJcl = isJcl(currentDate, equipmentPointMap);
-//                            if (ssgl<=0){
-//                                mxstatus=0.0;
-//                            }else if (isJcl){
-//                                mxstatus = 3.0;
-//                            }
-//                        }
-                    }
-
-
-                    if (mxstatus == 0 || mxstatus == 1){
+                    if (mxstatus == 0 || mxstatus == 1) {
                         status = 0.0;
-                    }else if(mxstatus == 2 || mxstatus == 3){
+                    } else if (mxstatus == 2 || mxstatus == 3) {
                         status = 1.0;
-                    }else if(mxstatus == 4 || mxstatus == 5){
+                    } else if (mxstatus == 4 || mxstatus == 5) {
                         status = 2.0;
-                    }else if(mxstatus == 6 || mxstatus == 7){
+                    } else if (mxstatus == 6 || mxstatus == 7) {
                         status = 3.0;
-                    }else if(mxstatus == 8 || mxstatus == 9){
+                    } else if (mxstatus == 8 || mxstatus == 9) {
                         status = 4.0;
-                    }else if(mxstatus == 10 || mxstatus == 11){
+                    } else if (mxstatus == 10 || mxstatus == 11) {
                         status = 5.0;
-                    }else if(mxstatus == 12 || mxstatus == 13){
+                    } else if (mxstatus == 12 || mxstatus == 13) {
                         status = 6.0;
                     }
                 }
-                if (mxstatus == mxzt){
-                    ztcxsj ++;
-                }else {
+                if (mxstatus == mxzt) {
+                    ztcxsj++;
+                } else {
                     ztcxsj = 0;
                 }
-                resultList.add(PointUtil.createPointData(currentDate,mxstatus,mxztPoint.getNemCode(),mxztPoint.getName()));
-                resultList.add(PointUtil.createPointData(currentDate,status,sbztPoint.getNemCode(),sbztPoint.getName()));
-                resultList.add(PointUtil.createPointData(currentDate,ztcxsj,ztcxsjPoint.getNemCode(),ztcxsjPoint.getName()));
+                resultList.add(PointUtil.createPointData(currentDate, mxstatus, mxztPoint.getNemCode(), mxztPoint.getName()));
+                resultList.add(PointUtil.createPointData(currentDate, status, sbztPoint.getNemCode(), sbztPoint.getName()));
+                resultList.add(PointUtil.createPointData(currentDate, ztcxsj, ztcxsjPoint.getNemCode(), ztcxsjPoint.getName()));
             } catch (Exception e) {
                 e.printStackTrace();
             }
 
-        });
+//        });
+        }
         edosUtil.sendMultiPoint(resultList);
     }
 
@@ -895,7 +1059,7 @@ public class StatusService {
         edosUtil.sendMultiPoint(resultList);
     }
 
-    private double getMxzt(Map<String, ProEconEquipmentmodel> modelMap,Map<String, Map<Integer, Integer>> aistateMap,Map<String, List<ProBasicStatusPoint>> statusMap,ProBasicEquipment wt) throws Exception {
+    private double getMxzt(double zjzt,Map<String, ProEconEquipmentmodel> modelMap,Map<String, Map<Integer, Integer>> aistateMap,Map<String, List<ProBasicStatusPoint>> statusMap,ProBasicEquipment wt) throws Exception {
 
         double mxstatus = 2;
 
@@ -917,19 +1081,50 @@ public class StatusService {
             //每个状态一个状态点
             Map<String,String> stateMap = new HashMap<>();
             List<ProBasicStatusPoint> windturbinestatusdis = statusMap.get(wt.getId()).stream().filter(w -> w.getUniformCode().equals(Contant.MX000) || w.getUniformCode().equals(Contant.MX002) || w.getUniformCode().equals(Contant.MX003) || w.getUniformCode().equals(Contant.MX006) || w.getUniformCode().equals(Contant.MX008)).collect(Collectors.toList());
-            for(ProBasicStatusPoint w : windturbinestatusdis){
-                PointData realData = edosUtil.getRealData(w.getNemCode());
-                if (realData.getPointValueInDouble()==1){
-                    stateMap.put(w.getUniformCode(),w.getTypeId());
-                    mxstatus = Double.parseDouble(w.getTypeId());
+
+
+            List<String> pointls=new ArrayList<>();
+            for (ProBasicStatusPoint w : windturbinestatusdis) {
+                pointls.add(w.getNemCode());
+            }
+            List<PointData> values= edosUtil.getRealData(pointls);
+
+
+            if(values.size()==windturbinestatusdis.size())
+            {
+                for (int i=0;i< windturbinestatusdis.size();i++) {
+                    ProBasicStatusPoint w=windturbinestatusdis.get(i);
+                    if (values.get(i).getPointValueInDouble() == 1) {
+                        stateMap.put(w.getUniformCode(), w.getTypeId());
+                        mxstatus = Double.parseDouble(w.getTypeId());
+                    }
+                }
+            }else
+            {
+                for (ProBasicStatusPoint w : windturbinestatusdis) {
+                    PointData realData = edosUtil.getRealData(w.getNemCode());
+                    if (realData.getPointValueInDouble() == 1) {
+                        stateMap.put(w.getUniformCode(), w.getTypeId());
+                        mxstatus = Double.parseDouble(w.getTypeId());
+                    }
                 }
             }
+
             if (stateMap.containsKey("MX006") && stateMap.containsKey("MX008")){
                 mxstatus = Double.parseDouble(stateMap.get("MX008"));
             }
+
             if (stateMap.containsKey("MX002") && stateMap.containsKey("MX003")){
                 mxstatus = Double.parseDouble(stateMap.get("MX003"));
             }
+            if (zjzt==3){
+                if ( stateMap.containsKey("MX006")){
+                    mxstatus = 9;
+                }else
+                {
+                    mxstatus = 8;
+                }
+            }
         }
 
 
@@ -1280,5 +1475,78 @@ public class StatusService {
     }
 
 
+    public void startStatusReal() throws Exception {
+
+        System.out.println("状态判定调度程序执行开始!。。。。。。");
+        while (true)
+        {
+//            Calendar c = Calendar.getInstance();
+//            Date begin=c.getTime();
+//            Date end=null;
+//            System.out.println("状态判定调度程序执行开始!。。。。。。");
+            statusReal();
+
+//            end=new Date();
+//            System.out.println("执行用时"+ DateUtils.secondsDiff(begin,end) +"秒");
+//            System.out.println("状态判定调度程序执行结束!。。。。。。");
+//            System.out.println("完成!。。。。。。");
+        }
+    }
+    public void startMiddleStatusReal() throws Exception {
+
+        System.out.println("中间状态判定调度程序执行开始!。。。。。。");
+        while (true)
+        {
+//            Calendar c = Calendar.getInstance();
+//            Date begin=c.getTime();
+//            Date end=null;
+//            System.out.println("中间状态判定调度程序执行开始!。。。。。。");
+
+            middleStatusReal();
+//            end=new Date();
+//            System.out.println("执行用时"+ DateUtils.secondsDiff(begin,end) +"秒");
+//            System.out.println("中间状态判定调度程序执行结束!。。。。。。");
+//            System.out.println("完成!。。。。。。");
+        }
+    }
+
+
+    public void startPowerRationing() throws Exception {
+
+        System.out.println("场站状态判定调度程序执行开始!。。。。。。");
+        while (true)
+        {
+//            Calendar c = Calendar.getInstance();
+//            Date begin=c.getTime();
+//            Date end=null;
+//            System.out.println("场站状态判定调度程序执行开始!。。。。。。");
+            powerRationing();
+
+//
+//            end=new Date();
+//            System.out.println("执行用时"+ DateUtils.secondsDiff(begin,end) +"秒");
+//            System.out.println("场站状态判定调度程序执行结束!。。。。。。");
+//            System.out.println("完成!。。。。。。");
+        }
+    }
+
+    public void startStatusNumber() throws Exception {
+
+        System.out.println("状态数量判定调度程序执行开始!。。。。。。");
+        while (true)
+        {
+//            Calendar c = Calendar.getInstance();
+//            Date begin=c.getTime();
+//            Date end=null;
+//            System.out.println("状态数量判定调度程序执行开始!。。。。。。");
+            calculateStatusNumber();
+
+
+//            end=new Date();
+//            System.out.println("执行用时"+ DateUtils.secondsDiff(begin,end) +"秒");
+//            System.out.println("场站状态数量判定调度程序执行结束!。。。。。。");
+//            System.out.println("完成!。。。。。。");
+        }
+    }
 
 }

+ 57 - 6
realtime/generationXK-service/src/main/java/com/gyee/generation/task/SaticScheduleCALTask.java

@@ -42,6 +42,8 @@ public class SaticScheduleCALTask {
     @Resource
     private SafetyDayService safetyDayService;
 
+
+
     /**
      * 全场状态,接入状态,总预测功率
      * 每秒执行一次
@@ -127,24 +129,73 @@ public class SaticScheduleCALTask {
         XxlJobHelper.log("实时指标调度任务处理完成!........");
     }
 
+
+    /**
+     * 中间状态计算
+     * 执行一次
+     */
+    @XxlJob("status_middleStatusReal")
+    public void status_powerRationing()  {
+
+        XxlJobHelper.log("中间状态计算调度程序执行开始!........");
+        try {
+            statusService.startMiddleStatusReal();
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("中间状态计算调度任务处理完成!........");
+    }
+
     /**
      * 状态计算
-     * 每秒执行一次
+     * 执行一次
      */
-    @XxlJob("status_CAL")
-    public void status_CAL()  {
+    @XxlJob("status_statusReal")
+    public void status_statusReal()  {
 
         XxlJobHelper.log("状态调度程序执行开始!........");
         try {
-            statusService.powerRationing();
-            statusService.statusReal();
-            statusService.calculateStatusNumber();
+            statusService.startStatusReal();
+
         } catch (Exception e) {
             e.printStackTrace();
         }
         XxlJobHelper.log("状态调度任务处理完成!........");
     }
+    /**
+     * 场站状态计算
+     * 执行一次
+     */
+    @XxlJob("calculate_powerRationing")
+    public void calculate_powerRationing()  {
 
+        XxlJobHelper.log("场站状态计算调度程序执行开始!........");
+        try {
+            statusService.startPowerRationing();
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("场站状态计算调度任务处理完成!........");
+    }
+
+
+    /**
+     * 状态数量计算
+     * 执行一次
+     */
+    @XxlJob("calculate_StatusNumber")
+    public void calculateStatusNumber()  {
+
+        XxlJobHelper.log("状态数量调度程序执行开始!........");
+        try {
+            statusService.startStatusNumber();
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("状态数量调度任务处理完成!........");
+    }
 
     /**
      * 自算功率,最优功率更新缓存

+ 98 - 0
realtime/generationXK-service/src/main/java/com/gyee/generation/task/SaticSchedulePgTask.java

@@ -3,6 +3,9 @@ package com.gyee.generation.task;
 
 import com.gyee.common.util.DateUtils;
 import com.gyee.generation.service.*;
+import com.gyee.generation.util.math.AvailablePowerAccuracyCalculator;
+import com.gyee.generation.util.math.PowerPredictionErrorCalculator;
+import com.gyee.generation.util.math.ShortTermPowerPredictionAccuracyCalculator;
 import com.xxl.job.core.context.XxlJobHelper;
 import com.xxl.job.core.handler.annotation.XxlJob;
 import org.slf4j.Logger;
@@ -1031,4 +1034,99 @@ public class SaticSchedulePgTask {
 //        }
 //        XxlJobHelper.log("屯留吾元光伏电站停机记录调度任务处理完成!........");
 //    }
+
+     /**
+     * 短期功率预测精度计算
+     * 每两秒执行一次
+     */
+    @XxlJob("shorttermpowerpredictionaccuracycalculator")
+    public void shorttermpowerpredictionaccuracycalculator()  {
+
+        XxlJobHelper.log("短期功率预测精度计算调度程序执行开始!........");
+
+        try {
+
+
+            // 输入数据
+            double[] predictedPower ={}; { /* 96个点的预测功率值 */ };
+            double[] actualPower ={}; { /* 96个点的实际功率值 */ };
+            double installedCapacity=0 ; /* 装机容量 */;
+
+            // 计算准确率
+            double accuracy = ShortTermPowerPredictionAccuracyCalculator.calculateAccuracy(predictedPower, actualPower, installedCapacity);
+
+            // 输出结果
+            System.out.println("超短期预测曲线准确率: " + accuracy + "%");
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("短期功率预测精度计算调度程序处理完成!........");
+
+    }
+
+
+    /**
+     * 功率预测错误计算
+     * 每两秒执行一次
+     */
+    @XxlJob("powerpredictionerrorcalculator ")
+    public void powerpredictionerrorcalculator() {
+
+        XxlJobHelper.log("功率预测错误计算调度程序执行开始!........");
+
+        try {
+
+            // 输入数据
+            double[] predictedPower = { /* 96个点的预测功率值 */};
+            double[] actualPower = { /* 96个点的实际功率值 */};
+            double installedCapacity = 0; /* 装机容量 */
+
+            double maxErrorPercentage = PowerPredictionErrorCalculator.calculateMaxErrorPercentage(predictedPower, actualPower, installedCapacity);
+
+            // 输出结果
+            System.out.println("日预测曲线最大误差值: " + maxErrorPercentage + "%");
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("功率预测错误计算调度程序处理完成!........");
+    }
+
+
+    /**
+     * 可用功率精度计算
+     * 每两秒执行一次
+     */
+    @XxlJob("availablepoweraccuracycalculator ")
+    public void availablepoweraccuracycalculator() {
+
+        XxlJobHelper.log("可用功率精度计算调度程序执行开始!........");
+
+        try {
+
+            // 输入数据
+            double actualGeneration =0; /* 当日新能源场站非限电时段实际发电量 */;
+            double availablePower =0; /* 当日新能源场站非限电时段可用电量 */;
+            double installedCapacity = 0;/* 全场装机容量 */;
+
+            // 计算日准确率
+            double accuracy = AvailablePowerAccuracyCalculator.calculateAccuracy(actualGeneration, availablePower);
+
+            // 输出结果
+            System.out.println("可用电量的日准确率: " + accuracy + "%");
+
+            // 计算考核分数
+            double score = AvailablePowerAccuracyCalculator.calculateAssessmentScore(accuracy, installedCapacity);
+
+            // 输出考核分数
+            System.out.println("考核分数: " + score + "分/万千瓦");
+
+
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        XxlJobHelper.log("可用功率精度计算调度程序处理完成!........");
+    }
 }

+ 40 - 0
realtime/generationXK-service/src/main/java/com/gyee/generation/util/math/AvailablePowerAccuracyCalculator.java

@@ -0,0 +1,40 @@
+package com.gyee.generation.util.math;
+
+public class AvailablePowerAccuracyCalculator {
+    public static void main(String[] args) {
+        // 输入数据
+        double actualGeneration =0; /* 当日新能源场站非限电时段实际发电量 */;
+        double availablePower =0; /* 当日新能源场站非限电时段可用电量 */;
+        double installedCapacity = 0;/* 全场装机容量 */;
+
+        // 计算日准确率
+        double accuracy = calculateAccuracy(actualGeneration, availablePower);
+
+        // 输出结果
+        System.out.println("可用电量的日准确率: " + accuracy + "%");
+
+        // 计算考核分数
+        double score = calculateAssessmentScore(accuracy, installedCapacity);
+
+        // 输出考核分数
+        System.out.println("考核分数: " + score + "分/万千瓦");
+    }
+
+    public static double calculateAccuracy(double actualGeneration, double availablePower) {
+        if (actualGeneration == 0) {
+            return 100.0; // 不考核
+        } else {
+            double accuracy = (actualGeneration - availablePower) / actualGeneration * 100;
+            return accuracy;
+        }
+    }
+
+    public static double calculateAssessmentScore(double accuracy, double installedCapacity) {
+        if (accuracy >= 97) {
+            return 0.0; // 准确率达标,不需要考核
+        } else {
+            double score = (97 - accuracy) * installedCapacity * 0.05;
+            return score;
+        }
+    }
+}

+ 30 - 0
realtime/generationXK-service/src/main/java/com/gyee/generation/util/math/PowerPredictionErrorCalculator.java

@@ -0,0 +1,30 @@
+package com.gyee.generation.util.math;
+
+public class PowerPredictionErrorCalculator {
+
+
+    public static double calculateMaxErrorPercentage(double[] predictedPower, double[] actualPower, double installedCapacity) {
+        int n = predictedPower.length;
+        double maxErrorPercentage = 0.0;
+
+        for (int i = 0; i < n; i++) {
+            double errorPercentage = 0.0;
+
+            if (predictedPower[i] == 0) {
+                if (Math.abs(actualPower[i]) <= 0.03 * installedCapacity) {
+                    continue; // 不考核
+                } else {
+                    errorPercentage = 100.0;
+                }
+            } else {
+                errorPercentage = Math.abs(predictedPower[i] - actualPower[i]) / predictedPower[i] * 100;
+            }
+
+            if (errorPercentage > maxErrorPercentage) {
+                maxErrorPercentage = errorPercentage;
+            }
+        }
+
+        return maxErrorPercentage;
+    }
+}

+ 33 - 0
realtime/generationXK-service/src/main/java/com/gyee/generation/util/math/ShortTermPowerPredictionAccuracyCalculator.java

@@ -0,0 +1,33 @@
+package com.gyee.generation.util.math;
+
+public class ShortTermPowerPredictionAccuracyCalculator {
+
+
+    public static double calculateAccuracy(double[] predictedPower, double[] actualPower, double installedCapacity) {
+        int n = predictedPower.length;
+        double totalError = 0.0;
+        int validPoints = 0;
+
+        for (int i = 0; i < n; i++) {
+            double errorPercentage = 0.0;
+
+            if (Math.abs(predictedPower[i] - actualPower[i]) <= 0.03 * installedCapacity) {
+                // 该点不计入误差计算
+                continue;
+            }
+
+            errorPercentage = Math.abs(predictedPower[i] - actualPower[i]) / installedCapacity * 100;
+
+            totalError += errorPercentage;
+            validPoints++;
+        }
+
+        if (validPoints == 0) {
+            return 100.0; // 所有点均在3%以内,准确率为100%
+        } else {
+            double accuracy = 100 - totalError / validPoints;
+            return accuracy;
+        }
+    }
+}
+

+ 44 - 27
realtime/generationXK-service/src/main/java/com/gyee/generation/util/realtimesource/EdosUtil.java

@@ -167,7 +167,7 @@ public class EdosUtil implements IEdosUtil {
         if(StringUtils.notEmp(point) && StringUtils.notEmp(point.getNemCode()) && !initialcode.equals(point.getNemCode()))
         {
             String rawUrl = "";
-            if(point.getTypeId().equals("G")){
+            if (point.getNemCode().startsWith("GF-")){
                 rawUrl = baseURL2 + "/history/section?null=0&tagNames=" + point.getNemCode() + "&ts=" + date;
             }else {
                 rawUrl = baseURL + "/history/section?null=0&tagNames=" + point.getNemCode() + "&ts=" + date;
@@ -458,7 +458,7 @@ public class EdosUtil implements IEdosUtil {
 
             try {
                 String url = "";
-                if (point.getTypeId().equals("G")){
+                if (point.getNemCode().startsWith("GF-")){
                     url = baseURL2 + "/latest?null=0";
                 }else {
                     url = baseURL + "/latest?null=0";
@@ -535,7 +535,7 @@ public class EdosUtil implements IEdosUtil {
 
             try {
                 String url ="";
-                if (point.getTypeId().equals("G")){
+                if (point.getNemCode().startsWith("GF-")){
                     url = baseURL2 + "/history/snap?null=0";
                 }else {
                     url = baseURL + "/history/snap?null=0";
@@ -579,7 +579,7 @@ public class EdosUtil implements IEdosUtil {
                             // 则代表该时间节点快照有效,否则为0
 
                             String rawUrl = baseURL + "/history/section?null=0&tagNames=" + point.getNemCode() + "&ts=" + snapItem.getPointTime() ;
-                            if (point.getTypeId().equals("G")){
+                             if (point.getNemCode().startsWith("GF-")){
                                 rawUrl = baseURL2 + "/history/section?null=0&tagNames=" + point.getNemCode() + "&ts=" + snapItem.getPointTime() ;
                             }
 
@@ -662,7 +662,7 @@ public class EdosUtil implements IEdosUtil {
             Optional<Long> endTs = Optional.ofNullable(endDate);
             try {
                 String url = "";
-                if (point.getTypeId().equals("G")){
+                if (point.getNemCode().startsWith("GF-")){
                     url = baseURL2 + "/history/snap?null=0";
                 }else {
                     url = baseURL + "/history/snap?null=0";
@@ -1258,7 +1258,7 @@ public class EdosUtil implements IEdosUtil {
 
             try {
                 String url = "";
-                if (point.getTypeId().equals("G")){
+                 if (point.getNemCode().startsWith("GF-")){
                     url = baseURL2 + "/history/stat?null=0";
                 }else {
                     url = baseURL + "/history/stat?null=0";
@@ -1608,6 +1608,13 @@ public class EdosUtil implements IEdosUtil {
     @Override
     public void updatePoint(List<PointData> pointls) throws Exception {
         String url = baseURL + "/history/batch";
+        if (!pointls.isEmpty() ) {
+
+            if (pointls.get(0).getEdnaId().startsWith("GF-")) {
+                url = baseURL2 + "/history/batch";
+            }
+        }
+
         List<JSONObject> writeList = new ArrayList<>();
 
         for (PointData entity : pointls) {
@@ -1628,7 +1635,9 @@ public class EdosUtil implements IEdosUtil {
     public void sendSinglePoint(PointData point) throws Exception {
         String url = baseURL + "/latest";
 
-
+        if (point.getEdnaId().startsWith("GF-")){
+            url = baseURL2 + "/latest";
+        }
         try {
             String result = restTemplate.postForObject(url, convertPointData(point), String.class);
         } catch (HttpClientErrorException exception) {
@@ -1645,34 +1654,42 @@ public class EdosUtil implements IEdosUtil {
 
         String url = baseURL + "/latest/batch";
 
-        List<JSONObject> writeList = new ArrayList<>();
+        if (!pointls.isEmpty() ){
 
-        int batchSize = 500; // 设置每次传输的批次大小
+            if ( pointls.get(0).getEdnaId().startsWith("GF-")){
+                url = baseURL2 + "/history/batch";
+            }
 
-        int totalSize = pointls.size();
-        int batchCount = totalSize % batchSize == 0 ? totalSize / batchSize : totalSize / batchSize + 1;
+            List<JSONObject> writeList = new ArrayList<>();
 
-        for (int i = 0; i < batchCount; i++) {
-            int startIndex = i * batchSize;
-            int endIndex = Math.min((i + 1) * batchSize, totalSize);
-            List<PointData> batch = pointls.subList(startIndex, endIndex);
+            int batchSize = 500; // 设置每次传输的批次大小
 
-            List<JSONObject> batchWriteList = new ArrayList<>();
-            for (PointData entity : batch) {
-                batchWriteList.add(convertPointData(entity));
-            }
+            int totalSize = pointls.size();
+            int batchCount = totalSize % batchSize == 0 ? totalSize / batchSize : totalSize / batchSize + 1;
 
-            try {
-                String result = restTemplate.postForObject(url, batchWriteList, String.class);
-                // 处理返回的结果
-            } catch (HttpClientErrorException exception) {
-                if (exception.getStatusCode() == HttpStatus.NOT_FOUND) {
-                    throw new Exception("404请求错误");
-                } else {
-                    throw exception;
+            for (int i = 0; i < batchCount; i++) {
+                int startIndex = i * batchSize;
+                int endIndex = Math.min((i + 1) * batchSize, totalSize);
+                List<PointData> batch = pointls.subList(startIndex, endIndex);
+
+                List<JSONObject> batchWriteList = new ArrayList<>();
+                for (PointData entity : batch) {
+                    batchWriteList.add(convertPointData(entity));
+                }
+
+                try {
+                    String result = restTemplate.postForObject(url, batchWriteList, String.class);
+                    // 处理返回的结果
+                } catch (HttpClientErrorException exception) {
+                    if (exception.getStatusCode() == HttpStatus.NOT_FOUND) {
+                        throw new Exception("404请求错误");
+                    } else {
+                        throw exception;
+                    }
                 }
             }
         }
+
     }
 
     @Override

+ 3 - 1
realtime/generationXK-service/src/main/resources/application-jn.yml

@@ -131,7 +131,9 @@ db:
 
 #参与计算的场站
 #runWindpowerstation: SDL_GDDL_QDJN_FDC_STA,SDL_GDDL_RZJX_FDC_STA,SDL_GDDL_WHWD_FDC_STA,SDL_GDDL_WHXQ_FDC_STA,SDL_GDDL_RZWL_FDC_STA,SDL_GDDL_WFZC_FDC_STA,SDL_GDDL_DZXJF_FDC_STA,SDL_GDDL_DZXJS_FDC_STA,SDL_GDDL_XTTA_FDC_STA
-runWindpowerstation: SXJ_KGDL_HSM_FDC_STA
+runWindpowerstation: SXJ_KGDL_SY_GDC_STA
+#runWindpowerstation: SXJ_KGDL_DJY_FDC_STA,SXJ_KGDL_NJL_FDC_STA,SXJ_KGDL_YF_FDC_STA,SXJ_KGDL_YLZ_FDC_STA,SXJ_KGDL_XWT_FDC_STA,SXJ_KGDL_PTZ_FDC_STA,SXJ_KGDL_GJY_FDC_STA,SXJ_KGDL_BHB_FDC_STA,SXJ_KGDL_HSM_FDC_STA,SXJ_KGDL_YTY_FDC_STA,SXJ_KGDL_BHB3_FDC_STA,SXJ_KGDL_SY_GDC_STA,SXJ_KGDL_PDL_FDC_STA,SXJ_KGDL_ZK_FDC_STA,SXJ_KGDL_JR_GDC_STA,SXJ_KGDL_FS_GDC_STA,SXJ_KGDL_HR_GDC_STA,SXJ_KGDL_YY_GDC_STA,SXJ_KGDL_PL_GDC_STA,SXJ_KGDL_YG_GDC_STA,SXJ_KGDL_YX_GDC_STA,SXJ_KGDL_TZ_GDC_STA,SXJ_KGDL_TL_GDC_STA
+#runWindpowerstation: SXJ_KGDL_SY_GDC_STA,SXJ_KGDL_JR_GDC_STA,SXJ_KGDL_FS_GDC_STA,SXJ_KGDL_HR_GDC_STA,SXJ_KGDL_YY_GDC_STA,SXJ_KGDL_PL_GDC_STA,SXJ_KGDL_YG_GDC_STA,SXJ_KGDL_YX_GDC_STA,SXJ_KGDL_TZ_GDC_STA,SXJ_KGDL_TL_GDC_STA
 clauStatus:
   ai: GJY03_GC,YLZ01_GC,PTZ02_GC   #配置期次
   di: GJY01_GC,GJY02_GC,DJY01_GC,DJY02_GC,YF01_GC,YF02_GC,HSM01_GC,PTZ01_GC,ZK01_GC,NJL01_GC,YTY01_GC,PDL01_GC