LinearRegression

Hesaplanan lineer regresyon değerleriyle bir vektör/matris hesaplar.

vector vector::LinearRegression();
 
matrix matrix::LinearRegression(
  ENUM_MATRIX_AXIS  axis=AXIS_NONE      // regresyonun hesaplandığı eksen
   );

Parametreler

axis

[in]  Regresyonun hesaplandığı eksen. ENUM_MATRIX_AXIS numaralandırmasından değer (AXIS_HORZ - yatay eksen, AXIS_VERT - dikey eksen).

Geri dönüş değeri

Hesaplanan lineer regresyon değerlerine sahip vektör veya matris.

Not

Lineer regresyon, standart regresyon denklemi kullanılarak hesaplanır: y(x)=a*x+b, burada a çizgi eğimi, b ise Y ekseni kaymasıdır.

linear_regression

Örnek:

#include <Graphics\Graphic.mqh>
 
#define GRAPH_WIDTH  750
#define GRAPH_HEIGHT 350
 
//+------------------------------------------------------------------+
//| Komut dosyası başlatma fonksiyonu                                |
//+------------------------------------------------------------------+
void OnStart()
  {
   vector vector_a;
   vector_a.CopyRates(_Symbol,_Period,COPY_RATES_CLOSE,1,100);
   vector vector_r=vector_a.LinearRegression();
 
//--- grafik gösterimini kapat
   ChartSetInteger(0,CHART_SHOW,false);
 
//--- grafik çizmek için diziler
   double x[];
   double y1[];
   double y2[];
   ArrayResize(x,uint(vector_a.Size()));
   ArrayResize(y1,uint(vector_a.Size()));
   ArrayResize(y2,uint(vector_a.Size()));
   for(ulong i=0i<vector_a.Size(); i++)
     {
      x[i]=(double)i;
      y1[i]=vector_a[i];
      y2[i]=vector_r[i];
     }
 
//--- grafik başlığı
   string title="Linear regression "+_Symbol+","+EnumToString(_Period);
 
   long   chart=0;
   string name="LinearRegression";
 
//--- grafik oluştur
   CGraphic graphic;
   graphic.Create(chart,name,0,0,0,GRAPH_WIDTH,GRAPH_HEIGHT);
   graphic.BackgroundMain(title);
   graphic.BackgroundMainSize(12);
   
//--- aktivasyon fonksiyonu grafiği
   CCurve *curvef=graphic.CurveAdd(x,y1,CURVE_POINTS_AND_LINES);
   curvef.Name("vector_a");
   curvef.LinesWidth(2);
   curvef.LinesSmooth(true);
   curvef.LinesSmoothTension(1);
   curvef.LinesSmoothStep(10);
 
//--- aktivasyon fonksiyonunun türevleri
   CCurve *curved=graphic.CurveAdd(x,y2,CURVE_LINES);
   curved.Name("vector_r");
   curved.LinesWidth(2);
   curved.LinesSmooth(true);
   curved.LinesSmoothTension(1);
   curved.LinesSmoothStep(10);
   graphic.CurvePlotAll();
   graphic.Update();
 
//--- basılan klavye düğmelerini tanımak için sonsuz döngü
   while(!IsStopped())
     {
      //--- programdan çıkmak için escape düğmesine bas
      if(TerminalInfoInteger(TERMINAL_KEYSTATE_ESCAPE)!=0)
         break;
      //--- grafiğin görüntüsünü kaydetmek için PgDn düğmesine bas
      if(TerminalInfoInteger(TERMINAL_KEYSTATE_PAGEDOWN)!=0)
        {
         string file_names[];
         if(FileSelectDialog("Save Picture",NULL,"All files (*.*)|*.*",FSD_WRITE_FILE,file_names,"LinearRegression.png")<1)
            continue;
         ChartScreenShot(0,file_names[0],GRAPH_WIDTH,GRAPH_HEIGHT);
        }
      Sleep(10);
     }
 
//--- temizle
   graphic.Destroy();
   ObjectDelete(chart,name);
   ChartSetInteger(0,CHART_SHOW,true);
  }

ENUM_MATRIX_AXIS

Matrisler için tüm istatistiksel fonksiyonlarda ekseni belirtmek için numaralandırma.

Kimlik

Açıklama

AXIS_NONE

Eksen belirtilmedi. Hesaplama, sanki bir vektörmüş gibi tüm matris elemanları üzerinden yapılır (Flat metoduna bakın)

AXIS_HORZ

Yatay eksen

AXIS_VERT

Dikey eksen