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 DevExpress.Mvvm.Native; using XdCxRhDW.Api; using XdCxRhDW.Dto; using XdCxRhDW.Entity; using XdCxRhDW.Repostory; using XdCxRhDW.WebApi; namespace XdCxRhDW.App.Controllers { /// /// 误差椭圆相关接口 /// public class EllipseController : BaseController { /// /// 两星一地误差椭圆(带参) /// /// /// public async Task> X2D1(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[2] { dto.CdbLon, dto.CdbLat }; double[] refLoc = new double[2] { dto.RefLon, dto.RefLat }; var res = ErrEllipseHepler.ErrorEllipse2X1D(dto.PosLon, dto.PosLat, mainEcef, adjaEcef, cdbLoc, refLoc, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint, dto.Pe); return Success(res); }); } /// /// 两星一地误差椭圆(无参) /// /// /// public async Task> X2D1NoRef(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[2] { dto.CdbLon, dto.CdbLat }; var res = ErrEllipseHepler.ErrorEllipse2X1DNoRef(dto.PosLon, dto.PosLat, mainEcef, adjaEcef, cdbLoc, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint, dto.Pe); return Success(res); }); } /// /// 低轨单星误差椭圆(单星没有参考) /// /// /// public async Task> X1Leo(ErrorEllipseLeoX1Dto dto) { return await Task.Run(() => { ErrorEllipseX1Option option = new ErrorEllipseX1Option() { MsEph = dto.MsEph, NsEph1 = dto.NsEph1, NsEph2 = dto.NsEph2, SelectPoint = dto.SelectPoint, DfoErr = dto.DfoErr, EphPosErr = dto.EphPosErr, EphVelErr = dto.EphVelErr, fu = dto.fu, Pe = dto.Pe }; var res = LeoErrorEllipseHelper.ErrorEllipseLeoX1(option, dto.OutputErrPoint); return Success(res); }); } /// /// 低轨双星带参误差椭圆 /// /// /// public async Task> X2Leo(ErrorEllipseLeoX2Dto dto) { return await Task.Run(() => { ErrorEllipseX2Option option = new ErrorEllipseX2Option() { MsEph = dto.MsEph, NsEph = dto.NsEph, RefGeod = dto.RefGeod, SelectPoint = dto.SelectPoint, DtoErr = dto.DtoErrUs / 1e6, DfoErr = dto.DfoErr, EphPosErr = dto.EphPosErr, EphVelErr = dto.EphVelErr, fu1 = dto.fu1, fu2 = dto.fu2, Pe = dto.Pe }; var res = LeoErrorEllipseHelper.ErrorEllipseLeoX2(option, dto.OutputErrPoint); return Success(res); }); } /// /// 三星双时差带参误差椭圆(高轨和低轨均适用) /// /// /// public async Task> X3TwoDto(ErrEllipseX3Dto dto) { return await Task.Run(() => { double[] mainEcef = new double[3] { dto.MainX, dto.MainY, dto.MainZ }; double[] adja1Ecef = new double[3] { dto.Adja1X, dto.Adja1Y, dto.Adja1Z }; double[] adja2Ecef = new double[3] { dto.Adja2X, dto.Adja2Y, dto.Adja2Z }; double[] refLoc = new double[2] { dto.RefLon, dto.RefLat }; var res = ErrEllipseHepler.ErrorEllipseX3(dto.PosLon, dto.PosLat, mainEcef, adja1Ecef, adja2Ecef, refLoc, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint, dto.Pe); return Success(res); }); } /// /// 三星双时差无参误差椭圆(高轨和低轨均适用) /// /// /// public async Task> X3TwoDtoNoRef(ErrEllipseX3NoRefDto dto) { return await Task.Run(() => { double[] mainEcef = new double[3] { dto.MainX, dto.MainY, dto.MainZ }; double[] adja1Ecef = new double[3] { dto.Adja1X, dto.Adja1Y, dto.Adja1Z }; double[] adja2Ecef = new double[3] { dto.Adja2X, dto.Adja2Y, dto.Adja2Z }; var res = ErrEllipseHepler.ErrorEllipseX3NoRef(dto.PosLon, dto.PosLat, mainEcef, adja1Ecef, adja2Ecef, dto.DtoErrus, dto.EphErr, dto.OutputErrPoint, dto.Pe); return Success(res); }); } } }