📄 modifyshiftaverageregress.cs
字号:
using System;
namespace InfieldForecast.ForecastModels
{
/// <summary>
/// ModifyShiftAverageRegress 的摘要说明。
/// </summary>
public class ModifyShiftAverageRegress:ShiftAverageStrategy
{
public ModifyShiftAverageRegress(double[] xArray,double[] yArray,int period)
{
//
// TODO: 在此处添加构造函数逻辑
//
this.xArray=xArray;
this.yArray=yArray;
this.period=period;
}
public double forecast(int interval)
{
double Mt = 0; //最近一个观察期的一次移动平均值
double Mt1 = 0; //上一个观察期的一次移动平均值
double[] Ft=new double[period]; //变动趋势值数组
double averageFt = 0; //平均变动趋势值
for(int i=0;i<period;i++)
{
Mt = 0;
Mt1 = 0;
Ft[i] = 0;
for(int j=0;j<period;j++)
{
Mt += yArray[yArray.Length-1-j-i];
Mt1 += yArray[yArray.Length-2-j-i];
}
Mt /= period;
Mt1 /= period; //求得上一个观察期的一次移动平均值
Ft[i] = Mt-Mt1; //求得变动趋势值数组
}
for(int i=0;i<period;i++)
{
averageFt += Ft[i];
}
averageFt /=period; //平均变动趋势值
Mt = 0;
for(int i=0;i<period;i++)
{
Mt += yArray[yArray.Length-1-i];
}
Mt /= period; //求得最近一个观察期的一次移动平均值
return Mt + interval * averageFt;
}
public override double[] getTrendArray()
{
if(this.trendArray==null)
trendArray=computeTrendArray();
return trendArray;
}
private double[] computeTrendArray()
{
trendArray=new double[yArray.Length-period+1];
for(int i=0;i<yArray.Length-period+1;i++)
{
double sum=0;
for(int j=0;j<period;j++)
{
sum+=yArray[i+j];
}
trendArray[i]=sum/period;
}
return trendArray;
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -