caterpillar

Author: Copyright � 2005, MetaQuotes Software Corp.
caterpillar
Miscellaneous
Implements a curve of type %1
0 Views
0 Downloads
0 Favorites
caterpillar
//+------------------------------------------------------------------+
//|                                                     Ãóñåíèöà.mq4 |
//|                      Copyright © 2005, MetaQuotes Software Corp. |
//|                                        http://www.metaquotes.net |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2005, MetaQuotes Software Corp."
#property link      "http://www.metaquotes.net"

#property indicator_chart_window
#property indicator_buffers 2
#property indicator_color1 Yellow
#property indicator_color2 Blue
//---- buffers
//---- indicator buffers
double ExtBuffer1[];
double ExtBuffer2[];

//300 - êîëè÷åñòâî áàðîâ
double X[300]; //ìàññèâ, â êîòîðûé çàïèñûâàþòñÿ êîòèðîâêè è îí ïåðåäàåòñÿ êàê äàííûå äëÿ ðàññ÷åòà Ãóñåíèöå
double Y1[300];//â ýòîì ìàññèâå õðàíÿòñÿ çíà÷åíèÿ Ãóñåíèöû ñ 1ûì íàáîðîì ïàðàìåòðîâ
double Y2[300];//â ýòîì ìàññèâå õðàíÿòñÿ çíà÷åíèÿ Ãóñåíèöû ñî 2ûì íàáîðîì ïàðàìåòðîâ

//èìïîðò ôóíêöèè Ãóñåíèöà èç áèáëèîòåêè
#import "ExpertSample.dll"
 void    fastsingular(double a[],int,int,int,double b[]);
  

//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
   IndicatorBuffers(2);
   SetIndexBuffer(0, ExtBuffer1);
   SetIndexBuffer(1, ExtBuffer2);
   SetIndexStyle(0,DRAW_LINE, EMPTY, 2);
   SetIndexStyle(1,DRAW_LINE, EMPTY, 2);
   IndicatorDigits(6);
   SetIndexDrawBegin(0,0);
   IndicatorShortName("Gus");
   return(0);
  }
int start()
  {
   //Èíèöèàëèçàöèÿ ìàññèâîâ íóëÿìè
   ArrayInitialize(X,0);
   ArrayInitialize(Y1,0);
   ArrayInitialize(Y2,0);
   
   //n - äëèíà ìàññèâà äàííûõ, ïåðåäàâàåìûõ ãóñåíèöå (ìàêñèìóì 4000, íî ëó÷øå áðàòü íåìíîãî...)
   //l1, l2 - äëèíû ëàãîâ (ìàêñèìóì 20)
   //s1, s2 - ÷èñëî ñîáñòâåííûõ êîìïîíåíò. åñëè èñïîëüçîâàòü òîëüêî äëÿ ñãëàæèâàíèÿ, òî = 1
   int i, n, l1, s1;
   n = 300; l1 = 7; s1 = 1;
   
    
   int l2, s2;
   l2 = 5; s2 = 1;
   
   //çàïîëíåíèå ìàññèâà öåíàìè
   
   for(i=299; i>=0; i--)
   {
      X[i] = Low[i] + (High[i]-Low[i])/2;
      //Print("--", X[i]);
   } 
   
   //ArrayCopy(X, Close, 0, 0, n);
   
   fastsingular(X, n, l1, s1, Y1); //âûçîâ ãóñåíèöû ñ 1ûì íàáîðîì ïàðàìåòðîâ
   fastsingular(X, n, l2, s2, Y2); //âûçîâ ãóñåíèöû ñî 2ûì íàáîðîì ïàðàìåòðîâ
   
   
   ArrayCopy(ExtBuffer1, Y1);
   ArrayCopy(ExtBuffer2, Y2);
   
   return(0);
  }
//+------------------------------------------------------------------+

Comments