黄金外汇交易开户链接

MT4智能交易的特性

在MetaTrader 4交易系统中创建并测试智能交易存在以下列举特性。
在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。

  1. if(AccountFreeMargin() < 1000) return(0); // 没有保证金 – 退出

您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。

  1. // 如果前一个蜡烛柱的Close少于前者的Close
  2. if(Close[1] < Close[2]) return(0);

使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。 

  1. double eur_close_m1[];
  2. int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, "EURUSD", PERIOD_M1);

智能交易的编写与其他程序创建一样需要一些附加的调试信息。 MQL4 语言提供了几种获取信息的方法。
函数 "Alert" 会出现一个对话窗口显示用户指定数据。

  1. Alert("FreeMargin grows to ", AccountFreeMargin(), "!");

函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"n" 使用于字行的转接。

  1. Comment("FreeMargin is ", AccountFreeMargin(), ".");

函数"Print"在系统日志中打印用户指定的数据。 

  1. Print("FreeMargin is ", AccountFreeMargin(), ".");

程序中错误的获取,函数"GetLastError"的功能非常有用。例如,交易订单经常返回替克数。如果这个替克数字等于 0 (在执行业务过程中出现了错误),获取这个错误的详细信息必须调用函数"GetLastError":

  1. int iTickNum = 0;
  2. int iLastError = 0;
  3. iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, 
  4.                      Ask + g_TakeProfit * g_Points);
  5. if(iTickNum <= 0) 
  6.   {
  7.     iLastError = GetLastError();
  8.     if(iLastError != ERR_NO_ERROR) 
  9.         Alert("Some Message");  }

调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。
怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。

第一种方法以检测柱的数量为基础:

  1. static int prevbars = 0;
  2. if(prevbars == Bars) return(0);
  3. prevbars = Bars;

这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。
接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:

  1. if( Volume[0] > 1) return(0);

这种方法在大量价格替克输入时可能会运行失败。问题在于价格替克的输入时实行单独的作业。如果当下一个替克进入时这个作业处于繁忙状态,那么进入的这个替克则不能进入以避免超载的出现!这种情况下可以使用先前保存的 "Volume"执行检测。
第三种方法是以柱的打开时间为基础:

  1. static datetime prevtime=0;
  2. if(prevtime == Time[0]) return(0);
  3. prevtime = Time[0];

这种方法是最保险的方法。它能够在任意条件下运行。
"CSV"类型文件运行的范例:

  1. int h1;
  2. h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE, ";");
  3. if(h1 < 0)
  4.   {
  5.    Print("Unable to open file my_data.csv");
  6.    return(false);
  7.   }
  8. FileWrite(h1, High[1], Low[1], Close[1], Volume[1]);  
  9. FileClose(h1);

对于代码的一些描述。首先打开"CSV"格式文件。在打开文件时生成错误将会对出程序。在文件成功打开后,清除文件内容并复制数据到文件内,随后关闭文件。如果您需要保存文件原有的内容,可以使用 MODE_READ模式打开:

  1. int h1;
  2. h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE | MODE_READ, ";");
  3. if(h1 < 0)
  4.   {
  5.    Print("Unable to open file my_data.csv");
  6.    return(false);
  7.   }
  8. FileSeek(h1, 0, SEEK_END);
  9. FileWrite(h1, High[1], Low[1], Close[1], Volume[1]);  
  10. FileClose(h1);

这个范例中数据被添加到文件的尾页。在文件打开后,我们可以使用函数 "FileSeek"。 

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容