tangxu
2022-10-31 8ea88fedd51e4961d0fd0aec6c2873a579fb6db8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using IStation.Application; 
using IStation.Dto;
 
namespace IStation.Calculation
{
    /// <summary>
    /// 计划分析计算器接口
    /// </summary>
    public class  PlanAnaBaseCalculator
    {
        /// <summary>
        /// 
        /// </summary>
        protected IStation.Calculation.DispatchAna.IOptAnaCalc _dispatchAnaCalc = null;
 
        /// <summary>
        /// 
        /// </summary>
        protected long _corpID = 0;
        /// <summary>
        /// 
        /// </summary>
        protected long _stationID = 0;
        /// <summary>
        /// 
        /// </summary>
        /// <param name="corpID"></param>
        /// <param name="stationID"></param>
        public void SetStationID(long corpID,long stationID)
        {
            this._corpID = corpID;
            this._stationID = stationID;
        }
 
        /// <summary>
        /// 
        /// </summary>
        /// <param name="tagname"></param>
        /// <returns></returns>
        public virtual bool Is液位Monitor(string tagname)
        {
            return false;
        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="tagname"></param>
        /// <returns></returns>
        public virtual string GetMonitorNameByTag(string tagname)
        {
            return "未知测点";
        }
        /// <summary>
        /// 
        /// </summary>
        /// <param name="tagname"></param>
        /// <returns></returns>
        public virtual bool IsIgnoreAble(string tagname)
        {
            return false;
        }
        /// <summary>
        /// 
        /// </summary>
        public virtual List<Dto.MonthCalcuResult> Calc (
            Model.Station station,int factoryId, 
            List<Dto.MonthSumRecord> allMonthSumRecord,
            out string error_info)
        {
            if(_dispatchAnaCalc == null)
            {
                //由继承类设置调度辅助类
                error_info = "未构建DispatchAna.IOptAnaCalc";
                return null;
            }
            int year = DateTime.Now.Year;
 
            List<Dto.MonthCalcuResult> monthRecordList = new List<Dto.MonthCalcuResult>();
            foreach (var monthRecord in allMonthSumRecord)
            { 
                //构建每小时的参数
                List<IStation.Calculation.DispatchAna.Model.HourRequest> allHourRequests = 
                    BuildHourRequest(monthRecord.HourRecords,out error_info);
                if(allHourRequests == null || allHourRequests.Count() == 0)
                {
                    error_info = "构建 HourRequests 失败,原因:" + error_info;
                    return null;
                }
                if (!string.IsNullOrEmpty(error_info))
                {
                    error_info = "构建 HourRequests 失败,原因:" + error_info;
                    return null;
                }
                //一个月的天数
                var dayNumber = DateTime.DaysInMonth(year, monthRecord.Month);
                //每天的汇总
                var daySum = this._dispatchAnaCalc.CalcSumData(allHourRequests, true, out error_info);
                if (daySum == null || daySum.Qt <= 0)
                {
                    error_info = String.Format( "{0}月,调度分析失败,原因:{1}" ,monthRecord.Month, error_info);
                    return null;
                }
                //计算每月的汇总
                Dto.MonthCalcuResult monthSum = new Dto.MonthCalcuResult();
                monthSum.Month = monthRecord.Month;
                monthSum.Qt = Math.Round(daySum.Qt * dayNumber, 1);
                monthSum.Dt = Math.Round(daySum.Dt * dayNumber, 2);
                monthSum.WP = Math.Round(daySum.WP, 3);
                monthRecordList.Add(monthSum);
            }
            error_info = null;
            return monthRecordList;
        }
 
        /// <summary>
        /// 构建每小时的参数
        /// </summary>
        /// <param name="HourSumRecords"></param>
        /// <param name="error_info"></param>
        /// <returns></returns>
        protected virtual List<IStation.Calculation.DispatchAna.Model.HourRequest> BuildHourRequest(
            List<IStation.Dto.HourSumRecord> HourSumRecords,
            out string error_info)
        {
            List<IStation.Calculation.DispatchAna.Model.HourRequest> allHourRequests = new List<DispatchAna.Model.HourRequest>();
 
            for (int i = 0; i <= 23; i++)
            {
                var hourSumRecord = new IStation.Calculation.DispatchAna.Model.HourRequest();
                hourSumRecord.Hour = i;
 
                var allRecords_hour = HourSumRecords[i].Records;
                hourSumRecord.Request = BuildDispatchAnaRequest(allRecords_hour,out error_info);
 
                if(hourSumRecord.Request == null)
                {
                    return allHourRequests;
                }
 
                allHourRequests.Add(hourSumRecord);
            }
 
            error_info = null;
            return allHourRequests;
        }
 
        /// <summary>
        /// 根据三高提供的参数,构建调度分析所需的参数, 每个泵站, 这个地方都不一样
        /// </summary>
        /// <param name="allRecords_hour"></param>
        /// <param name="error_info"></param>
        /// <returns></returns>
        protected virtual DispatchAna.Model.RequestParasComplex BuildDispatchAnaRequest(
            List<IStation.Dto.MonitorRecord4SG> allRecords_hour,
            out string error_info)
        { 
            error_info = "未实例化BuildDispatchAnaRequest";
            return null;
        }
 
    }
}