Tables.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace Uestc.Auto6.Dso.ComModel
  7. {
  8. public static class Tables
  9. {
  10. private static readonly Dictionary<Int32, (Int64 Span,Int32 Key,Int32 Ext, Double SampleRate,Double DDCGain)> _AnalogRFSpanScaleTable = new Dictionary<Int32, (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain)>{
  11. {0 ,( 0, 0, 1, 1,1)},
  12. {1 ,( 8_000,127,2000000, 10_000,0.6776)},//0418,RBW修改为10Hz,抽取比修改为2000000
  13. //{1 ,( 6_250,127,2560000, 7_812.5,0.6776)},
  14. {2 ,( 25_000,123,640000 , 31_250,0.6776)},
  15. {3 ,( 62_500,119,256000 , 78_125,0.4441)},
  16. {4 ,( 250_000,115,64000 , 312_500,0.4441)},
  17. {5 ,( 625_000,111,25600 , 781_250,0.5821)},
  18. {6 ,( 2_500_000,107,6400 , 3_125_000,0.5821)},
  19. {7 ,( 6_250_000,103,2560 , 7_812_500,0.7629)},
  20. {8 ,( 25_000_000,99,640 , 31_250_000,1)},
  21. {9 ,( 50_000_000,98,320 , 62_500_000,1)},
  22. {10,( 100_000_000,97,160 , 125_000_000,1)},
  23. {11,( 200_000_000,96,80 , 250_000_000,1)},
  24. {12,( 800_000_000,64,20 , 1000_000_000,1)},
  25. {13,(2_000_000_000,32,8 , 2_500_000_000,1)},
  26. {14,(8_000_000_000, 0,1 ,20_000_000_000,1)},
  27. };
  28. public static readonly Dictionary<RFWindowType,Double> WindowGainTable = new Dictionary<RFWindowType, Double>{
  29. {RFWindowType.Rectangle ,0.89},
  30. {RFWindowType.Hann ,1.44},
  31. {RFWindowType.Hamming ,1.3},
  32. {RFWindowType.Blackman ,1.9},
  33. {RFWindowType.Flattop ,3.77},
  34. {RFWindowType.Kaiser ,2.23},
  35. {RFWindowType.Gaussian ,1.4468},
  36. };
  37. public static (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain) GetRFHDScale(Int64 value, ChannelId id)
  38. {
  39. if (id == ChannelId.RF)
  40. {
  41. return Get10GRFHDScale(value);
  42. }
  43. return GetRFHDScale(value);
  44. }
  45. public static Double GetRFTranslateSampleRate(Int64 value, ChannelId id)
  46. {
  47. if (id == ChannelId.RF)
  48. {
  49. return Get10GRFTranslateSampleRate(value);
  50. }
  51. return GetRFTranslateSampleRate(value);
  52. }
  53. public static (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain) GetRFHDScale(Int64 value)
  54. {
  55. for (int i = 0; i < _AnalogRFSpanScaleTable.Count - 1; i++)
  56. {
  57. if (value> _AnalogRFSpanScaleTable[i].Span && value <= _AnalogRFSpanScaleTable[i+1].Span)
  58. {
  59. return _AnalogRFSpanScaleTable[i + 1];
  60. }
  61. }
  62. return _AnalogRFSpanScaleTable[_AnalogRFSpanScaleTable.Count - 1];
  63. }
  64. public static Double GetRFTranslateSampleRate(Int64 value)
  65. {
  66. for (int i = 0; i < _AnalogRFSpanScaleTable.Count - 1; i++)
  67. {
  68. if (value > _AnalogRFSpanScaleTable[i].Span && value <= _AnalogRFSpanScaleTable[i + 1].Span)
  69. {
  70. return _AnalogRFSpanScaleTable[i + 1].SampleRate;
  71. }
  72. }
  73. return _AnalogRFSpanScaleTable[_AnalogRFSpanScaleTable.Count - 1].SampleRate;
  74. }
  75. private static readonly Dictionary<Int32, (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain)> _10GRFSpanScaleTable = new Dictionary<Int32, (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain)>{
  76. {0 ,( 0 / 2, 0, 1, 1,1)},
  77. {1 ,( 8_000 / 2,127,2000000, 10_000 / 2,0.6776)},//0418,RBW修改为10Hz,抽取比修改为2000000
  78. {2 ,( 25_000 / 2,123,640000 , 31_250 / 2,0.6776)},
  79. {3 ,( 62_500 / 2,119,256000 , 78_125 / 2,0.4441)},
  80. {4 ,( 250_000 / 2,115,64000 , 312_500 / 2,0.4441)},
  81. {5 ,( 625_000 / 2,111,25600 , 781_250 / 2,0.5821)},
  82. {6 ,( 2_500_000 / 2,107,6400 , 3_125_000 / 2,0.5821)},
  83. {7 ,( 6_250_000 / 2,103,2560 , 7_812_500 / 2,0.7629)},
  84. {8 ,( 25_000_000 / 2,99,640 , 31_250_000 / 2,1)},
  85. {9 ,( 50_000_000 / 2,98,320 , 62_500_000 / 2,1)},
  86. {10,( 100_000_000 / 2,97,160 , 125_000_000 / 2,1)},
  87. {11,( 200_000_000 / 2,96,80 , 250_000_000 / 2,1)},
  88. {12,( 800_000_000 / 2,64,20 , 1_000_000_000 / 2,1)},
  89. {13,(2_000_000_000 / 2,32,8 , 2_500_000_000 / 2,1)},
  90. {14,(8_000_000_000 / 2, 0,1 ,20_000_000_000 / 2,1)},
  91. };
  92. public static (Int64 Span, Int32 Key, Int32 Ext, Double SampleRate, Double DDCGain) Get10GRFHDScale(Int64 value)
  93. {
  94. for (int i = 0; i < _10GRFSpanScaleTable.Count - 1; i++)
  95. {
  96. if (value > _10GRFSpanScaleTable[i].Span && value <= _10GRFSpanScaleTable[i + 1].Span)
  97. {
  98. return _10GRFSpanScaleTable[i + 1];
  99. }
  100. }
  101. return _10GRFSpanScaleTable[_10GRFSpanScaleTable.Count - 1];
  102. }
  103. public static Double Get10GRFTranslateSampleRate(Int64 value)
  104. {
  105. for (int i = 0; i < _10GRFSpanScaleTable.Count - 1; i++)
  106. {
  107. if (value > _10GRFSpanScaleTable[i].Span && value <= _10GRFSpanScaleTable[i + 1].Span)
  108. {
  109. return _10GRFSpanScaleTable[i + 1].SampleRate;
  110. }
  111. }
  112. return _10GRFSpanScaleTable[_10GRFSpanScaleTable.Count - 1].SampleRate;
  113. }
  114. }
  115. }