MathArctan2

Возвращает в радианах значение угла, тангенс которого равен отношению двух указанных чисел.

double  MathArctan2(
   double  y      // y-координата точки
   double  x      // x-координата точки
   );

Параметры

y

[in]  Число, представляющее координату Y.

x

[in]  Число, представляющее координату X.

Возвращаемое значение

MathArctan2 возвращает значение угла θ в диапазоне от -π до π радиан, так что MathTan(θ)=y/x.

Обратите внимание на следующее:

  • Для (x, y) в квадранте 1, 0 < θ < π/2
  • Для (x, y) в квадранте 2, π/2 < θ≤π
  • Для (x, y) в квадранте 3, -π < θ < -π/2
  • Для (x, y) в квадранте 4, -π/2 < θ < 0

Для точек за пределами указанных квадрантов возвращаемое значение указано ниже:

  • Если y равно 0, и x не является отрицательным, то θ = 0.
  • Если y равно 0, и x является отрицательным, то θ = π.
  • Если y — положительное число, а x равно 0, то θ = π/2.
  • Если y — отрицательное число, а х равно 0, то θ = -π/2.
  • Если y равен 0, и х равен 0, то θ = 0.

Примечание

Вместо функции MathArctan2() можно использовать функцию atan2().

 

Пример:

#define GRAPH_WIDTH  750
#define GRAPH_HEIGHT 350
 
#include <Graphics\Graphic.mqh>
 
CGraphic ExtGraph;
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
   vector delta=vector::Full(10,10);
   delta[0]=0;
//--- получим 101 значение от 0 до 2 пи с шагом delta
   vector X=delta.CumSum();
//--- рассчитываем значение арктангенса для каждого значения вектора X
   vector Y=delta.CumSum();
   
   Print("vector delta = \n",delta);
   Print("vector X = \n",X);
   Print("vector Y = \n",Y);
   
//--- переносим рассчитанные значения из векторов в массивы
   double x_array[];;
   double y_array[];;
   X.Swap(x_array);
   Y.Swap(y_array);
   
   double array[10];
   for(int i=0i<10i++)
     {
      array[i]=MathArctan2(y_array[i],x_array[i]);
     }
 
//--- нарисуем график рассчитанных значений вектора
   CurvePlot(x_array,y_array,clrDodgerBlue);
 
//--- ожидаем нажатия клавиш Escape или PgDn для удаления графика (создания скриншота) и завершения работы
   while(!IsStopped())
     {
      if(StopKeyPressed())
         break;
      Sleep(16);
     }
 
//--- чистим за собой
   ExtGraph.Destroy();
  }
//+------------------------------------------------------------------+
//| При нажатии ESC возвращает true                                  |
//| При нажатии PgDn делает скриншот графика и возвращает true       |
//| Иначе - возвращает false                                         |
//+------------------------------------------------------------------+
bool StopKeyPressed()
  {
//--- если нажата ESC - возвращаем true
   if(TerminalInfoInteger(TERMINAL_KEYSTATE_ESCAPE)!=0)
      return(true);
//--- если нажата PgDn и успешно сделан скриншот графика - возвращаем true
   if(TerminalInfoInteger(TERMINAL_KEYSTATE_PAGEDOWN)!=0 && MakeAndSaveScreenshot(MQLInfoString(MQL_PROGRAM_NAME)+"_Screenshot"))
      return(true);
//--- возвращаем false 
   return(false);
  }
//+------------------------------------------------------------------+
//| Создаёт объект-график и рисует кривую                            |
//+------------------------------------------------------------------+
void CurvePlot(double &x_array[], double &y_array[], const color colour)
  {
   ExtGraph.Create(ChartID(), "Graphic"000GRAPH_WIDTHGRAPH_HEIGHT);
   ExtGraph.CurveAdd(x_arrayy_arrayColorToARGB(colour), CURVE_LINES);
   ExtGraph.IndentUp(30);
   ExtGraph.CurvePlotAll();
   string text1="Press ESC to delete the graph and stop the script, or";
   string text2="Press PgDn to create a screen, delete the graph and stop the script";
   ExtGraph.TextAdd(549text1ColorToARGB(clrBlack));
   ExtGraph.TextAdd(54,21text2ColorToARGB(clrBlack));
   ExtGraph.Update();
  }
//+------------------------------------------------------------------+
//| Создаёт скриншот экрана и сохраняет изображение в файл           |
//+------------------------------------------------------------------+
bool MakeAndSaveScreenshot(const string file_name)
  {
   string file_names[];
   ResetLastError();
   int selected=FileSelectDialog("Save Picture"NULL"All files (*.*)|*.*"FSD_WRITE_FILEfile_namesfile_name+".png");
   if(selected<1)
     {
      if(selected<0)
         PrintFormat("%s: FileSelectDialog() function returned error %d"__FUNCTION__GetLastError());
      return false;
     }
   
   bool res=false;
   if(ChartSetInteger(0,CHART_SHOW,false))
      res=ChartScreenShot(0file_names[0], GRAPH_WIDTHGRAPH_HEIGHT);
   ChartSetInteger(0,CHART_SHOW,true);
   return(res);
  }

 

Результат:

MathArctan2_Screenshot