//首先,选择在起始时刻所有满足条件的卫星,
        //查找这些卫星的最大高度角的位置(附近6小时内),选择距离远的,
        //查找其结束点高度角时刻,
        //继续遍历
        public PeriodPrn BuildOnePeriodPrnByCenterTop(Time startTime)
        {
            var endTime = startTime + SearchTimeSpan;

            List <String>    prnsString = GetStartPrns(startTime);
            List <TableCell> maxCells   = new List <TableCell>();

            foreach (var colName in prnsString)
            {
                if (SatElevationTable.MinusNext(colName, startTime) < 0) //方向必须朝上
                {
                    var max = SatElevationTable.GetFirstSlopeApproxTo(colName, CutOffAngle, startTime, false);

                    //   var max = SatElevationTable.GetMaxCell(colName, startTime, endTime);
                    maxCells.Add(max);
                }
            }
            if (maxCells.Count == 0)
            {
                return(null);
            }

            var longest = maxCells.OrderByDescending(m => m.RowNumber).First();

            SatelliteNumber selectedPrn = SatelliteNumber.Parse(longest.ColName);

            var endTimePeriod = (Time)SatElevationTable.GetIndexValue(longest.RowNumber);

            TimePeriod TimePeriod = new Geo.Times.TimePeriod(startTime, endTimePeriod);
            var        PeriodPrn  = new PeriodPrn(TimePeriod, selectedPrn);

            return(PeriodPrn);
        }
        /// <summary>
        /// 选择
        /// </summary>
        /// <returns></returns>
        public override PeriodPrnManager Select()
        {
            this.DetailResultTable = new ObjectTableStorage("DetailResultTableOfFlexible_" + CutOffAngle + "deg");

            var PeriodPrnManager = new PeriodPrnManager();

            var totalEndTime   = SatElevationTable.GetLastIndexValue <Time>();
            var firstStartTime = SatElevationTable.GetFirstIndexValue <Time>();

            var prevEndPeriodTime = firstStartTime;

            while (prevEndPeriodTime < totalEndTime)
            {
                // PeriodPrn PeriodPrn = BuildOnePeriodPrnByCenterTop2(prevEndPeriodTime);
                var PeriodPrn = BuildOnePeriodPrnByCenterTop(prevEndPeriodTime);

                if (PeriodPrn == null || PeriodPrn.TimePeriod.Span == 0)
                {
                    log.Error("无满足条件的时段。" + PeriodPrn);
                    break;
                }

                AddPeriodPrnToManager(PeriodPrnManager, PeriodPrn);

                prevEndPeriodTime = PeriodPrn.TimePeriod.End;
            }

            return(PeriodPrnManager);
        }
        private PeriodPrn BuildOnePeriodPrnByCenterTop2(Time startTime)
        {
            var endTime = startTime + SearchTimeSpan;

            List <String>    prnsString = GetStartPrns(startTime);
            List <TableCell> maxCells   = new List <TableCell>();

            foreach (var item in prnsString)
            {
                if (SatElevationTable.MinusNext(item, startTime) < 0) //方向必须朝上
                {
                    var max = SatElevationTable.GetMaxCell(item, startTime, endTime);
                    maxCells.Add(max);
                }
            }
            var longest = maxCells.FindAll(m => (double)m.Value > CutOffAngle).OrderByDescending(m => m.RowNumber).First();

            SatelliteNumber selectedPrn = SatelliteNumber.Parse(longest.ColName);
            //查找其结尾处,满足条件的时刻或历元
            var       startTime2    = (Time)SatElevationTable.GetIndexValue(longest.RowNumber);
            var       endTime2      = startTime2 + SearchTimeSpan;
            TableCell endCell       = SatElevationTable.GetCellApproxTo(longest.ColName, CutOffAngle, startTime2, endTime2);
            var       endTimePeriod = (Time)SatElevationTable.GetIndexValue(endCell.RowNumber);

            TimePeriod TimePeriod = new Geo.Times.TimePeriod(startTime, endTimePeriod);
            var        PeriodPrn  = new PeriodPrn(TimePeriod, selectedPrn);

            return(PeriodPrn);
        }
示例#4
0
        /// <summary>
        /// 将选择结果添加到管理器
        /// </summary>
        /// <param name="PeriodPrnManager"></param>
        /// <param name="PeriodPrn"></param>
        protected void AddPeriodPrnToManager(Gnsser.PeriodPrnManager PeriodPrnManager, PeriodPrn PeriodPrn)
        {
            DetailResultTable.NewRow();
            DetailResultTable.AddItem("Period", PeriodPrn.TimePeriod.ToString());
            DetailResultTable.AddItem("Span", PeriodPrn.TimePeriod.TimeSpan.TotalHours.ToString("0.00"));
            DetailResultTable.AddItem("Prn", PeriodPrn.Value);

            var statAngle = SatElevationTable.GetValue <double>(PeriodPrn.TimePeriod.Start, PeriodPrn.Value.ToString());
            var endAngle  = SatElevationTable.GetValue <double>(PeriodPrn.TimePeriod.End, PeriodPrn.Value.ToString());
            var maxAngle  = SatElevationTable.GetMaxValue(PeriodPrn.Value.ToString(), PeriodPrn.TimePeriod.Start, PeriodPrn.TimePeriod.End);

            DetailResultTable.AddItem("StartAngle", statAngle);
            DetailResultTable.AddItem("MaxAngle", maxAngle);
            DetailResultTable.AddItem("EndAngle", endAngle);
            DetailResultTable.EndRow();


            //如果与上次基准星一致,则扩展弧段
            if (IsExpandPeriodWhenSamePrn && PeriodPrnManager.Count > 0 && PeriodPrnManager.Last.Value == PeriodPrn.Value)
            {
                log.Debug("基准星 " + PeriodPrn.Value + "相同,扩展时段 " + PeriodPrnManager.Last.TimePeriod + " 到 " + PeriodPrn.TimePeriod.End);
                PeriodPrnManager.Last.TimePeriod.End = PeriodPrn.TimePeriod.End;
            }
            else
            {
                if (PeriodPrn.Value.SatelliteType == SatelliteType.U)
                {
                    int a = 0;
                }
                if (PeriodPrn.Value != null)
                {
                    PeriodPrnManager.Add(PeriodPrn);
                }
            }
        }
示例#5
0
        /// <summary>
        /// 选择
        /// </summary>
        /// <returns></returns>
        public override PeriodPrnManager Select()
        {
            this.DetailResultTable = new ObjectTableStorage("DetailResultTableOf_" + TableSatSelectorType + "_" + PeriodCount + "Count");

            var PeriodPrnManager = new PeriodPrnManager();

            var startTime  = (Time)SatElevationTable.GetIndexValue(0);
            var stepPeriod = TotalPeriodSpan / PeriodCount;

            for (int i = 0; i < PeriodCount; i++)
            {
                var        start      = startTime + TimeSpan.FromSeconds(i * stepPeriod);
                var        end        = start + TimeSpan.FromSeconds(stepPeriod);
                TimePeriod TimePeriod = new TimePeriod(start, end);

                BaseTableSatelliteSelector selector = null;
                switch (TableSatSelectorType)
                {
                case Gnsser.BaseSatSelectionType.MaxElevation:
                    selector = new TableElevationSatSelector(SatElevationTable, TimePeriod, CutOffAngle, false);
                    break;

                case Gnsser.BaseSatSelectionType.MaxCenterElevation:
                    selector = new TableElevationSatSelector(SatElevationTable, TimePeriod, CutOffAngle, true, 1);
                    break;

                case Gnsser.BaseSatSelectionType.MaxTimeSpan:
                    selector = new TableSpanSatSelector(SatElevationTable, TimePeriod, CutOffAngle);
                    break;
                }

                SatelliteNumber prn       = selector.Select();
                var             PeriodPrn = new PeriodPrn(TimePeriod, prn);

                this.AddPeriodPrnToManager(PeriodPrnManager, PeriodPrn);
            }
            return(PeriodPrnManager);
        }