LevelCurveManager.cs 1.0 KB

123456789101112131415161718192021222324252627282930313233343536
  1. using Aitex.Core.Util;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace CyberX8_RT.Devices.Reservoir
  8. {
  9. public class LevelCurveManager : Singleton<LevelCurveManager>
  10. {
  11. /// <summary>
  12. /// 计算Level
  13. /// </summary>
  14. /// <param name="waterLevel"></param>
  15. /// <param name="levelCurve"></param>
  16. /// <returns></returns>
  17. public double CalculateLevelByWaterLevel(double waterLevel,string levelCurve)
  18. {
  19. string[] strAry= levelCurve.Split(',');
  20. if (strAry.Length >= 3)
  21. {
  22. double.TryParse(strAry[strAry.Length - 1], out double c);
  23. double.TryParse(strAry[strAry.Length-2], out double b);
  24. double.TryParse(strAry[strAry.Length-3], out double a);
  25. return a*Math.Pow(waterLevel,2)+b*waterLevel+c;
  26. }
  27. else
  28. {
  29. return 0;
  30. }
  31. }
  32. }
  33. }