yuripk>>: Переделать индюк например моментум, обозвав его чуть иначе, добавить внешнюю переменную TF = 15, считаем на данных M1 для примера. В Init определяем нужный множитель coef = 15. На каждом баре смотрим, является ли этот бар началом и для пятнадцатиминтного ТФ, на нём в индикаторе считаем значение моментума один раз для этого бара и при 14 последующих барах возвращаем это же значение. Важно наверное, чтобы минутки не имели пропусков, или несколько иначе считать показания индикатора, проверяя время каждого бара. Подсчёт значения на нужном баре: Осталось реализовать.
vladv002>>: В процессе познания MQL4, выяснил что, как минимум мой тесер не отдает информацию с других ТФ. Вот код проверки, его можна на любой эксперт подвесить, у моего тестера меняются показания только того ТФ на котором тестирую, а другие стоят на месте.
j=coef*i; MomBuffer[j]=Close[j]*100/Close[j+MomPeriod*coef];
あとは、実行あるのみです。Sych писал(а) >>
ArrayCopyRates関数を使用してみてください。
これは、コピーではなく、リダイレクションを行うだけなので、問題なく動作しますし、なによりも高速です。
残念ながら、この数値はArrayCopyRates()では動作せず、テストが実行されているそのTFのみであった。
隣接するものは無音!
ArrayCopyRates()」のように9つの配列を作り、そこに9つのファイルからすべてのデータをロードする必要があります。
あなたの提案と尊敬する「アバタラ」を組み合わせれば、何かがうまくいくはずです。
とりあえず、ファイルからどのように読み取るかを確認します。
Переделать индюк например моментум, обозвав его чуть иначе, добавить внешнюю переменную TF = 15, считаем на данных M1 для примера. В Init определяем нужный множитель coef = 15. На каждом баре смотрим, является ли этот бар началом и для пятнадцатиминтного ТФ, на нём в индикаторе считаем значение моментума один раз для этого бара и при 14 последующих барах возвращаем это же значение. Важно наверное, чтобы минутки не имели пропусков, или несколько иначе считать показания индикатора, проверяя время каждого бара. Подсчёт значения на нужном баре:
Осталось реализовать.
もう一つの普通のオプションは、データが入ってきたときに自分でバーを作ることです。ここには何かありますが、頭を悩ませることになるでしょう
ありがとうございます。
В процессе познания MQL4, выяснил что, как минимум мой тесер не отдает информацию
с других ТФ. Вот код проверки, его можна на любой эксперт подвесить, у моего тестера
меняются показания только того ТФ на котором тестирую, а другие стоят на месте.
Еще нормальный вариант - делать свои бары по ходу поступления данных, тут чтото есть, но надо репу почесать!
Спасибо.
その通りです。私はそれをモデリングと呼んでいます;)
そして、その正しさは常に保証されます。
さらに、非標準のTFを実現することができるようになります。例えばM3...またはH8。H6が面白い。
------
テスターを分単位で動かすだけです。
もう一つの普通のオプションは、データが入ってきたときに自分でバーを作ることです。ここには何かありますが、頭を悩ませることになるでしょう
>> ありがとうございました。
通常の動作例https://www.mql5.com/ru/code/9603
Нормальный пример работы https://www.mql5.com/ru/code/9603テスターで?
>> テスターで?
テスターでは、通常のインジケーターも正常に動作します。マルチカレンシー、マルチタイムフレームの両方が可能。
Вы что, проверяете этот код в режиме визуального тестирования? Почитайте статью Тестер в терминале MetaTrader 4: Это необходимо знать
他にヒストリー上でインジケーターの挙動を素早く確認する方法はありますか?
私の例では、分単位のデータが正しくありません。
非視覚的なテストでは、より正しくなるのでしょうか?
私は多分、頭が悪いのでしょう・・・。
Нормальный индикатор корректно работает и в тестере тоже. И Мультивалютный, и мультитаймфреймный.
お手数ですが、コードの修正をお願いします。M1から正しいデータを出力すればいいのです。
#property indicator_buffers 2
#property indicator_style1 0
#property indicator_color1 Orange
#property indicator_width1 2
#property indicator_style2 0
#property indicator_color2 BlueViolet
#property indicator_width2 2
extern bool Test=true;
//03/04/10
//SetIndexStyle(0, DRAW_LINE, STYLE_SOLID, 2);
//---- buffers
double DMA[];string PARA;int hFile,j=0,shift,dayshift;
double Mtimes[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{PARA=Symbol();
if (Test) hFile=FileOpen("Dt"+Symbol()+Period()+".csv",FILE_CSV |FILE_WRITE,";");
ArrayCopySeries(Mtimes,MODE_CLOSE,Symbol(),PERIOD_M1);
int error=GetLastError();
if(error==4066)
{
//---- делаем еще 2 попытки чтения
for(int i=0;i<2; i++)
{
Sleep(5000);
ArrayCopySeries(Mtimes,MODE_CLOSE,Symbol(),PERIOD_M1);
}
}
if (Test) FileWrite(hFile,"-Begin--",Mtimes[0]);
//---- indicators
SetIndexStyle(0,DRAW_LINE);
SetIndexBuffer(0,DMA);
SetIndexShift(0,0);
SetIndexLabel(0,"inv");
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
if (Test) FileClose(hFile);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
//----
int counted_bars=IndicatorCounted();
int i,N;double Value;
N=Bars-counted_bars;
if(counted_bars<0) return(-1);
//---- last counted bar will be recounted
if (N==0) return(0);
j++;
if (Test){ FileWrite(hFile,j,"--1M15 ",StrTime(iTime(Symbol(),Period(),1)),iClose(PARA,0,1));
FileWrite(hFile,j,"--0M15 ",StrTime(iTime(Symbol(),Period(),0)),iClose(PARA,0,0));
FileWrite(hFile,j,"--0M1 ",StrTime(iTime(Symbol(),Period(),0)),iClose(PARA,1,0));
FileWrite(hFile,j,"--1001M15 ",StrTime(iTime(Symbol(),Period(),1000)),iClose(PARA,0,1001));
}
for (i=N-1; i>=0; i--)
{
Value=iClose(PARA,0,i);
// Print (i,"=",Value);
DMA[i]=Value;
}
return(0);
}
//+------------------------------------------------------------------+
string StrTime(datetime IT){
return(StringConcatenate(TimeYear(IT),".",TimeMonth(IT),".",TimeDay(IT)
, "-",TimeHour(IT),"^",TimeMinute(IT),"^",TimeSeconds(IT)));
}
ありがとうございました。