ICalc.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Numerics;
  4. using System.Runtime.Intrinsics;
  5. using System.Text;
  6. namespace FxpConvert.Common
  7. {
  8. public interface ICalc
  9. {
  10. /// <summary>
  11. /// 加法
  12. /// </summary>
  13. public IAdd Add { get; }
  14. /// <summary>
  15. /// 减法
  16. /// </summary>
  17. public ISubtract Subtract { get; }
  18. /// <summary>
  19. /// 乘法
  20. /// </summary>
  21. public IMultiply Multiply { get; }
  22. /// <summary>
  23. /// 除法
  24. /// </summary>
  25. public IDivision Division { get; }
  26. /// <summary>
  27. /// FFT
  28. /// </summary>
  29. public IFFT FFT { get; }
  30. /// <summary>
  31. /// Clamp
  32. /// </summary>
  33. public IClamp Clamp { get; }
  34. /// <summary>
  35. /// 数组求和
  36. /// </summary>
  37. public IArraySum Sum { get; }
  38. public void Fill(ref float result, float value, uint count);
  39. public void Fill(ref double result, double value, uint count);
  40. }
  41. public interface IArraySum
  42. {
  43. public float Sum(ref float value,uint count);
  44. public double Sum(ref double value,uint count);
  45. public float Rms(ref float value, uint count);
  46. public double Rms(ref double value,uint count);
  47. }
  48. public interface IClamp
  49. {
  50. public void Clamp(ref float value, float min, float max, uint count);
  51. public void Clamp(ref double value, double min, double max, uint count);
  52. public void Clamp(ref float value,ref float min,ref float max, uint count);
  53. public void Clamp(ref double value,ref double min,ref double max, uint count);
  54. public void In(ref float value, float min, float max, uint count,ref int result);
  55. public void In(ref double value, double min, double max, uint count, ref long result);
  56. public void In(ref float value, ref float min, ref float max, uint count, ref int result);
  57. public void In(ref double value, ref double min, ref double max, uint count, ref long result);
  58. }
  59. public interface IFFT
  60. {
  61. public void FFT(double[] real, double[] imaginary);
  62. public void FFT(float[] real, float[] imaginary);
  63. public void IFFT(double[] real, double[] imaginary);
  64. public void IFFT(float[] real, float[] imaginary);
  65. }
  66. public interface IAdd
  67. {
  68. public void Add(ref float left, float right, uint count, ref float result);
  69. public void Add(ref float left, ref float right, uint count, ref float result);
  70. public void Add(ref float left, float right, uint count);
  71. public void Add(ref float left, ref float right, uint count);
  72. public void Add(ref double left, double right, uint count, ref double result);
  73. public void Add(ref double left, ref double right, uint count, ref double result);
  74. public void Add(ref double left, double right, uint count);
  75. public void Add(ref double left, ref double right, uint count);
  76. }
  77. public interface ISubtract
  78. {
  79. public void Subtract(ref float left, float right, uint count, ref float result);
  80. public void Subtract(ref float left, ref float right, uint count, ref float result);
  81. public void Subtract(ref float left, float right, uint count);
  82. public void Subtract(ref float left, ref float right, uint count);
  83. public void Subtract(ref double left, double right, uint count, ref double result);
  84. public void Subtract(ref double left, ref double right, uint count, ref double result);
  85. public void Subtract(ref double left, double right, uint count);
  86. public void Subtract(ref double left, ref double right, uint count);
  87. }
  88. public interface IMultiply
  89. {
  90. public void Multiply(ref float left, float right, uint count, ref float result);
  91. public void Multiply(ref float left, ref float right, uint count, ref float result);
  92. public void Multiply(ref float left, float right, uint count);
  93. public void Multiply(ref float left, ref float right, uint count);
  94. public void Multiply(ref double left, double right, uint count, ref double result);
  95. public void Multiply(ref double left, ref double right, uint count, ref double result);
  96. public void Multiply(ref double left, double right, uint count);
  97. public void Multiply(ref double left, ref double right, uint count);
  98. }
  99. public interface IDivision
  100. {
  101. public void Division(ref float left, float right, uint count, ref float result);
  102. public void Division(ref float left, ref float right, uint count, ref float result);
  103. public void Division(ref float left, float right, uint count);
  104. public void Division(ref float left, ref float right, uint count);
  105. public void Division(ref double left, double right, uint count, ref double result);
  106. public void Division(ref double left, ref double right, uint count, ref double result);
  107. public void Division(ref double left, double right, uint count);
  108. public void Division(ref double left, ref double right, uint count);
  109. }
  110. }