123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829 |
- using System;
- using System.Configuration;
- using System.Data.Entity;
- using System.Threading.Tasks;
- using System.Web.Http;
- using XdCxRhDW.Api;
- using XdCxRhDW.App.Model;
- using XdCxRhDW.Dto;
- using XdCxRhDW.Entity;
- using XdCxRhDW.Repostory;
- using XdCxRhDW.WebApi;
- namespace XdCxRhDW.App.Controllers
- {
- /// <summary>
- /// 定位功能相关接口
- /// </summary>
- public class PosController : BaseController
- {
- #region 两星一地定位
- /// <summary>
- /// 两星一地无参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosX2D1NoParAsync(X2D1NoParPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到两星一地无参定位(含星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- });
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.SxDto, 10),
- Dfo1 = Math.Round(dto.SxDfo, 10),
- Snr1 = Math.Round(dto.SxSnr, 1),
- DtoCdb = Math.Round(dto.XdDto, 10),
- DfoCdb = Math.Round(dto.XdDfo, 10),
- SnrCdb = Math.Round(dto.XdSnr, 1),
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- TaskID = runTask.ID,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- MainVx = dto.MainVX,
- MainVy = dto.MainVY,
- MainVz = dto.MainVZ,
- Adja1Vx = dto.AdjaVX,
- Adja1Vy = dto.AdjaVY,
- Adja1Vz = dto.AdjaVZ,
- TarFreqUp = dto.FreqUp,
- TarFreqDown = dto.FreqDown,
- });
- double[] res;
- if (ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"] != null
- && ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"].ToLower() != "false"
- && ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"].ToLower() != "0")
- {
- res = PosApi.X2D1_PosNoRef_ZL(cgRes, StationRes);
- }
- else
- {
- res = PosApi.X2D1_PosNoRef(cgRes, StationRes, dto.CalcConfidence);
- }
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X2D1NoRef,
- };
- if (dto.TheoryDfoCalc && posRes.PosLon != 999)
- posRes.TargetState = TheoryDtoDfoApi.TheoryDfo(cgRes, StationRes, posRes, SysConfig.Config.YDPZThreshold);
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- /// <summary>
- /// 两星一地无参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosX2D1NoXlNoParAsync(X2D1NoXlNoParlPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到两星一地无参定位(无星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- var xl1 = await XlRepository.GetLatestAsync(dto.MainCode, dto.SigTime);
- if (xl1 == null)
- {
- await LogHelper.Error($"系统缺少编号{dto.MainCode}卫星的星历!");
- return Error<PosResDto>($"系统缺少编号{dto.MainCode}卫星的星历!");
- }
- await LogHelper.Info($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");
- var xl2 = await XlRepository.GetLatestAsync(dto.AdjaCode, dto.SigTime);
- if (xl2 == null)
- {
- await LogHelper.Error($"系统缺少编号{dto.AdjaCode}卫星的星历!");
- return Error<PosResDto>($"系统缺少编号{dto.AdjaCode}卫星的星历!");
- }
- await LogHelper.Info($"卫星{dto.AdjaCode}使用发布时刻为{xl2.TimeUTC:yyyyMMddHHmmss}的星历进行推算");
- var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);
- if (ephMain.code != 200)
- {
- await LogHelper.Error($"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}");
- return Error<PosResDto>($"推算卫星{dto.MainCode}的ECEF星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };
- var ephAdja = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);
- if (ephAdja.code != 200)
- {
- await LogHelper.Error($"推算卫星{dto.AdjaCode}的ECEF星历出错.{ephAdja.msg}");
- return Error<PosResDto>($"推算卫星{dto.AdjaCode}的ECEF星历出错");
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- });
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.SxDto, 10),
- Dfo1 = Math.Round(dto.SxDfo, 10),
- Snr1 = Math.Round(dto.SxSnr, 1),
- DtoCdb = Math.Round(dto.XdDto, 10),
- DfoCdb = Math.Round(dto.XdDfo, 10),
- SnrCdb = Math.Round(dto.XdSnr, 1),
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainXlTime = ephMain.data.TleTime,
- Adja1XlTime = ephAdja.data.TleTime,
- TaskID = runTask.ID,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja.data.X,
- Adja1Y = ephAdja.data.Y,
- Adja1Z = ephAdja.data.Z,
- MainVx = ephMain.data.VX,
- MainVy = ephMain.data.VY,
- MainVz = ephMain.data.VZ,
- Adja1Vx = ephAdja.data.VX,
- Adja1Vy = ephAdja.data.VY,
- Adja1Vz = ephAdja.data.VZ,
- TarFreqUp = dto.FreqUp,
- TarFreqDown = dto.FreqDown,
- });
- double[] res;
- if (ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"] != null
- && ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"].ToLower() != "false"
- && ConfigurationManager.AppSettings["UseNewPosX2D1NoRef"].ToLower() != "0")
- {
- res = PosApi.X2D1_PosNoRef_ZL(cgRes, StationRes);
- }
- else
- {
- res = PosApi.X2D1_PosNoRef(cgRes, StationRes, dto.CalcConfidence);
- }
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X2D1NoRef,
- };
- if (dto.TheoryDfoCalc && posRes.PosLon != 999)
- posRes.TargetState = TheoryDtoDfoApi.TheoryDfo(cgRes, StationRes, posRes, SysConfig.Config.YDPZThreshold);
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- #endregion
- #region 三星双时差定位
- /// <summary>
- /// 三星双时差无参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoNoParAsync(X3TwoDtoNoParPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X3TwoDto && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到三星双时差无参定位(含星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- });
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.Dto1, 10),
- Dfo1 = Math.Round(dto.Dfo1, 10),
- Snr1 = Math.Round(dto.Snr1, 1),
- Dto2 = Math.Round(dto.Dto2, 10),
- Dfo2 = Math.Round(dto.Dfo2, 10),
- Snr2 = Math.Round(dto.Snr2, 1),
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- TaskID = runTask.ID,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- MainVx = dto.MainVX,
- MainVy = dto.MainVY,
- MainVz = dto.MainVZ,
- Adja1X = dto.Adja1X,
- Adja1Y = dto.Adja1Y,
- Adja1Z = dto.Adja1Z,
- Adja1Vx = dto.Adja1VX,
- Adja1Vy = dto.Adja1VY,
- Adja1Vz = dto.Adja1VZ,
- Adja2X = dto.Adja2X,
- Adja2Y = dto.Adja2Y,
- Adja2Z = dto.Adja2Z,
- Adja2Vx = dto.Adja2VX,
- Adja2Vy = dto.Adja2VY,
- Adja2Vz = dto.Adja2VZ,
- TarFreqUp = dto.FreqUp,
- TarFreqDown = dto.FreqDown,
- });
- var res = PosApi.X3_PosNoRef(cgRes, StationRes, dto.CalcConfidence);
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X3TwoDtoNoRef,
- };
- if (dto.TheoryDfoCalc && posRes.PosLon != 999)
- posRes.TargetState = TheoryDtoDfoApi.TheoryDfo(cgRes, StationRes, posRes, SysConfig.Config.YDPZThreshold);
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- /// <summary>
- /// 三星双时差无参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoNoXlNoParAsync(X3TwoDtoNoXlNoParPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X3TwoDto && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到三星双时差无参定位(无星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- var xl1 = await XlRepository.GetLatestAsync(dto.MainCode, dto.SigTime);
- if (xl1 == null)
- {
- await LogHelper.Error($"系统缺少编号{dto.MainCode}卫星的星历!");
- return Error<PosResDto>($"系统缺少编号{dto.MainCode}卫星的星历!");
- }
- await LogHelper.Info($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");
- var xl2 = await XlRepository.GetLatestAsync(dto.Adja1Code, dto.SigTime);
- if (xl2 == null)
- {
- await LogHelper.Error($"系统缺少编号{dto.Adja1Code}卫星的星历!");
- return Error<PosResDto>($"系统缺少编号{dto.Adja1Code}卫星的星历!");
- }
- await LogHelper.Info($"卫星{dto.Adja1Code}使用发布时刻为{xl2.TimeUTC:yyyyMMddHHmmss}的星历进行推算");
- var xl3 = await XlRepository.GetLatestAsync(dto.Adja2Code, dto.SigTime);
- if (xl3 == null)
- {
- await LogHelper.Error($"系统缺少编号{dto.Adja2Code}卫星的星历!");
- return Error<PosResDto>($"系统缺少编号{dto.Adja2Code}卫星的星历!");
- }
- await LogHelper.Info($"卫星{dto.Adja2Code}使用发布时刻为{xl3.TimeUTC:yyyyMMddHHmmss}的星历进行推算");
- var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);
- if (ephMain.code != 200)
- {
- await LogHelper.Error($"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}");
- return Error<PosResDto>($"推算卫星{dto.MainCode}的ECEF星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };
- var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);
- if (ephAdja1.code != 200)
- {
- await LogHelper.Error($"推算卫星{dto.Adja1Code}的ECEF星历出错.{ephAdja1.msg}");
- return Error<PosResDto>($"推算卫星{dto.Adja1Code}的ECEF星历出错");
- }
- var XlCalcDto3 = new XlCalcDto() { tleStr = xl3.TwoLine, SigTime = dto.SigTime };
- var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto3);
- if (ephAdja2.code != 200)
- {
- await LogHelper.Error($"推算卫星{dto.Adja2Code}的ECEF星历出错.{ephAdja2.msg}");
- return Error<PosResDto>($"推算卫星{dto.Adja2Code}的ECEF星历出错");
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- });
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.Dto1, 10),
- Dfo1 = Math.Round(dto.Dfo1, 10),
- Snr1 = Math.Round(dto.Snr1, 1),
- Dto2 = Math.Round(dto.Dto2, 10),
- Dfo2 = Math.Round(dto.Dfo2, 10),
- Snr2 = Math.Round(dto.Snr2, 1),
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainXlTime = ephMain.data.TleTime,
- Adja1XlTime = ephAdja1.data.TleTime,
- Adja2XlTime = ephAdja2.data.TleTime,
- TaskID = runTask.ID,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- MainVx = ephMain.data.VX,
- MainVy = ephMain.data.VY,
- MainVz = ephMain.data.VZ,
- Adja1X = ephAdja1.data.X,
- Adja1Y = ephAdja1.data.Y,
- Adja1Z = ephAdja1.data.Z,
- Adja1Vx = ephAdja1.data.VX,
- Adja1Vy = ephAdja1.data.VY,
- Adja1Vz = ephAdja1.data.VZ,
- Adja2X = ephAdja2.data.X,
- Adja2Y = ephAdja2.data.Y,
- Adja2Z = ephAdja2.data.Z,
- Adja2Vx = ephAdja2.data.VX,
- Adja2Vy = ephAdja2.data.VY,
- Adja2Vz = ephAdja2.data.VZ,
- TarFreqUp = dto.FreqUp,
- TarFreqDown = dto.FreqDown,
- });
- var res = PosApi.X3_PosNoRef(cgRes, StationRes, dto.CalcConfidence);
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X3TwoDtoNoRef,
- };
- if (dto.TheoryDfoCalc && posRes.PosLon != 999)
- posRes.TargetState = TheoryDtoDfoApi.TheoryDfo(cgRes, StationRes, posRes, SysConfig.Config.YDPZThreshold);
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- #endregion
- #region 低轨单星双频差定位
- //(单星没有参考的概念)
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosLeX1ParAsync(LeoX1ParPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X1Leo && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到低轨单星带参定位(含星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动低轨定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.Dto1, 10),
- Dfo1 = Math.Round(dto.Dfo1, 10),
- Snr1 = Math.Round(dto.Snr1, 1),
- Dto2 = Math.Round(dto.Dto2, 10),
- Dfo2 = Math.Round(dto.Dfo2, 10),
- Snr2 = Math.Round(dto.Snr2, 1),
- StationResID = 0,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- TaskID = runTask.ID,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- MainVx = dto.MainVX,
- MainVy = dto.MainVY,
- MainVz = dto.MainVZ,
- Adja1X = dto.Adja1X,
- Adja1Y = dto.Adja1Y,
- Adja1Z = dto.Adja1Z,
- Adja1Vx = dto.Adja1VX,
- Adja1Vy = dto.Adja1VY,
- Adja1Vz = dto.Adja1VZ,
- Adja2X = dto.Adja2X,
- Adja2Y = dto.Adja2Y,
- Adja2Z = dto.Adja2Z,
- Adja2Vx = dto.Adja2VX,
- Adja2Vy = dto.Adja2VY,
- Adja2Vz = dto.Adja2VZ,
- TarFreqUp = dto.FreqUp,
- TarFreqDown = dto.FreqDown,
- });
- var res = LeoPosApi.X1_POS(cgRes, dto.FreqUp);
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X1Leo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- #endregion
- #region 低轨双星时频差带参定位
- [HttpPost]
- public async Task<AjaxResult<PosResDto>> PosLeX2ParAsync(LeoX2ParPosDto dto)
- {
- TaskInfo runTask;
- using (RHDWContext db = new RHDWContext())
- {
- if (dto.TaskID == null)
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group
- && p.PosType == EnumPosType.X1Leo && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- await LogHelper.Warning($"接收到低轨双星带参定位(含星历)参数,由于找不到执行中的任务忽略本次定位");
- return Error<PosResDto>($"多模式融合定位平台没有启动低轨定位任务");
- }
- }
- else
- {
- runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == dto.TaskID);
- if (runTask == null)
- {
- await LogHelper.Warning($"找不到任务,ID={dto.TaskID}");
- return Error<PosResDto>($"找不到ID={dto.TaskID}的任务");
- }
- }
- }
- using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
- {
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var ckRes = new CheckRes()
- {
- FileName = dto.CheckRes?.FileName,
- SmpStart = dto.CheckRes?.SmpStart,
- SmpCount = dto.CheckRes?.SmpCount,
- PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
- ModRate = dto.CheckRes?.ModRate,
- ModType = dto.CheckRes?.ModType,
- UserName = dto.CheckRes?.UserName,
- FfcHz = dto.CheckRes?.FfcHz,
- Snr = dto.CheckRes?.Snr
- };
- db.CheckRes.Add(ckRes);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = Math.Round(dto.Dto, 10),
- Dfo1 = Math.Round(dto.Dfo, 10),
- Snr1 = Math.Round(dto.Snr, 1),
- YbMainDto = Math.Round(dto.YbMainDto, 10),
- YbAdja1Dto = Math.Round(dto.YbAdjaDto, 10),
- YbMainDfo = Math.Round(dto.YbMainDfo, 10),
- YbAdja1Dfo = Math.Round(dto.YbAdjaDfo, 10),
- TarFreqUp = dto.TarFreqUp,
- TarFreqDown = dto.TarFreqDown,
- RefFreqUp = dto.RefFreqUp,
- RefFreqDown = dto.RefFreqDown,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- TaskID = runTask.ID,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- MainVx = dto.MainVx,
- MainVy = dto.MainVy,
- MainVz = dto.MainVz,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- Adja1Vx = dto.AdjaVx,
- Adja1Vy = dto.AdjaVy,
- Adja1Vz = dto.AdjaVz,
- });
- var res = LeoPosApi.X2_POS(cgRes, StationRes, dto.TarFreqUp, dto.RefFreqUp);
- PosRes posRes = new PosRes()
- {
- FreqUpHz = (long)cgRes.TarFreqUp.Value,
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- CheckResID = ckRes.ID,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- Confidence = (int)res[6],
- PosResType = EnumPosResType.X2Leo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
- return Success(MapDto(posRes));
- }
- }
- #endregion
- private PosResDto MapDto(PosRes res)
- {
- return new PosResDto()
- {
- ID = res.ID,
- FreqUpHz = res.FreqUpHz,
- SigTime = res.SigTime,
- TaskInfoID = res.TaskInfoID,
- TarName = res.TargetInfo?.TargetName,
- PosLon = res.PosLon,
- PosLat = res.PosLat,
- MirrLon = res.MirrLon,
- MirrLat = res.MirrLat,
- CheckType = res.CheckRes?.PosCheckType == null ? "" : res.CheckRes?.PosCheckType?.GetEnumDisplayName(),
- TargetState = (EnumTargetStateDto)res.TargetState,
- PosResType = (EnumPosResTypeDto)res.PosResType,
- Confidence = res.Confidence,
- };
- }
- private ModelPosRes MapModel(PosRes res)
- {
- return new ModelPosRes()
- {
- ID = res.ID,
- FreqUpHz = res.FreqUpHz,
- SigTime = res.SigTime,
- TaskInfoID = res.TaskInfoID,
- PosLon = res.PosLon,
- PosLat = res.PosLat,
- MirrLon = res.MirrLon,
- MirrLat = res.MirrLat,
- TargetState = res.TargetState,
- PosResType = res.PosResType,
- CgResID = res.CgResID,
- CheckRes = res.CheckRes,
- CheckResID = res.CheckResID,
- ColorKey = res.ColorKey,
- CreateTime = res.CreateTime,
- CxResID = res.CxResID,
- StationResID = res.StationResID,
- TargetInfo = res.TargetInfo,
- TargetInfoID = res.TargetInfoID,
- UpdateTime = res.UpdateTime,
- Confidence = res.Confidence,
- };
- }
- }
- }
|