SlotHelper.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Linq;
  5. using System.Runtime.InteropServices;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace X3TaskServer54
  9. {
  10. static class SlotHelper
  11. {
  12. #region cpp dll Interop
  13. private const string slotDll = @"AddIns\时隙获取\SlotChecker.dll";
  14. [DllImport(slotDll, EntryPoint = "getslots", CallingConvention = CallingConvention.Cdecl)]
  15. private extern static int GetFileSlots(string file, byte[] fileTime, ref float frequenceM, ref float fsampleM,
  16. ref int multi, ref int slotscount, out IntPtr slotst, out IntPtr slotle);
  17. [DllImport(slotDll, EntryPoint = "freeslots", CallingConvention = CallingConvention.Cdecl)]
  18. private extern static void Free(IntPtr slotst, IntPtr slotle);
  19. #endregion
  20. public static SlotsInfo GetFileSlots(string file)
  21. {
  22. SlotsInfo res = new SlotsInfo();
  23. string name = Path.GetFileName(file);
  24. res.FreqDownMHz = Convert.ToDouble(name.Split(new string[] { "_", "MHz" }, StringSplitOptions.RemoveEmptyEntries)[1]);
  25. byte[] timeData = new byte[6];
  26. float frequenceM = 0, fsampleM = 0;
  27. int multi = 0, slotscount = 0;
  28. IntPtr slotst, slotle;
  29. var ret = GetFileSlots(file, timeData, ref frequenceM, ref fsampleM, ref multi, ref slotscount, out slotst, out slotle);
  30. if (ret == 0)
  31. {
  32. res.FrequenceM = (float)((long)((decimal)frequenceM * 1000000) / 1e6);
  33. res.FsampleM = fsampleM;
  34. res.Multi = multi;
  35. res.AdTime = new DateTime(2000 + timeData[0], timeData[1], timeData[2], timeData[3], timeData[4], timeData[5]);
  36. float[] startsF = new float[slotscount];
  37. float[] lenF = new float[slotscount];
  38. Marshal.Copy(slotst, startsF, 0, slotscount);
  39. Marshal.Copy(slotle, lenF, 0, slotscount);
  40. for (int i = 0; i < slotscount; i++)
  41. {
  42. Slot s = new Slot()
  43. {
  44. StartPoint = (int)(fsampleM * 1e6 / multi * startsF[i]),
  45. Len = (int)(fsampleM * 1e6 / multi * lenF[i] * 1e-3)
  46. };
  47. res.Slots.Add(s);
  48. }
  49. }
  50. Free(slotst, slotle);
  51. return res;
  52. }
  53. }
  54. /// <summary>
  55. /// 突发信息
  56. /// </summary>
  57. class SlotsInfo
  58. {
  59. /// <summary>
  60. /// 采集时刻
  61. /// </summary>
  62. public DateTime AdTime { get; set; }
  63. /// <summary>
  64. /// 信号下行频点MHz
  65. /// </summary>
  66. public double FreqDownMHz { get; set; }
  67. /// <summary>
  68. /// AD采样率
  69. /// </summary>
  70. public float FsampleM { get; set; }
  71. /// <summary>
  72. /// 信号下行频点
  73. /// </summary>
  74. public float FrequenceM { get; set; }
  75. /// <summary>
  76. /// 抽取倍数
  77. /// </summary>
  78. public float Multi { get; set; }
  79. /// <summary>
  80. /// 时隙位置集合
  81. /// </summary>
  82. public List<Slot> Slots { get; set; } = new List<Slot>();
  83. }
  84. /// <summary>
  85. /// 时隙信息
  86. /// </summary>
  87. class Slot
  88. {
  89. /// <summary>
  90. /// 起始样点
  91. /// </summary>
  92. public int StartPoint { get; set; }
  93. /// <summary>
  94. /// 结束样点
  95. /// </summary>
  96. public int Len { get; set; }
  97. }
  98. }