ningshuxia
2022-12-01 ad494f13d2ddf31f142cf7fb908b3a6e90395a1a
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
using IStation.Untity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace IStation.Calculation
{
    /// <summary>
    /// 能效汇总多年辅助类
    /// </summary>
    public class EtaSumMultiYearHelper
    {
        /// <summary>
        /// 汇总
        /// </summary>
        public static List<Model.EtaSumMultiYearRecord> Sum
                 (
                    long CorpID,
                    string ObjectType,
                    long ObjectID,
                    int DataYear,
                    IEnumerable<Model.EtaSumMultiMonthRecord> list
                 )
        {
            if (list == null || list.Count() < 1)
                return default;
            var group_list = list.GroupBy(x => new {
                CorpID = x.CorpID,
                ObjectType = x.ObjectType,
                ObjectID = x.ObjectID,
                RunningCount = x.RunningCount,
                RunningFlag = IntListHelper.ToString(x.RunningFlag)
            }).ToList();
 
            var result = group_list.Select(x => {
                var model = new Model.EtaSumMultiYearRecord();
                model.CorpID = CorpID;
                model.ObjectType = ObjectType;
                model.ObjectID = ObjectID;
                model.DataYear = DataYear;
                model.DataTime = DateTime.Now;
                model.RunningCount = x.Key.RunningCount;
                model.RunningFlag = IntListHelper.ToList(x.Key.RunningFlag);
                model.Qt = list.Sum(x => x.Qt);
                model.Dt = list.Sum(x => x.Dt);
                model.RunTime = list.Sum(x => x.RunTime);
                model.PointCount = list.Sum(x => x.PointCount);
 
                model.Qmin = list.Min(t => t.Qmin);
                model.Qmax = list.Max(t => t.Qmax);
                model.Qavg = list.Sum(t => t.Qavg * ((double)t.PointCount) / ((double)model.PointCount));
 
                model.Emin = list.Min(t => t.Emin);
                model.Emax = list.Max(t => t.Emax);
                model.Eavg = list.Sum(t => t.Eavg * ((double)t.PointCount) / ((double)model.PointCount));
 
                model.Hmin = list.Min(t => t.Hmin);
                model.Hmax = list.Max(t => t.Hmax);
                model.Havg = list.Sum(t => t.Havg * ((double)t.PointCount) / ((double)model.PointCount));
 
                model.Pmin = list.Min(t => t.Pmin);
                model.Pmax = list.Max(t => t.Pmax);
                model.Pavg = list.Sum(t => t.Pavg * ((double)t.PointCount) / ((double)model.PointCount));
 
                model.WPmin = list.Min(t => t.WPmin);
                model.WPmax = list.Max(t => t.WPmax);
                model.WPavg = list.Sum(t => t.WPavg * ((double)t.PointCount) / ((double)model.PointCount));
 
                model.UWPmin = list.Min(t => t.UWPmin);
                model.UWPmax = list.Max(t => t.UWPmax);
                model.UWPavg = list.Sum(t => t.UWPavg * ((double)t.PointCount) / ((double)model.PointCount));
 
                return model;
 
            }).ToList();
 
            return result;
 
        }
 
 
    }
}