X2D1PosHandle.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. using DevExpress.Utils.About;
  2. using System;
  3. using System.Collections.Concurrent;
  4. using System.Collections.Generic;
  5. using System.Data.Entity;
  6. using System.Linq;
  7. using System.Security.Policy;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Documents;
  11. using XdCxRhDW.Dto;
  12. using XdCxRhDW.Entity;
  13. using XdCxRhDW.Repostory;
  14. namespace XdCxRhDW.App
  15. {
  16. public class X2D1PosItem
  17. {
  18. public X2D1PosItem(X2D1NoXlNoParlPosDto x2D1)
  19. {
  20. this.Dto = x2D1;
  21. this.CreateTime = DateTime.Now;
  22. }
  23. public X2D1NoXlNoParlPosDto Dto { get; set; }
  24. public DateTime CreateTime { get; set; }
  25. }
  26. /// <summary>
  27. /// 两星一地定位取参考
  28. /// </summary>
  29. public class X2D1PosHandle
  30. {
  31. public int TaskId;
  32. //多少分钟时间内的参考信号数据
  33. private double takeRefTimeSeconds;
  34. private bool isRuning = true;
  35. BlockingCollection<X2D1PosItem> posItems = new BlockingCollection<X2D1PosItem>();
  36. public X2D1PosHandle(int taskId, double takeRefTime)
  37. {
  38. takeRefTimeSeconds = takeRefTime * 60;//秒
  39. TaskId = taskId;
  40. StartMonitor();
  41. }
  42. public void StartMonitor()
  43. {
  44. Task.Run(async () =>
  45. {
  46. while (isRuning)
  47. {
  48. try
  49. {
  50. var posItem = posItems.Take();
  51. var dto = posItem.Dto;
  52. FixedStation fixedStation;
  53. int fixedStationId = dto.FixedStationId.HasValue ? dto.FixedStationId.Value : 0;
  54. using (RHDWContext db = new RHDWContext())
  55. {
  56. fixedStation = await db.FixedStation.FirstOrDefaultAsync(f => f.ID == fixedStationId);
  57. }
  58. if (fixedStation == null)//没有固定站
  59. {
  60. SendX2D1NoXlNoParAsync(dto);
  61. continue;
  62. }
  63. using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
  64. {
  65. DateTime min = dto.SigTime.AddSeconds(-takeRefTimeSeconds);
  66. DateTime max = dto.SigTime.AddSeconds(takeRefTimeSeconds);
  67. //获取设定分钟之内的固定站数据
  68. var cgResRefs = await db.CgRes.Where(m => m.TaskID == dto.TaskID && m.FixedStationID == dto.FixedStationId && m.SigTime >= min && m.SigTime <= max).OrderBy(d => d.SigTime).ToListAsync();
  69. List<CgRes> matchCgList = new List<CgRes>();
  70. cgResRefs.ForEach(c =>
  71. {
  72. if ((dto.SigTime - c.SigTime).TotalSeconds <= takeRefTimeSeconds)
  73. {
  74. matchCgList.Add(c);
  75. }
  76. });
  77. var cgOrderList = matchCgList.OrderBy(d => d.SigTime).ToList();
  78. var point1 = cgOrderList.Where(c => c.SigTime <= dto.SigTime).FirstOrDefault();
  79. var point2 = cgOrderList.Where(c => c.SigTime >= dto.SigTime).FirstOrDefault();
  80. if (point1 == null || point2 == null)//若参考频点未出结果,查找目标信号出
  81. {
  82. bool isTarAny = await db.CgRes.AnyAsync(m => m.TaskID == dto.TaskID && !m.FixedStationID.HasValue && m.TarFreqUp.HasValue && m.TarFreqUp.Value == fixedStation.FreqUpHz && m.SigTime >= dto.SigTime);
  83. if (!isTarAny && (DateTime.Now - posItem.CreateTime).TotalMinutes < 2)//目标未出结果
  84. {
  85. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}目标未出结果");
  86. posItems.Add(posItem);
  87. continue;
  88. }
  89. else if (!isTarAny && (DateTime.Now - posItem.CreateTime).TotalMinutes >= 2)//目标两分钟之内未出结果走无参
  90. {
  91. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}目标未出结果超时");
  92. SendX2D1NoXlNoParAsync(dto);
  93. continue;
  94. }
  95. }
  96. if (point1 != null && point2 != null)
  97. {
  98. //通过双星时差及超短波时差怎么计算参考信息的时差
  99. double refDto = LinearInterpolation.CalSigTimeDto(dto.SigTime, point1.SigTime, point2.SigTime, point1.Dto1.Value, point2.Dto1.Value);
  100. double refDtoCdb = LinearInterpolation.CalSigTimeDto(dto.SigTime, point1.SigTime, point2.SigTime, point1.DtoCdb.Value, point2.DtoCdb.Value);
  101. //执行两星一地有参定位
  102. X2D1NoXlPosDto X2D1NoXlPosDto = new X2D1NoXlPosDto()
  103. {
  104. SigTime = dto.SigTime,
  105. MainCode = dto.MainCode,
  106. AdjaCode = dto.AdjaCode,
  107. SxDto = dto.SxDto,
  108. XdDto = dto.XdDto,
  109. MainYbDto = refDto,
  110. AdjaYbDto = refDtoCdb,
  111. SatTxLon = dto.SatTxLon,
  112. SatTxLat = dto.SatTxLat,
  113. CdbTxLon = dto.CdbTxLon,
  114. CdbTxLat = dto.CdbTxLat,
  115. RefLon = fixedStation.Lon,
  116. RefLat = fixedStation.Lat,
  117. FreqDown = dto.FreqDown,
  118. FreqUp = dto.FreqUp,
  119. XdDfo = dto.XdDfo,
  120. XdSnr = dto.XdSnr,
  121. SxDfo = dto.SxDfo,
  122. SxSnr = dto.SxSnr,
  123. CalcConfidence = true,
  124. TheoryDfoCalc = true,
  125. TaskID = dto.TaskID,
  126. };
  127. var result = await HttpHelper.PostRequestAsync<PosResDto>(SysConfig.GetUrl("Pos/PosX2D1NoXlAsync"), X2D1NoXlPosDto);
  128. if (result.code != 200)
  129. {
  130. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地定位失败{result.msg}");
  131. }
  132. else
  133. {
  134. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地定位完成{result.msg}");
  135. }
  136. }
  137. }
  138. }
  139. catch (Exception ex)
  140. {
  141. await LogHelper.Error($"【取参考信号流程异常{ex.Message}", ex);
  142. }
  143. }
  144. });
  145. }
  146. /// <summary>
  147. /// 发送两星一地无参定位
  148. /// </summary>
  149. /// <param name="dto"></param>
  150. private async void SendX2D1NoXlNoParAsync(X2D1NoXlNoParlPosDto dto)
  151. {
  152. dto.BeFindRef = false;
  153. dto.FixedStationId = null;
  154. var result = await HttpHelper.PostRequestAsync<PosResDto>(SysConfig.GetUrl("Pos/PosX2D1NoXlNoParAsync"), dto);
  155. if (result.code != 200)
  156. {
  157. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地无参定位失败{result.msg}");
  158. }
  159. else
  160. {
  161. Serilog.Log.Information($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地无参定位完成{result.msg}");
  162. }
  163. }
  164. public void Append(X2D1NoXlNoParlPosDto dto)
  165. {
  166. X2D1PosItem posItem = new X2D1PosItem(dto);
  167. bool ret = posItems.TryAdd(posItem);
  168. if (!ret)
  169. {
  170. Serilog.Log.Information($"【任务{dto.TaskID}】添加取参考Dto");
  171. }
  172. }
  173. public void Stop()
  174. {
  175. //当前任务停止处理
  176. isRuning = false;
  177. }
  178. }
  179. }