tangxu
2022-11-04 4dc0d885c843d494a05ee86c01818abc4e640bab
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace IStation.Model
{
    /// <summary>
    /// 特性曲线辅助类
    /// </summary>
    public class FeatCurveHelper
    {
        /// <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);
        }
 
        /// <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);
        }
 
 
    }
}