X2D1PosHandle.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286
  1. using DevExpress.Utils.About;
  2. using DevExpress.XtraTreeList;
  3. using System;
  4. using System.Collections.Concurrent;
  5. using System.Collections.Generic;
  6. using System.Data.Entity;
  7. using System.Linq;
  8. using System.Security.Policy;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Documents;
  12. using XdCxRhDW.Dto;
  13. using XdCxRhDW.Entity;
  14. using XdCxRhDW.Repostory;
  15. namespace XdCxRhDW.App
  16. {
  17. public class X2D1PosItem
  18. {
  19. public X2D1PosItem(X2D1NoXlNoParlPosDto x2D1, DateTime date)
  20. {
  21. this.Dto = x2D1;
  22. this.CreateTime = date;
  23. this.IsDw = false;
  24. }
  25. public X2D1NoXlNoParlPosDto Dto { get; set; }
  26. public DateTime CreateTime { get; set; }
  27. public bool IsDw { get; set; }
  28. }
  29. /// <summary>
  30. /// 两星一地定位取参考
  31. /// </summary>
  32. public class X2D1PosHandle
  33. {
  34. public int TaskId;
  35. //多少分钟时间内的参考信号数据
  36. private double takeRefTimeSeconds;
  37. private bool isRuning = true;
  38. BlockingCollection<List<X2D1PosItem>> posItems = new BlockingCollection<List<X2D1PosItem>>();
  39. public X2D1PosHandle(int taskId, double takeRefTime)
  40. {
  41. takeRefTimeSeconds = takeRefTime * 60;//秒
  42. TaskId = taskId;
  43. StartMonitor();
  44. }
  45. public void StartMonitor()
  46. {
  47. Task.Run(async () =>
  48. {
  49. while (isRuning)
  50. {
  51. try
  52. {
  53. var X2D1PosItems = posItems.Take();
  54. var firstdto = X2D1PosItems.First().Dto;
  55. FixedStation fixedStation;
  56. int fixedStationId = firstdto.FixedStationId.HasValue ? firstdto.FixedStationId.Value : 0;
  57. using (RHDWContext db = new RHDWContext())
  58. {
  59. fixedStation = await db.FixedStation.FirstOrDefaultAsync(f => f.ID == fixedStationId);
  60. }
  61. List<X2D1NoXlNoParlPosDto> listNoRef = new List<X2D1NoXlNoParlPosDto>();
  62. List<X2D1NoXlPosDto> listRef = new List<X2D1NoXlPosDto>();
  63. foreach (var posItem in X2D1PosItems)
  64. {
  65. try
  66. {
  67. var dto = posItem.Dto;
  68. if (fixedStation == null)//没有固定站
  69. {
  70. posItem.IsDw = true;
  71. listNoRef.Add(dto);
  72. continue;
  73. }
  74. List<CgRes> cgResRefs = new List<CgRes>();
  75. using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
  76. {
  77. DateTime min = dto.SigTime.AddSeconds(-takeRefTimeSeconds);
  78. DateTime max = dto.SigTime.AddSeconds(takeRefTimeSeconds);
  79. //获取设定分钟之内的固定站数据
  80. 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();
  81. }
  82. List<CgRes> matchCgList = new List<CgRes>();
  83. cgResRefs.ForEach(c =>
  84. {
  85. if ((dto.SigTime - c.SigTime).TotalSeconds <= takeRefTimeSeconds)
  86. {
  87. matchCgList.Add(c);
  88. }
  89. });
  90. var cgOrderList = matchCgList.OrderBy(d => d.SigTime).ToList();
  91. var point1 = cgOrderList.Where(c => c.SigTime <= dto.SigTime).FirstOrDefault();
  92. var point2 = cgOrderList.Where(c => c.SigTime >= dto.SigTime).FirstOrDefault();
  93. if (point1 == null || point2 == null)//若参考频点未出结果,查找目标信号出
  94. {
  95. if ((DateTime.Now - posItem.CreateTime).TotalMinutes >= 2)//两分钟之内未出结果走无参
  96. {
  97. await LogHelper.Warning($"任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}参考未出结果超时");
  98. posItem.IsDw = true;
  99. listNoRef.Add(dto);
  100. continue;
  101. }
  102. bool isTarAny = false;
  103. using (RHDWPartContext db = RHDWPartContext.GetContext(dto.SigTime, true))
  104. {
  105. 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);
  106. }
  107. if (!isTarAny && (DateTime.Now - posItem.CreateTime).TotalMinutes < 2)//目标未出结果
  108. {
  109. posItem.IsDw = false;
  110. continue;
  111. }
  112. }
  113. if (point1 != null && point2 != null)
  114. {
  115. posItem.IsDw = true;
  116. //通过双星时差及超短波时差怎么计算参考信息的时差
  117. double refDto = LinearInterpolation.CalSigTimeDto(dto.SigTime, point1.SigTime, point2.SigTime, point1.Dto1.Value, point2.Dto1.Value);
  118. double refDtoCdb = LinearInterpolation.CalSigTimeDto(dto.SigTime, point1.SigTime, point2.SigTime, point1.DtoCdb.Value, point2.DtoCdb.Value);
  119. //执行两星一地有参定位
  120. X2D1NoXlPosDto X2D1NoXlPosDto = new X2D1NoXlPosDto()
  121. {
  122. SigTime = dto.SigTime,
  123. MainCode = dto.MainCode,
  124. AdjaCode = dto.AdjaCode,
  125. SxDto = dto.SxDto,
  126. XdDto = dto.XdDto,
  127. MainYbDto = refDto,
  128. AdjaYbDto = refDtoCdb,
  129. SatTxLon = dto.SatTxLon,
  130. SatTxLat = dto.SatTxLat,
  131. CdbTxLon = dto.CdbTxLon,
  132. CdbTxLat = dto.CdbTxLat,
  133. RefLon = fixedStation.Lon,
  134. RefLat = fixedStation.Lat,
  135. FreqDown = dto.FreqDown,
  136. FreqUp = dto.FreqUp,
  137. XdDfo = dto.XdDfo,
  138. XdSnr = dto.XdSnr,
  139. SxDfo = dto.SxDfo,
  140. SxSnr = dto.SxSnr,
  141. CalcConfidence = true,
  142. TheoryDfoCalc = true,
  143. TaskID = dto.TaskID,
  144. CheckRes = dto.CheckRes,
  145. };
  146. listRef.Add(X2D1NoXlPosDto);
  147. }
  148. }
  149. catch (Exception ex)
  150. {
  151. posItem.IsDw = false;
  152. await LogHelper.Error($"【取参考信号流程异常{ex.Message}", ex);
  153. }
  154. }
  155. var poslist = X2D1PosItems.Where(x => !x.IsDw);
  156. if (poslist.Count() > 0)
  157. {
  158. posItems.Add(poslist.ToList());
  159. }
  160. SendPos(listNoRef, listRef);
  161. }
  162. catch (Exception ex)
  163. {
  164. await LogHelper.Error($"【取参考信号流程异常{ex.Message}", ex);
  165. }
  166. }
  167. });
  168. }
  169. private void SendPos(List<X2D1NoXlNoParlPosDto> listNoRef, List<X2D1NoXlPosDto> listRef)
  170. {
  171. SendX2D1NoXlNoParAsync(listNoRef);
  172. SendX2D1RefAsync(listRef);
  173. }
  174. /// <summary>
  175. /// 发送两星一地无参定位
  176. /// </summary>
  177. /// <param name="dtos"></param>
  178. private void SendX2D1NoXlNoParAsync(List<X2D1NoXlNoParlPosDto> dtos)
  179. {
  180. Task.Run(async () =>
  181. {
  182. foreach (var dto in dtos)
  183. {
  184. try
  185. {
  186. dto.BeFindRef = false;
  187. dto.FixedStationId = null;
  188. var result = await HttpHelper.PostRequestAsync<PosResDto>(SysConfig.GetUrl("Pos/PosX2D1NoXlNoParAsync"), dto);
  189. if (result.code != 200)
  190. {
  191. await LogHelper.Error($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地无参定位失败{result.msg}");
  192. }
  193. else
  194. {
  195. await LogHelper.Info($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地无参定位完成{result.msg}");
  196. }
  197. }
  198. catch (Exception ex)
  199. {
  200. await LogHelper.Error($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地无参定位失败{ex.Message}");
  201. }
  202. }
  203. });
  204. }
  205. /// <summary>
  206. /// 发送两星一地无参定位
  207. /// </summary>
  208. /// <param name="dtos"></param>
  209. private void SendX2D1RefAsync(List<X2D1NoXlPosDto> dtos)
  210. {
  211. Task.Run(async () =>
  212. {
  213. foreach (var dto in dtos)
  214. {
  215. try
  216. {
  217. var result = await HttpHelper.PostRequestAsync<PosResDto>(SysConfig.GetUrl("Pos/PosX2D1NoXlAsync"), dto);
  218. if (result.code != 200)
  219. {
  220. await LogHelper.Error($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地定位失败{result.msg}");
  221. }
  222. else
  223. {
  224. await LogHelper.Info($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地定位完成{result.msg}");
  225. }
  226. }
  227. catch (Exception ex)
  228. {
  229. await LogHelper.Error($"找参考任务{dto.TaskID}-{dto.SigTime:yyyy-MM-dd HH:mm:ss}两星一地定位失败{ex.Message}");
  230. }
  231. }
  232. });
  233. }
  234. public void Append(List<X2D1NoXlNoParlPosDto> dtos)
  235. {
  236. DateTime dt = DateTime.Now;
  237. List<X2D1PosItem> list = new List<X2D1PosItem>();
  238. foreach (var dtoitem in dtos)
  239. {
  240. X2D1PosItem posItem = new X2D1PosItem(dtoitem, dt);
  241. list.Add(posItem);
  242. }
  243. bool ret = posItems.TryAdd(list);
  244. if (!ret)
  245. {
  246. LogHelper.Warning($"【任务{dtos.First().TaskID}】添加取参考Dto").GetAwaiter();
  247. }
  248. }
  249. public void Stop()
  250. {
  251. //当前任务停止处理
  252. isRuning = false;
  253. }
  254. }
  255. }