ningshuxia
2024-04-09 51730f13db4aa7e353be3c8133e8429bf19ea3b1
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
namespace IStation.Model
{
    /// <summary>
    /// 特性曲线辅助类
    /// </summary>
    public class FeatCurveHelper
    {
 
        /// <summary>
        /// 通过 频率 计算流量扬程曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQhByHz(Model.CurveExpress curve, double hz)
        {
            if (curve == null)
                return default;
            var points = curve.GetFitPoints(20);
            return CalcuCurveQhByHz(points, curve.FitType, hz);
        }
 
        /// <summary>
        /// 通过 频率 计算流量扬程曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQhByHz(List<CurvePoint> pts, eCurveFitType fit, double hz)
        {
            if (pts == null)
                return default;
            var fit_pow = CurveExpress.GetFitPow(fit);
            if (pts.Count < fit_pow + 1)
                return default;
            double f_ratio = hz / 50.0;
            var list = pts.Select(x => new CurvePoint(x.X * f_ratio, x.Y * f_ratio * f_ratio)).ToList();
            return new CurveExpress(list, fit, true);
        }
 
        /// <summary>
        /// 通过 频率 计算流量功率曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQpByHz(Model.CurveExpress curve, double hz)
        {
            if (curve == null)
                return default;
            var points = curve.GetFitPoints(20);
            return CalcuCurveQpByHz(points, curve.FitType, hz);
        }
 
        /// <summary>
        /// 通过 频率 计算流量功率曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQpByHz(List<CurvePoint> pts, eCurveFitType fit, double hz)
        {
            if (pts == null)
                return default;
            var fit_pow = CurveExpress.GetFitPow(fit);
            if (pts.Count < fit_pow + 1)
                return default;
            double f_ratio = hz / 50.0;
            var list = pts.Select(x => new CurvePoint(x.X * f_ratio, x.Y * f_ratio * f_ratio * f_ratio)).ToList();
            return new CurveExpress(list, fit, true);
        }
 
 
        /// <summary>
        /// 通过 频率 计算流量功率曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQeByHz(Model.CurveExpress curve, double hz)
        {
            if (curve == null)
                return default;
            var points = curve.GetFitPoints(20);
            return CalcuCurveQeByHz(points, curve.FitType, hz);
        }
 
        /// <summary>
        /// 通过 频率 计算流量功率曲线表达式
        /// </summary>
        public static CurveExpress CalcuCurveQeByHz(List<CurvePoint> pts, eCurveFitType fit, double hz)
        {
            if (pts == null)
                return default;
            var fit_pow = CurveExpress.GetFitPow(fit);
            if (pts.Count < fit_pow + 1)
                return default;
            double f_ratio = hz / 50.0;
            var list = pts.Select(x => new CurvePoint(x.X * f_ratio, x.Y)).ToList();
            return new CurveExpress(list, fit, true);
        }
    }
}