请 [注册] 或 [登录]  | 返回主站

量化交易吧 /  量化策略 帖子:3364794 新帖:30

智能交易的特性

我太难了发表于:4 月 17 日 19:23回复(1)

在MetaTrader 4交易系统中创建并测试智能交易存在以下列举特性。

  • 在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。

    if(AccountFreeMargin() < 1000) return(0); // 没有保证金 - 退出
  • 您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。

    // 如果前一个蜡烛柱的Close少于 
    // 前者的Close
    if(Close[1] < Close[2]) return(0);
  • 使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。

    double eur_close_m1[];
    int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, 
                                        "EURUSD", PERIOD_M1);
  • 智能交易的编写与其他程序创建一样需要一些附加的调试信息。 MQL4 语言提供了几种获取信息的方法。

    • 函数 "Alert" 会出现一个对话窗口显示用户指定数据。

      Alert("FreeMargin grows to ", AccountFreeMargin(), "!");
    • 函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"\n" 使用于字行的转接。

      Comment("FreeMargin is ", AccountFreeMargin(), ".");
    • 函数"Print"在系统日志中打印用户指定的数据。

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

    int iTickNum = 0;
    int iLastError = 0;
    ...
    iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, 
                         Ask + g_TakeProfit * g_Points);
    if(iTickNum <= 0) 
      {
        iLastError = GetLastError();
        if(iLastError != ERR_NO_ERROR) 
            Alert("Some Message");  }
    调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。
  • 怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。


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

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

    这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。

    接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:

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

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

    第三种方法是以柱的打开时间为基础:

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

    这种方法是最保险的方法。它能够在任意条件下运行。

  • "CSV"类型文件运行的范例:

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

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

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

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

全部回复

0/140

量化课程

    移动端课程