AutoGraf Série 4 - Fonctionnalités MQL. - page 33

 

Mesdames et messieurs !

Veuillez répondre à ma question.

Comment et où dans le code devez-vous désigner les variables externes?

Ce n'est pas clair dans l'exemple ci-dessus.

//================================================================================== 4 ==
   double AT[33];                                  // Массив для внешних переменных
   bool New_Parametr = false;                      // Обновления параметров пока не было
   for (int i=0; i<=32; i++)                       // Поищем обновлённый параметр
      {                                            // Если какой-то параметр обновлён..
      if(NormalizeDouble(AT[i], 8) !=  NormalizeDouble(Instrument[0][0][i][0],8))
         {
         New_Parametr = true;                      // .. запоминаем этот факт..         
         for (i=0; i<=32; i++)                     // .. то присвоим новые значения всем
            AT[i] = Instrument[0][0][i][0];        // Для удобства пользования
         break;                                    // .. и выходим из цикла перебора
         }
      }
//================================================================================== 5 ==
   int Strategy = NormalizeDouble(AT[0],0);
   switch(Strategy)
      {

Comment faire pour que les variables externes dans les paramètres de l'application ne soient pas dépersonnalisées AT_1...AT_32, parce qu'on ne se souvient pas de la signification de chaque chiffre ?

 

Les valeurs des variables externes pour les stratégies sont spécifiées (ainsi que toutes les valeurs des variables externes) dans les paramètres du conseiller expert.

Vous ne pouvez pas changer les noms des variables externes dans le Conseiller Expert, car ils sont écrits dans le code du Conseiller Expert AG_exp.ex4.

Les noms des variables externes de l'Expert Advisor sont transmis au fichier joint de la stratégie via le tableau Instrument.

Les noms des variables locales dans la stratégie, correspondant aux variables externes dans l'Expert Advisor, peuvent être modifiés dans la stratégie.

C'est le cas dans cet exemple :

AT[i] = Instrument[0][0][i][0];        // Для удобства пользования

Vous pouvez spécifier vos propres noms si vous le souhaitez.

Par exemple, au lieu de AT[i], indiquez Alfa, Beta, etc.

Instrument Array [][][] : http://autograf.dp.ua/Pages/2/26/267/2676.htm
Stratégies dans AG_AT() : http://autograf.dp.ua/Pages/2/26/267/26711/26711_1.htm
Stratégies d'attachement : http://autograf.dp.ua/Pages/2/26/267/26711/26711_2.htm
Exemples de stratégies de codage :
http://autograf.dp.ua/Pages/2/26/267/26712/26712_1.htm
и http://autograf.dp.ua/Pages/2/26/267/26712/26712_2.htm

 

Maintenant je comprends. Sans aucune expérience de la programmation, je ne comprends pas tout de suite. Merci.

Если программно, то можно воспользоваться функцией ObjectDelete() или ObjectsDeleteAll().

Et où dois-je le placer dans ma stratégie ? Ou les objets seront créés et supprimés à chaque fois qu'une fonction personnalisée sera appelée ?

 
LeonidSB писал(а) >>

Maintenant je comprends. Sans aucune expérience de la programmation, je ne comprends pas tout de suite. Merci.

Et où dois-je le placer dans ma stratégie ? Ou les objets seront créés et supprimés à chaque fois que la fonction utilisateur sera appelée ?

Elle n'a pas besoin d'être prescrite dans une fonction utilisateur ou dans une stratégie.

Faites un simple script séparé. Après avoir éteint la stratégie, jetez-la dans la fenêtre, elle supprimera toutes les choses inutiles.

(dans AG 5 nous devrons faire une sorte de désinit dans la stratégie ; mais la solution dépendra des possibilités de MQL5)

 

Merci pour ces conseils avisés. Vous êtes le seul à me surestimer. Je ne me suis pas encore occupé des scripts, mais je vais aller dans cette direction. Si possible, veuillez me donner un lien vers un analogue.

Je n'ai fait connaissance qu'avec l'indicateur jusqu'à présent.

J'ai pris TD_Points&Line_mgtd1.1.mq4 de Vladislav Goshkov (VG) comme analogue, j'ai ajouté log.mq4 Copyright © 2006, komposter pour la création de rapports et j'ai obtenu plus de 2 000 lignes de mon indicateur.

J'ai fait son projet. Il compte environ 500 lignes. Je vais peut-être le découper, mais c'est bon pour l'instant.

Par icône

// --- // ---

est l'emplacement des découpes.

Pour l'instant, j'ai la structure en tête, je veux donc obtenir la fonctionnalité souhaitée. Ensuite, nous peignerons tout selon les règles (le coût de la qualité est géométriquement progressif).

Eh bien, il n'y a pas de ligne 521 dans le SRC : "le texte est plus grand que la taille autorisée". Nous devrons joindre le fichier

Dossiers :
 

À ce stade, vous devez vous familiariser avec les fonctions spéciales et les types d'applications.

La meilleure façon de procéder est de prendre le manuel du MQL4 et de le lire depuis le début, un par un. Si vous avez des questions, posez-les, j'essaierai d'y répondre.

 
SK. >> :

À ce stade, vous devez vous familiariser avec les fonctions spéciales et les types d'applications.

La meilleure façon de le faire est de prendre le manuel du MQL4 et de le lire depuis le début, un par un. Si vous avez des questions, posez-les, j'essaierai d'y répondre.

Votre manuel est mon livre de référence. Je l'ai téléchargé et imprimé et je l'utilise tout le temps.

Des questions surgissent si je ne comprends pas ce que je lis ou si certains sujets ne sont pas abordés.

Il y a deux échantillons avec l'écriture de données dans un fichier externe ou la lecture d'un fichier de nouvelles et ceci est un appel à la fonction Start(). Plus d'un mois de bricolage jusqu'à ce qu' Andrey Khatimlianskii (komposter) trouve l'exemple qui répond à mes besoins. A savoir : init() - formation de l'en-tête du tableau du rapport (environ 30 colonnes), start() - formation d'une ligne avec les paramètres de chaque transaction de la session, deinit() - formation du résultat de la session. J'ai créé trois types de rapports (tableau avec les paramètres de chaque transaction, colonne avec les totaux de session et tableau avec les totaux de session) et je peux les utiliser dans différentes configurations pour un traitement ultérieur dans Excel. D'ailleurs, dans deinit() ObjectsDeleteAll(). Mais ça, c'était plus tard, mais dès le début, j'avais fait un tas de graphiques , afin de pouvoir tout voir et analyser dans le testeur et dans la vie réelle. Cela aide beaucoup lors de la programmation, car MQL-4 n'a pas de débogueur, et de cette façon il est possible de voir sur le graphique quelles lignes (conditions d'ouverture et de fermeture, objectifs, lignes de transaction) le programme construit et comment il le fait. Mais tout cela est dans le cadre de l'indicateur et il ne négocie pas en temps réel. Par conséquent, il est nécessaire de joindre le Conseiller Expert pour obtenir la possibilité de trading non-virtuel, plus la possibilité d'utiliser les données du rapport du testeur avec la possibilité d'optimisation automatique. Et tout cela sans perdre la fonctionnalité existante mise en œuvre jusqu présent dans l'indicateur.

Malheureusement, 495 pages du tutoriel, 180 pages du manuel de l'AutoGraf-4, 370 pages deMetaEditor, l'aide de MT, il est impossible de tout montrer, et la vie ne suffit pas à lire le forum. Mais c'est juste pour le plaisir.

À l'adresse , j'ai créé un schéma de code des fonctions de stratégie (basé sur l'algorithme de l'indicateur) et je ne suis pas sûr de savoir où et comment y placer le script pour ObjectsDeleteAll(). Ai-je raison de placer les fonctions de négociation (elles sont mises en évidence par "zzzzzzzzzzzz") ? >> S'il vous plaît, jetez un coup d'oeil à ce truc :

 

Diagramme du code de la fonction de la stratégie (basé sur l'algorithme de l'indicateur)



//+------------------------------------------------------------------+
//|                                          Shema_3_TD_BLS_21_1.mq4 |  
//|                                 Copyright © 2009, Leonid Belskiy |  
//|                                         leonid.belskiy@gmail.com |   
//+------------------------------------------------------------------+  
#property copyright "Copyright © 2009, Leonid Belskiy"
#property link      "leonid.belskiy@gmail.com"
//жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
#property library                                                                                                        //ж
                                                                                                                         //ж
#import "AG_Lib.ex4"                                                                                                     //ж
    int AG_Magic_Number();                                 // Вычисление MN                                              //ж
    int AG_Message(string & Message[], string _Text);      // Запись сообщений в массив Message[]                        //ж
                                  // Запись управляющих воздействий ф-ии АТ в массив Manager[][]:                        //ж
    int AG_Set_Instr(double & Manager[][], int ii, double v1, double v2, double v3,                                      //ж
                     double v4, double v5, double v6, int io , int ih);                                                  //ж
    int AG_Delete_Instr(double&Manager[][], int ii, int io,int ih);  //Удаление инструментов                             //ж
#import                                                                                                                  //ж
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -                                //ж
    int TD_BLS_21_2(int Parol_S, double Order[][], string Object[],                                                      //ж
                    double Instrument[][][][], int Ddraw_Object[][],                                                     //ж
                    double& Tuning[], double& Manager[][], string& Message[])                                            //ж
        {                                                                                                                //ж
         static int Count = 0;                             // Счётчик посещений этого блока                              //ж
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -                                //ж
         double Lot= NormalizeDouble(Tuning[1],2);         // Значение лотов                                             //ж
         int Per   = NormalizeDouble(Tuning[2],0);         // Значение % (целое)                                         //ж
         int Slip  = NormalizeDouble(Tuning[3],0);         // Проскальзывание (пунктов)                                  //ж
         int SL    = NormalizeDouble(Tuning[4],0);         // StopLoss (пунктов)                                         //ж
         int TP    = NormalizeDouble(Tuning[5],0);         // TakeProfit (пунктов)                                       //ж 
         int Ds    = NormalizeDouble(Tuning[6],0);         // Дистанция (пунктов)                                        //ж
         int St    = NormalizeDouble(Tuning[7],0);         // Шаг модификации (пунктов)                                  //ж
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -                                //ж
         if (Count==0)                                     // Это можно делать один раз в начале                         //ж
             {                                             // Пример сообщения (максимум 62 симв):                       //ж
              AG_Message(Message, "Разработчик J.Smith, http://company.com");                                            //ж
              Count++;                                     // Количество посещений этого блока                           //ж 
                                                                                                                         //ж
              Lot   = 0.1;                                 // Если количество лотов Lot (Tuning[1]) больше нуля, ..      //ж
              Per   = 0;                                   // .. независимо от значения переменной Per (Tuning[2]).      //ж
//              Lot   = 0.0;                                 // 0.0 означает, что колич лотов высчитывается в AutoGraf   //ж
//              Per   = 7;                                   // .. на основе значения % (здесь 7%) суммы баланса         //ж
              Slip  = 1;                                                                                                 //ж   
              SL    = 25;                                                                                                //ж       
              TP    = 100;                                                                                               //ж         
//              Ds    = 20;                                                                                              //ж          
//              St    = 3;                                                                                               //ж          
              Tuning[1] = Lot;                             // Значение лотов                                             //ж          
              Tuning[2] = Per;                             // Значение % (целое)                                         //ж          
              Tuning[3] = Slip;                            // Проскальзывание (пунктов)                                  //ж          
              Tuning[4] = SL;                              // StopLoss (пунктов)                                         //ж          
              Tuning[5] = TP;                              // TakeProfit (пунктов)                                       //ж          
              Tuning[6] = Ds;                              // Дистанция (пунктов)                                        //ж          
              Tuning[7] = St;                              // Шаг модификации (пунктов)                                  //ж          
              AG_Message(Message,"Изменение настроек из АТ.");       // Пример сообщения (макс.62 симв.)                 //ж          
              return(1);                                   // Выход после перенастроек параметров                        //ж          
             }                                                                                                           //ж          
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -                                //ж          
         int MN;                                           // MagicNumber в ф-ии AG_Magic_Number()                       //ж          
         string Comm = "AG_AT";                            // Комментарий (рекомендуется "AG_AT")                        //ж          
         static int Ticket;                                // Номер ордера                                               //ж          
         int _Ord_Ticket = 0;                              // Номер ордера                                               //ж          
         double _Ord_Lots = 0;                             // Полное закрытие                                            //ж          
//- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -                                //ж          
   double AT[33];                                  // Массив для внешних переменных                                      //ж          
   bool New_Parametr = false;                      // Обновления параметров пока не было                                 //ж          
   for (int i=0; i<=32; i++)                       // Поищем обновлённый параметр                                        //ж          
      {                                            // Если какой-то параметр обновлён..                                  //ж          
       AT[1]=11;                                                                                                         //ж          
                                                                                                                         //ж          
      if(NormalizeDouble(AT[i], 8) !=  NormalizeDouble(Instrument[0][0][i][0],8))                                        //ж          
         {                                                                                                               //ж          
         New_Parametr = true;                      // .. запоминаем этот факт..                                          //ж                  
         for (i=0; i<=32; i++)                     // .. то присвоим новые значения всем                                 //ж          
            AT[i] = Instrument[0][0][i][0];        // Для удобства пользования                                           //ж          
         break;                                    // .. и выходим из цикла перебора                                     //ж          
         }                                                                                                               //ж          
      }                                                                                                                  //ж          
//жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
    if((nTime!=Time[0])||(CurPeriod!=Period()))                      // На новом баре или изменении таймфрейма все пересчитываем 
        {                                                            // Period Возвращает значение числа минут периода для текущего графика. 
//=================================================
//******** Поиск опорных точек предложения ********
//=================================================
         for(i=2+StepBack,D=2,NP=0; (NP<D)&&(i<Bars); i++)           // Перебираем бары влево начиная со 2-го бара от текущего
             {                                                       // Begin
//            --- // ---
             }                                                       // End;
//=================================================
//********** Поиск опорных точек спроса ***********
//=================================================
         for(i=2+StepBack,D=2,NP=0; (NP<D)&&(i<Bars); i++)           // Перебираем бары влево начиная со 2-го бара от текущего 
             {                                                       // Begin
//            --- // ---
             }                                                       // End;
//=================================================
//****       Рисуем  TD-линии                  ****
//=================================================
//            --- // ---
         CurPeriod=Period();                                         // Соответствие минут графика с минутами системы
         nTime=Time[0];                                              // Соответствие время текущего и бара программы 
        }
//=================================================
//****     Формирование сигналов для сделок    ****
//=================================================
    Fun_New_Bar();                                                   // Определение нового бара
//=================================================
//****     Формирование сигналов на покупку    ****
//=================================================
    if((Close[i]>UpP[0]+UpV*(UpB[0]-i)+Puncture*Point) && (High[i+1]<=UpP[0]+UpV*(UpB[0]-(i+1)))) // Сигнал на покупку
        {
//            --- // ---                                                Нахождение баров для расчета проекторов
//            --- // ---                                                Расчет цен проекторов
//            --- // ---                                                Расчет размеров проекторов
         if(NoQw ... )                                               // Определение квалификаторов прорыва
             {
//            --- // ---                                                Формирование массива цен уровней целей
//            --- // ---                                                Создаем и рисуем сигнал на покупку кружок (красный)
              if(Flag_Up==true)
                  {
//            --- // ---                                                Создаем и рисуем линию на покупку (красный)
//            --- // ---                                                Создаем и рисуем линии целей
//================================================
//****         Открываем сделку  Buy          ****
//================================================
                   if(MiB_Up[1]==0 && Flag_Up_CD_Start==false && Flag_Up_Start==false && Flag_Dn_Start==false)
                       {
                        MiB_Up[1]=i;                                 // Массив номеров баров точек Up сделки MiB_Up[1]-левая, MiB_Up[0]-правая
                        MiP_Up[1]=Close[i];                          // Массив цен точек Up сделки MiP_Up[1]-левая, MiP_Up[0]-правая
                        MiBT_Up[1]=TimeCurrent();                    // Количество секунд в момент открытия сделки
                        Flag_Up_CD_Start=true;                       // Флаг рисования линий сделок на покупку - покупки запрещены    
                        Flag_Up_CD_End=false;                        // до закрытия сделки и образования нового бара
                        Flag_Dn_Start=true;                          // Запрещено открывать противоположную Dn сделку
//                      жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
                        AG_Message(Message, "АТ: сработал критерий открытия Buy.");                          // Сообщение(макс.62симв)                ж 
                        MN = AG_Magic_Number();                                                              // Вычисление MagicNumber (рекомендуется)ж 
                        OrderSend( Symbol(), OP_BUY, Lot, Ask, 2, Bid-SL*Point, Bid+TP*Point, Comm, MN);     // Открытие ордера Buy:                  ж
//                      жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
                       }                                   
                   bay++;                                            // Счетчик нарисованных линий целей на покупку
                   Flag_Up=false;                                    // Линии нарисовали - флаг опустили до образования нового бара
                  }
             }
        }
//=================================================
//****           Закрываем сделку  Buy         ****
//=================================================
    if(Flag_Up_CD_Start==true && Flag_Up_CD_End==false)              // Флаг конца рисования линий сделок на покупку - закрытие сделки       
        {                                                            // Пока сделка открыта, пересчитываем точку [0] и перерисовываем линию
//            --- // ---                                             // Расчет времени слелки (статистика отчета)
//            --- // ---                                             // Расчет результата слелки (статистика отчета)
//            --- // ---                                             // Рисуем линию сделки Up
//-------жжжжжжжжжжжжжжжжжжжжжжжжж Выбор условий закрытия слелки Up
         if(CD_TrSL && Close[i]<iP_Up-TrStopLoss*Point)              // (TrStopLoss==TrSL) Если цена пересекла TrStopLoss        
             {
//            жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
              if (NormalizeDouble(Order[1][6],0) == 0.0)             // Если тип ордера Buy                                                           ж
                  {                                                                                                                                   ж
               _Ord_Ticket = NormalizeDouble(Order[1][4],0);         // Номер ордера                                                                  ж
               _Ord_Lots = NormalizeDouble(Order[1][5],2);           // Полное закрытие                                                               ж
               OrderClose(_Ord_Ticket, _Ord_Lots, Bid, 2);           // Закрыть ордер Buy                                                             ж
                  }                                                                                                                                   ж
//            жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
//            --- // ---                                             // Расчет времени по всем Up сделкам (статистика отчета)
//            --- // ---                                             // Расчет времени по всем сделкам (статистика отчета)
//            --- // ---                                             // Расчет баланса и результатов Up сделок (статистика отчета)
//            --- // ---                                             // Формируем строку отчета (статистика отчета)
             }
         WindowRedraw();         
        }
//=================================================
//****     Формирование сигналов на продажу    ****
//=================================================
    if((Close[i]<DownP[0]+DownV*(DownB[0]-i)-Puncture*Point) && (Low[i+1]>=DownP[0]+DownV*(DownB[0]-(i+1)))) // Сигнал на продажу
        {
//            --- // ---                                                Нахождение баров для расчета проекторов
//            --- // ---                                                Расчет цен проекторов
//            --- // ---                                                Расчет размеров проекторов
         if(NoQw ... )                                               // Определение квалификаторов прорыва
             {
//            --- // ---                                                Формирование массива цен уровней целей
//            --- // ---                                                Создаем и рисуем сигнал на продажу кружок (синий)
              if(Flag_Dn==true)
                  {
//            --- // ---                                                Создаем и рисуем линию на продажу (синий)
//            --- // ---                                                Создаем и рисуем линии целей
//=================================================
//****       Открываем сделку Sell             ****
//=================================================
                   if(MiB_Dn[1]==0 && Flag_Dn_CD_Start==false && Flag_Dn_Start==false && Flag_Up_Start==false)
                       {
                        MiB_Dn[1]=i;                                 // Массив номеров баров точек Dn сделки iB_Up[1]-левая, iB_Dn[0]-правая
                        MiP_Dn[1]=Close[i];                          // Массив цен точек Dn сделки iP_Dn[1]-левая, iP_Dn[0]-правая
                        MiBT_Dn[1]=TimeCurrent();                    // Массив времени баров содержащих точки Dn сделки iBT_Dn[1]-левая, iBT_Dn[0]-правая
                        Flag_Dn_CD_Start=true;                       // Флаг начала рисования линий сделок на продажу                       
                        Flag_Dn_CD_End=false;                        // Флаг конца рисования линий сделок на продажу                       
                        Flag_Up_Start=true;                          // Запрещено открывать противоположную Up сделку
//                      жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
                        AG_Message(Message, "АТ: сработал критерий открытия Sell.");                         //Сообщение(макс62симв)                  ж
                        MN = AG_Magic_Number();                                                              // Вычисление MagicNumber (рекомендуется)ж
                        OrderSend( Symbol(), OP_SELL, Lot, Bid, 2, Ask+SL*Point, Ask-TP*Point, Comm, MN);    // Открытие ордера Sell:                 ж
//                      жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
                       }
                   sell++;                                           // Счетчик нарисованных линий целей на продажу
                   Flag_Dn=false;                                    // Линии нарисовали - флаг опустили до образования нового бара
                  }
             }
        }
//=================================================
//****           Закрываем сделку Sell         ****
//=================================================
    i=0;
    if(Flag_Dn_CD_Start==true && Flag_Dn_CD_End==false)              // Флаг конца рисования линий сделок на продажу - закрытие сделки      
        {                                                            // Пока сделка открыта, пересчитываем точку [0] и перерисовываем линию
//            --- // ---                                             // Расчет времени слелки (статистика отчета)
//            --- // ---                                             // Расчет результата слелки (статистика отчета)
//            --- // ---                                             // Рисуем линию сделки Dn
//            --- // ---
//-------жжжжжжжжжжжжжжжжжжжжжжжжж Выбор условий закрытия слелки Dn
         if(CD_TrSL && Close[i]>iP_Dn+TrStopLoss*Point)              // (TrStopLoss==TrSL) Если цена пересекла TrStopLoss        
             {
//            жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
              if (NormalizeDouble(Order[1][6],0) == 1.0)             // Если тип ордера Sell                                                          ж
                  {                                                                                                                                   ж
                   _Ord_Ticket = NormalizeDouble(Order[1][4],0);     // Номер ордера                                                                  ж
                   _Ord_Lots = NormalizeDouble(Order[1][5],2);       // Будем закр.ордер полностью                                                    ж
                   OrderClose(_Ord_Ticket, _Ord_Lots, Ask, 2);       // Закрыть ордер Sell                                                            ж
                  }                                                                                                                                   ж
//            жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
//            --- // ---                                             // Расчет времени по всем Dn сделкам (статистика отчета)
//            --- // ---                                             // Расчет времени по всем сделкам (статистика отчета)
//            --- // ---                                             // Расчет баланса и результатов Dn сделок (статистика отчета)
//            --- // ---                                             // Формируем строку отчета (статистика отчета)
             }
         WindowRedraw();         
        }
   }
//  жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
    return(1);           // Нормальный выход                                                                                      ж
   }                                                                                                                              ж
//  жжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжжж
void Fun_New_Bar()                                                   // Функция определения образования нового бара
//            --- // ---


 
LeonidSB писал(а) >>

Mais exactement j'ai fait un schéma de code de fonction de stratégie (basé sur l'algorithme de l'indicateur) et je ne sais pas où et comment insérer le script pour ObjectsDeleteAll() ? Ai-je correctement saisi les fonctions de négociation (elles sont mises en évidence par des "zzzzzzzz") ? S'il vous plaît, jetez un coup d'oeil à ce truc :

Je pense que tu vas beaucoup trop vite.

En programmation, on ne peut pas travailler au feeling.

Vous ne devez pas utiliser dans votre propre code quoi que ce soit qu'un programmeur ne comprend pas ou pas du tout.

De cette façon, rien n'est fait.

La programmation, peut-être plus que toute autre activité, exige par essence une clarté totale et une déclaration complète de soi.

Commencez par écrire un code élémentaire. Ne passez à des codes plus complexes que lorsque vous avez une explication complète de chaque lettre de votre code.

--

Le manuel contient des exemples de conseillers experts simples.

Plus tôt, dans l'introduction à la programmation, il y a une classification des programmes d'application (signes et différences entre les Expert Advisors, les scripts et les indicateurs).

Un script ne peut pas être "branché" sur un conseiller expert. Il s'agit d'un programme indépendant distinct.

Au premier coup d'œil, je peux dire que votre code est mal formaté.
En outre, la plupart des blocs pourraient être conçus comme des fonctions. Ce serait plus clair (sinon vous ne serez plus capable de lire votre propre code dans quelques mois).

 

Vous avez tout à fait raison. Je suis d'accord avec vous sur tous les points. Merci d'avoir pris le temps de formuler des critiques constructives!


Par "inclure", j'entends écrire un code liant l'opération de script à AG_AT() ou à sa fonction, qui met en œuvre la stratégie.


Dans le tutoriel, l'exemple d'un Expert Advisor simple contient start(), alors que dans l'exemple normal, toutes les fonctions spéciales sont présentes. Il n'y a pas de problèmes, mais comme on dit, "l'appétit vient avec le repas".

La question est de savoir comment utiliser toutes les fonctionnalitésde l'AutoGraf-4. Que dois-je faire ?