DetectCgController.cs 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Threading.Tasks;
  7. using DW5S.KxcApi;
  8. using DW5S.DTO;
  9. using DW5S.Repostory;
  10. using DW5S.WebApi;
  11. using Microsoft.AspNetCore.Mvc;
  12. using DW5S.Service;
  13. using Serilog;
  14. namespace DW5S.Controllers
  15. {
  16. /// <summary>
  17. /// 检测参估变采样识别相关接口
  18. /// </summary>
  19. public class DetectCgController : BaseController
  20. {
  21. ILogger logger { get; set; }
  22. IUnitOfWork unitOfWork { get; set; }
  23. /// <summary>
  24. /// CPU参估计算(需要先上传文件)
  25. /// </summary>
  26. /// <param name="dto">CPU参估参数</param>
  27. /// <returns></returns>
  28. [HttpPost]
  29. public async Task<AjaxResult<CpuCgResDto>> CpuCgCalc(CpuCgDto dto)
  30. {
  31. try
  32. {
  33. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
  34. dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr);
  35. dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr);
  36. var res = await HttpHelper.PostRequestAsync<CpuCgResDto>(svr.BaseHttpAddr + "CpuCg/Calc", dto);
  37. return res;
  38. }
  39. catch (TaskCanceledException)
  40. {
  41. return Error<CpuCgResDto>($"CPU参估超时");
  42. }
  43. }
  44. /// <summary>
  45. /// CPU参估多个时隙的参估计算(需要先上传文件)
  46. /// </summary>
  47. /// <param name="dto">CPU多时隙参估参数模型</param>
  48. /// <returns>返回结果个数始终和传入的时隙个数相同</returns>
  49. [HttpPost]
  50. public async Task<AjaxResult<List<CpuCgResDto>>> CpuCgMultiCalc(CpuCgMultiDto dto)
  51. {
  52. try
  53. {
  54. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
  55. dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr);
  56. dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr);
  57. var res = await HttpHelper.PostRequestAsync<List<CpuCgResDto>>(svr.BaseHttpAddr + "CpuCg/MultiCalc", dto);
  58. if (res.code != 200)
  59. {
  60. return Error<List<CpuCgResDto>>(res.msg);
  61. }
  62. else
  63. {
  64. return Success(res.data);
  65. }
  66. }
  67. catch (TaskCanceledException)
  68. {
  69. return Error<List<CpuCgResDto>>($"CPU参估超时({dto.smpPositions.Count}个突发)");
  70. }
  71. }
  72. /// <summary>
  73. /// 参估画图
  74. /// </summary>
  75. /// <returns></returns>
  76. [HttpPost]
  77. public async Task<AjaxResult<List<ImageResultDto>>> DrawImage(CpuCgDto dto)
  78. {
  79. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
  80. dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr);
  81. dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr);
  82. var res = await HttpHelper.PostRequestAsync<List<ImageResultDto>>(svr.BaseHttpAddr + "CpuCg/DrawImage", dto);
  83. return res;
  84. }
  85. /// <summary>
  86. /// GPU参估计算(需要先上传文件)
  87. /// </summary>
  88. /// <param name="dto">GPU参估参数</param>
  89. /// <returns></returns>
  90. [HttpPost]
  91. public async Task<AjaxResult<List<GpuCgResponseDto>>> GpuCgCalc(GpuCgRequestDto dto)
  92. {
  93. try
  94. {
  95. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.GpuCgSvr);
  96. dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr);
  97. dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr);
  98. var res = await HttpHelper.PostRequestAsync<List<GpuCgResponseDto>>(svr.BaseHttpAddr + "GpuCg/Calc", dto);
  99. return res;
  100. }
  101. catch (TaskCanceledException)
  102. {
  103. return Error<List<GpuCgResponseDto>>($"GPU参估超时");
  104. }
  105. }
  106. /// <summary>
  107. /// 信号检测(支持DAMA、IBS、能量检测)(需要先上传文件,会根据信号带宽自动对文件进行滤波)
  108. /// </summary>
  109. /// <param name="dto">信号检测参数</param>
  110. /// <returns></returns>
  111. [HttpPost]
  112. public async Task<AjaxResult<List<DetectResDto>>> DetectCalc(DetectDto dto)
  113. {
  114. try
  115. {
  116. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
  117. dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr);
  118. var res = await HttpHelper.PostRequestAsync<List<DetectResDto>>(svr.BaseHttpAddr + "Check/Calc", dto);
  119. if (res.code != 200)
  120. {
  121. return Error<List<DetectResDto>>(res.msg);
  122. }
  123. if (dto.SigProc && res.data.Any())
  124. {
  125. SignalProcDto procDto = new SignalProcDto()
  126. {
  127. File = dto.file1,
  128. Fs = (long)dto.fsHz,
  129. Smps = res.data.Select(p => new SmpPosition() { smpStart = p.Start, smpCount = p.Length }).ToList(),
  130. };
  131. var procRes = await HttpHelper.PostRequestAsync<List<SignalProcResDto>>(svr.BaseHttpAddr + "Check/SignalProc", procDto);
  132. if (procRes.data == null || res.data.Count != procRes.data.Count)
  133. {
  134. throw new Exception($"信号识别结果个数和检测结果个数不一致");
  135. }
  136. for (int i = 0; i < res.data.Count; i++)
  137. {
  138. res.data[i].ModRate = procRes.data[i].Rate;
  139. res.data[i].ModType = procRes.data[i].ModType.GetEnumDisplayName();
  140. res.data[i].FfcHz = procRes.data[i].Ffc;
  141. res.data[i].Snr = procRes.data[i].Snr;
  142. }
  143. }
  144. return res;
  145. }
  146. catch (TaskCanceledException)
  147. {
  148. return Error<List<DetectResDto>>($"信号检测超时");
  149. }
  150. }
  151. /// <summary>
  152. /// 信号识别(调制类型、调制速率、频偏)
  153. /// </summary>
  154. /// <param name="dto">信号检测参数</param>
  155. /// <returns></returns>
  156. [HttpPost]
  157. public async Task<AjaxResult<List<SignalProcResDto>>> SignalProc(SignalProcDto dto)
  158. {
  159. try
  160. {
  161. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
  162. dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr);
  163. var res = await HttpHelper.PostRequestAsync<List<SignalProcResDto>>(svr.BaseHttpAddr + "Check/SignalProc", dto);
  164. return res;
  165. }
  166. catch (TaskCanceledException)
  167. {
  168. return Error<List<SignalProcResDto>>($"信号识别超时");
  169. }
  170. }
  171. /// <summary>
  172. /// 滤波处理(滤波处理文件)
  173. /// </summary>
  174. /// <param name="dto">滤波处理参数</param>
  175. /// <returns></returns>
  176. [HttpPost]
  177. public async Task<AjaxResult<SigFilterResponseDto>> SigFilterProc(SigFilterDto dto)
  178. {
  179. try
  180. {
  181. if (dto.BandHz <= 0 || dto.BandHz > dto.FsHz)
  182. {
  183. dto.BandHz = 25000;
  184. //return new AjaxResult<SigFilterResponseDto>() { code = 200, data = new SigFilterResponseDto() { File = dto.File } };
  185. }
  186. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
  187. dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr);
  188. var res = await HttpHelper.PostRequestAsync<SigFilterResponseDto>(svr.BaseHttpAddr + "Check/SigFilterProc", dto);
  189. await HttpHelper.DownloadFileAsync(svr.BaseHttpAddr, res.data.File, GetLocalFile(res.data.File));
  190. return res;
  191. }
  192. catch (TaskCanceledException)
  193. {
  194. return Error<SigFilterResponseDto>($"信号滤波超时");
  195. }
  196. }
  197. /// <summary>
  198. /// 文件变采样(需要先上传文件)
  199. /// </summary>
  200. /// <param name="dto"></param>
  201. /// <returns></returns>
  202. [HttpPost]
  203. public async Task<AjaxResult<ResampleResponseDto>> Resample(ResampleRequestDto dto)
  204. {
  205. var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
  206. dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr);
  207. var res = await HttpHelper.PostRequestAsync<ResampleResponseDto>(svr.BaseHttpAddr + "Check/Resample", dto);
  208. await HttpHelper.DownloadFileAsync(svr.BaseHttpAddr, res.data.File, GetLocalFile(res.data.File));
  209. return res;
  210. }
  211. }
  212. }