CpkPro.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace ProjectBase.Util
  7. {
  8. public class CpkPro
  9. {
  10. private static float StDev(float[] arrData) //计算标准偏差
  11. {
  12. float xSum = 0F;
  13. float xAvg = 0F;
  14. float sSum = 0F;
  15. float tmpStDev = 0F;
  16. int arrNum = arrData.Length;
  17. for (int i = 0; i < arrNum; i++)
  18. {
  19. xSum += arrData[i];
  20. }
  21. xAvg = xSum / arrNum;
  22. for (int j = 0; j < arrNum; j++)
  23. {
  24. sSum += ((arrData[j] - xAvg) * (arrData[j] - xAvg));
  25. }
  26. tmpStDev = Convert.ToSingle(Math.Sqrt((sSum / (arrNum - 1))).ToString());
  27. return tmpStDev;
  28. }
  29. private static float Cp(float UpperLimit, float LowerLimit, float StDev)//计算cp
  30. {
  31. float tmpV = 0F;
  32. tmpV = UpperLimit - LowerLimit;
  33. return Math.Abs(tmpV / (6 * StDev));
  34. }
  35. private static float Avage(float[] arrData) //计算平均值
  36. {
  37. float tmpSum = 0F;
  38. for (int i = 0; i < arrData.Length; i++)
  39. {
  40. tmpSum += arrData[i];
  41. }
  42. return tmpSum / arrData.Length;
  43. }
  44. private static float Max(float[] arrData) //计算最大值
  45. {
  46. float tmpMax = 0;
  47. for (int i = 0; i < arrData.Length; i++)
  48. {
  49. if (tmpMax < arrData[i])
  50. {
  51. tmpMax = arrData[i];
  52. }
  53. }
  54. return tmpMax;
  55. }
  56. private static float Min(float[] arrData) //计算最小值
  57. {
  58. float tmpMin = arrData[0];
  59. for (int i = 1; i < arrData.Length; i++)
  60. {
  61. if (tmpMin > arrData[i])
  62. {
  63. tmpMin = arrData[i];
  64. }
  65. }
  66. return tmpMin;
  67. }
  68. private static float CpkU(float UpperLimit, float Avage, float StDev)//计算CpkU
  69. {
  70. float tmpV = 0F;
  71. tmpV = UpperLimit - Avage;
  72. return tmpV / (3 * StDev);
  73. }
  74. private static float CpkL(float LowerLimit, float Avage, float StDev) //计算CpkL
  75. {
  76. float tmpV = 0F;
  77. tmpV = Avage - LowerLimit;
  78. return tmpV / (3 * StDev);
  79. }
  80. private static float Cpk(float CpkU, float CpkL) //计算Cpk
  81. {
  82. return Math.Abs(Math.Min(CpkU, CpkL));
  83. }
  84. public static float getR_value(float[] k_valuesTOO)
  85. {
  86. float min = k_valuesTOO[0];
  87. float max = k_valuesTOO[0];
  88. for (int i = 0; i < k_valuesTOO.Length; i++)
  89. {
  90. if (k_valuesTOO[i] < min)
  91. {
  92. min = k_valuesTOO[i];
  93. }
  94. if (k_valuesTOO[i] > max)
  95. {
  96. max = k_valuesTOO[i];
  97. }
  98. }
  99. return max - min;
  100. }
  101. public static float getCPK(float[] k, float UpperLimit, float LowerLimit) //获取CPK值
  102. {
  103. if (k.Length <= 1 || UpperLimit <= LowerLimit)
  104. {
  105. return -1;
  106. }
  107. float cpk = Cpk(CpkU(UpperLimit, Avage(k), StDev(k)), CpkL(LowerLimit, Avage(k), StDev(k)));
  108. return cpk;
  109. }
  110. }
  111. }