ningshuxia
2024-06-18 e83dca6e861b622b54d3392ca0d3f1f1eb69f7c9
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
using IStation.Epanet.Analysis;
using IStation.Epanet.Enums;
using System.Text;
using Yw;
 
namespace IStation.Epanet
{
    /// <summary>
    /// 水力模型调度
    /// </summary>
    public class StationScheduleHelper
    {
         
        public static string Schedule(int stationId,string filePath)
        { 
          
 
            var err = EpanetMethods.ENopen(filePath, "", "");
            if (err != 0)
            {
                return $"ENopen:{new EnException(err).Message}!";
            }
 
 
            int tstep = 0;
            EpanetMethods.ENopenH();
            EpanetMethods.ENinitH(0);
 
            do
            {
                const int MAXID = 31;
                var idBuild = new StringBuilder(MAXID);
                var jsonBuild = new StringBuilder();
 
                EpanetMethods.ENrunH(out int t);
 
                EpanetMethods.ENgetcount(CountType.Node, out int nodeCount);
                EpanetMethods.ENgetcount(CountType.Link, out int linkCount);
 
                for (int i = 1; i <= nodeCount; i++)
                {
                    if (EpanetMethods.ENgetnodeid(i, idBuild) != 0)
                        continue;
                    jsonBuild.Clear();
                    jsonBuild.Append("{");
                    foreach (NodeValue f in Enum.GetValues(typeof(NodeValue)))
                    {
                        EpanetMethods.ENgetnodevalue(i, f, out float v);
                        jsonBuild.Append($"\"{f}\":\"{v}\",");
                    }
                    jsonBuild.Remove(jsonBuild.Length - 1, 1);
                    jsonBuild.Append("}");
 
                    EpanetMethods.ENgetnodetype(i, out NodeType type);
                    var outNode = JsonHelper.Json2Object<OutNode>(jsonBuild.ToString());
                    outNode.NodeType = type;
                    outNode.ID = idBuild.ToString();
                    outNode.Time = TimeSpan.FromSeconds(t);
 
                    output.Nodes.Add(outNode);
                }
 
                for (int i = 1; i <= linkCount; i++)
                {
                    if (EpanetMethods.ENgetlinkid(i, idBuild) != 0)
                        continue;
 
                    jsonBuild.Clear();
                    jsonBuild.Append("{");
                    foreach (LinkValue f in Enum.GetValues(typeof(LinkValue)))
                    {
                        EpanetMethods.ENgetlinkvalue(i, f, out float v);
                        jsonBuild.Append($"\"{f}\":\"{v}\",");
                    }
                    jsonBuild.Remove(jsonBuild.Length - 1, 1);
                    jsonBuild.Append("}");
 
                    EpanetMethods.ENgetlinktype(i, out LinkType type);
                    var outLink = JsonHelper.Json2Object<OutLink>(jsonBuild.ToString());
                    outLink.LinkType = type;
                    outLink.ID = idBuild.ToString();
                    outLink.Time = TimeSpan.FromSeconds(t);
                    output.Links.Add(outLink);
                }
 
                EpanetMethods.ENnextH(out tstep);
 
            } while (tstep > 0);
            EpanetMethods.ENcloseH();
 
            return string.Empty;
        }
         
    }
 
}