123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- 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
- {
- /// <summary>
- /// 误差椭圆相关接口
- /// </summary>
- public class EllipseController : BaseController
- {
- /// <summary>
- /// 两星一地误差椭圆(带参)
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<AjaxResult<ErrEllipseResDto>> 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);
- });
- }
- /// <summary>
- /// 两星一地误差椭圆(无参)
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<AjaxResult<ErrEllipseResDto>> 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);
- });
- }
- /// <summary>
- /// 低轨单星带参误差椭圆
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<AjaxResult<ErrEllipseResDto>> X1Leo(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);
- });
- }
- /// <summary>
- /// 低轨双星带参误差椭圆
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<AjaxResult<ErrEllipseResDto>> X2Leo(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);
- });
- }
- /// <summary>
- /// 低轨三星带参误差椭圆
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<AjaxResult<ErrEllipseResDto>> X3Leo(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);
- });
- }
- }
- }
|