using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Threading.Tasks; using DW5S.KxcApi; using DW5S.DTO; using DW5S.Repostory; using DW5S.WebApi; using Microsoft.AspNetCore.Mvc; using DW5S.Service; using Serilog; namespace DW5S.Controllers { /// /// 检测参估变采样识别相关接口 /// public class DetectCgController : BaseController { ILogger logger { get; set; } IUnitOfWork unitOfWork { get; set; } /// /// CPU参估计算(需要先上传文件) /// /// CPU参估参数 /// [HttpPost] public async Task> CpuCgCalc(CpuCgDto dto) { try { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr); dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr); dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync(svr.BaseHttpAddr + "CpuCg/Calc", dto); return res; } catch (TaskCanceledException) { return Error($"CPU参估超时"); } } /// /// CPU参估多个时隙的参估计算(需要先上传文件) /// /// CPU多时隙参估参数模型 /// 返回结果个数始终和传入的时隙个数相同 [HttpPost] public async Task>> CpuCgMultiCalc(CpuCgMultiDto dto) { try { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr); dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr); dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "CpuCg/MultiCalc", dto); if (res.code != 200) { return Error>(res.msg); } else { return Success(res.data); } } catch (TaskCanceledException) { return Error>($"CPU参估超时({dto.smpPositions.Count}个突发)"); } } /// /// 参估画图 /// /// [HttpPost] public async Task>> DrawImage(CpuCgDto dto) { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr); dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr); dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "CpuCg/DrawImage", dto); return res; } /// /// GPU参估计算(需要先上传文件) /// /// GPU参估参数 /// [HttpPost] public async Task>> GpuCgCalc(GpuCgRequestDto dto) { try { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.GpuCgSvr); dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr); dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "GpuCg/Calc", dto); return res; } catch (TaskCanceledException) { return Error>($"GPU参估超时"); } } /// /// 信号检测(支持DAMA、IBS、能量检测)(需要先上传文件,会根据信号带宽自动对文件进行滤波) /// /// 信号检测参数 /// [HttpPost] public async Task>> DetectCalc(DetectDto dto) { try { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr); dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "Check/Calc", dto); if (res.code != 200) { return Error>(res.msg); } if (dto.SigProc && res.data.Any()) { SignalProcDto procDto = new SignalProcDto() { File = dto.file1, Fs = (long)dto.fsHz, Smps = res.data.Select(p => new SmpPosition() { smpStart = p.Start, smpCount = p.Length }).ToList(), }; var procRes = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "Check/SignalProc", procDto); if (procRes.data == null || res.data.Count != procRes.data.Count) { throw new Exception($"信号识别结果个数和检测结果个数不一致"); } for (int i = 0; i < res.data.Count; i++) { res.data[i].ModRate = procRes.data[i].Rate; res.data[i].ModType = procRes.data[i].ModType.GetEnumDisplayName(); res.data[i].FfcHz = procRes.data[i].Ffc; res.data[i].Snr = procRes.data[i].Snr; } } return res; } catch (TaskCanceledException) { return Error>($"信号检测超时"); } } /// /// 信号识别(调制类型、调制速率、频偏) /// /// 信号检测参数 /// [HttpPost] public async Task>> SignalProc(SignalProcDto dto) { try { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr); dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "Check/SignalProc", dto); return res; } catch (TaskCanceledException) { return Error>($"信号识别超时"); } } /// /// 滤波处理(滤波处理文件) /// /// 滤波处理参数 /// [HttpPost] public async Task> SigFilterProc(SigFilterDto dto) { try { if (dto.BandHz <= 0 || dto.BandHz > dto.FsHz) { dto.BandHz = 25000; //return new AjaxResult() { code = 200, data = new SigFilterResponseDto() { File = dto.File } }; } var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr); dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync(svr.BaseHttpAddr + "Check/SigFilterProc", dto); await HttpHelper.DownloadWithNameAsync(res.data.File, GetLocalFile(res.data.File)); return res; } catch (TaskCanceledException) { return Error($"信号滤波超时"); } } /// /// 文件变采样(需要先上传文件) /// /// /// [HttpPost] public async Task> Resample(ResampleRequestDto dto) { var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr); dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr); var res = await HttpHelper.PostRequestAsync(svr.BaseHttpAddr + "Check/Resample", dto); await HttpHelper.DownloadWithNameAsync(res.data.File, GetLocalFile(res.data.File)); return res; } } }