AdcFileUtil.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. using Ips.Ddc;
  2. using Ips.Library.Basic;
  3. using Ips.Library.Entity;
  4. using Ips.Library.LocLib;
  5. using Ips.Library.Signals;
  6. using Ips.Tpdx;
  7. using Microsoft.VisualBasic.FileIO;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Reflection.Metadata.Ecma335;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. namespace Ips.AdcAlgorithm
  15. {
  16. public static class AdcFileUtil
  17. {
  18. public static Task<AdcResult> BuildAdcResult(AdcOptions options, Func<AdcOptions, int, string> getAdcSrcFileName, CancellationToken token = default)
  19. {
  20. options.StartTime = options.StartTime.ClearMillisecond();
  21. var result = new AdcResult(options.StartTime, options.StorePath);
  22. if (options.Channels.IsNullOrEmpty())
  23. {
  24. for (int i = 1; i <= options.ChCount; i++)
  25. {
  26. if (token.IsCancellationRequested) break;
  27. string sourceFile = getAdcSrcFileName(options, i);
  28. if (!File.Exists(sourceFile))
  29. {
  30. IpsLogger.Warn($"采集落盘文件:{sourceFile}不存在!");
  31. continue;
  32. }
  33. int bandWidth = (int)(options.ClockFreq / options.Mutil);
  34. //var fileItem = new AdcFile(options.StartTime, i, 0, bandWidth, "");
  35. var fs = SigCalcUtil.CalcFs(options.ClockFreq, bandWidth, 1);
  36. var fileItem = SignalFile.Create(options.StartTime, 0, bandWidth, 0, "", "", i, "");
  37. string targetFile = fileItem.GetLocalFullName(options.StorePath);
  38. DirectoryUtil.CreateIfNotExists(Path.GetDirectoryName(targetFile));
  39. File.Move(sourceFile, targetFile, true);
  40. result.FileList.Add(fileItem);
  41. }
  42. }
  43. else
  44. {
  45. foreach (var ch in options.Channels)
  46. {
  47. foreach (var sig in ch.Signals)
  48. {
  49. if (token.IsCancellationRequested) break;
  50. string sourceFile = getAdcSrcFileName(options, ch.ChNum);
  51. if (!File.Exists(sourceFile))
  52. {
  53. IpsLogger.Warn($"文件不存在,采集文件失败!{sourceFile}");
  54. continue;
  55. }
  56. //AdcFile fileItem = new AdcFile(options.StartTime, ch.ChNum, sig.FreqUp, sig.BandWidth, sig.SigName);
  57. var fs = SigCalcUtil.CalcFs(options.ClockFreq, sig.BandWidth, 1);
  58. SignalFile fileItem = SignalFile.Create(options.StartTime, sig.FreqUp, sig.BandWidth, fs, ch.SiteCode, ch.AdcCode, ch.ChNum, sig.SigName);
  59. string targetFile = fileItem.GetLocalFullName(options.StorePath);
  60. DirectoryUtil.CreateIfNotExists(Path.GetDirectoryName(targetFile));
  61. File.Move(sourceFile, targetFile, true);
  62. result.FileList.Add(fileItem);
  63. }
  64. }
  65. }
  66. return Task.FromResult(result);
  67. }
  68. public static async Task<AdcResult> BuildDdcResult(AdcOptions options, Func<AdcOptions, int, string> getSrcFileName, CancellationToken token = default)
  69. {
  70. options.StartTime = options.StartTime.ClearMillisecond();
  71. var adcResult = new AdcResult(options.StartTime, options.StorePath);
  72. foreach (var ch in options.Channels)
  73. {
  74. string sourceFile = getSrcFileName(options, ch.ChNum);
  75. if (!File.Exists(sourceFile))
  76. {
  77. IpsLogger.Warn($"信道化采集失败,文件[{sourceFile}]不存在!");
  78. continue;
  79. }
  80. var fsad = options.ClockFreq / options.Mutil;
  81. var ddcItems = ch.Signals.Select(m =>
  82. {
  83. var ffc = ch.CenterFreq - m.FreqPoint;
  84. var mutil = SigCalcUtil.CalcMutil(fsad, m.BandWidth, false);
  85. var item = new DdcSignalItem(m, ffc, mutil);
  86. item.IsTpdx = false;
  87. double bw = m.BandWidth / 2;
  88. double startFreq = m.FreqUp - bw;
  89. double endFreq = m.FreqUp + bw;
  90. var dxSignale = ch.DxSignals.FirstOrDefault(m => m.FreqUp >= startFreq && m.FreqUp <= endFreq);
  91. if (dxSignale != null)
  92. {
  93. item.DxSigOption = dxSignale;
  94. item.IsTpdx = true;//是否做同频对消
  95. }
  96. return item;
  97. }).ToArray();
  98. bool success;
  99. try
  100. {
  101. var ddcSigList = ddcItems.Select(m => new DdcSigItem(m.Ffc, m.Mutil)).ToList();
  102. var ddcResult = await DdcUtil.ExecAsync(sourceFile, fsad, options.StorePath, ddcSigList, options.Real, options.UseGpuDdc, token);
  103. success = ddcResult.ExitCode == 0;
  104. if (ddcResult.ExitCode != 0)
  105. {
  106. IpsLogger.Error($"信道化失败,{ddcResult.ExitMsg}");
  107. break;
  108. }
  109. foreach (var sig in ddcItems)
  110. {
  111. string ddcFileName = Path.Combine(options.StorePath, $"{sig.Ffc}_{sig.Mutil}.dat");
  112. //AdcFile fileItem = new AdcFile(options.StartTime, ch.ChNum, sig.SigOption.FreqPoint, sig.SigOption.BandWidth, sig.SigOption.SigName);
  113. var fs = SigCalcUtil.CalcFs(options.ClockFreq, sig.SigOption.BandWidth, options.Mutil);
  114. if (sig.IsTpdx)
  115. {
  116. var fc = sig.DxSigOption.FreqUp - sig.SigOption.FreqUp;
  117. var dxsigItem = new DxSigItem(fc, sig.DxSigOption.BandWidth, fs, sig.DxSigOption.Mod);
  118. IpsLogger.Info($"频点:{sig.SigOption.FreqUp}-{ddcFileName}执行同频对消开始");
  119. string outFile = await TpdxUtil.ExecAsync(ddcFileName, options.StorePath, dxsigItem, options.UseGpuDdc, token);
  120. ddcFileName = outFile;
  121. IpsLogger.Info($"执行同频对消结束{ddcFileName}");
  122. }
  123. SignalFile fileItem = SignalFile.Create(options.StartTime, sig.SigOption.FreqUp, sig.SigOption.BandWidth, fs, ch.SiteCode, ch.AdcCode, ch.ChNum, sig.SigOption.SigName);
  124. string targetFile = fileItem.GetLocalFullName(options.StorePath);
  125. DirectoryUtil.CreateIfNotExists(Path.GetDirectoryName(targetFile));
  126. File.Move(ddcFileName, targetFile, true);
  127. adcResult.FileList.Add(fileItem);
  128. }
  129. FileUtil.DeleteIfExists(sourceFile);
  130. }
  131. catch (Exception ex)
  132. {
  133. IpsLogger.Error($"信道化失败",ex);
  134. }
  135. }
  136. return adcResult;
  137. }
  138. public static Task<AdcResult> BuildDdcResult_dll(AdcOptions options, Func<AdcOptions, int, string> getSrcFileName, CancellationToken token = default)
  139. {
  140. options.StartTime = options.StartTime.ClearMillisecond();
  141. var adcResult = new AdcResult(options.StartTime, options.StorePath);
  142. foreach (var ch in options.Channels)
  143. {
  144. string sourceFile = getSrcFileName(options, ch.ChNum);
  145. if (!File.Exists(sourceFile))
  146. {
  147. IpsLogger.Warn($"信道化采集失败,文件[{sourceFile}]不存在!");
  148. continue;
  149. }
  150. var fsad = options.ClockFreq / options.Mutil;
  151. var ptr = DdcInterop.InitDDC(fsad, sourceFile, options.StorePath);
  152. var ddcItems = ch.Signals.Select(m =>
  153. {
  154. var ffc = ch.CenterFreq - m.FreqPoint;
  155. var mutil = SigCalcUtil.CalcMutil(fsad, m.BandWidth, false);
  156. var item = new DdcSignalItem(m, ffc, mutil);
  157. return item;
  158. }).ToArray();
  159. var ffcs = ddcItems.Select(m => m.Ffc).ToArray();
  160. var mutils = ddcItems.Select(m => m.Mutil).ToArray();
  161. bool success;
  162. try
  163. {
  164. success = DdcInterop.AddSignals(ptr, ffcs, mutils, ffcs.Length);
  165. if (!success)
  166. {
  167. IpsLogger.Warn($"信道化失败,频点超出范围!");
  168. continue;
  169. }
  170. DdcInterop.Start(ptr);
  171. foreach (var sig in ddcItems)
  172. {
  173. string ddcFileName = Path.Combine(options.StorePath, $"{sig.Ffc}_{sig.Mutil}.dat");
  174. //AdcFile fileItem = new AdcFile(options.StartTime, ch.ChNum, sig.SigOption.FreqPoint, sig.SigOption.BandWidth, sig.SigOption.SigName);
  175. var fs = SigCalcUtil.CalcFs(options.ClockFreq, sig.SigOption.BandWidth, options.Mutil);
  176. SignalFile fileItem = SignalFile.Create(options.StartTime, sig.SigOption.FreqUp, sig.SigOption.BandWidth, fs, ch.SiteCode, ch.AdcCode, ch.ChNum, sig.SigOption.SigName);
  177. if (sig.SigOption.FreqUp == 0)
  178. {
  179. string targetFile = fileItem.GetLocalFullName(options.StorePath);
  180. DirectoryUtil.CreateIfNotExists(Path.GetDirectoryName(targetFile));
  181. File.Move(ddcFileName, targetFile, true);
  182. }
  183. adcResult.FileList.Add(fileItem);
  184. }
  185. FileUtil.DeleteIfExists(sourceFile);
  186. }
  187. catch (Exception ex)
  188. {
  189. IpsLogger.Error($"信道化失败",ex);
  190. }
  191. finally
  192. {
  193. DdcInterop.FreeDDC(ptr);
  194. }
  195. }
  196. return Task.FromResult(adcResult);
  197. }
  198. public static AdcResult BuildDdcResult(AdcOptions options, Func<AdcOptions, AdcChOptions, AdcSigOptions, string> getSrcFileName)
  199. {
  200. options.StartTime = options.StartTime.ClearMillisecond();
  201. var adcResult = new AdcResult(options.StartTime, options.StorePath);
  202. foreach (var ch in options.Channels)
  203. {
  204. foreach (var sig in ch.Signals)
  205. {
  206. string sourceFile = getSrcFileName(options, ch, sig);
  207. if (!File.Exists(sourceFile)) continue;
  208. //AdcFile fileItem = new AdcFile(options.StartTime, ch.ChNum, sig.FreqPoint, sig.BandWidth, sig.SigName);
  209. var fs = SigCalcUtil.CalcFs(options.ClockFreq, sig.BandWidth, options.Mutil);
  210. SignalFile fileItem = SignalFile.Create(options.StartTime, sig.FreqUp, sig.BandWidth, fs, ch.SiteCode, ch.AdcCode, ch.ChNum, sig.SigName);
  211. if (sig.FreqUp == 0)
  212. {
  213. string targetFile = fileItem.GetLocalFullName(options.StorePath);
  214. DirectoryUtil.CreateIfNotExists(Path.GetDirectoryName(targetFile));
  215. File.Move(sourceFile, targetFile, true);
  216. }
  217. adcResult.FileList.Add(fileItem);
  218. }
  219. }
  220. return adcResult;
  221. }
  222. }
  223. }