Qualquer pergunta de novato, de modo a não desorganizar o fórum. Profissionais, não passem por aqui. Em nenhum lugar sem você - 6. - página 167

 
Como obter Open[] do gráfico atual , mas não do cronograma atual?
 

Olá a todos!

Graças a todos que ajudam os recém-chegados, não poupando seu tempo, apesar de o altruísmo ter perdido seu valor nestes dias.

Peço ajuda aos usuários do fórum, li todos os tópicos do Igor, mas não encontrei o que eu precisava, então decidi escrever aqui.

Uma função que suspeito não é difícil e em algum lugar já é, mas...

Como calcular o máximo/mínimo da corrente (anterior, ...) diariamente (semanal, ...) vela a MINUTO(5,15,30,60, ...) VOLTAR?

Serei muito grato aos profissionais altruístas.

 
KAVrus:

Olá a todos!

Graças a todos que ajudam os recém-chegados, não poupando seu tempo, apesar de o altruísmo ter perdido seu valor nestes dias.

Peço ajuda aos usuários do fórum, li todo o tópico Igor, mas não encontrei o que precisava, então decidi escrever aqui.

Suspeito que a função não é complicada e já existe em algum lugar, mas...

Como calcular o máximo/mínimo da corrente (anterior, ...) diariamente (semanal, ...) vela um MINUTO(5,15,30,60, ...) VOLTAR?

Serei muito grato aos profissionais altruístas.


)))- isso é engraçado.

Continue lendo - você vai encontrar muitas coisas interessantes. :)))

 
boing9267:
Como obter Open[] do gráfico atual , mas não do cronograma atual?
iOpen().
 
TarasBY:

))-))-) - me fez rir.

Continue lendo - você vai encontrar muitas coisas interessantes. :)))


É um pecado rir de .....))))


Eu o li... "Volumes de outros períodos de tempo não são modelados"

Devo ter perdido o sentido da pergunta, então... Vou tentar simplificá-lo:

Como você calcula o máximo/mínimo da vela atual de um MINUTO DEPOIS?

 
TarasBY:
iOpen().


Obrigado
 
KAVrus:

É um pecado rir de .....))))


Leia... "Volumes de outros períodos de tempo não são simulados"

Devo ter perdido o sentido da pergunta, então... Vou tentar simplificá-lo:

Como você calcula o máximo/mínimo da vela diária atual de um MINUTO DEPOIS?

É mais fácil rir do que ler (quanto mais "escavar"). :)))

Vamos tentar resolver o problema em código:

    //---- Находим последний расчётный бар на нужном нам тамфрейме
    int li_Shift = iBarShift (Symbol(), PERIOD_M1, iTime (Sumbol(), PERIOD_D1, 0)),
        //---- Ищем на нужном промежутке номер бара с High
        li_Bar = iHighest (Symbol(), PERIOD_M1, MODE_HIGH, li_Shift, 1);
    //---- Получаем значение High
    double ld_HIGH = iHigh (Symbol(), PERIOD_M1, li_Bar);

Na imagem e semelhança com o mínimo que você pode lidar com isso?! ;)

P.S. Como na história dos preços temos uma discrição com um tamanho mínimo de 1 minuto, é correto dizer não "há um minuto", mas "sem contar o último minuto".

 
TarasBY:

Rir é mais fácil do que ler (quanto mais "entrar")... :)))

Tentando resolver o problema em código:

À sua imagem, você consegue lidar com o mínimo?! ;)

P.S. Como na história dos preços temos uma discrição, cujo mínimo é 1 minuto, é correto dizer não "um minuto atrás", mas " sem contar o último minuto".


Obrigado!!!
 
Olá pessoal, por favor, ajudem com o indicador sAccelerator.mq4. Quero fazer um alerta quando a linha 0 for cruzada, e o alerta para remover a repintura, não funciona, e em mql francamente eu não entendo.
//+------------------------------------------------------------------+
//|                                                 sAccelerator.mq4 |
//|                      Copyright © 2005, MetaQuotes Software Corp. |
//|                                       http://www.metaquotes.net/ |
//+------------------------------------------------------------------+
#property  copyright "Copyright © 2005, MetaQuotes Software Corp."
#property  link      "http://www.metaquotes.net/"
//---- indicator settings
#property  indicator_separate_window
#property  indicator_buffers 3
#property  indicator_color1  Black
#property  indicator_color2  Lime
#property  indicator_color3  Red
//---- indicator buffers
double ExtBuffer0[];
double ExtBuffer1[];
double ExtBuffer2[];
double ExtBuffer3[];
double ExtBuffer4[];
// Номер бара, по которому будет искаться сигнал
#define SIGNAL_BAR 1
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
//---- 2 additional buffers are used for counting.
   IndicatorBuffers(5);
//---- drawing settings
   SetIndexStyle(0, DRAW_NONE);
   SetIndexStyle(1, DRAW_HISTOGRAM);
   SetIndexStyle(2, DRAW_HISTOGRAM);
   IndicatorDigits(Digits + 2);
   SetIndexDrawBegin(0, 38);
   SetIndexDrawBegin(1, 38);
   SetIndexDrawBegin(2, 38);
//---- 4 indicator buffers mapping
   SetIndexBuffer(0, ExtBuffer0);
   SetIndexBuffer(1, ExtBuffer1);
   SetIndexBuffer(2, ExtBuffer2);
   SetIndexBuffer(3, ExtBuffer3);
   SetIndexBuffer(4, ExtBuffer4);
//---- name for DataWindow and indicator subwindow label
   IndicatorShortName("sAC");
   SetIndexLabel(1, NULL);
   SetIndexLabel(2, NULL);
//---- initialization done
   return(0);
  }
//+------------------------------------------------------------------+
//| Accelerator/Decelerator Oscillator                               |
//+------------------------------------------------------------------+
int start()
  {
   int    limit;
   int    counted_bars = IndicatorCounted();
   double prev, current;
//---- last counted bar will be recounted
   if(counted_bars > 0) 
       counted_bars--;
   limit = Bars - counted_bars;
//---- macd counted in the 1-st additional buffer
   for(int i = 0; i < limit; i++)
       ExtBuffer3[i] = iMA(NULL, 0, 5, 0, MODE_SMA, PRICE_MEDIAN, i) - 
                       iMA(NULL, 0, 34, 0, MODE_SMA, PRICE_MEDIAN, i);
//---- signal line counted in the 2-nd additional buffer
   for(i = 0; i < limit; i++)
       ExtBuffer4[i] = iMAOnArray(ExtBuffer3, Bars, 5, 0, MODE_SMA, i);
//---- dispatch values between 2 buffers
   bool up = true;
   for(i = limit - 1; i >= 0; i--)
     {
       current = ExtBuffer3[i] - ExtBuffer4[i];
       prev = ExtBuffer3[i+1] - ExtBuffer4[i+1];
       if(current > prev) 
           up = true;
       if(current < prev) 
           up = false;
       if(!up)
         {
           ExtBuffer2[i] = current;
           ExtBuffer1[i] = 0.0;
         }
       else
         {
           ExtBuffer1[i] = current;
           ExtBuffer2[i] = 0.0;
         }
       ExtBuffer0[i] = current;
     }
//---- done
    //---- Статические переменные, в которых хранятся
    //---- время последнего бара и направление последнего сигнала
    static int PrevSignal = 0, PrevTime = 0;
 
    //---- Если баром для анализа выбран не 0-й, нам нет смысла проверять сигнал
    //---- несколько раз. Если не начался новый бар, выходим.
    if(SIGNAL_BAR > 0 && Time[0] <= PrevTime ) 
        return(0);
    //---- Отмечаем, что этот бар проверен
    PrevTime = Time[0];
          if(PrevSignal <= 0)
      {
        if(MainBuffer[SIGNAL_BAR] - 0.0 > 0 && 
           0.0 - MainBuffer[SIGNAL_BAR+1] >= 0)
          {
            PrevSignal = 1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  BUY!!!");
          }
      }
    if(PrevSignal >= 0)
      {
        if(0.0 - MainBuffer[SIGNAL_BAR] > 0 && 
           MainBuffer[SIGNAL_BAR+1] - 0.0 >= 0)
          {
            PrevSignal = -1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  SELL!!!");
          }
      } 
   return(0);
  }
//+------------------------------------------------------------------+

 

Cavalheiros, por favor, aconselhem como encontrar os carrapatos médios em um bar. Presumo o seguinte:

Média[i] = (quantidade total de carrapatos da barra[i])/Volume[i]; Como encontrar a quantidade total de carrapatos da barra desejada?