CgService.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. using DevExpress.Pdf;
  2. using Ips.Library.Basic;
  3. using Ips.Library.Entity;
  4. using Ips.Library.Signals;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. namespace Ips.Service.GpuServer
  13. {
  14. /// <summary>
  15. /// 参估处理服务
  16. /// </summary>
  17. public class CgService
  18. {
  19. private bool isBusy = false;
  20. private string exeName = "cog";
  21. /// <summary>
  22. /// 开始
  23. /// </summary>
  24. /// <param name="dto"></param>
  25. /// <returns></returns>
  26. public async Task<CorResult[]> StartAsync(CorParams dto)
  27. {
  28. if (isBusy)
  29. {
  30. throw new Exception("上次GPU调用未结束");
  31. }
  32. //直接从采集上下载文件到本地
  33. string[] files = new string[] { dto.File1, dto.File2 };
  34. for (int i = 0; i < 2; i++)
  35. {
  36. string localFile = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Download", files[i]);
  37. if (!File.Exists(localFile))
  38. {
  39. var res = await HttpHelper.DownloadFileAsync(dto.AdFileDownloadUrl, files[i], localFile);
  40. if (!res)
  41. {
  42. throw new Exception($"文件下载失败,url=[{dto.AdFileDownloadUrl}?filename={files[i]}]");
  43. }
  44. }
  45. if (i == 0)
  46. dto.File1 = localFile;
  47. else
  48. dto.File2 = localFile;
  49. }
  50. return await Task.Run(() =>
  51. {
  52. try
  53. {
  54. isBusy = true;
  55. Process p = new Process();
  56. p.StartInfo.FileName = $"参数估计\\{exeName}.exe";
  57. StringBuilder sb = new StringBuilder();
  58. sb.Append($"{dto.File1} ");
  59. sb.Append($"{dto.File2} ");
  60. sb.Append($"{dto.DtoCenter} ");
  61. sb.Append($"{dto.DtoRange} ");
  62. sb.Append($"{dto.Snr} ");
  63. sb.Append($"{dto.DfoRange} ");
  64. sb.Append($"{dto.DtoCorr} ");
  65. sb.Append($"{dto.DfoCorr} ");
  66. sb.Append($"{dto.Fs} ");
  67. sb.Append($"-l {dto.DataLen} ");
  68. sb.Append($"-z {dto.AddZero} ");
  69. sb.Append($"-o {dto.TimeOffset} ");
  70. sb.Append($"-f {(int)dto.OffsetType} ");
  71. if (dto.Timeslots != null)
  72. {
  73. sb.Append($"-d {string.Join(" ", dto.Timeslots)} ");
  74. sb.Append($"-m {dto.MergeType.ToString("d")}");
  75. }
  76. p.StartInfo.Arguments = sb.ToString();
  77. p.StartInfo.CreateNoWindow = true;
  78. p.StartInfo.RedirectStandardError = true;
  79. p.StartInfo.RedirectStandardOutput = true;
  80. p.StartInfo.UseShellExecute = false;
  81. IpsLogger.Info($"开始参估计算.可打开Logs目录查看{exeName}.exe命令行参数详细");
  82. IpsLogger.Info($"开始参估计算.{exeName}.exe参数={p.StartInfo.Arguments}",false);
  83. p.Start();
  84. var succeed = p.WaitForExit(30 * 1000);
  85. if (!succeed)
  86. {
  87. Stop();
  88. throw new Exception($"计算超时");
  89. }
  90. var err = p.StandardError.ReadToEnd();
  91. if (!string.IsNullOrWhiteSpace(err))
  92. {
  93. throw new Exception(err);
  94. }
  95. var str = p.StandardOutput.ReadToEnd();
  96. var result = CorResult.FromLines(str, dto.Snr);
  97. return result;
  98. }
  99. finally
  100. {
  101. isBusy = false;
  102. }
  103. });
  104. }
  105. /// <summary>
  106. /// 停止
  107. /// </summary>
  108. public void Stop()
  109. {
  110. var pros = Process.GetProcessesByName(exeName);
  111. foreach (var item in pros)
  112. {
  113. try
  114. {
  115. item.Kill();
  116. }
  117. catch
  118. { }
  119. }
  120. }
  121. private CorResult[] FromLines(string result, double snr)
  122. {
  123. if (string.IsNullOrWhiteSpace(result))
  124. return new CorResult[0];
  125. var lines = result.Split(Environment.NewLine, StringSplitOptions.RemoveEmptyEntries);
  126. CorResult[] results = new CorResult[lines.Length];
  127. for (int i = 0; i < lines.Length; i++)
  128. {
  129. results[i] = FromLine(lines[i], snr);
  130. }
  131. return results;
  132. }
  133. private CorResult FromLine(string line, double snr)
  134. {
  135. if (string.IsNullOrWhiteSpace(line)) throw new ArgumentNullException(nameof(line));
  136. CorResult corResult = new CorResult();
  137. var cafItems = line.Split(";".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
  138. corResult.Message = line;
  139. if (cafItems.Length == 0) return corResult;
  140. int i = 0;
  141. var cafitem = cafItems[i];
  142. var resitems = cafitem.Split(',');
  143. if (resitems.Length != 6) return corResult;
  144. corResult.Start = int.Parse(resitems[0]);
  145. corResult.Length = int.Parse(resitems[1]);
  146. corResult.Dto = double.Parse(resitems[2]);
  147. corResult.Dfo = double.Parse(resitems[3]);
  148. corResult.Snr = double.Parse(resitems[4]);
  149. corResult.UseTime = double.Parse(resitems[5]);
  150. corResult.IsValid = corResult.Snr > snr;
  151. if (cafItems.Length > 1)
  152. {
  153. for (i = 1; i < cafItems.Length; i++)
  154. {
  155. resitems = cafItems[i].Split(',');
  156. XgfItem xgfItem = new XgfItem()
  157. {
  158. Dto = double.Parse(resitems[0]),
  159. Dfo = double.Parse(resitems[1]),
  160. Snr = double.Parse(resitems[2])
  161. };
  162. corResult.XgfList.Add(xgfItem);
  163. }
  164. }
  165. return corResult;
  166. }
  167. }
  168. }