Array fuori portata in Bisogno di aiuto - pagina 12

 
Алексей Тарабанов:

Quarto giorno... tutta l'umanità progressista...

Ed è fuori portata.

Ti stiamo aspettando!

 
Dark Kchlyzov:

Non capisco bene.

Prima ricordiamo la dimensione dell'array, poi precontrolliamo l'indice per non più della dimensione dell'array.

Quando si cercano gli estremi, non so nemmeno quanti ce ne saranno. Memorizzo quanti ne ho trovati nella variabile. Dopo di che, controllo se il numero di estremi trovati non esce. Sto lavorando con array statici dove un overstepping è irto di valori nulli o casuali.

Non mi piacciono gli array dinamici, ma il tuo caso è abbastanza grande.

Ho capito che il tuo compito era quello di cercare gli stessi minimi giornalieri.

Io lo risolverei in questo modo. Per prima cosa, memorizzerei gli estremi minimi nell'array (nell'immagine l'hai esattamente così, e nella condizione in cui stai confrontando tutti i prezzi minimi giornalieri). E poi cercherei gli stessi con una certa precisione.

 

Invitiamo i nostri esperti:

1) Vitaly Muzichenko è il più importante esperto del nostro post (Guru) a giudicare dai prodotti che ha scritto.

2)Valeriy Yastremskiy

3)Alexey Tarabanov

4)Aleksey Stepanenko- Un uomo che non sta solo parlando ma ha scritto un codice da zero, ma il problema rimane.

5) E tutto il resto.

Ecco qui: ho testato il codice scrittoda Aleksei Stepanenko#property versione "2.00".

Vedere lo screenshot 1

Quello che vediamo è che Day1 e DayMin sono ad un parallelo 0.67366 ,

inoltre: se non ci fosse una storia per questo strumento sarebbe normale.

Apriamo lo strumento, tracciamo le linee; non torna indietro nel tester.

e passare alla storia manualmente.


Nella storia del 2019.10.16 alle 15.00 troviamo il minimo giornaliero

gettiamo una lenza e andiamo all'indietro.

E poi ci rendiamo conto che qualcosa è sbagliato qui e il livello (valore) di DayMin sullo schermo 1 dovrebbe essere = 67233

Ho appena iniziato a studiare MQL4, è difficile per me capire il codicedi Aleksei Stepanenko(classe nella classe, array che sovrascrivono gli array, ecc.)

Ho una domanda per gli esperti su come funzionano i vostri indicatori e tutti i vostri prodotti (me ne vergognerei)

A pagina 9 del post il motivo dell'indirizzo in forma estesa https://www.mql5.com/ru/forum/357558/page9#comment_19689951

 
Dark Kchlyzov:

Invitiamo i nostri esperti:

1) Vitaly Muzichenko è il più importante esperto del nostro post (Guru) a giudicare dai prodotti che ha scritto.

2)Valeriy Yastremskiy

3)Alexey Tarabanov

4)Aleksey Stepanenko- Un uomo che non sta solo parlando ma ha scritto un codice da zero, ma il problema rimane.

5) E tutto il resto.

Ecco qui: ho testato il codice scrittoda Aleksei Stepanenko#property versione "2.00".

Vedi schermata 1

Quello che vediamo è che Day1 e DayMin sono ad un parallelo 0.67366 ,

Inoltre: se non ci fosse una storia per questo strumento, sarebbe normale.

Guardiamo lo screenshot 2

Apriamo lo strumento, gettiamo le linee; non traballa nel tester

e passare alla storia manualmente.

Guardiamolo screenshot 3

Nella storia del 2019.10.16 alle 15.00 troviamo il minimo giornaliero

Gettiamo la linea e andiamo all'indietro

Guardiamo loscreenshot 4

E poi capiamo che qualcosa è sbagliato qui e il livello (valore) di DayMin sullo screenshot 1 dovrebbe essere = 67233

Sto appena iniziando a imparare MQL4, è difficile per me capire il codicedi Aleksei Stepanenko(c'è una classe nella classe, gli array stanno riscrivendo le cose, ecc.)

Ho una domanda per gli esperti su come funzionano i vostri indicatori e tutti i vostri prodotti (me ne vergognerei)

A pagina 9 del post il motivo del ricorso in forma estesa https://www.mql5.com/ru/forum/357558/page9#comment_19689951

L'algoritmo fa quello che dice, non quello che tu pensi che faccia. Stampo anche su un file e vedo cosa è contato, e spesso non è quello che penso, ma quello che scrivo.

 
Valeriy Yastremskiy :

L'algoritmo fa quello che dice, non quello che pensi. Stampo anche su un file e vedo cosa viene calcolato lì, e spesso, non quello che ho pianificato, ma quello che ho scritto.

Non so come qualcuno scriva il codice.

Ma personalmente, scrivo tutto in modo semplice e chiaro per me stesso negli stili attuali e non riesco a ottenere valori casuali.

ma è chiaro da dove crescono le gambe. e se fuori portata è così, e non fischiato ulteriormente.

(l'algoritmo fa ciò che è scritto e non come pensi ) l'algoritmo dovrebbe fare come pensi e non come vuole. altrimenti è uno scarico del deposito. E personalmente, questa opzione non fa per me.

esempio   variabili globali   (Anche se questo può sembrare un antidiluviano per alcuni)

 //+------------------------------------------------------------------+
//|                                                     new_test.mq4 |
//|                        Copyright 2020, MetaQuotes Software Corp. |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2020, MetaQuotes Software Corp."
#property link        "https://www.mql5.com"
#property version    "1.4" 
#property strict
//------------------------------------------------------------------+
int Order_MagicNumber; // для авто торговли 
int Magic = 0 ;         //для ручная торговля
//------------------------------------------------------------------+
extern color   Color               = Black;   // Color линия Bid
extern bool    Objects             = true ;     // Удалять объекты созданные Cоветником
extern int     In_Time             = 3 ;       // Время входа эксперта на рынок  (время терминала)
extern int     Out_Time            = 23 ;       // Время выхода эксперта с рынка  (время терминала)
extern int     Time_End_Friday     = 18 ;       // Время после которого не торгуем в пятницу (время терминала)
extern string r_t                 = "" ;       // + 
extern int     Step                = 10 ;       // Step trailing stop            ( Шаг трал стопа ) 
//--------------------------------------------------------------------------------------------------------
extern string R_T   = "Параметры" ;           // ===================== Ручная Торговля ====================
extern int     Take_Profit         = 5000 ;     // Take Profit   
extern int     Stop_Loss           = 1200 ;     // Stop Loss           
extern int     Stop_Loss_Profit    = 15 ;       // Stop loss without loss   ( Стоп-лосс без убытка )
extern int     Start_Profit        = 50 ;       // Start Trailing Stop          ( Старт трейлинг стоп )
extern string a_t                 = "" ;       // + 
//--------------------------------------------------------------------------------------------------------
extern string A_T  = "Параметры" ;             // ================ Автоматическая торговля =================
extern int     Take_Profit_A       = 2500 ;     // Take Profit   
extern int     Stop_Loss_A         = 1200 ;     // Stop Loss    
extern int     Stop_Loss_Profit_A  = 15 ;       // Stop loss without loss   ( Стоп-лосс без убытка )
extern int     Start_Profit_A      = 50 ;       // Start Trailing Stop          ( Старт трейлинг стоп )  

//------------------------------------------------------------------+
//--------------------------------------------------------------------------------------------------------
extern string A_S  = "Параметры" ;             // ======================= Scalping =========================
extern int     Take_Profit_S       = 10000 ;     // Take Profit   
extern int     Stop_Loss_S         = 1500 ;     // Stop Loss    
extern int     Stop_Loss_Profit_S  = 15 ;       // Stop loss without loss   ( Стоп-лосс без убытка )
extern int     Start_Profit_S      = 30 ;     // Start Trailing Stop          ( Старт трейлинг стоп )  

//------------------------------------------------------------------+
string symbol_EURUSD = "EURUSD" ;
string symbol_GBPUSD = "GBPUSD" ;
string symbol_AUDUSD = "AUDUSD" ;
string symbol_NZDUSD = "NZDUSD" ;
string symbol_USDCHF = "USDCHF" ;
string symbol_USDJPY = "USDJPY" ;
string symbol_USDCAD = "USDCAD" ;
string symbol_USDCNH = "USDCNH" ;
string symbol_SPX500 = "SPX500" ;
//-------------------------------------------------------------------+
double Rvi_Blue_H1;
double Rvi_Red_H1;
double Rvi_Blue_H4;
double Rvi_Red_H4;
double Rvi_Blue_D1;
double Rvi_Red_D1;
double Rvi_Blue_W1;
double Rvi_Red_W1;
//-------------------------------------------------------------------+
double TakeProfit     = NormalizeDouble (Take_Profit* _Point , _Digits );       // Тейк-профит         ручная торговля
double StopLoss       = NormalizeDouble (Stop_Loss* _Point , _Digits );         // Стоп-лосс           ручная торговля
double StopLossProfit = NormalizeDouble (Stop_Loss_Profit* _Point , _Digits ); // Стоп-лосс безубытка ручная торговля
double StartProfit    = NormalizeDouble (Start_Profit* _Point , _Digits );     // Стрт-профит         ручная торговля

//-------------------------------------------------------------------+

double TakeProfit_S     = NormalizeDouble (Take_Profit_S* _Point , _Digits );       // Тейк-профит         Scalping 
double StopLoss_S       = NormalizeDouble (Stop_Loss_S* _Point , _Digits );         // Стоп-лосс           Scalping  
double StopLossProfit_S = NormalizeDouble (Stop_Loss_Profit_S* _Point , _Digits ); // Стоп-лосс безубытка Scalping 
double StartProfit_S    = NormalizeDouble (Start_Profit_S* _Point , _Digits );     // Стрт-профит         Scalping 

//-------------------------------------------------------------------+ 

double TakeProfit_B   = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит Breakdown автоматической торговли 
double TakeProfit_C   = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит Center    автоматической торговли 
double TakeProfit_ATR = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит ATR       автоматической торговли
double TakeProfit_H1  = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит H1        автоматической торговли
double TakeProfit_H4  = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит H4        автоматической торговли
double TakeProfit_D1  = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит D1        автоматической торговли
double TakeProfit_W1  = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит W1        автоматической торговли
double TakeProfit_TB  = NormalizeDouble (Take_Profit_A* _Point , _Digits );     // Тейк-профит Trend_Bar автоматической торговли


double StopLoss_B   = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс Breakdown автоматической торговли
double StopLoss_C   = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс Cente     автоматической торговли
double StopLoss_ATR = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс ATR       автоматической торговли
double StopLoss_H1  = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс H1        автоматической торговли
double StopLoss_H4  = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс H4        автоматической торговли
double StopLoss_D1  = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс D1        автоматической торговли
double StopLoss_W1  = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс W1        автоматической торговли
double StopLoss_TB  = NormalizeDouble (Stop_Loss_A* _Point , _Digits );   // Стоп-лосс Trend_Bar автоматической торговли


double StopLossProfit_B   = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка Breakdown автоматической торговли
double StopLossProfit_C   = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка Center    автоматической торговли
double StopLossProfit_ATR = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка ATR       автоматической торговли
double StopLossProfit_H1  = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка H1        автоматической торговли
double StopLossProfit_H4  = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка H4        автоматической торговли
double StopLossProfit_D1  = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка D1        автоматической торговли
double StopLossProfit_W1  = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка W1        автоматической торговли
double StopLossProfit_TB  = NormalizeDouble (Stop_Loss_Profit_A* _Point , _Digits );   // Стоп-лосс безубытка Trend_Bar автоматической торговли


double StartProfit_B   = NormalizeDouble (Start_Profit_A* _Point , _Digits );         // Стрт-профит Breakdown автоматической торговли
double StartProfit_C   = NormalizeDouble (Start_Profit_A* _Point , _Digits );         // Стрт-профит Center    автоматической торговли
double StartProfit_ATR = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит ATR       автоматической торговли
double StartProfit_H1  = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит H1        автоматической торговли
double StartProfit_H4  = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит H4        автоматической торговли
double StartProfit_D1  = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит D1        автоматической торговли
double StartProfit_W1  = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит W1        автоматической торговли
double StartProfit_TB  = NormalizeDouble ((Start_Profit_A* 2 )* _Point , _Digits );     // Стрт-профит Trend_Bar автоматической торговли

double step           = NormalizeDouble (Step* _Point , _Digits );             // Шаг трал стопа      ручная торговля
//-------------------------------------------------------------------+
//+------------------------------------------------------------------+
//|                        Функция Level 
//+------------------------------------------------------------------+
double   Bar_data_D1  [][6]; // Копирует в массив данные баров указанного графика и возвращает количество скопированных баров D1
int      ACR_D1;             // Возвращает количество скопированных баров D1
double   Bar_data_W1  [][6]; // Копирует в массив данные баров указанного графика и возвращает количество скопированных баров W1
int      ACR_W1;             // Возвращает количество скопированных баров W1
double   Bar_data_MN1 [][6]; // Копирует в массив данные баров указанного графика и возвращает количество скопированных баров MN1
int      ACR_MN1;            // Возвращает количество скопированных баров MN1
double   High_D1_Level;      // Возвращает значение максимальной цены бара D1
double   Low_D1_Level;       // Возвращает значение минимальной цены бара  D1
double   High_W1_Level;      // Возвращает значение максимальной цены бара W1
double   Low_W1_Level ;      // Возвращает значение минимальной цены бара  W1
double   High_MN1_Level;     // Возвращает значение максимальной цены бара MN1
double   Low_MN1_Level;      // Возвращает значение минимальной цены бара  MN1
double   Max_D_Level;        // ближайшей максимальный D уровень
double   Min_D_Level ;       // ближайшей минимальный  D уровень
double   Max_W_Level ;       // ближайшей максимальный W уровень
double   Min_W_Level ;       // ближайшей минимальный  W уровень
double   Max_MN_Level ;      // ближайшей максимальный MN уровень
double   Min_MN_Level ;      // ближайшей минимальный  MN уровень
//+------------------------------------------------------------------+
double Lots;            // переменная для расчёта лота и вывода в кнопке
string lots;            // переменная для отоброжения имя кнопки Lots
string sell;            // переменная для отоброжения имя кнопки Sell
string bay;             // переменная для отоброжения имя кнопки Bay
string balance;         // переменная для отоброжения имя кнопки balance
int    avto_torgovlya;  // объекта «Кнопка» Авто_торговля
int    avto_tral_stop;  // объекта «Кнопка» Авто_трал_стоп
int    break_even;      // объекта «Кнопка» Безубыток
int    scalper;         // объекта «Кнопка» scalper  
//-------------------------------------------------------------------+
int       Time_Seconds;        // сохроняем секунду 
int       Time_Minute;         // сохроняем минуту 
int       Time_Hour;           // сохроняем час
int       ticks_to_close = 10; // количество тиков до снятия эксперта с терменала
int       ExtRVIPeriod   = 10;
datetime  Order_datetime_S;
datetime  Time_Day;

//-------------------------------------------------------------------+

 
string String_Order;      // описание сигнала Bay или Sell
int Signal_Order_1;       // если 1 то Bay - если -1 то сел (обнуляем 1 раз в день) 
double BuyTralStop_S,    SellTralStop_S;
int N1_Order_Bay_Time;   // записываем время последней сделки (обнуляем 1 раз в день) 
int N1_Order_Sell_Time;  // записываем время последней сделки (обнуляем 1 раз в день) 

int tframe[] = { 1 , 5 , 15 , 30 , 60 , 240 , 1440 , 10080 , 43200 };              
string tf[]  = { "M1" , "M5" , "M15" , "M30" , " H1" , " H4" , "D1" , "W1" , "MN1" }; 
int tfnumber = 9 ;    

int     ADX_Period = 14 ;                                          
int     ADX_Price  = PRICE_CLOSE ; 
double Step_Psar  = 0.02 ;
double Max_Psar   = 0.2 ;

color   UpColor   = clrBlue ;                                       
color   DownColor = clrRed ;                               // Trend_Bar
color   FlatColor = clrLime ;
color   TextColor = clrGreen ;
int     Corner    = 0 ;

double Psar;                                                     
double PADX,NADX;                                             
string TimeFrameStr;                                     
double IndVal[ 9 ];                  
//-------------------------------------------------------------------+

string lots;             // переменная для отображения имя кнопки Lots
string sell;             // переменная для отображения имя кнопки Sell
string bay;             // переменная для отображения имя кнопки Bay
string balance;         // переменная для отображения имя кнопки balance
int     avto_torgovlya;   // объекта «Кнопка» Авто_торговля
int     avto_tral_stop;   // объекта «Кнопка» Авто_трал_стоп
int     break_even;       // объекта «Кнопка» Без убыток
int     scalper;         // объекта «Кнопка» scalper  
//-------------------------------------------------------------------+
double     Lots;                 // переменная для расчёта лота
int        Time_Seconds;         // сохраняем секунду 
int        Time_Minute;         // сохраняем минуту 
int        Time_Hour;           // сохраняем час
int        Friday;               //переменная для торговли в пятницу если равно 0 торговля разрешена 1 торговля запрещена 
int        ticks_to_close = 10 ; // количество тиков до снятия эксперта с терминала
int        ExtRVIPeriod   = 10 ;
datetime   Order_datetime_S;

//-------------------------------------------------------------------+
string File_Name;
int file_handle;
int Signal[ 100 ]; // Signal [0] текущий день   Signal [10]  Shaping_Signal Bay       
                 // Signal [1] H1             Signal [11]  Shaping_Signal Sell
                 // Signal [2] H4             Signal [12]        
                 // Signal [3] D1             Signal [13]
                 // Signal [4] W1             Signal [14]
                 // Signal [5] Scalper        Signal [15]
                 // Signal [6] Breakdown      Signal [16]
                 // Signal [7] Center         Signal [17]
                 // Signal [8] ATR            Signal [18]
                 // Signal [9] Trend_Bar      Signal [19]
//-------------------------------------------------------------------+
int     ATR_Period = 5 ;
double beginner   = 0 ;
int     timeshift  = 0 , timeshifts = 0 ;
double H4, L4, H4t, L4t;   
double fullatr;
double ATR_Level_5, ATR_Level_6;
double rates_d1 [][ 6 ];
double ATR_Level [ 10 ]; //Сохраняем  в массиве Signal[100] значение линий 
                       //ATR_Level[0] line BAY
                       //ATR_Level[1] line SELL  
                       //ATR_Level[2] line Center
                       //ATR_Level[3] line High_d1 Предыдущий день
                       //ATR_Level[4] line Low_d1  Предыдущий день 
                       //ATR_Level[5] line D_max от line SELL
                       //ATR_Level[6] line D_min от line BAY                
//-------------------------------------------------------------------+
double BuyTralStop,     SellTralStop;
double BuyTralStopS,    SellTralStopS;
double BuyTralStopH1,   SellTralStopH1;
double BuyTralStopH4,   SellTralStopH4;
double BuyTralStopD1,   SellTralStopD1;
double BuyTralStopW1,   SellTralStopW1;
double BuyTralStop_C,   SellTralStop_C;
double BuyTralStop_B,   SellTralStop_B;
double BuyTralStop_ATR, SellTralStop_ATR;
double BuyTralStop_TB, SellTralStop_TB;
//-------------------------------------------------------------------+
int S_Order_Time[ 2 ]; // [0] Bay
                     // [1] Sell
string S_Order; // описание сигнала                     
Документация по MQL5: Основы языка / Переменные / Глобальные переменные
Документация по MQL5: Основы языка / Переменные / Глобальные переменные
  • www.mql5.com
Глобальные переменные создаются путем размещения их объявлений вне описания какой-либо функции. Глобальные переменные определяются на том же уровне, что и функции, т. е. не локальны ни в каком блоке. Область видимости глобальных переменных - вся программа, глобальные переменные доступны из всех функций, определенных в программе...
 
Алексей Тарабанов:

Quarto giorno... tutta l'umanità progressista...

Ed è fuori portata.

Ti stiamo aspettando!

 
Vitaly Muzichenko:

Come la vedo io.

Non vedo l'ora di vederti!

 
Dark Kchlyzov:

Cercatelo, non è vero?

File:
20201213.log  588 kb
 
Dark Kchlyzov:

Ma personalmente, scrivo tutto in modo semplice e chiaro in questo stile , e non ottengo valori casuali .

Ma è chiaro da dove crescono le gambe. E se è vero che è fuori portata, non vola via con un fischio in più.

Non credo, ma è chiaro da dove vengono le gambe. se è fuori portata, è vero, non solo più lontano.(L'algoritmo fa quello che dice, non quello che pensi) l'algoritmo dovrebbe fare come pensi, altrimenti cancella il tuo deposito. Personalmente non mi piace questa opzione.


Non c'è logica. Non hai valori casuali, ma c'è un outlier nell'array.

E la contraddizione principale è che l'algoritmo non fa come vuole, ma come è scritto. Senza alcuna correlazione con i desideri.

 

Perché non chiedete agli autori?

#property copyright "Copyright 2020, MetaQuotes Software Corp."
#property link "https://www.mql5.com"

Открой новые возможности в MetaTrader 5 с сообществом и сервисами MQL5
Открой новые возможности в MetaTrader 5 с сообществом и сервисами MQL5
  • www.mql5.com
One Click Close The script allows users to easily close positions if their profit/loss reaches or exceeds a value specified in pips. Please set slippage value first. Sometimes some positions do not close due to high volatility of the market. Please set larger slippage or restart the script. The free demo version is: ...
Motivazione: