当前位置: 首页>>代码示例>>C#>>正文


C# Series.Copy方法代码示例

本文整理汇总了C#中Series.Copy方法的典型用法代码示例。如果您正苦于以下问题:C# Series.Copy方法的具体用法?C# Series.Copy怎么用?C# Series.Copy使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Series的用法示例。


在下文中一共展示了Series.Copy方法的14个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: MonthlyToDailyConversion

 public MonthlyToDailyConversion(Series observedDaily, Series monthly )
 {
     this.daily = observedDaily.Copy();
     this.monthly = monthly;
     MedianOnly = false;
     FillMissingWithZero = true;
 }
开发者ID:usbr,项目名称:Pisces,代码行数:7,代码来源:MonthlyToDailyConversion.cs

示例2: CipolettiWeir

 public static Series CipolettiWeir(Series head, double length)
 {
     var s = new Series();
     var h = head.Copy();
     h.RemoveMissing(true);
     s = Math.Pow(Math.Max(h, 0.0), 1.5) * length * 3.367;
     return s;
 }
开发者ID:usbr,项目名称:Pisces,代码行数:8,代码来源:Math.Hydromet.cs

示例3: GenericWeir

 public static Series GenericWeir(Series head,double offset, double width_factor, double exponent)
 {
     double shift = Convert.ToDouble(head.Properties.Get("shift", "0"));
     var s = new Series();
     var h = head.Copy();
     h.RemoveMissing(true);
     h = h + offset + shift;
     s = Math.Pow(Math.Max(h,0), exponent) * width_factor;
     return s;
 }
开发者ID:usbr,项目名称:Pisces,代码行数:10,代码来源:Math.Hydromet.cs

示例4: ConstantShift

        public static Series ConstantShift(Series h)
        {
            double shift = Convert.ToDouble(h.Properties.Get("shift", "0"));
            var rval = h.Copy();
            rval.RemoveMissing();
            rval = rval * 0.0;
            rval = rval + shift;

            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:10,代码来源:Math.Hydromet.cs

示例5: InterpolateWithStyle

        public static Series InterpolateWithStyle(Series sReal, Series sEst, params string[] dates)
        {
            var dateArray = getDates(dates);
            Series sOut = sEst.Copy();
            for (int i = 0; i < dateArray.Count; i = i + 2)
            {
                DateTime t1 = dateArray[i];
                DateTime t2 = dateArray[i + 1];
                Series sOuti = InterpolateWithStyleMain(sReal, sOut, t1, t2);
                sOut = Reclamation.TimeSeries.Math.Merge(sOuti, sOut);

                double sum1 = sEst.Values.Sum();
                double sum2 = sOut.Values.Sum();
                Console.WriteLine("Date Range " + t1.ToShortDateString() + " - " + t2.ToShortDateString() + " Processed.");
                Console.WriteLine("Flow Balance Check || Original Flow Sum:" + sum1 + "    Interpolated Flow Sum: " + sum2);
            }
            // Label interpolated series
            sOut.Name = sEst.Name + "_Interp";
            sOut.Units = sEst.Units;
            sOut.Provider = "Series";
            return sOut;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:22,代码来源:Math.Estimation.cs

示例6: Quality

        public static Series Quality(Series s, double lowLimit, double highLimit)
        {
            Series rval = s.Copy();
            for (int i = 0; i < rval.Count; i++)
            {
                Point pt = rval[i];

                if (!pt.IsMissing)
                {
                    //pt.Value += d;
                    rval[i] = pt;
                }
            }
            ///Here, we're going to take the bad data and make it good data
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:16,代码来源:Math.Estimation.cs

示例7: RectangularContractedWeir

 public static Series RectangularContractedWeir(Series head, double length)
 {
     var s = new Series();
     var h = head.Copy();
     h.RemoveMissing(true);
     s = (h * -.2 + length) * 3.33 * Math.Pow(Math.Max(h, 0.0), 1.5);
     return s;
 }
开发者ID:usbr,项目名称:Pisces,代码行数:8,代码来源:Math.Hydromet.cs

示例8: VerifyWithMonthlyVolume

 /// <summary>
 /// verify if the monthly data agrees with estimated daily
 /// adjust if we are not within 10%
 /// adjust using simple conversion of monthly
 /// </summary>
 /// <param name="monthly"></param>
 /// <param name="estimatedDaily">Series to be adjusted to match monthly</param>
 private static void VerifyWithMonthlyVolume(Series monthly, Series estimatedDaily)
 {
     var est_af = estimatedDaily.Copy();
     Math.Multiply(est_af, 1.98347);
     var m_af = Math.MonthlySum(est_af);
     var diff = (m_af - monthly) / m_af;
     diff = Math.Abs(diff);
     for (int i = 0; i < diff.Count; i++)
     {
         if (!monthly[i].IsMissing && diff[i].Value > .1) // 10% error
         { // proabaly zero value in exceedance lookup.
             // use monthly value instead of estimated value.
             DateTime t = monthly[i].DateTime;
             double avgFlow = monthly[i].Value / 1.98347 / DateTime.DaysInMonth(t.Year, t.Month);
             SetDailyValueForMonth(estimatedDaily, t.Year,t.Month, avgFlow,"monthly avg flow");
         }
     }
 }
开发者ID:usbr,项目名称:Pisces,代码行数:25,代码来源:MonthlyToDailyConversion.cs

示例9: Compare

        internal static Series Compare(Series series, double p, Func<double,double,double> f)
        {
            Series rval = series.Copy();
            for (int i = 0; i < rval.Count; i++)
            {
                Point pt = rval[i];
                var missing = new Point(pt.DateTime, Point.MissingValueFlag, PointFlag.Missing);
                if (pt.IsMissing  || Point.IsMissingValue(p))
                {
                    pt = missing;
                }
                else
                {
                  pt.Value = f(pt.Value,p);
                }

                rval[i] = pt;
            }
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:20,代码来源:Math.cs

示例10: Subtract

        /// <summary>
        /// s - d
        /// </summary>
        /// <param name="s"></param>
        /// <param name="d"></param>
        /// <returns></returns>
        internal static Series Subtract(Series s, double d)
        {
            Series rval = s.Copy();
            for (int i = 0; i < rval.Count; i++)
            {
                Point pt = rval[i];

                if (!pt.IsMissing)
                {
                    pt.Value -= d;
                    rval[i] = pt;
                }
            }
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:21,代码来源:Math.cs

示例11: Shift

        /// <summary>
        /// Shift the series in time 
        /// for Daily series timeOffset represents days
        /// for Monthly series timeOffset represntes months
        /// </summary>
        public static Series Shift(Series s, int timeOffset)
        {
            Series rval = s.Clone();
            if (timeOffset == 0)
                return s.Copy();

            for (int i = 0; i < s.Count; i++)
            {
                Point pt = s[i];
                pt.Flag = PointFlag.Edited;
                if (s.TimeInterval == TimeInterval.Daily)
            {
                    pt.DateTime = pt.DateTime.AddDays(timeOffset);
            }
                else if (s.TimeInterval == TimeInterval.Monthly)
                {// maintain end of month or first of month
                    bool eom = pt.DateTime.EndOfMonth() == pt.DateTime;
                    bool fom = pt.DateTime.FirstOfMonth() == pt.DateTime;

                    pt.DateTime = pt.DateTime.AddMonths(timeOffset);

                    if (eom)
                        pt.DateTime = pt.DateTime.EndOfMonth();

                    if (fom)
                        pt.DateTime = pt.DateTime.FirstOfMonth();
                }
                else
                {
                    throw new NotImplementedException("time offset not implemented for "+s.TimeInterval);
                }

                rval.Add(pt);
            }
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:41,代码来源:Math.cs

示例12: RoutingWithLags

        /// <summary>
        /// Routes input series using lag coefficients
        /// </summary>
        /// <param name="s"></param>
        /// <param name="lagCoefficients"></param>
        public static Series RoutingWithLags(Series s, double[] lagCoefficients)
        {
            double[] result = new double[s.Count];

            Series rval = s.Copy();
            int sz = s.Count;
            Math.Multiply(rval, 0);
            Series.CopyAttributes(s, rval);

            for (int i = 0; i < s.Count; i++)
            {
                double v = s[i].Value;

                for (int j = 0; j < lagCoefficients.Length && i+j <sz; j++)
                {
                    result[i + j] += v * lagCoefficients[j];
                }
            }

            // put results back into Series format.
            rval.Values = result;
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:28,代码来源:Math.cs

示例13: FillMissingWithZero

        /// <summary>
        /// Fills in missing data in the series with zeros.
        /// adds rows if necessary
        /// </summary>
        /// <param name="series"></param>
        /// <param name="t1"></param>
        /// <param name="t2"></param>
        public static Series FillMissingWithZero(Series s, DateTime t1, DateTime t2)
        {
            Series rval = s.Copy();
            Logger.WriteLine("FillMissingWithZero("+rval.Name+")");
            Logger.WriteLine("before fill s.Count=" + rval.Count);
            if (rval.TimeInterval != TimeInterval.Daily && rval.TimeInterval != TimeInterval.Monthly
                && rval.TimeInterval != TimeInterval.Hourly)
            {
                Logger.WriteLine(rval.TimeInterval.ToString() + " not supported in FillMissingWithZero");
                return rval;
            }

            if (t2 <= t1)
                return rval;

            DateTime t = t1;
            while (t <=t2)
            {
                int idx = rval.IndexOf(t);
                if (idx < 0)
                {
                    rval.Add(t, 0);
                }
                else
                {
                    var pt = rval[idx];
                    if (pt.IsMissing)
                    {
                        pt.Value = 0;
                        pt.Flag = PointFlag.Estimated;
                        rval[idx] = pt;
                    }
                }

                t = rval.IncremetDate(t);
            }
            Logger.WriteLine("after fill s.Count=" + rval.Count);
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:46,代码来源:Math.cs

示例14: Max

        /// <summary>
        /// computes the Max value 
        /// </summary>
        /// <param name="s"></param>
        /// <returns></returns>
        static Series Max(Series s, double value)
        {
            Series rval = s.Copy();
            for (int i = 0; i < s.Count; i++)
            {
                Point pt = s[i];
                if (pt.IsMissing)
                {
                    continue;
                }

                pt.Value = System.Math.Max(pt.Value, value);
                rval[i] = pt;
            }
            return rval;
        }
开发者ID:usbr,项目名称:Pisces,代码行数:21,代码来源:HydrometRuleCurve.cs


注:本文中的Series.Copy方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。