[Toute question de débutant, afin de ne pas encombrer le forum. Professionnels, ne passez pas votre chemin. Je ne peux aller nulle part sans toi. - page 702

 
keekkenen:

static int time = Time[0] ;

if (time < Time[0]){

// vieille bougie

} else {

// nouvelle bougie

time = Time[0] ;

}

Il y a maintenant deux fois moins d'offres qu'auparavant.
 
T-G:
Les échanges sont maintenant deux fois moins longs qu'avant.

Au lieu de vérifier la présence d'une nouvelle barre, il suffit de faire une pause entre les ouvertures, définie en secondes :

//+----------------------------------------------------------------------------+
//|  Автор    : Ким Игорь В. aka KimIV,  http://www.kimiv.ru                   |
//+----------------------------------------------------------------------------+
//|  Версия   : 19.02.2008                                                     |
//|  Описание : Возвращает количество секунд после открытия последней позиций. |
//+----------------------------------------------------------------------------+
//|  Параметры:                                                                |
//|    sy - наименование инструмента   (""   - любой символ,                   |
//|                                     NULL - текущий символ)                 |
//|    op - операция                   (-1   - любая позиция)                  |
//|    mn - MagicNumber                (-1   - любой магик)                    |
//+----------------------------------------------------------------------------+
datetime SecondsAfterOpenLastPos(string sy="", int op=-1, int mn=-1) {
  datetime t;
  int      i, k=OrdersTotal();

  if (sy=="0") sy=Symbol();
  for (i=0; i<k; i++) {
    if (OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) {
      if (OrderSymbol()==sy || sy=="") {
        if (OrderType()==OP_BUY || OrderType()==OP_SELL) {
          if (op<0 || OrderType()==op) {
            if (mn<0 || OrderMagicNumber()==mn) {
              if (t<OrderOpenTime()) t=OrderOpenTime();
            }
          }
        }
      }
    }
  }
  return(TimeCurrent()-t);
}

Je le vérifie de cette façon (en gras, ignorez /*PauseMain*/ - c'est une valeur aléatoire de délai en minutes - de 5 à 9) :

// Тут начало функции открытия позиций (открытие Buy)....

// Ниже код открытия Sell:        
          PauseMain51=random(5,9)*60;
         if (!Lot()) return;               // Средств не хватает на миним.- выходим
         if (!OpnSell51 || !Trade) return;
         if (ExistPositions(NULL, OP_SELL, 51, 0))  // Если есть такой же открытый Sell
               {
                 if (SecondsAfterOpenLastPos(NULL, OP_SELL, 51)<=/* PauseMain51*/ 7*60) return; (7*60 сек = 7 минут)
                  // Если прошло мало времени - валим
               }
//---------------------- Позиции ещё нету - открываемся...-----------------------------
         divider=1;
         Lots=GetSizeLot();
         Magic=51;                                          // Задаём магик... 5 и 1; 5 = пять минут, 1 = стратегия 1
         New_Comm="Sell_M5_Стратегия_1_Основная позиция";   // Задаём комментарий для позиции
         Lots_New=NormalizeLot(Lots/divider, False, NULL);
         OpenPosition(NULL,OP_SELL,Lots_New,0,pb-tp*po,Magic,New_Comm);

         return;            

J'espère que ça a un sens...

 
Question - est-il possible que les objets graphiques ne soient pas simulés dans le testeur de stratégie en mode non visuel ? Par exemple, je testais un code qui ouvre des trades en cassant le canal OBJ_REGRESSION - il trade en mode visuel, mais si je le désactive, il n'y a pas de trades... Comment mener l'optimisation dans ce cas ?
 
ToLik_SRGV:

Boris, petite correction dans le code, j'ai oublié d'ajouter une réinitialisation de la position du tableau, lors du retour au lot d'origine :


MERCI BEAUCOUP ! Tout s'est arrangé. Va bien et met les bons lots ! !!
 
Veuillez me dire ce qu'il faut faire et modifier ou ajouter au code pour définir la largeur de la barre de l'histogramme ?
 
odiseif:
Comment puis-je modifier ou ajouter quelque chose au code pour définir la largeur de la barre ?

dans les paramètres de l'indicateur - type de ligne, couleur et largeur/épaisseur
 
IgorM:

dans les paramètres de l'indicateur - type de ligne, couleur et épaisseur/largeur
SetIndexStyle(0, DRAW_NONE) ;
SetIndexStyle(1, DRAW_LINE,EMPTY) ;
SetIndexStyle(2, DRAW_NONE) ;
SetIndexStyle(3, DRAW_NONE) ;
SetIndexStyle(4, DRAW_NONE) ;
c'est ici ....... mais mon outil a une largeur de ligne de 0 et je veux définir une largeur de 2 pour ne pas avoir à m'occuper des réglages ...... je ne sais pas comment faire .... je ne suis pas un programmeur .... alors aidez-moi ))))
 

Je ne connais rien du tout à la programmation. Je voulais que le filtre CCI (https://www.forex-tsd.com/indicators-metatrader-4/3356-cci-filter.html) soit le même pour le WPR, j'ai changé le CCI en WPR et j'ai changé les niveaux dans les conditions de coloration des barres (pas -100, 0, 100 comme le CCI, mais -60, -50 et -40, parce que dans MT le WPR a une plage de -100 à 0, je pense, n'est-ce pas ?) Mais pour une raison quelconque, il compile avec une erreur, et l'écran affiche un indicateur monochrome. Qu'est-ce qui ne va pas ? Merci d'avance

#property copyright "Copyright © 2006, Forex-TSD.com "
#property link      "https://www.forex-tsd.com/"

#property indicator_separate_window
#property indicator_minimum -0.05
#property indicator_maximum 1.05
#property indicator_buffers 4
#property indicator_color1 MediumBlue
#property indicator_color2 Crimson
#property indicator_color3 LightBlue
#property indicator_color4 Orange



//---- input parameters
extern int PeriodWPR=18;
//---- indicator buffers
double UpBuffer1[];
double DnBuffer1[];
double UpBuffer2[];
double DnBuffer2[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
  int init()
  {
   string short_name;
//---- indicator line
   SetIndexStyle(0,DRAW_HISTOGRAM,STYLE_SOLID,2);
   SetIndexStyle(1,DRAW_HISTOGRAM,STYLE_SOLID,2);
   SetIndexStyle(2,DRAW_HISTOGRAM,STYLE_SOLID,2);
   SetIndexStyle(3,DRAW_HISTOGRAM,STYLE_SOLID,2);
   
   SetIndexBuffer(0,UpBuffer1);
   SetIndexBuffer(1,DnBuffer1);
   SetIndexBuffer(2,UpBuffer2);
   SetIndexBuffer(3,DnBuffer2);
   
   IndicatorDigits(MarketInfo(Symbol(),MODE_DIGITS));
//---- name for DataWindow and indicator subwindow label
   short_name="WPR Filter("+PeriodWPR+")";
   IndicatorShortName(short_name);
   SetIndexLabel(0,"UpTrend");
   SetIndexLabel(1,"DownTrend");
   SetIndexLabel(2,"Mild UpTrend");
   SetIndexLabel(3,"Mild DownTrend");
   
//----
   SetIndexDrawBegin(0,PeriodWPR);
   SetIndexDrawBegin(1,PeriodWPR);
   SetIndexDrawBegin(2,PeriodWPR);
   SetIndexDrawBegin(3,PeriodWPR);  
//----
   return(0);
  }

//+------------------------------------------------------------------+
//| WPRFilter                                                         |
//+------------------------------------------------------------------+
int start()
  {
   int shift,trend;
   double WPR0;

   
   for(shift=Bars-PeriodWPR-1;shift>=0;shift--)
   {    
   WPR0=iWPR(NULL,0,PeriodWPR,PRICE_CLOSE);
        
          if (WPR0>-50 && WPR0<-40)  trend=1;
          if (WPR0>-40)  trend=2;  
          if (WPR0<-50 && WPR0>-60) trend=-1;
          if (WPR0<-60)  trend=-2;
          
          if (trend==1) 
          {
          
          UpBuffer1[shift]=0;
          UpBuffer2[shift]=1;
          DnBuffer1[shift]=0;
          DnBuffer2[shift]=0;
          
          }
          if (trend==2) 
          {
          
          UpBuffer1[shift]=1;
          UpBuffer2[shift]=0;
          DnBuffer1[shift]=0;
          DnBuffer2[shift]=0;
          
          }
          if (trend==-1) 
          {
           
          UpBuffer1[shift]=0;
          UpBuffer2[shift]=0;
          DnBuffer1[shift]=0;
          DnBuffer2[shift]=1;
          }
          
          if (trend==-2) 
          {
          
          UpBuffer1[shift]=0;
          UpBuffer2[shift]=0;
          DnBuffer1[shift]=1;
          DnBuffer2[shift]=0; 
          
          }
        }
        return(0);      
 }
 
Infinity:

La mémoire est inutile).

Je veux savoir quel type de monnaie, prescrire les variables

chaîne EUR="EURUSD" ;
chaîne GBP="GBPUSD" ;

string symbl = "" ;

J'écris ce qui suit au début :

symbl = symbl() ; // obtenir la valeur du symbole

Je veux comparer la valeur reçue du symbl avec les valeurs de mes variables, et si elles correspondent, alors prendre une décision.

switch (symbl) {

cas .......... alors rien ne se passe (( break ;

cas ................ rupture ;

}

Rafraîchissez-moi la mémoire))

J'ai compris que seule une constante de caractère peut être utilisée, mais comment faire ?


 
Infinity:

La mémoire est inutile).

Je veux savoir quel type de monnaie, prescrire les variables

chaîne EUR="EURUSD" ;
chaîne GBP="GBPUSD" ;

string symbl = "" ;

J'écris ce qui suit au début :

symbl = symbl() ; // obtenir la valeur du symbole

Je veux comparer la valeur reçue du symbl avec les valeurs de mes variables, et si elles correspondent, alors prendre une décision.

switch (symbl) {

cas .......... alors rien ne se passe (( break ;

cas ................ rupture ;

}

Rafraîchissez votre mémoire ;)


Les docks du commutateur indiquent clairement que l'expression entre parenthèses, c'est-à-dire symbl, doit être de type entier, mais vous l'enfilez...