using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using System.Web.Http;
using DevExpress.Data.Svg;
using XdCxRhDW.Api;
using XdCxRhDW.Dto;
using XdCxRhDW.Entity;
using XdCxRhDW.Repostory;
using XdCxRhDW.WebApi;
namespace XdCxRhDW.App.Controllers
{
///
/// 检测参估变采样识别相关接口
///
public class DetectCgController : BaseController
{
///
/// CPU参估计算(需要先上传文件)
///
/// CPU参估参数
///
[HttpPost]
public async Task> CpuCgCalc(CpuCgDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync(svr.BaseHttpAddr + "CpuCg/Calc", dto, dto.TimeoutSeconds);
return res;
}
///
/// CPU参估多个时隙的参估计算(需要先上传文件)
///
/// CPU多时隙参估参数模型
/// 返回结果个数始终和传入的时隙个数相同
[HttpPost]
public async Task>> CpuCgMultiCalc(CpuCgMultiDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "CpuCg/MultiCalc", dto, dto.TimeoutSeconds);
return res;
}
///
/// 参估画图
///
///
[HttpPost]
public async Task>> DrawImage(CpuCgDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CpuCgSvr);
dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "CpuCg/DrawImage", dto, dto.TimeoutSeconds);
return res;
}
///
/// GPU参估计算(需要先上传文件)
///
/// GPU参估参数
///
[HttpPost]
public async Task>> GpuCgCalc(GpuCgRequestDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.GpuCgSvr);
dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
dto.file2 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file2), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "GpuCg/Calc", dto, dto.TimeoutSeconds);
return res;
}
///
/// 信号检测(支持DAMA、IBS、能量检测)(需要先上传文件)
///
/// 信号检测参数
///
[HttpPost]
public async Task>> DetectCalc(DetectDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
dto.file1 = await HttpHelper.UploadFileAsync(GetLocalFile(dto.file1), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync>(svr.BaseHttpAddr + "Check/Calc", dto, dto.TimeoutSeconds);
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;
}
///
/// 信号识别(调制类型、调制速率、频偏)
///
/// 信号检测参数
///
[HttpPost]
public async Task>> SignalProc(SignalProcDto 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/SignalProc", dto);
return res;
}
///
/// 文件变采样(需要先上传文件)
///
///
///
public async Task> Resample(ResampleRequestDto dto)
{
var svr = ServerContext.Instance.GetRandomOne(EnumSvrType.CheckSvr);
dto.File = await HttpHelper.UploadFileAsync(GetLocalFile(dto.File), svr.BaseHttpAddr, timeoutSeconds: dto.TimeoutSeconds);
var res = await HttpHelper.PostRequestAsync(svr.BaseHttpAddr + "Check/Resample", dto, dto.TimeoutSeconds);
await HttpHelper.DownloadFileAsync(svr.BaseHttpAddr, res.data.File, GetLocalFile(res.data.File), dto.TimeoutSeconds);
return res;
}
///
/// 两星一地误差椭圆(带参)
///
///
///
public async Task> ErrorEllipse2X1D(ErrEllipseX2D1Dto dto)
{
return await Task.Run(() =>
{
double[] mainEcef = new double[3] { dto.MainX, dto.MainY, dto.MainZ };
double[] adjaEcef = new double[3] { dto.AdjaX, dto.AdjaY, dto.AdjaZ };
double[] cdbLoc = new double[3] { dto.CdbLon, dto.CdbLat, 0 };
double[] refLoc = new double[3] { dto.RefLon, dto.RefLat, 0 };
var res = ErrEllipseHepler.ErrorEllipse2X1D(dto.PosLon, dto.PosLat, mainEcef, adjaEcef, cdbLoc, refLoc, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint);
return Success(res);
});
}
///
/// 两星一地误差椭圆(无参)
///
///
///
public async Task> ErrorEllipse2X1DNoRef(ErrEllipseX2D1NoRefDto dto)
{
return await Task.Run(() =>
{
double[] mainEcef = new double[3] { dto.MainX, dto.MainY, dto.MainZ };
double[] adjaEcef = new double[3] { dto.AdjaX, dto.AdjaY, dto.AdjaZ };
double[] cdbLoc = new double[3] { dto.CdbLon, dto.CdbLat, 0 };
var res = ErrEllipseHepler.ErrorEllipse2X1DNoRef(dto.PosLon, dto.PosLat, mainEcef, adjaEcef, cdbLoc, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint);
return Success(res);
});
}
///
/// 低轨单星带参误差椭圆
///
///
///
public async Task> ErrorEllipseX1Leo(ErrorEllipseLeoX1Dto dto)
{
return await Task.Run(() =>
{
ErrorEllipseX1Option option = new ErrorEllipseX1Option();
option.MsEph = dto.MsEph;
option.NsEph1 = dto.NsEph1;
option.NsEph2 = dto.NsEph2;
option.SelectPoint = dto.SelectPoint;
option.DfoErr = dto.DfoErr;
option.EphPosErr = dto.EphPosErr;
option.EphVelErr = dto.EphVelErr;
option.fu = dto.fu;
option.Pe = dto.Pe;
var res = LeoErrorEllipseHelper.ErrorEllipseLeoX1(option,dto.OutputErrPoint);
return Success(res);
});
}
///
/// 低轨双星带参误差椭圆
///
///
///
public async Task> ErrorEllipseX2Leo(ErrorEllipseLeoX2Dto dto)
{
return await Task.Run(() =>
{
ErrorEllipseX2Option option = new ErrorEllipseX2Option();
option.MsEph = dto.MsEph;
option.NsEph = dto.NsEph;
option.RefGeod = dto.RefGeod;
option.SelectPoint = dto.SelectPoint;
option.DtoErr = dto.DtoErr;
option.DfoErr = dto.DfoErr;
option.EphPosErr = dto.EphPosErr;
option.EphVelErr = dto.EphVelErr;
option.fu1 = dto.fu1;
option.fu2 = dto.fu2;
option.Pe = dto.Pe;
var res = LeoErrorEllipseHelper.ErrorEllipseLeoX2(option, dto.OutputErrPoint);
return Success(res);
});
}
///
/// 低轨三星带参误差椭圆
///
///
///
public async Task> ErrorEllipseX3Leo(ErrorEllipseLeoX3Dto dto)
{
return await Task.Run(() =>
{
ErrorEllipseX3Option option = new ErrorEllipseX3Option();
option.MsEph = dto.MsEph;
option.NsEph1 = dto.NsEph1;
option.NsEph2 = dto.NsEph2;
option.RefGeod = dto.RefGeod;
option.SelectPoint = dto.SelectPoint;
option.DtoErr = dto.DtoErr;
option.DfoErr = dto.DfoErr;
option.EphPosErr = dto.EphPosErr;
option.EphVelErr = dto.EphVelErr;
option.fu1 = dto.fu1;
option.fu2 = dto.fu2;
option.Pe = dto.Pe;
var res = LeoErrorEllipseHelper.ErrorEllipseLeoX3(option, dto.OutputErrPoint);
return Success(res);
});
}
}
}